【运维】docker-compose部署mysql5.7、mysql 8,单节点,双主

2024-04-23 13:36

本文主要是介绍【运维】docker-compose部署mysql5.7、mysql 8,单节点,双主,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、docker-composemysql 5.7

单机版mysql 5.7

## docker-compose config                  ## 检查当前目录docker-compose.yml文件配置是否正确
## docker-compose up -d                   ## -d 为后台启动
## docker-compose up -d --force-rereate  ## 强制重新创建容器,修改挂载文件后使用该命令启动,谨慎使用,调试时可使用,使用此命令可能造成数据丢失version: "3"
services:mysql:image: docker.io/mysql:5.7container_name: mysql5.7restart: alwayscommand: ['--default-authentication-plugin=mysql_native_password','--character-set-server=utf8mb4','--collation-server=utf8mb4_general_ci','--explicit_defaults_for_timestamp=true','--lower_case_table_names=1']environment:MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PWD}MYSQL_INITDB_SKIP_TZINFO: "Asia/Shanghai"#MYSQL_DATABASE: data_sysvolumes:#数据目录,要确保先创建好- ./mysql/data:/var/lib/mysql- ./mysql/logs:/var/log/mysql##初始化的脚本,初始化我们存放的init.sql文件- ./mysql/initdb:/docker-entrypoint-initdb.d/- ./mysql/conf:/etc/mysql/conf.dports:- 3306:3306healthcheck:test: mysqladmin ping -uroot -p${MYSQL_ROOT_PWD}#test: [ "CMD", "mysqladmin", "ping", "-h", "localhost", "-uroot", "-p123456" ]interval: 6stimeout: 5sretries: 10#network_mode: host

双主热备mysql5.7配置步骤

1、启动docker-compose并配置m1和m2的双主

启动(双主)

创建docker-compose.yml配置文件

version: "3"
services:mysql:image: docker.io/mysql:5.7container_name: mysql5.7mmrestart: alwayscommand: ['--default-authentication-plugin=mysql_native_password','--character-set-server=utf8mb4','--collation-server=utf8mb4_general_ci','--explicit_defaults_for_timestamp=true','--lower_case_table_names=1']environment:MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PWD}MYSQL_INITDB_SKIP_TZINFO: "Asia/Shanghai"#MYSQL_DATABASE: data_sysvolumes:#数据目录,要确保先创建好- ./mysql/data:/var/lib/mysql- ./mysql/logs:/var/log/mysql#初始化的脚本,初始化我们存放的init.sql文件- ./mysql/initdb:/docker-entrypoint-initdb.d/- ./mysql/my.cnf:/etc/mysql/my.cnfports:- 3306:3306healthcheck:test: mysqladmin ping -uroot -p${MYSQL_ROOT_PWD}#test: [ "CMD", "mysqladmin", "ping", "-h", "localhost", "-uroot", "-p123456" ]interval: 6stimeout: 5sretries: 10#network_mode: host

创建my.cnf配置文件

mkdir mysql && cd mysql
vim my.cnf

my.cnf

[mysqld]
# binlog 配置
log-bin=mysql-bin
binlog_format=mixed# server-id 配置,必须唯一
server-id = 2# 确保binlog日志写入后与硬盘同步
sync_binlog = 1# 如果当前实例既做主库又做从库次选线必须开启
log-slave-updates=ON# 自增长ID
# 特殊说明 当该实例为双主的架构时要特殊配置 以避免自增id冲突的问题
auto_increment_offset = 1
auto_increment_increment = 2# 复制过滤:也就是指定哪个数据库不用同步(mysql库一般不同步)
# binlog-ignore-db=mysql
# 要同步的数据库名
# replicate-do-db=test_db# 跳过所有的错误,继续执行复制操作
slave-skip-errors = all  

分别在两台主机上启动

docker-compose up -d

进入m1和m2下执行下列命令来获取各自的master status 和同步账号

m1和m2:

docker exec -it mysql-m1 bashmysql -uroot -p123456# 查看m1 File和Position
mysql> show master status;
+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000005 |      154 |              | mysql            |                   |
+------------------+----------+--------------+------------------+-------------------+# 创建同步账号
mysql> grant replication slave,replication client on *.* to 'slave'@'%' identified by "pwd-ms-sync";
mysql> flush privileges;

