CentOS双机中Docker下安装Mysql并配置互为主从模式

目录

1、搜索镜像... 1

2、拉取镜像... 1

3、绑定端口: 1

4、配置文件(修改/etc/mysql/my.cnf文件)... 2

5、重启mysql... 2

6、进入mysql 2

7、创建同步用户... 2

8、在mysql中查看主服务状态:... 2

9、链接master... 3

10、启动从服务:... 3

11、查看slave状态... 3

12B服务器如上配置... 3

附录:... 3

解决方案1... 4

解决方案2... 4

解决方案3... 4

双服务器(已安装docker)如下:

A服务器:192.168.0.90

B服务器:192.168.0.230

先进入A服务器

1、搜索镜像

#docker search mysql

2、拉取镜像

#docker pull mysql:5.7

3、绑定端口:

#docker run --name test-mysql -v /data/mysql-db:/var/lib/mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=test@2018 -d --restart=always mysql:5.7  映射到宿主端口3306

test@2018mysql密码

-d --restart=always mysql:5.7:配置为宿主重启自启动mysql

、配置文件(修改/etc/mysql/my.cnf文件)

#echo  -e '[mysqld]\nlog-bin=mysql-bin\nserver-id=90' > /etc/mysql/my.cnf

mysql-bin:日志二进制文件

server-id:服务器唯一ID

skip-name-resolve:跳过域名解析【可选】

lower_case_table_names=1//忽略表名大小写      sql-mode="STRICT_ALL_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ZERO_DATE,NO_ZERO_IN_DATE,NO_AUTO_CREATE_USER"//忽略1055信息

      default-time_zone = '+8:00'

5、重启mysql

#service mysql restart

6、进入mysql

       #mysql -u root -p

       输入mysql密码:test@2018

7、创建同步用户

       a、创建备份账号及密码

mysql>grant all privileges on *.* to `test_replic`@`%` identified by 'test@2018';

b、提交

              mysql>flush privileges;//

c、查看账号信息:

mysql>select host,user,authentication_string from user;

8、在mysql中查看主服务状态:

show master status;

日志文件:例:mysql-bin.000001

Position:例:596

9、链接master

mysql>change master to master_host='192.168.0.230',master_user='test_replic',master_password='test@2018',master_log_file='mysql-bin.000001',master_log_pos=1011;

mysql-bin.000001B服务器日志文件【查看show master status;

1011B服务器日志文件位置【查看show master status;

test_replicB服务器中第7创建的用户

test@2018B服务器中第7创建的密码

10、启动从服务:

mysql>start slave

11、查看slave状态

mysql>show slave status\G;

Slave_IO_RunningSlave_SQL_Running都为YES的时候就表示主从同步设置成功

12B服务器如上配置

附录:

解决方案1

1、停止slave

mysql> stop slave;

2、跳过错误点

mysql> SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1;

3、启动slave

mysql> start slave;

解决方案2

1、停止slave

mysql> stop slave;

2、改position位置

mysql> change master to master_log_file='mysql-bin.000288',master_log_pos=627625751;

3、启动slave

mysql> start slave;

解决方案3

删除mysql binlog

mysql>purge master logs before'2016-09-01 17:20:00';

