线上突发:MySQL 自增 ID 用完,怎么办?

线上突发:MySQL 自增 ID 用完,怎么办?

  • 1. 问题背景
  • 2. 场景复现
  • 3. 自增id用完怎么办?
  • 4. 总结

1. 问题背景

最近,我们在数据库巡检的时候发现了一个问题:线上的地址表自增主键用的是int类型。随着业务越做越大,数据量也越来越多,自增ID眼看就要到头了——上限是2147483647


一旦自增ID到达上限,会发生什么呢?

2. 场景复现

为了让问题更加清晰,咱们用一个简单的Demo来验证一下。

  1. 创建表并设置自增ID接近上限
CREATE TABLE t (
    id INT AUTO_INCREMENT PRIMARY KEY
) AUTO_INCREMENT = 2147483647;
  1. 向表中插入一条数据
insert INTO t values(NULL);
  1. 执行查询语句
select * from t;

发现ID是 2147483647,成功了。
在这里插入图片描述

  1. 可再次插入数据
insert into t values(null);

在这里插入图片描述
原因很简单,int类型的自增ID上限已到,再次插入时仍尝试使用相同的值,导致主键冲突。

3. 自增id用完怎么办?

1. 方案一:更改字段类型为BIGINT

  • 将 id 字段类型从 INT 修改为 BIGINT,这样 ID 的最大值将从 2147483647 提升到 2^63-1,大大增加了可用的 ID 范围。
  • 执行SQL语句:ALTER TABLE table_name MODIFY id BIGINT AUTO_INCREMENT;
  • 优点:操作简单,不需要改业务逻辑;
  • 缺点:如果表数据量很大,修改字段类型可能会导致性能问题,尤其是在没有停机维护的情况下,可能会影响数据库的响应速度。

2. 方案二:使用 UUID 替代自增 ID

  • 将主键字段类型改为 CHAR(36),然后使用 UUID() 函数生成全局唯一标识符。
  • 执行SQL语句:ALTER TABLE your_table_name MODIFY id CHAR(36) PRIMARY KEY;
  • 优点:ID是全局唯一的,不用担心冲突;
  • 缺点:存储空间增大,索引效率也稍微差一点,但一般影响不大。

3. 方式三:分布式ID生成(如 Snowflake 算法)

  • 使用分布式 ID 生成器(如 Twitter 的 Snowflake 算法)或者借助 Redis、Zookeeper 等工具生成唯一 ID。
  • 优点:高性能、高扩展性,特别适合大规模分布式系统。
  • 缺点:实现起来稍微复杂一点,需要额外的工具支持。

4. 方式四:防患于未然——监控自增 ID 使用情况

  • 提前监控:定期检查自增 ID 的使用情况,提前发现接近最大值的风险。通过定期查询最大 ID 值,可以避免最后一刻的紧急应对。

  • 检查 SQL 很简单:

SELECT 
    COL.TABLE_SCHEMA,
    COL.TABLE_NAME,
    COL.COLUMN_NAME,
    COL.DATA_TYPE,
    TAB.AUTO_INCREMENT 
FROM 
    information_schema.COLUMNS COL 
    JOIN information_schema.TABLES TAB ON COL.TABLE_NAME = TAB.TABLE_NAME 
WHERE 
    COL.EXTRA = 'auto_increment' 
    AND COL.DATA_TYPE = 'int' 
    AND TAB.AUTO_INCREMENT > 1647483647;

4. 总结

自增 ID 用尽确实是个让人头疼的问题,但其实并不可怕。只要我们提前做好准备,问题就能轻松解决。具体来说:

  • 提前搭建监控和预警机制:定期检查自增ID的使用情况,避免等到 ID 用完了才慌忙应对。一旦发现接近上限,及时采取措施,就能有效避免线上故障。
  • 系统设计时多考虑细节:设计数据库时多考虑未来的扩展性。如果业务增长迅速,早期就可以用 BIGINT 替代 INT,或者直接考虑分布式 ID 生成方案。这样一来,未来的数据增长就不会成为问题。

总之,技术问题并不可怕,真正可怕的是没有提前规划和准备。只要在日常工作中多留心、提前设计,麻烦就能在萌芽阶段被解决。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/958013.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Golang之Context详解

引言 之前对context的了解比较浅薄,只知道它是用来传递上下文信息的对象; 对于Context本身的存储、类型认识比较少。 最近又正好在业务代码中发现一种用法:在每个协程中都会复制一份新的局部context对象,想探究下这种写法在性能…

从桌面到前端:效率与渲染优化的技术进化20250122

从桌面到前端:效率与渲染优化的技术进化 在应用开发的广袤天地中,我们见证了从传统桌面开发(如 MFC、PyQt)向现代 Web 前端框架(如 React、Vue)的华丽转变。这一变革犹如一场技术革命,带来了开…

web服务器 网站部署的架构

WEB服务器工作原理 Web web是WWW(World Wide Web)的简称,基本原理是:请求(客户端)与响应(服务器端)原理,由遍布在互联网中的Web服务器和安装了Web浏览器的计算机组成 客户端发出请求的方式:地址栏请求、超链接请求、表单请求 …

快速构建springboot+vue后台管理系统

项目介绍 1.需求定义:外包项目如雨后春笋,开发工期被迫压缩,为了开发人员专注开发项目业务,早点下班能陪老婆、孩子。 2.产品定位: 简约后台管理系统 3.项目特点:此项目代码清晰、界面简洁、springboot layuiadmin 构…

C语言--数据在内存中的存储

数据在内存中的存储 主要研究整型和浮点型在内存中的存储。 1. 整数在内存中的存储 在学习操作符的时候,就了解过了下面的内容: 整数的2进制表示方法有三种,即原码、反码和补码。 有符号的整数,三种表示方法均有符号位和数值…

