使用podman搭建MySQL 8.0主从避坑指北

镜像准备和选择

由于mysql自带许多工具,比如mysqlbinlog之类的,但是普通数字版本号的就直接阉割掉了(如mysql:8.0),mysqlbinlog binary is missing on docker image 8.0.30,当时一度以为是自己容器水平不过关,最后是这么个事儿,所以要选择8.0.30-debian之类的版本号。加上最近dockerhub也被墙了,大伙自己想办法吧,我的办法是梯子+TUN模式。

为什么选择podman而不用docker

因为podman装起来实在是很方便,而且可以root-less运行,别的好处先不谈,你是否在linux上经常在docker命令前忘记加sudo?

安装

先要准备两个配置文件!位置随你放,但是你-v的时候要设置对,记得一定一定一定要叫*.cnf!!!!!!!!!!
在从机上只能读,不能写!这是原则问题,一旦写了,那么就会有奇怪的数据同步问题产生,因为从机是单方面的从主机拉数据罢了。所以要配置一个从机上只读的账号!
这里还有个坑,尽管在cnf已经加上read_only=1,但是创建一个普通用户依然可以写入。所以,尽管在从机上创建一个只读账户。再加上read_only才能生效。

config 复制代码
[mysqld]
# log-bin、binlog-do-db、binlog-ignore-db、server-id
log-bin = mysql-bin
# 需要同步的数据库名,多个配置多行
#binlog-do-db = test
# 不同步的数据库,多个配置多行
binlog-ignore-db = sys
#主节点id
server-id = 1

config 复制代码
[mysqld]
# log-bin、binlog-do-db、binlog-ignore-db、server-id
log-bin = mysql-bin
# 需要同步的数据库名,多个配置多行
#binlog-do-db = test
# 不同步的数据库,多个配置多行
binlog-ignore-db = sys
#主节点id
server-id = 2
# 设置只读
read_only=1

只有ID有区别,别的你可以自己设置。 主机和从机都安装

bash 复制代码
podman run --name some-mysql-debian -v ./conf:/etc/mysql/conf.d   -v ./data:/var/lib/mysql   -e MYSQL_ALLOW_EMPTY_PASSWORD=true -p 3306:3306 -d 你的自备镜像

一定要提前准备confdata这两个文件夹 详细的compose文件大家可能看得更清楚,也可以用podman-compose部署

yml 复制代码
version: '3.0'

services:
  mysql-debian-server:
    image: mysql:latest  # 请根据实际情况指定MySQL镜像版本
    container_name: some-mysql-debian
    volumes:
      - ~/podman-mysql/conf:/etc/mysql/conf.d
      - ~/podman-mysql/data:/var/lib/mysql
    environment:
      MYSQL_ALLOW_EMPTY_PASSWORD: true
    ports:
      - "3306:3306"
    command: mysqld
    restart: always

相信大家也能发现,我没有预设密码。不设密码有如下好处: 以后改密码的时候,再升级镜像或者换镜像,都可以直接用data,一开始就设置密码,可能导致有些数据加密,新的密码与老的冲突,寄。

进容器设置

主,从都要!

sql 复制代码
podman exec -it 你的容器 /bin/bash`
mysql -u root
ALTER USER 'your_username'@'localhost' IDENTIFIED BY 'new_password';

主机还要再加用户给从机同步

sql 复制代码
CREATE USER 'repl'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';
flush privileges;
show master status;

执行到show master status应该打印出一个表格:

像我这样名字是mysql-bin.00000X开头是对的 如果你的结果是这样:

那你就寄了,再仔细检查一下前面的工作吧。

让我们再转到从机进行设置! 同样的,给自己设置一个密码

sql 复制代码
podman exec -it 你的容器 /bin/bash`
mysql -u root
// % 表示允许所有用户
ALTER USER 'your_username'@'%' IDENTIFIED BY 'new_password';
// 再设置一个只读账号!
CREATE USER 'reader'@'%' IDENTIFIED BY 'new_password';

开始主从相关的设置了!

ini 复制代码
CHANGE MASTER TO
MASTER_HOST='你的主机IP',
MASTER_USER='repl',
MASTER_PASSWORD='123456',
MASTER_LOG_FILE='mysql-bin.000001',
MASTER_LOG_POS=157;
ini 复制代码
start slave;
show slave status ;

就全部完成了。

一点个人经验

如果一个数据库已经用了很久,要再加一台数据库做从机的话,那么只能先手动同步内容,内容一样后再开二进制同步。

相关推荐
考虑考虑26 分钟前
Postgerssql格式化时间
数据库·后端·postgresql
Chan1638 分钟前
【智能协同云图库】基于统一接口架构构建多维度分析功能、结合 ECharts 可视化与权限校验实现用户 / 管理员图库统计、通过 SQL 优化与流式处理提升数据
java·spring boot·后端·sql·spring·intellij-idea·echarts
库库林_沙琪马1 小时前
REST接口幂等设计深度解析
spring boot·后端
IT_陈寒1 小时前
Redis性能提升50%的7个关键优化策略,90%开发者都不知道第5点!
前端·人工智能·后端
智商偏低1 小时前
ASP.NET Core 身份验证概述
后端·asp.net
冷冷的菜哥1 小时前
ASP.NET Core使用MailKit发送邮件
后端·c#·asp.net·发送邮件·mailkit
canonical_entropy1 小时前
XDef:一种面向演化的元模型及其构造哲学
后端
小林coding2 小时前
再也不怕面试了!程序员 AI 面试练习神器终于上线了
前端·后端·面试
lypzcgf2 小时前
Coze源码分析-资源库-删除插件-后端源码-错误处理与总结
人工智能·后端·go·coze·coze源码分析·ai应用平台·agent平台
文心快码BaiduComate2 小时前
WAVE SUMMIT深度学习开发者大会2025举行 文心大模型X1.1发布
前端·后端·程序员