Docker内部MySQL如何开启binlog日志
查看 binlog状态
在MySQL终端执行一下,Navicat都行
show variables like '%log_bin%'

发现是没有开启binlog
修改Docker的MySQL的my.cnf配置文件
添加下面内容
注意:
log-bin = /logs/mysql-bin.log 是Docker内部的路径,不是Linux宿主机的路径
#设置日志格式 binlog_format = mixed #设置日志路径,注意路经需要mysql用户有权限写 log-bin = /logs/mysql-bin.log #设置binlog清理时间 expire_logs_days = 5 #binlog每个日志文件大小 max_binlog_size = 50m #binlog缓存大小 binlog_cache_size = 4m #最大binlog缓存大小 max_binlog_cache_size = 512m
重启docker容器重启失败发现报错信息
docker restart 命令重启docker之后发现重启失败
查看docker日志:
docker logs 容器id
2021-01-16 07:05:53 0 [Note] mysqld (mysqld 5.6.49-log) starting as process 29 ... mysqld: File '/logs/mysql-bin.index' not found (Errcode: 13 - Permission denied) 2021-01-16 07:05:53 29 [ERROR] Aborting 2021-01-16 07:05:53 29 [Note] Binlog end
上面意思是没权限,需要给docker内部的这个/logs赋予权限
开始解决问题
把上面修改binlog的配置还原回来,重启docker容器,让docker重启成功,进入docker容器
命令 : docker exec -it 容器id bash
进入容器之后执行:
chown -R mysql:mysql /logs
修改MySQL目录的用户和用户组权限
修改完了之后退出docker
然后再给修改binlog日志信息,接着重启docker容器,发现docker容器启动成功
验证一下
连接MySQL执行一下
show variables like '%log_bin%'

发现已经开启binlog
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
您可能感兴趣的文章
- 12-22nginx代理实现静态资源访问的示例代码
- 12-22Docker 存储管理的几种方式
- 12-22nginx静态资源的服务器配置方法
- 12-22Docker Compose部署微服务项目上线功能
- 12-22GPU服务器的多用户配置方法
- 12-22docker-compose搭建etcd集群的实现(三节点)
- 12-22docker中mysql开启日志的实现步骤
- 12-22Linux下docker安装mysql8并配置远程连接
- 12-22docker部署mysql8并设置可远程连接
- 12-22阿里云oss对象存储使用详细步骤


阅读排行
推荐教程
- 12-11docker存储目录迁移示例教程
- 12-10docker start启动容器后仍然exit状态的解决
- 12-10Linux下如何安装Logstash
- 12-19Zabbix SAML SSO 登录绕过漏洞的操作流程
- 12-15Docker-Compose搭建Spark集群的实现方法
- 12-14Docker Desktop无法正常启动解决(failed to start...)
- 12-14k8s 与docker空间使用分析与清理方法
- 12-13k8s编排之Deployment知识点详解
- 12-13Nginx IP封禁及自动封禁IP的实现
- 12-13Nginx代理Partainer如何使用





