Mysql误删恢复
- 啊南
- 163阅读
- 2020.11.27
查看
查看mysql版本
select version();
查看开启状态
show variables like 'log_bin';
如果值为OFF 则未开启
开启
启用binlog,通过配置/etc/my.cnf的log-bin选项:
在配置文件中加入log-bin配置,表示启用binlog,如果没有给定值,写成log-bin=,则默认名称为主机名。(注:名称若带有小数点,则只取第一个小数点· 前的部分作为名称)
mkdir /data/mysql/logs/ chown -R mysql.mysql /data/mysql/logs/
[mysqld] #设置日志格式 binlog_format = row #设置日志路径,注意路经需要mysql用户有权限写 log-bin = /data/mysql/logs/mysql-bin.log #设置binlog清理时间保留天数 expire_logs_days = 7 #binlog每个日志文件大小 max_binlog_size = 100m #binlog缓存大小 binlog_cache_size = 4m #最大binlog缓存大小 max_binlog_cache_size = 512m
常用命令
# 是否启用binlog日志 show variables like 'log_bin'; # 查看详细的日志配置信息 show global variables like '%log%'; # mysql数据存储目录 show variables like '%dir%'; # 查看binlog的目录 show global variables like "%log_bin%"; # 查看当前服务器使用的biglog文件及大小 show binary logs; # 查看最新一个binlog日志文件名称和Position show master status; # 事件查询命令 # IN 'log_name' :指定要查询的binlog文件名(不指定就是第一个binlog文件) # FROM pos :指定从哪个pos起始点开始查起(不指定就是从整个文件首个pos点开始算) # LIMIT [offset,] :偏移量(不指定就是0) # row_count :查询总条数(不指定就是所有行) show binlog events [IN 'log_name'] [FROM pos] [LIMIT [offset,] row_count]; # 查看 binlog 内容 show binlog events; # 查看具体一个binlog文件的内容 (in 后面为binlog的文件名) show binlog events in 'master.000003'; # 设置binlog文件保存事件,过期删除,单位天 set global expire_log_days=10; # 删除当前的binlog文件 reset master; # 删除slave的中继日志 reset slave; # 删除指定日期前的日志索引中binlog日志文件 purge master logs before '2019-03-09 14:00:00'; # 删除指定日志文件 purge master logs to 'master.000003';