MySQL5.5 数据库主从复制

Wesley13
• 阅读 283

        今天参照网上的资料进行mysql数据库的主从复制研究,本来网上的资料已经很详细,但是我在实践中还是遇到了很多问题,下面就根据网上的资料以及我遇到的问题进行一个总结。

        系统环境:Ubuntu12.04

        软件版本:mysql-server-5.5

        主机IP:192.168.0.200

        从机IP:192.168.0.201

操作:

    1、主机操作:

        1)、编辑mysql配置文件my.cnf

                [mysqld]

                server-id=1

                log-bin=mysql-bin

        注:网上还有一些其他的配置,但是为了偷懒只配置了这两个重要的,当然这两个也是必须的。

        2)、用root登陆mysql执行下面的代码

                //建立一个用户dean密码123456,并赋予replication slave权限:

                mysql>grant replication slave on *.* to 'dean'@'192.189.0.201' identified by '123456';

                //让权限立即生效

                mysql>flush privileges;

                //查询二进制文件的文件名和状态(后面要用)

                mysql>show master status \G

                                File:mysql-bin.000006

                         Position:107

               Binlog_Do_DB:

         Binlog_Ignore_DB:

    2、从机操作:

        1)、编辑myslq配置文件my.cnf:

                [mysqld]

                server-id=2   //只要和主机不同即可

        2)、登陆mysql,输入以下命令:

               a)、 mysql>change master to master_host='192.168.0.200',master_user='dean', \

                               master_password='123456',master_log_file='mysql-bin.000006',

                                master_log_pos=107;

                b)、mysql>start slave;

                c)、 mysql>show slave status \G

        如果出现:Slave_IO_Running:Yes

                        Slave_SQL_Running:Yes

        那么说明没有问题了,就可以在主机上面建库建表写测试数据,然后在从机上查询看有没有数据。一般是没有问题了。

        但是如果是出现:

                        Slave_IO_Running:Connecting

                        Slave_SQL_Running:Yes 

        那么就表示主从服务有问题了,我也就是遇到这个问题下面是我的解决方案:

        1)、在从机上直接远程登陆主机mysql服务器:

            #mysql -udean -h 192.168.0.200 -p123456

            如果被拒绝那么就需要检查主机的用户dean的权限、防火墙等设置是否正确。(我的被拒绝了)

        2)、检查权限。

            用root登入mysql 并选择mysql库

                mysql>use mysql;

            查询用户的访问

                mysql>select host,user from user;

               从查询数据看没有问题,有dean用户 接受192.168.0.201的访问

        3)、防火墙设置

                将端口为3306 的访问设为允许

                    #sudo ufw allow 3306

                将ip为192.168.0 .201的访问设为允许

                    #sudo ufw allow 192.168.0.201

                查看状态

                      # sudo ufw status

        设置完后还是从机还是不能直接远程访问主机

        4)、查看端口监听

                    #netstat -anpy|grep 3306

            发现当前的端口3306只在127.0.0.1监听,找到问题所在。修改mysql配置文件my.cnf将里面的bind-address=127.0.0.1注释调,重新察看端口监听发现监听是0.0.0.0:3306,好了测试一下果真可以进行远程访问。

        重新进行主机从机的操作,但是发现在从机中不能进行第2步a操作,执行下面命令

                mysql>stop slave;//关闭slave

                mysql>reset slave;//重置slave

        继续执行a操作并往下继续操作。

        最终完成了Mysql 数据库的主从复制。

        另:根据网上资料显示,如果主机在搭建主从复制前已经有数据需要先在主机上加锁:

            mysql>flush tables with read lock;

            然后打包数据目录并拷贝到从机上,然后解锁。

点赞
收藏
评论区
推荐文章
blmius blmius
1年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录 问题 用navicat导入数据时,报错: 原因这是因为当前的MySQL不支持datetime为0的情况。 解决修改sql\mode: sql\mode:SQL Mode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。 全局s
Stella981 Stella981
1年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置 1、virsh edit centos7 找到“memory”和“vcpu”标签,将 <name>centos7</name> <uuid>2220a6d1-a36a-4fbb-8523-e078b3dfe795</uuid>
Easter79 Easter79
1年前
Twitter的分布式自增ID算法snowflake (Java版)
概述 == 分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。 有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。 而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Stella981 Stella981
1年前
ASMSupport教程4.9 生成三元运算符
<p>这节我们介绍如何用ASMSupport生成三元运算符(... ? ... : ... )运算符。我们预计生成如下代码:</p> <div id="scid:9D7513F9-C04C-4721-824A-2B34F0212519:935e30cc-3321-4e00-93ba-9834f3a4e044" class="wlWriterEditableS
Stella981 Stella981
1年前
Android蓝牙连接汽车OBD设备
//设备连接 public class BluetoothConnect implements Runnable {     private static final UUID CONNECT_UUID = UUID.fromString("00001101-0000-1000-8000-00805F9B34FB");
Wesley13 Wesley13
1年前
PHP中的NOW()函数
是否有一个PHP函数以与MySQL函数`NOW()`相同的格式返回日期和时间? 我知道如何使用`date()`做到这一点,但是我问是否有一个仅用于此的函数。 例如,返回: 2009-12-01 00:00:00 * * * ### #1楼 使用此功能: function getDatetimeNow() {
Wesley13 Wesley13
1年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
#### 背景描述 # Time: 2019-01-24T00:08:14.705724+08:00 # User@Host: **[**] @ [**] Id: ** # Schema: sentrymeta Last_errno: 0 Killed: 0 # Query_time: 0.315758 Lock_
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞 # 背景 在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
3A网络 3A网络
2个月前
理解 virt、res、shr 之间的关系(linux 系统篇)
# 理解 virt、res、shr 之间的关系(linux 系统篇) **前言** 想必在 linux 上写过程序的同学都有分析进程占用多少内存的经历,或者被问到这样的问题 —— 你的程序在运行时占用了多少内存(物理内存)? 通常我们可以通过 t
3A网络 3A网络
2个月前
开发一个不需要重写成 Hive QL 的大数据 SQL 引擎
# 开发一个不需要重写成 Hive QL 的大数据 SQL 引擎 学习大数据技术的核心原理,掌握一些高效的思考和思维方式,构建自己的技术知识体系。明白了原理,有时甚至不需要学习,顺着原理就可以推导出各种实现细节。 各种知识表象看杂乱无章,若只是学习