相信我,看完这一篇,mysql主从复制能遇到的错误在我这里都遇到了,docker能遇到的错误在我这里也遇到了,包括centos的错误,看吧,都是成长
docker基础教程:https://blog.csdn.net/hello_list/article/details/124221409
Linux基础教程:https://blog.csdn.net/hello_list/article/details/123977208
Linux安装mysql:https://blog.csdn.net/hello_list/article/details/124761680
如果你还没有用docker搭建过mysql先不要急着搭建集群,可以显示着用docker搭建一个mysql,这里有教程,可以先试着去搭建一个mysql:
之前我们使用docker搭建了一个Mysql,那既然一个Mysql我们可以搭建成功,集群还不是分分钟,今天我们就简单搭建一个Mysql集群,就搭建一个最简单的一主一从的主从复制吧,如果一个搭建成功一主多从也是很简单,废话不多说,直接开始
这里我们只说安装啊,不说什么原理:

我们首先就是安装Mysql一样;其实就相当于虚拟机跑了两个mysql而且,平常怎么搭建Mysql就怎么搭建,这里如果不是学习不建议mysql用docker容器搭建,因为我们知道一个容器可以被删除卸载,而数据库作为保存数据的,跑在docker上还是不安全,虽然有挂载,还是不建议;
启动容器
docker run -p 3308:3306 --name mysql-master \ # -p 映射端口 --name 取容器名字
-v /mydata/mysql-master/log:/var/log/mysql \ # 这三个都是挂载目录
-v /mydata/mysql-master/data:/var/lib/mysql \
-v /mydata/mysql-master/conf:/etc/mysql \
–privileged=true \ # 提升容器权限
-e MYSQL_ROOT_PASSWORD=root \ # 初始化密码
-d mysql:5.7 # 后台运行容器
启动成功

配置master的my.cnf文件
> vim /mydata/mysql-master/conf/my.cnf
[mysqld]
## 同一局域网内注意要唯一
server-id=1
## 开启二进制日志功能,可以随便取(关键)
log-bin=mysql-bin
## 复制过滤:不需要备份的数据库,不输出(mysql库一般不同步)
binlog-ignore-db=mysql
## 为每个session 分配的内存,在事务过程中用来存储二进制日志的缓存
binlog_cache_size=1M
## 主从复制的格式(mixed,statement,row,默认格式是statement)
binlog_format=mixed
配置成功

查看下主机是有的:

这里重启下记得,重新加载下配置文件;
到后面进入容器的时候,才发现容器有问题,就是做的时候先把自己环境清理赶紧,然后重新执行,这次容器启动起来了,配置文件那个目录什么的都清理干净

启动容器
配置slave01的my.cnf文件
cd /
mkdir mydata
cd mydata
mkdir mysql-slave01
cd mysql-slave01
mkdir conf
cd conf
vim my.cnf
> vim /mydata/mysql-slave01/conf/my.cnf
[mysqld]
## 设置server_id,注意要唯一
server-id=2
## 开启二进制日志功能,以备Slave作为其它Slave的Master时使用
log-bin=mysql-slave-bin
## relay_log配置中继日志
relay_log=edu-mysql-relay-bin
##复制过滤:不需要备份的数据库,不输出(mysql库一般不同步)
binlog-ignore-db=mysql
## 如果需要同步函数或者存储过程
log_bin_trust_function_creators=true
## 为每个session 分配的内存,在事务过程中用来存储二进制日志的缓存
binlog_cache_size=1M
## 主从复制的格式(mixed,statement,row,默认格式是statement)
binlog_format=mixed
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062
与第一步一样:


废了九牛二虎之劲把两个容器启动起来了,主要是我的虚拟机存储满了,第二个容器一直启动不起来:

可以看到虚拟机启动起来,用的是我们的配置文件

但是还要从启动下,加载下配置文件,之后查看,是否是我们自己配置的id:
SHOW VARIABLES LIKE 'server_id';

查看下,我们两台容器的IP地址
docker inspect mysql-master
master地址是0.2

docker inspect mysql-slave01 # 03

进入master容器,执行以下命令
docker exec -it mysql-master /bin/bash
mysql > mysql -uroot -pmaster的密码
# 授予slave服务器可以同步master服务
mysql > grant replication slave, replication client on *.* to 'root'@'slave服务的ip' identified by 'slave服务器的密码';
#这里是grant replication slave, replication client on *.* to 'root'@'172.17.0.3' identified by 'root';
mysql > flush privileges;
# 查看MySQL现在有哪些用户及对应的IP权限(可以不执行,只是一个查看)
mysql > select user,host from mysql.user;