CentOS双机中Docker下安装Mysql并配置互为主从模式的更多相关文章

  1. CentOS 7 中 Docker 的安装

    CentOS 7 中 Docker 的安装 Docker 软件包已经包括在默认的 CentOS-Extras 软件源里.因此想要安装 docker,只需要运行下面的 yum 命令: [root@loc ...

  2. ubuntu下安装mysql和配置远程访问

    ubuntu下安装mysql和配置远程访问   下载安装mysql sudo apt-get install mysql-client mysql-server 安装的时候会提示要设置root密码,如 ...

  3. CentOS7下安装MySQL并配置远程连接

    一.CentOS7下安装MySQL数据库 CentOS7默认的安装包里面已经没有 MySQL-Server安装包了,远程镜像中也没有了. 默认的是MariaDB (MySQL的一个分支,开发这个分支的 ...

  4. Linux(CentOS 7)环境下安装MySQL

    在CentOS中默认安装有MariaDB,但是我们需要的是MySQL,安装MySQL可以覆盖MariaDB MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可 ...

  5. CentOS下安装mysql及配置使用

    最近一直使用的是CentOS,平时用的最多的数据库是Sql Server,对于mysql还停留在上学的时候,早已忘得一干二净,写这篇内容目的是,重新学习如何安装使用mysql. 一.安装mysql 操 ...

  6. CentOS 7 中 Docker 的安装和卸载

    安装Dokcer Docker 软件包已经包括在默认的 CentOS-Extras 软件源里.因此想要安装 docker,只需要运行下面的 yum 命令: [root@localhost ~]# yu ...

  7. docker下安装mysql数据库

    因为用了.net core 所以想学习下使用docker: 项目中刚好要用到mysql数据库,所用用docker来安装一次,我使用的是5.6版本: 1.拉取官方镜像 docker pull mysql ...

  8. 2016-1-8 windows 7下安装mysql及其配置和运用

    绪言 最近学习了一下mysql的相关用法,以及vs2010结合mysql的使用. 遇到的问题:1.安装mysql 5.6 绿色免安装版本,出现mysql server not connect loca ...

  9. linux 下安装 mysql 并配置 python 开发环境

    1.安装 mysql ,安装过程中将提示设置 root 用户的密码,默认可以设置为 rootadmin . $ sudo apt-get install mysql-server 2.安装 mysql ...

随机推荐

  1. sql server 实现多表连接查询

    项目中要实现多表查询,用外连接实现. a表 a(aid,aname) 其中aid为pk b表 b(aid,bname,aid) 其中 bid为pk,aid为fk c表 c(cid,cname,aid) ...

  2. 转:jdk动态代理实现

    原文链接: jdk动态代理 注:文章中用常用的流程实现 动态代理,流程逻辑比较清晰.文章后面对 “为什么要使用接口” 原理分析还未细看. jdk的动态代理为什么用接口,内部是什么原理呢?看了几篇文章貌 ...

  3. 抽屉之Tornado实战(6)--session工厂(工厂方法模式)

    我之前写的session一般保存在服务器的内存里,那可以保存在缓存,或是数据库,那问题来了,不同地方,保存方式是不同的,所以需要定义不同的类,cache/redis/memcached类 sessio ...

  4. ORACLE network environment

    监听程序 建立网络连接 要建立客户机或中间层连接,Oracle Net要求客户机 下列事项: 运行监听程序的主机 监听程序监视的端口 监听程序使用的协议 监听程序处理的服务名 Hostname/ip ...

  5. es6学习笔记入门总结

    1.let const block 作用域 let 代替var 来声明块级作用域,没有变量提升,只在块内有作用 const 可以声明一个常量,类似于指针,指向某一个引用,这个常量并非一成不变的,但是不 ...

  6. Web Deploy远程部署配置图解

    原文链接:https://jingyan.baidu.com/album/642c9d34e614de644a46f783.html

  7. Python开发【模块】:aiohttp(二)

    AIOHTTP 1.文件上传 ① 单个文件上传 服务端 async def post(self, request): reader = await request.multipart() # /!\ ...

  8. @property专题

    “属性” (property)作为 Objective-C 的一项特性,主要的作用就在于封装对象中的数据. Objective-C 对象通常会把其所需要的数据保存为各种实例变量.实例变量一般通过“存取 ...

  9. 弱网测试之基于TP-LINK

    使用路由器做弱网测试应该是最真实的,网络工程师/运维工程师体会应该最深刻.这种方式测试成本也不高,比较推荐. 设置的方式不在赘述,参见使用手册,高级设置即可. 结束语: 这样测试的时候,测试机器连接该 ...

  10. head 命令 读取文件的前n行,默认查看文件的前十行

    head 命令 读取文件的前n行 默认查看文件的前十行 head /etc/passwd # 默认查看文件的前十行 /etc/passwd # 查看文件的前两行