2、设置主主

根据master状态拼接设置slave的命令
# 设置当前节点监听的master节点
change master TO master_host = '172.16.223.140',master_port = 3306,master_user = 'slave',master_password = 'pwd-ms-sync',master_log_file = 'mysql-bin.000003',master_log_pos = 620,master_connect_retry=30;# 启动当前为从节点
start slave;
# 停止从节点
stop slave;# 查看主从状态
show slave status\G;

m1:

mysql> change master to master_host='mysql-m2',master_user='slave',master_password='pwd-ms-sync',master_port=3306,master_log_file='mysql-bin.000005', master_log_pos=154,master_connect_retry=30;mysql> start slave;mysql> show slave status \G
*************************** 1. row ***************************Slave_IO_State: Waiting for master to send eventMaster_Host: mysql-m2Master_User: slaveMaster_Port: 3306Connect_Retry: 30Master_Log_File: mysql-bin.000005Read_Master_Log_Pos: 620Relay_Log_File: de7a84f1b7f1-relay-bin.000002Relay_Log_Pos: 786Relay_Master_Log_File: mysql-bin.000005Slave_IO_Running: YesSlave_SQL_Running: YesReplicate_Do_DB:Replicate_Ignore_DB:

m2:

mysql> change master to master_host='mysql-m1',master_user='slave',master_password='pwd-ms-sync',master_port=3306,master_log_file='mysql-bin.000005', master_log_pos=154,master_connect_retry=30;mysql> start slave;mysql> show slave status \G
*************************** 1. row ***************************Slave_IO_State: Waiting for master to send eventMaster_Host: mysql-m1Master_User: slaveMaster_Port: 3306Connect_Retry: 30Master_Log_File: mysql-bin.000005Read_Master_Log_Pos: 1086Relay_Log_File: 65322be4d8a9-relay-bin.000002Relay_Log_Pos: 786Relay_Master_Log_File: mysql-bin.000005Slave_IO_Running: YesSlave_SQL_Running: YesReplicate_Do_DB:Replicate_Ignore_DB:
如下两个配置为Yes表示从节点设置成功Slave_IO_Running: YesSlave_SQL_Running: Yes

参考文档:https://dogslee.top/2021/08/23/docker-compose%E6%90%AD%E5%BB%BAMySql%E4%B8%BB%E4%BB%8E%E5%92%8C%E5%8F%8C%E4%B8%BB/

二、docker-compose部署mysql 8

1、单机版mysql 8.0

## docker-compose config                  ## 检查当前目录docker-compose.yml文件配置是否正确
## docker-compose up -d                   ## -d 为后台启动
## docker-compose up -d --force-rereate  ## 强制重新创建容器,修改挂载文件后使用该命令启动,谨慎使用,调试时可使用,使用此命令可能造成数据丢失version: "3"
services:mysql:image: mysql:8.0.33container_name: mysql8restart: alwayscommand: ['--default-authentication-plugin=mysql_native_password','--character-set-server=utf8mb4','--collation-server=utf8mb4_general_ci','--explicit_defaults_for_timestamp=true','--lower_case_table_names=1']environment:MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PWD}MYSQL_INITDB_SKIP_TZINFO: "Asia/Shanghai"volumes:#数据目录,要确保先创建好- ./mysql/data:/var/lib/mysql- ./mysql/logs:/logs##初始化的脚本,初始化我们存放的init.sql文件- ./mysql/initdb:/docker-entrypoint-initdb.d/- ./mysql/conf:/etc/mysql/conf.dports:- 3306:3306healthcheck:test: mysqladmin ping -uroot -p${MYSQL_ROOT_PWD}#test: [ "CMD", "mysqladmin", "ping", "-h", "localhost", "-uroot", "-p123456" ]interval: 6stimeout: 5sretries: 10#network_mode: host

2、双主热备mysql8配置步骤

分别在两台主机上启动,在两个节点上先执行完前两步
创建docker-compose.yml文件

