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. 一次Flannel和Docker网络不通定位问题

    一次Flannel和Docker网络不通定位问题    查看路由表的配置 路由表情况 [root@k8s-master ~]# route -n Kernel IP routing table Des ...

  2. [skill][c] *(char**)

    /* scmp: string compare of *p1 and *p2 */ int scmp(const void *p1, const void *p2) { char *v1, *v2; ...

  3. LeetCode 706 Design HashMap 解题报告

    题目要求 Design a HashMap without using any built-in hash table libraries. To be specific, your design s ...

  4. HTML5上传文件显示进度

    下面我们使用Html 5的新特性file api实现上传文件,并显示上传文件进度百分比.意图是这样的,当选择文件时,显示当前文件信息.这里我们是结合Asp.net MVC做为服务端,您也可以是其它的服 ...

  5. Java之旅_高级教程_网络编程

    摘自:http://www.runoob.com/java/java-networking.html JAVA网络编程 网络编程是指编写运行在多个设备(计算机)的程序,这些设备都通过网络连接起来. j ...

  6. Python开发【笔记】:aiohttp搭建简易聊天室

    简易聊天室: 1.入口main.py import logging import jinja2 import aiohttp_jinja2 from aiohttp import web from a ...

  7. Python中的下划线(转)

    译文原文:https://segmentfault.com/a/1190000002611411 原文地址这篇文章讨论Python中下划线_的使用.跟Python中很多用法类似,下划线_的不同用法绝大 ...

  8. C# Asp.net中xml串与对象互相转换

    public class XmlUtil { #region 反序列化 /// <summary> /// 将XML字符串反序列化为对象 /// </summary> /// ...

  9. es6 学习二 Generator

    安装babel的拓展包(Polyfill) ,对Generator的转义 这是一个补完babel支持es6的拓展包,配置步骤为3个: 打开命令行键入 npm install --save-dev ba ...

  10. Erlang调度器

    1. Erlang 抢占式调度 Erlang实现公平调度基于Reduction Budget(运行次数限制).每一个进程创建时初始reduction budget值为2000,任何Erlang系统中的 ...