查询下当前结点位置
mysql > show master status;

进入从mysql-slave01,这里我直接开启了两个终端,这样方便:
docker exec -it mysql-slave01 /bin/bash

绑定主mysql
mysql> change master to master_host='master服务器ip', master_user='root', master_password='master密码', master_port=3306, master_log_file='mysql-bin.000003(这里跟前面我画箭头那对应起来)',master_log_pos=618(这里也是);
最后是
change master to master_host='172.17.0.2', master_user='root', master_password='root', master_port=3308, master_log_file='mysql-bin.000003',master_log_pos=618;

在从mysql slave下开启主从复制功能:
mysql> start slave;
Query OK, 0 rows affected (0.00 sec)
查看状态:
mysql> show slave status\G
一直显示连接中,证明没有开启成功

看错误提示:

这个错误我找了差不都两个小时,然后我尝试着链接不上?我用本机也就是虚拟机然后链接,一下就连上了

容器内我怎么也连接不上,但是
ERROR 2003 (HY000): Can't connect to MySQL server on '172.17.0.2' (111)
root@d6b141ceb723:/# mysql -uslave -h 172.17.0.2 -p -P3308
我发现我通过虚拟机ip可以连接,突然想明白了,我们是在容器内和容器外做的端口映射,而映射到虚拟机也就是本机是3308,容器内端口还是3306,然后就,之前写草稿的时候我还括号了这点,坑死了,啊~,可以说我这篇是把遇到的问题都遇到了,我成长了,成长了太多了,啊!!!


解决完之后又遇到一个错误:

uuid重复了,查看:确实重复了,我感觉这些错误,可以了
show variables like '%server_uuid%';

在主机中的文件,找到任意一个
vim /mydata/mysql-slave01/data/auto.cnf
修改一下,保存,重新启动mysql-slave容器:

然后我们在执行:
1、查看master节点
2、查看授权信息
3、进行授权
4、绑定主mysql
5、开启主从复制
mysql> stop slave;
Query OK, 0 rows affected (0.00 sec)
mysql> change master to master_host='172.17.0.2', master_user='root', master_password='root', master_port=3306, master_log_file='mysql-bin.000008',master_log_pos=1210;
Query OK, 0 rows affected, 2 warnings (0.01 sec)
mysql> start slave;
Query OK, 0 rows affected (0.04 sec)

在开发中主从复制之后不可以随意新增数据库,但是今天我们就尝试下,可以看到我们已经完成了主从复制:

启动第二个容器老是失败,提示我centos虚拟机存储快满了,我一看,确实满了,安装了不少东西,而且docker也挺费的,当初就是使用的20G,已经可以了,扩容到了30G,哈哈,看着这个教程扩容的,它的虚拟机跟我的一模一样,真好,直接看着就做下来了,扩容成功:https://www.cnblogs.com/friendwang1001/p/15725732.html