version: "3"
services:mysql:image: mysql:8.0.33container_name: mysql8mmrestart: alwayscommand: ['--default-authentication-plugin=mysql_native_password','--character-set-server=utf8mb4','--collation-server=utf8mb4_general_ci','--explicit_defaults_for_timestamp=true','--lower_case_table_names=1']environment:MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PWD}MYSQL_INITDB_SKIP_TZINFO: "Asia/Shanghai"#MYSQL_DATABASE: data_sysvolumes:#数据目录,要确保先创建好- ./mysql/data:/var/lib/mysql- ./mysql/logs:/var/log/mysql#初始化的脚本,初始化我们存放的init.sql文件- ./mysql/initdb:/docker-entrypoint-initdb.d/- ./mysql/my.cnf:/etc/my.cnfports:- 3306:3306healthcheck:test: mysqladmin ping -uroot -p${MYSQL_ROOT_PWD}#test: [ "CMD", "mysqladmin", "ping", "-h", "localhost", "-uroot", "-p123456" ]interval: 6stimeout: 5sretries: 10#network_mode: host

创建my.cnf配置文件

mkdir mysql && cd mysql
vim my.cnf

my.cnf

[mysqld]
# binlog 配置
log-bin=mysql-bin
binlog_format=mixed# server-id 配置,必须唯一
server-id = 2# 确保binlog日志写入后与硬盘同步
sync_binlog = 1# 如果当前实例既做主库又做从库次选线必须开启
log_replica_updates=ON # 自增长ID
# 特殊说明 当该实例为双主的架构时要特殊配置 以避免自增id冲突的问题
auto_increment_offset = 1
auto_increment_increment = 2# 复制过滤:也就是指定哪个数据库不用同步(mysql库一般不同步)
# binlog-ignore-db=mysql
# 要同步的数据库名
# replicate-do-db=test_db

1)、创建同步用户

create user 'slave'@'%' identified by 'pwd-ms-sync';

2)、赋权同步权限

grant replication slave,replication client on *.* to 'slave'@'%';
flush privileges;

3)、先查master节点的状态

设置主主

两台机器互为主从,交换完成如下几步
先在master执行第3步,然后再在slave节点执行第4、5、6步

mysql> show master status;
+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000005 |      154 |              | mysql            |                   |
+------------------+----------+--------------+------------------+-------------------+

4)、根据第3步的master状态拼接设置slave的命令

change master TO master_host = '172.16.223.140',master_port = 3306,master_user = 'slave',master_password = 'pwd-ms-sync',master_log_file = 'mysql-bin.000003',master_log_pos = 863,master_connect_retry=30;

5)、启动当前为从节点

start slave;

6)、查看主从状态

show slave status\G;
mysql> show slave status\G;
*************************** 1. row ***************************Slave_IO_State: Waiting for source to send eventMaster_Host: 172.16.223.140Master_User: slaveMaster_Port: 3307Connect_Retry: 30Master_Log_File: mysql-bin.000003Read_Master_Log_Pos: 863Relay_Log_File: f45bf55e91c3-relay-bin.000002Relay_Log_Pos: 324Relay_Master_Log_File: mysql-bin.000003Slave_IO_Running: YesSlave_SQL_Running: Yes
如下两个配置为Yes表示从节点设置成功Slave_IO_Running: YesSlave_SQL_Running: Yes

这篇关于【运维】docker-compose部署mysql5.7、mysql 8,单节点,双主的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/928934

相关文章

闲置电脑也能活出第二春?鲁大师AiNAS让你动动手指就能轻松部署

对于大多数人而言,在这个“数据爆炸”的时代或多或少都遇到过存储告急的情况,这使得“存储焦虑”不再是个别现象,而将会是随着软件的不断臃肿而越来越普遍的情况。从不少手机厂商都开始将存储上限提升至1TB可以见得,我们似乎正处在互联网信息飞速增长的阶段,对于存储的需求也将会不断扩大。对于苹果用户而言,这一问题愈发严峻,毕竟512GB和1TB版本的iPhone可不是人人都消费得起的,因此成熟的外置存储方案开

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推