mysql开启配置binlog

1. binlog日志基本概念

binlog是MySQL sever层维护的一种二进制日志,binlog是记录所有数据库表结构变更(例如CREATE、ALTER TABLE、DROP等)以及表数据修改(INSERT、UPDATE、DELETE、TRUNCATE等)的二进制日志。不会记录SELECT和SHOW这类操作,因为这类操作对数据本身并没有修改。

  • 主从复制:多个数据库做主从复制,读写分离
  • 数据审计

2. 查看binlog日志记录启用状态

MySQL安装完成后,MySQL5.7版本binlog默认是不开启的,MySQL8默认开启binlog,登录MySQL后,可以通过SHOW VARIABLES LIKE '%log_bin%';命令查看是否开启binlog。

bash 复制代码
# 查看是否开启binlog
mysql> SHOW VARIABLES LIKE '%log_bin%';

3. 开启binlog日志

  • 编辑配置文件
bash 复制代码
# 在centos中mysql的配置文件一般都在/etc/mysql目录下,如果不在可以通过 find / -name "my.cnf" 查找
vi /etc/mysql/my.cnf
  • 添加配置
bash 复制代码
# 服务ID
server-id=1
# binlog 配置 只要配置了log_bin地址 就会开启
log_bin = /var/lib/mysql/mysql_bin
# 日志存储天数 默认0 永久保存
# 如果数据库会定期归档,建议设置一个存储时间不需要一直存储binlog日志,理论上只需要存储归档之后的日志
expire_logs_days = 30
# binlog最大值
max_binlog_size = 1024M
# 规定binlog的格式,binlog有三种格式statement、row、mixad,默认使用statement,建议使用row格式
binlog_format = ROW
# 在提交n次事务后,进行binlog的落盘,0为不进行强行的刷新操作,而是由文件系统控制刷新日志文件,如果是在线交易和账有关的数据建议设置成1,如果是其他数据可以保持为0即可
sync_binlog = 1
  • 重启MySQL服务使配置生效
bash 复制代码
systemctl restart mysqld
相关推荐
是阿建吖!7 分钟前
【MySQL】表的操作
数据库·mysql
wertuiop_10 分钟前
MySQL事务详解:从理论到实践,保障数据一致性
数据库·mysql
crossoverJie40 分钟前
StarRocks 升级注意事项
数据库·后端
小吕学编程44 分钟前
破局 MySQL 死锁:深入理解锁机制与高效解决方案
java·数据库·sql·mysql
恰恰虎1 小时前
向量数据库技术系列二-Milvus介绍
数据库·向量·milvus
一 乐2 小时前
招聘信息|基于SprinBoot+vue的招聘信息管理系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·招聘系统
不爱学英文的码字机器2 小时前
[操作系统] 进程间通信:匿名管道原理与操作
java·服务器·数据库
shansheng2 小时前
MacBook部署达梦V8手记
数据库·spring boot·sql·docker·mybatis
小鱼冻干3 小时前
数据验证
前端·数据库·mysql
小鱼冻干3 小时前
mysql-访问器和虚拟字段
前端·数据库·mysql