0

0

Linux环境下单机上实现MySQL5主从数据库同步复制

php中文网

php中文网

发布时间:2016-06-07 16:59:18

|

1221人浏览过

|

来源于php中文网

原创

1.安装MySQL(http://www.linuxidc.com/Linux/2009-03/18988.htm)2.启动多个MySQL服务器 要实现在单机上启动多个MySQL服务器

1.安装mysql()
2.启动多个mysql服务器
    要实现在单机上启动多个mysql服务器,,有两种方法,一种是直接使用mysqld_safe来运行多个服务器
当然这样分别编辑配置文件,而且关闭服务器的时候也要读取配置文件,所以比较麻烦,另一种方法是使用
mysql提供到工具mysqld_multi脚本来管理多个服务器,下面使用的方法是mysqld_safe来实现。
3.前置条件
    假设mysql安装到目录为/usr/local/mysql/,设为mysql_dir通常它是一个链接文件。
    数据文件目录为$mysql_dir/data。
现在要添加另一个服务器的数据目录,因为为了模拟分布式服务器到同步,不可能让多个服务器共享一个数据目录。
$cd $mysql_dir
$sudo cp -r -p data var2
    上面的指令将data保留原来到权限复制一份到var2,var2也就是另一个服务器的数据目录,这样,在原始
状态下,两个数据库服务器的数据是一致的。
4.假设有mysql的合法用户root:root。
5.启动安装好以后的那个服务器
    $cd $mysql_dir/bin
    $sudo ./mysqld_safe --user=mysql --binlog-do-db=test &
    上面的命令表示启动服务器并且使用二进制日志记录数据库test的更新动作。
6.测试是否启动成功
    $mysql -u root -p -s/tmp/mysql.sock
    输入密码后,如果能够成功登录的话表示成功,这里最容易出现2002错误,表示socket文件错误,你可以
使用命令
    $ps aux|grep mysql
来查看当前服务器使用的socket文件,然后在登录的时候使用相应的socket文件。
7.编辑配置文件
    $sudo vi /etc/my.cnf
最初的时候,这个配置文件是针对前面启动的服务器的,现在我们把它修改一下,然后就可以启动另一个服务器
找到[mysqld]段落,然后修改如下:
[mysqld]
server-id=2    #原来是1
socket=/tmp/mysql.sock2    #原来是/tmp/mysql.sock
port=3307                #原来是3306
#下面3行是添加的
pid-file=$mysql_dir/var2/localhost.pid2
datadir=$mysql_dir/var2
log=$mysql_dir/var2/db2.log
    注意使用最前面的mysql安装目录来代替上面的$mysql_dir。
8.启动第二个服务器
    $cd $mysql_dir/bin
    $sudo ./mysqld_safe --user=mysql  &
9.测试第二个服务器
    $mysql -u root -p -p 3307 -s /tmp/mysql.sock2
    输入密码后,应该能够正确连接到mysql服务器。
现在,两个服务器能够正常的运行在同一台机器上了,剩下的就是配置主从服务器,然后让主服务器更新,从服务器
连接主服务器并且保持同步。
10.同步服务器
    注意到我们启动第一个服务器的时候使用了一个参数--binlog-do-db=test表示,我们希望把数据库test的更新
操作都记录到二进制日志文件中。
    1)登录到主服务器
        $mysql -u root -p -p 3306 -s /tmp/mysql.sock
    2)查看主服务器的状态   
        mysql>show processlist\g
            上面这条命令执行后应该看到至少两个线程,第一个就是登录的线程,第二个就是发送二进制日志
            的线程。
        mysql>flush tables with read lock;
        mysql>show master status;
        mysql>unlock tables;
    记住show master status\g命令输出的结果,这里的file是二进制日志文件,position是偏移量,binlog_do_db
表示对哪些数据库记录更新操作,binlog_ignore_db表示忽略哪些数据库更新。待会儿配置从服务器时要使用file和
position。
    3)登录到从服务器
        $mysql -u root -p -p 3307 -s /tmp/mysql.sock2
    4)配置从服务器
        首先要确保停止从服务器同步线程
        mysql>stop slave;
        然后设置主服务器参数
        mysql>change master to
            ->master_host='127.0.0.1',
            ->master_user='root',
            ->master_password='root',
            ->master_log_file='mysql-bin.000016',
            ->master_log_pos=102;
        最后启动从服务器同步线程
        mysql>start slave;
        检查从服务器同步线程是否启动成功
        mysql>show slave status\g
            如果从上面的输出中看到了io线程和log线程都是yes的话,那么表示启动成功,最后一行输出表示从服务器
            比主服务器滞后多少。
        查看线程
        mysql>show processlist;
            当从服务器同步成功启动以后,上面这条命令应该输出至少3个线程,第一个是登录线程,第二个是io线程,第
            三个是日志线程。
11.测试同步
    在主服务器中的数据库test中任意执行一些更新操作,然后在从服务器中查看,应该马上就能够看到更新结果。

linux

相关专题

更多
Word 字间距调整方法汇总
Word 字间距调整方法汇总

本专题整合了Word字间距调整方法,阅读下面的文章了解更详细操作。

2

2025.12.24

任务管理器教程
任务管理器教程

本专题整合了任务管理器相关教程,阅读下面的文章了解更多详细操作。

2

2025.12.24

AppleID格式
AppleID格式

本专题整合了AppleID相关内容,阅读专题下面的文章了解更多详细教程。

0

2025.12.24

csgo视频观看入口合集
csgo视频观看入口合集

本专题整合了csgo观看入口合集,阅读下面的文章了知道更多入口地址。

29

2025.12.24

yandex外贸入口合集
yandex外贸入口合集

本专题汇总了yandex外贸入口地址,阅读下面的文章了解更多内容。

58

2025.12.24

添加脚注通用方法
添加脚注通用方法

本专题整合了添加脚注方法合集,阅读专题下面的文章了解更多内容。

1

2025.12.24

重启电脑教程汇总
重启电脑教程汇总

本专题整合了重启电脑操作教程,阅读下面的文章了解更多详细教程。

3

2025.12.24

纸张尺寸汇总
纸张尺寸汇总

本专题整合了纸张尺寸相关内容,阅读专题下面的文章了解更多内容。

5

2025.12.24

Java Spring Boot 微服务实战
Java Spring Boot 微服务实战

本专题深入讲解 Java Spring Boot 在微服务架构中的应用,内容涵盖服务注册与发现、REST API开发、配置中心、负载均衡、熔断与限流、日志与监控。通过实际项目案例(如电商订单系统),帮助开发者掌握 从单体应用迁移到高可用微服务系统的完整流程与实战能力。

1

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 0.6万人学习

Node.js 教程
Node.js 教程

共57课时 | 7.2万人学习

CSS3 教程
CSS3 教程

共18课时 | 3.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号