docker 2个mysql容器共享同一份数据卷导致的报错问题

docker run --name mysql-test -p 8888:3306 -e MYSQL_ROOT_PASSWORD=123456 -v /root/data:/var/lib/mysql -d mysql:8.0
docker run --name mysql-test2 -p 9200:3306 -e MYSQL_ROOT_PASSWORD=123456 -v /root/data:/var/lib/mysql -d mysql:8.0

创建了2个mysql容器,并且同时挂载到本地的同一个目录下,准备共享数据,启动一切正常;
使用docker ps查看,也是2个都在运行中,但是过一会第二个启动的容器就会自动停止;
通过docker ps -a 可以查看到已停止的容器,发现exited(1)容器异常停止
在这里插入图片描述
通过docker logs mysql-test2查看,发现容器一直在报错
在这里插入图片描述
查看本地/root/data目录,确实发现了ibdata1该文件;
两个实例使用同一份数据卷,从错误来看innodb数据文件加了锁导致第二个实例无法正常读取。我对于共享数据出现了偏差,认为2个mysql容器共享一个数据卷可以实现2个数据库内容完全一致,但是MySQL并不属于存算分离架构做不到一份数据同时被多个实例使用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值