1.Mysql集群------Docker下的Mysql主从复制
前言:
实话说,我想做的是Mysql集群架构。
我的计划是:
1.实现Docker下的Mysql主从复制
2.实现MyCat基于Mysql的读写分离
3.实现MyCat的分库分表
4.实现pxc集群
5.综合MyCat和pxc实现高可用、高并发的数据库集群架构
当然,现在的我还是一个小菜鸟,尤其是第一次上手docker上配置Mysql的主从复制,
自己一路跳坑,终于走出了黑暗。
这里,我就带领大家进入我的坑计划。
开始搬砖:
1.安装docker
(1)登录linux
(2)下载docker
| 命令:yum install docker |
就这么简单
2.安装mysql镜像
(1)开启docker
命令:service docker start
(2)拉取Mysql,注意Mysql5以后的版本才支持主从复制
我这里是去网易蜂巢取得镜像:https://c.163yun.com/hub#/m/home/
命令:docker pull hub.c.163.com/library/mysql:latest
拉取完之后查询镜像
命令:docker images

3.配置主从复制
(1)创建配置文件
目录:/usr/local/mysql/ 注意:目录你个人设定,这不过是我自己的爱好
主数据库(master)配置文件/usr/local/mysql/master/my.cnf:
[mysqld]
log-bin=mysql-bin
server-id=1 #注意这个id>0且要唯一
从数据库(slave)配置文件/usr/local/mysql/slave/my.cnf:
[mysqld]
log-bin=mysql-bin
server-id=2 #注意这个id>0且要唯一
注意:我是在容器外部进行的配置,喜欢进入容器内部配置的请稍等。
(2)开启主从数据库
开启主数据库:

开启从数据库:

查看容器状态:

在这里,容器就正常打开了。
喜欢进入容器内部修改配置文件的注意了:
进入主数据库命令:docker exec -it mysql /bin/bash

修改my.cnf配置文件命令:vi /etc/mysql/my.cnf

oh my 上帝!里面的vi、vim命令都不能用!!!
上天难不倒有心之人,我装一个vim(实话说,vi是怎么装怎么失败,vim偶尔成功,但老子用的是集群啊,对,每一个容器都得装一遍vim,so,我启用外部的配置文件)
命令:apt-get update

命令:apt-get install vim

(这一次神奇的装成功了)
照着上边修改配置文件修改下my.cnf就可以了。
命令:vim /etc/mysql/my.cnf

配置成功的同学,保存,重启容器,照此再配置从服务器。
(3)重中之重的主从配置环节
---------------------------------------------------------------------------------------------------------------------------------master数据库配置-----------------------------------------------------------------------------------------------------------------------
master数据库创建授权用户:
grant all privileges on *.* to 'username'@'ip' identified by 'password' with grant option;
flush privileges;

%是统配字符,表示所有ip都可以连接,这个ip主要是从数据库的ip
喜欢进入容器内部进行黑窗操作的同学请不要介意,我是喜欢这样用客户端哈哈。
查询用户,host:select user,host from mysql.user;

查看master状态:show master status;

主数据库的配置环节到此就完成了。
---------------------------------------------------------------------------------------------------------------------------------slave数据库配置-----------------------------------------------------------------------------------------------------------------------
停止slave:stop slave;
配置连接master数据库:
change master to master_host=’ip’, master_user=’username’, master_password=’password’, master_log_file=’log_file_name’;

开启slave:start slave;
查询slave状态:show slave status;

当你的Slave_IO_State也是这样就完成了。
但是可惜的是,如果你不知道这个细节,你永远是完不成的。
注意:上面填写的ip,一定一定是docker容器的ip,而不是虚拟机的ip。
来查看下,docker容器的ip:

1.Mysql集群------Docker下的Mysql主从复制的更多相关文章
- MySQL集群(一)之主从复制
前面学完了JDBC,接下来带大家感受一下MySQL集群!其实什么是MySQL集群?简单的说就是一群机器(服务器)的集合,它们连在一起来工作. 其实各种数据库都有自己的集群,常常的多: 我们要学习的就是 ...
- MySQL集群---②Windows平台搭建MySQL CLUSTER集群
原文:http://blog.csdn.net/mazhaojuan/article/details/42211857 本文将通过两台电脑来简单介绍一下Windows平台如何搭建MySQL集群. My ...
- 【MySQL集群】——Java程序连接MySQL集群
上篇简介了怎样在Windows环境下建立配置MySQL集群,这里用一个实现注冊功能的小Demo通过jdbc的方式连接到MySQL集群中. 外部程序想要远程连接到mysql集群,还须要做的一个操作就是设 ...
- Docker环境下的前后端分离项目部署与运维(六)搭建MySQL集群
单节点数据库的弊病 大型互联网程序用户群体庞大,所以架构必须要特殊设计 单节点的数据库无法满足性能上的要求 单节点的数据库没有冗余设计,无法满足高可用 单节点MySQL的性能瓶领颈 2016年春节微信 ...
- Docker部署Mysql集群
单节点数据库的弊病 大型互联网程序用户群体庞大,所以架构必须要特殊设计 单节点的数据库无法满足性能上的要求 单节点的数据库没有冗余设计,无法满足高可用 单节点MySQL的性能瓶领颈 2016年春节微信 ...
- 高可用性、负载均衡的mysql集群解决方案
高可用性.负载均衡的mysql集群解决方案 一.mysql的市场占有率 二.mysql为什么受到如此的欢迎 三.mysql数据库系统的优缺点 四.网络服务器的需求 五.什么是mysql的集群 六.什么 ...
- [原]项目进阶 之 集群环境搭建(二)MySQL集群
上次的博文中我们介绍了一下集群的相关概念,今天的博文我们介绍一下MySQL集群的相关内容. 1.MySQL集群简介 MySQL群集技术在分布式系统中为MySQL数据提供了冗余特性,增强了安全性,使得单 ...
- MySQL集群(三)mysql-proxy搭建负载均衡与读写分离
前言 前面学习了主从复制和主主复制,接下来给大家分享一下怎么去使用mysql-proxy这个插件去配置MySQL集群中的负载均衡以及读写分离. 注意:这里比较坑的就是mysql-proxy一直没有更新 ...
- mysql集群7.4.1
一:mysql集群原理: 1 mysql集群分为三个节点: 1.1 控制节点:本身不提供服务只是控制整个集群的开启与关闭 1.2 数据节点:真正提供数据库的存储,并和其他数据节点关联用 1.3 sql ...
随机推荐
- 多线程编程_控制并发线程数的Semaphore
简介 Semaphore(信号量)是用来控制同时访问特定资源的线程数量,它通过协调各个线程,以保证合理的使用公共资源.很多年以来,我都觉得从字面上很难理解Semaphore所表达的含义,只能把它比作是 ...
- 时间比较早晚java
package demo; import java.text.SimpleDateFormat;import java.util.Date;import java.util.Locale; publi ...
- hdu 2222 ac自动机更新模板 for onSite contest
http://acm.split.hdu.edu.cn/showproblem.php?pid=2222 #include <cstdio> #include <cstdlib> ...
- (转)轻松掌握shell编程中数组的常见用法及示例
缘起:在老男孩进行linux培训shell编程教学中,发现不少水平不错的网友及同学对数组仍然很迷糊,下面就给大家分享下数组的用法小例子,希望能给大家一点帮助.其实SHELL的数组很简单,好用.我们学习 ...
- php 可逆的加密算法
代码: <?php class Test { private $authCodeKey = 'khUvFB9pijNyCYMGZdzqeKalyg7dh'; function authCode( ...
- 三、gridView增删改查
1. 新增或修改一条数据 1.1 添加 新增或修改按钮 <div style="width: 120px; float: right; padding-top: 3px"&g ...
- the wait queue
using System; using System.Collections.Concurrent; using System.Threading; namespace Base { public c ...
- 如何在Chrome粘贴图片直接上传
背景 截图或页面复制图片,可以直接通过Ctrl+v 粘贴上传图片 原理 操作:复制(截图)=>粘贴=>上传 监听粘贴事件=>获取剪贴板里的内容=>发请求上传 浏览器:Chrom ...
- Android 开发知识结构图
- AngularJS 指令解析(二)
AngularJS 指令解析(二) 第一篇我们讲过了作用域(scope)这块内容,现在我们进入正题,讲AngularJS的指令. 什么是指令? 这里我们引用官方的一句话: Custom directi ...