但是扩容之后,网络启动失败,可能是扩容的时候什么文件的原因吧,然后又找到一篇博客,就搞定了,这里,报错就是这个报错:(2条消息) Job for network.service failed because the control process exited with error code.报错解决方法_如是我愿的博客-CSDN博客
service NetworkManager stop 关闭 NetworkManger 服务
chkconfig NetworkManager off 永久关闭 Manager网卡
service network restart 重启network网卡
文章目录一、概述简介原理模块二、配置Mysql使用版本环境要求1.操作系统2.mysql要求三、配置canal-server离线下载在线下载上传解压修改配置单机配置集群配置分库分表配置1.修改全局配置2.实例配置垂直分库水平分库3.修改group-instance.xml4.启动监听四、配置canal-adapter1修改启动配置2配置映射文件3启动ES数据同步查询所有订阅同步数据同步开关启动4.验证五、配置canal-admin一、概述简介canal是Alibaba旗下的一款开源项目,Java开发。基于数据库增量日志解析,提供增量数据订阅&消费。Git地址:https://github.co
1.错误信息:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaitingheaders)或者:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:TLShandshaketimeout2.报错原因:docker使用的镜像网址默认为国外,下载容易超时,需要修改成国内镜像地址(首先阿里
我看到其他人也遇到过类似的问题,但没有一个解决方案对我有用。0.3.14gem与其他gem文件一起存在。我已经完全按照此处指示完成了所有操作:https://github.com/brianmario/mysql2.我仍然得到以下信息。我不知道为什么安装程序指示它找不到include目录,因为我已经检查过它存在。thread.h文件存在,但不在ruby目录中。相反,它在这里:C:\RailsInstaller\DevKit\lib\perl5\5.8\msys\CORE\我正在运行Windows7并尝试在Aptana3中构建我的Rails项目。我的Ruby是1.9.3。$gemin
我想编写一个ruby脚本来递归复制目录结构,但排除某些文件类型。因此,给定以下目录结构:folder1folder2file1.txtfile2.txtfile3.csfile4.htmlfolder2folder3file4.dll我想复制这个结构,但不包含.txt和.cs文件。因此,生成的目录结构应如下所示:folder1folder2file4.htmlfolder2folder3file4.dll 最佳答案 您可以使用查找模块。这是一个代码片段:require"find"ignored_extensions=[".cs"
我已经开始使用mysql2gem。我试图弄清楚一些基本的事情——其中之一是如何明确地执行事务(对于批处理操作,比如多个INSERT/UPDATE查询)。在旧的ruby-mysql中,这是我的方法:client=Mysql.real_connect(...)inserts=["INSERTINTO...","UPDATE..WHEREid=..",#etc]client.autocommit(false)inserts.eachdo|ins|beginclient.query(ins)rescue#handleerrorsorabortentirelyendendclient.commi
之前有人问过这个问题,我发现了以下clip关于如何一次设置一个类对象的所有属性,但由于批量分配保护,这在Rails中是不可能的。(例如,您不能Object.attributes={})有没有一种很好的方法可以将一个类的属性合并到另一个类中?object1.attributes=object2.attributes.inject({}){|h,(k,v)|h[k]=vifObjectModel.column_names.include?(k);h}谢谢。 最佳答案 利用assign_attributes使用:without_prote
(跟进我之前的问题,Ruby:howcanIcopyavariablewithoutpointingtothesameobject?)我正在编写一个简单的Ruby程序来在.svg文件中进行一些替换。第一步是从文件中提取信息并将其放入数组中。为了避免每次调用此函数时都从磁盘读取文件,我尝试使用memoize设计模式-在第一次调用后的每次调用中都使用缓存结果。为此,我使用了一个在函数之前定义的全局变量。但是,即使我在返回局部变量之前将该变量.dup为局部变量,调用该变量的函数仍在修改全局变量。这是我的实际代码:#memoizetokeepfromhavingtoreadoriginalfi
我正在尝试绕过rails配置这个极其复杂的迷宫。到目前为止,我设法在ubuntu上设置了rvm(出于某种原因,ruby在ubuntu存储库中已经过时了)。我设法建立了一个Rails项目。我希望我的测试项目使用mysql而不是mysqlite。当我尝试“rakedb:migrate”时,出现错误:“!!!缺少mysql2gem。将其添加到您的Gemfile:gem'mysql2'”当我尝试“geminstallmysql”时,出现错误,告诉我需要为安装命令提供参数。但是,参数列表很大,我不知道该选择哪些。如何通过在ubuntu上运行的rvm和mysql获取rails3?谢谢。
我正在尝试使用docker运行一个Rails应用程序。通过github的sshurl安装的gem很少,如下所示:Gemfilegem'swagger-docs',:git=>'git@github.com:xyz/swagger-docs.git',:branch=>'my_branch'我在docker中添加了keys,它能够克隆所需的repo并从git安装gem。DockerfileRUNmkdir-p/root/.sshCOPY./id_rsa/root/.ssh/id_rsaRUNchmod700/root/.ssh/id_rsaRUNssh-keygen-f/root/.ss
我在Heroku上构建了一个必须在Docker容器内运行的RoR应用程序。为此,我使用officialDockerfile.因为它在Heroku中很常见,所以我需要一些附加组件才能使这个应用程序完全运行。在生产中,变量DATABASE_URL在我的应用程序中可用。但是,如果我尝试其他一些使用环境变量(在我的例子中是Mailtrap)的加载项,变量不会在运行时复制到实例中。所以我的问题很简单:如何让docker实例在Heroku上执行时知道环境变量?您可能会问,我已经知道我们可以在docker-compose.yml中指定一个environment指令。我想避免这种情况,以便能够通过项目