HTB:Sauna[WriteUP]

目录 连接至HTB服务器并启动靶机 信息收集 使用rustscan对靶机TCP端口进行开放扫描 将靶机TCP开放端口号提取并保存 使用nmap对靶机TCP开放端口进行脚本、服务扫描 使用nmap对靶机TCP开放端口进行漏洞、系统扫描 使用nmap对靶机常用UDP端口进行开放扫描 使用nmap对靶机…

wireshark工具简介

目录 1 wireshark介绍 2 wireshark抓包流程 2.1 选择网卡 2.2 停止抓包 2.3 保存数据 3 wireshark过滤器设置 3.1 显示过滤器的设置 3.2 抓包过滤器 4 wireshark的封包列表与封包详情 4.1 封包列表 4.2 封包详情 参考文献 1 wireshark介绍 wireshark是非常流行的网络…

2025.1.20——一、[RCTF2015]EasySQL1 二次注入|报错注入|代码审计

题目来源:buuctf [RCTF2015]EasySQL1 目录 一、打开靶机,整理信息 二、解题思路 step 1:初步思路为二次注入,在页面进行操作 step 2:尝试二次注入 step 3:已知双引号类型的字符型注入,构造…

kong 网关和spring cloud gateway网关性能测试对比

该测试只是简单在同一台机器设备对spring cloud gateway网关和kong网关进行对比,受限于笔者所拥有的资源,此处仅做简单评测。 一、使用spring boot 的auth-service作为服务提供者 该服务提供了一个/health接口,接口返回"OK"&…

winfrom项目,引用EPPlus.dll实现将DataTable 中的数据保存到Excel文件

最近研究不安装office也可以保存Excel文件,在网上查询资料找到这个方法。 第一步:下载EPPlus.dll文件(自行去网上搜索下载) 第二步:引用到需要用的项目中,如图所示: 第三步:写代码…

框架层实现cpu高负载(cpuload)的检测方案

摘要 这是2018年在小厂的老方案了,现在看方案已经过时了也不太合理,仅供参考,上层框架开启一个5分钟定时器,检测5分钟内总cpu负载和每个线程cpu负载情况,当检测到cpu负载大于绿盟性能或功耗定义的阈值时,结…

Android BitmapShader简洁实现马赛克,Kotlin(一)

Android BitmapShader简洁实现马赛克,Kotlin(一) 这一篇, Android使用PorterDuffXfermode模式PorterDuff.Mode.SRC_OUT橡皮擦实现马赛克效果,Kotlin(3)-CSDN博客 基于PorterDuffXfermode实现马…

人工智能在数字化转型中的角色:从数据分析到智能决策

引言 在数字化转型浪潮中,人工智能(AI)正迅速崛起,成为推动企业创新和变革的关键力量。面对日益复杂的市场环境和激烈的行业竞争,企业亟需借助技术手段提高运营效率、优化决策过程,并增强市场竞争力。而AI…

「全网最细 + 实战源码案例」设计模式——工厂方法模式

核心思想 简单工厂模式是一种创建者模式,它通过一个工厂类负责创建不同类型的对象,根据传入的参数决定实例化的具体类,也被称为“静态工厂方法”模式,因为工厂方法通常是静态的。 结构 1. 工厂类: 提供一个静态方法…

我的图形布局 组织结构图布局

组织结构图布局,有的人也叫它树状布局,在图形中是经常用到的布局算法.形成类似如下图的图形布局方式 首先创建一个类, public class TreeLayouter {private int m_space 40;/// <summary>/// 空间间隔/// </summary>public int Space{get { return m_space; }se…

Golang:使用DuckDB查询Parquet文件数据

本文介绍DuckDB查询Parquet文件的典型应用场景&#xff0c;掌握DuckDB会让你的产品分析能力更强&#xff0c;相反系统运营成本相对较低。为了示例完整&#xff0c;我也提供了如何使用Python导出MongoDB数据。 Apache Parquet文件格式在存储和传输大型数据集方面变得非常流行。最…

Rust Actix Web 项目实战教程 mysql redis swagger:构建用户管理系统

Rust Actix Web 项目实战教程&#xff1a;构建用户管理系统 项目概述 本教程将指导你使用 Rust 和 Actix Web 构建一个完整的用户管理系统&#xff0c;包括数据库交互、Redis 缓存和 Swagger UI 文档。 技术栈 Rust 编程语言Actix Web 框架SQLx (MySQL 数据库)Redis 缓存Uto…

校园网上店铺的设计与实现(代码+数据库+LW)

摘 要 如今社会上各行各业&#xff0c;都喜欢用自己行业的专属软件工作&#xff0c;互联网发展到这个时候&#xff0c;人们已经发现离不开了互联网。新技术的产生&#xff0c;往往能解决一些老技术的弊端问题。因为传统校园店铺商品销售信息管理难度大&#xff0c;容错率低&a…

生成对抗网络(GAN)入门与编程实现

生成对抗网络&#xff08;Generative Adversarial Networks, 简称 GAN&#xff09;自 2014 年由 Ian Goodfellow 等人提出以来&#xff0c;迅速成为机器学习和深度学习领域的重要工具之一。GAN 以其在图像生成、风格转换、数据增强等领域的出色表现&#xff0c;吸引了广泛的研究…

26、正则表达式

目录 一. 匹配字符 .&#xff1a;匹配除换行符外的任意单个字符。 二. 位置锚点 ^&#xff1a;匹配输入字符串的开始位置。 $&#xff1a;匹配输入字符串的结束位置。 \b&#xff1a;匹配单词边界。 \B&#xff1a;匹配非单词边界。 三. 重复限定符 *&#xff1a;匹配…