MySQL主从复制配置(Docker容器内配置)
主从工作原理:
配置介绍:
MASTER:172.17.0.2
SLAVE:172.17.0.3
MASTER内数据库:
仅仅同步以上两个库(在configerdata库中创建了wu2表)
SLAVE库:
空空如也
1、将MASTER库的数据库导入到SLAVE库中
(1)使用mysqldump备份MASTER库
备份前最好将服务停止,防止有数据在设置过程中写入
#将configerdata userdata两个库的结构与数据全部备份到/root/baksql.sql中
mysqldump -h 127.0.0.1 -uroot -proot1 --databases configerdata userdata > /root/baksql.sql --all-databases #备份所有的数据库
--databases #备份指定库,多个库用空格隔开
--database 数据库名 表1 表2 #备份指定库的表,多个表用空格隔开
--database 库名 | gzip #备份库时进行压缩
mysqldump -h 127.0.0.1 -uroot -proot1 --databases configerdata userdata > /root/baksql.sql
(2)将导出的库文件传输到SLAVE中(scp、lrzsz均可)
(3)将.sql文件导入到SLAVE数据库中
进入输入库,执行:
source /root/baksql.sql
查看SLAVE库内有无MASTER中的表
ok,导入成功
2、修改MySQL配置文件使用bin-log进行同步
(1)一般在配置文件是/etc/my.cnf,我的是apt-get装,所以位置不同
vim /etc/mysql/mysql.conf.d/mysqld.cnf
在mysqld参数下添加:
log-bin = mysql-bin
server-id = replicate-do-db=configerdata #指定同步的数据库(若需将所有数据库同步,则不需加此配置项)
replicate-do-db=userdata #指定同步的数据库
#replicate-ignore-db=mysql 此配置为指定不同步的数据库
service mysql restart #重启mysql
(2)进入MASTER mysql中,创建用于SLAVE的用户
GRANT ALL ON *.* TO liu@172.17.0.3 IDENTIFIED BY 'liu1'; #赋予liu用户所有数据库所有权限
GRANT ALL PRIVILEGES ON *.* TO fan@172.17.0.3 IDENTIFIED BY 'fan'; #在SLAVE中创建在MASTER有所有特殊权限的用户
FLUSH PRIVILEGES; #刷新权限
(3)前往SLAVE主机测试登录刚刚创建的用户
显示无法连接,但是网是通的
问题在于MASTER配置文件中限制了其他主机登录,修改以下配置重启即可:
现在连接:
ok,连接成功
3、从节点配置访问主节点的参数信息
(1)首先编辑从机配置文件,添加如下配置:
server-id=2
service mysql restart #重启mysql
(2)赋予权限
查看主服务器的节点
show master status\G;
在从服务中配置:
首先关闭SLAVE线程;STOP SLAVE;
然后再执行:
CHANGE MASTER TO MASTER_HOST='172.17.0.2',MASTER_USER='fan',MASTER_PASSWORD='fan1', MASTER_LOG_FILE='mysql-bin.000002',MASTER_LOG_POS=;
特别注意:MASTER_LOG_FILE= 、MASTER_LOG_POS= 必须和MASTER一致
查看SLAVE状态,已经同步成功
开启SLAVE线程:
4、测试数据是否同步
在MASTER中添加数据
进SLAVE库中查有无同步
ok,已同步。
如有转载请标明出处 谢谢
MySQL主从复制配置(Docker容器内配置)的更多相关文章
- Docker 容器内配置Tomcat manager 远程控制
下载tomcat镜像 , docker run it docker exec -ti 容器ID /bin/bash 进入容器 apt-get update , apt-get install vi ...
- Docker容器内Mysql大小写敏感方案解决
Docker容器内Mysql大小写敏感方案解决 一.(lower_case_table_names)参数说明 二.Docker 部署 MySql 并修改为大小写不敏感 2.1直接在Docker启动的时 ...
- Docker容器内连接宿主机即CentOS的Mysql服务器
docker的宿主机是虚拟机下的CentOS 博主最近遇到一种情况,从服务器拷贝了一份数据库在宿主机Mysql服务器上,想要用本地的数据库测试自己的代码正确性,但是项目程序都是靠docker一键部署的 ...
- Docker容器网络配置
Docker容器网络配置 1.Linux内核实现名称空间的创建 1.1 ip netns命令 可以借助ip netns命令来完成对 Network Namespace 的各种操作.ip netns命令 ...
- 配置docker容器上ssh无密登录
配置docker容器上ssh无密登录 1.修改所有容器中root账户密码 ssh到远程主机时,首次需要密码访问,因此需要修改root账号密码. 密码必须要8位以上字母数字混合. $>passwd ...
- Docker容器安装配置SQLServer服务(Linux)
一:前言 随着不断的对Docker容器的实践和学习,越来越觉得容器的强大,把 SQL Server 数据库服务放在docker容器中,比你自己在宿主服务器上面安装配置一个SQL Server服务器是要 ...
- 记录一次docker容器内修改my.cnf配置文件max_allowed_packet参数的过程
1. 问题背景 在一次新版本功能开发完毕,配合测试的过程中,测试反馈某个XxlJob定时任务一直执行失败,在分析了日志之后,找到了报错的原因: Packet for query is too larg ...
- Jenkins(Docker容器内)使用宿主机的docker命令
1.Jenkins镜像 Docker容器内的Jenkins使用容器外宿主机的Docker(即DooD,还有另外的情况就是DioD),google一下有几种说法,但是都没试成功(试过一种就是修改宿主机/ ...
- Flume+Kafka收集Docker容器内分布式日志应用实践
1 背景和问题 随着云计算.PaaS平台的普及,虚拟化.容器化等技术的应用,例如Docker等技术,越来越多的服务会部署在云端.通常,我们需要需要获取日志,来进行监控.分析.预测.统计等工作,但是云端 ...
随机推荐
- AI本质就是“暴力计算”?看华为云如何应对算力挑战
随着AI人工智能技术的飞速发展,相关的AI应用场景已经拓宽至各行各业.你可能想象不到的是,现在大家手上的智能手机的运算能力,甚至比美国航空航天局1969年登月计划中最先进计算机还高出几百上千万倍乃至更 ...
- Java 从入门到进阶之路(十二)
在之前的文章我们介绍了一下 Java 类的重写及与重载的区别,本章我们来看一下 Java 类的 private,static,final. 我们在之前引入 Java 类概念的时候是通过商场收银台来引入 ...
- 【强化学习】DQN 算法改进
DQN 算法改进 (一)Dueling DQN Dueling DQN 是一种基于 DQN 的改进算法.主要突破点:利用模型结构将值函数表示成更加细致的形式,这使得模型能够拥有更好的表现.下面给出公式 ...
- go实践之apiserver搭建
文章目录 go实践之apiserver搭建 1.配置文件读取 2.数据连接 3.日志初始化 4.server初始化 5.接口编写 go实践之apiserver搭建 本文主要记录下博主用gin搭建app ...
- 【原创】(十三)Linux内存管理之vma/malloc/mmap
背景 Read the fucking source code! --By 鲁迅 A picture is worth a thousand words. --By 高尔基 说明: Kernel版本: ...
- SPOJ Free TourII(点分治+启发式合并)
After the success of 2nd anniversary (take a look at problem FTOUR for more details), this 3rd year, ...
- tensorflow SavedModelBuilder用法
训练代码: # coding: utf-8 from __future__ import print_function from __future__ import division import t ...
- 分享和探讨——如何测试Java类的线程安全性?
缺乏线程安全性导致的问题很难调试,因为它们是零星的,几乎不可能有意复制.你如何测试对象以确保它们是线程安全的? 我在最近的学习中和优锐课老师谈到了这个问题.现在,是时候以书面形式进行解释了.线程安全是 ...
- 在ASP.NET Core中使用托管启动(hosting startup)程序集,实现批量注册service
在启动ASPNET Core时可以从外部程序集向应用添加增强功能.例如,外部库可以用托管启动( hosting startup) 实现为应用程序提供附加配置(Configuration)或服务(ser ...
- IOS系统定时APP
将页面分为时间显示部分,控制部分,显示计次共三个部分.实现的功能有:启动定时器,计次,停止,复位. 计算:当前显示的时间 = 当前计次的累积时间 + 已经结束的所有计次的累积时间和: 关于 new D ...