linux mysql 数据库复制

linux mysql 数据库复制一、主服务器配置 1、配置文件my.cnf的修改 [root@localhost mysql]# vim /etc/my.cnf #在[mysqld]中添加:server-id=1log_bin=ma

一、主服务器配置

1、配置文件my.cnf的修改

[root@localhost mysql]# vim /etc/my.cnf

#在[mysqld]中添加:
server-id=1
log_bin=master-bin
log_bin_index=master-bin.index
binlog_do_db=test
#备注:
#server-id 服务器唯一标识。
#log_bin 启动MySQL二进制日志,即数据同步语句,从数据库会一条一条的执行这些语句。
#binlog_do_db 指定记录二进制日志的数据库,即需要复制的数据库名,如果复制多个数据库,重复设置这个选项即可。
#binlog_ignore_db 指定不记录二进制日志的数据库,即不需要复制的数据库名,如果有多个数据库,重复设置这个选项即可。
#其中需要注意的是,binlog_do_db和binlog_ignore_db为互斥选项,一般只需要一个即可。

2、创建从服务器的用户和权限

#进入mysql数据库
[root@localhost mysql]# mysql -uroot -p
Enter password:

#创建从数据库的masterbackup用户和权限
mysql> grant replication slave on *.* to masterbackup@”192.168.17.%” identified by “123456”;
#备注
#192.168.17.%通配符,表示0-255的IP都可访问主服务器,正式环境请配置指定从服务器IP
#若将 192.168.17.% 改为 %,则任何ip均可作为其从数据库来访问主服务器

#退出mysql
mysql> exit;

3、重启mysql服务

[root@localhost mysql]# service mysqld restart

4、查看主服务器状态

#进入mysql数据库
[root@localhost mysql]# mysql -uroot -p
Enter password:

#查看主服务器状态
mysql> show master status;
+——————-+———-+————–+——————+——————-+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+——————-+———-+————–+——————+——————-+
| master-bin.000001 | 154 | test | | |
+——————-+———-+————–+——————+——————-+
1 row in set (0.00 sec)

ps:如果执行show master status,输出结果为空(mysql没有开启日志)

在mysql 配置文件 /etc/my.cnf中

[mysqld]下添加:

log-bin=mysql-bin

二、slave从服务器的配置

1 、配置文件my.cnf的修改

[root@localhost mysql]# vim /etc/my.cnf

#在[mysqld]中添加:
server-id=2
relay-log=slave-relay-bin
relay-log-index=slave-relay-bin.index
#replicate-do-db=test
#备注:
#server-id 服务器唯一标识,如果有多个从服务器,每个服务器的server-id不能重复,跟IP一样是唯一标识,如果你没设置server-id或者设置为0,则从服务器不会连接到主服务器。
#relay-log 启动MySQL二进制日志,可以用来做数据备份和崩溃恢复,或主服务器挂掉了,将此从服务器作为其他从服务器的主服务器。
#replicate-do-db 指定同步的数据库,如果复制多个数据库,重复设置这个选项即可。若在master端不指定binlog-do-db,则在slave端可用replication-do-db来过滤。
#replicate-ignore-db 不需要同步的数据库,如果有多个数据库,重复设置这个选项即可。
#其中需要注意的是,replicate-do-db和replicate-ignore-db为互斥选项,一般只需要一个即可。

2、 重启mysql服务

[root@localhost mysql]# service mysql restart

3、 连接master主服务器

#进入mysql数据库
[root@localhost mysql]# mysql -uroot -p
Enter password:

#连接master主服务器
mysql> change master to master_host=”192.168.17.130″,master_port=3306,master_user=”masterbackup”,master_password=”123456″,master_log_file=”master-bin.000001″,master_log_pos=154;
#备注:
#master_host对应主服务器的IP地址。
#master_port对应主服务器的端口。
#master_log_file对应show master status显示的File列:master-bin.000001。
#master_log_pos对应show master status显示的Position列:154。

4、启动slave数据同步

#启动slave数据同步
mysql> start slave;

#停止slave数据同步(若有需要)
mysql> stop slave;

5、查看slave信息

mysql> show slave statusG;

linux mysql 数据库复制

Slave_IO_Running和Slave_SQL_Running都为yes,则表示同步成功。

三、解决错误

1、在从数据库中,使用SET全局sql_slave_skip_counter来跳过事件,跳过这一个错误,然后执行从下一个事件组开始。

#在从数据库上操作
mysql > stop slave;
mysql > set global sql_slave_skip_counter=1;
mysql > start slave;

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/10574.html

(0)
上一篇 2022-12-25
下一篇 2022-12-25

相关推荐

  • 用Python下载Jupyter Notebook文件

    用Python下载Jupyter Notebook文件随着人工智能和数据科学的快速发展,Jupyter Notebook成为了一个极其受欢迎的交互式编程和数据分析环境。Jupyter Notebook可以将代码,文本,图形和可视化工具集成在一起,并且是一个非常适合数据科学和机器学习的平台。在数据科学实践中,我们通常会将代码和文本组合在一个Jupyter Notebook文档中,以便共享给其他人进行更好的协作和交流。在这种情况下,我们需要使用Python来下载Jupyter Notebook文件。

    2024-09-17
    23
  • 一周信创舆情观察(7.13~7.19)「终于解决」

    一周信创舆情观察(7.13~7.19)「终于解决」一、一周舆情要点 中国移动大规模采集国产数据库,自主可控数据库有望迎来全方位增长。中国移动此次预计采购1500套数据库产品及服务,金额在6000万元左右,中标候选人包括南大通用、人大金仓、阿里云、万…

    2023-03-25
    151
  • 大数据-业务数据采集[通俗易懂]

    大数据-业务数据采集[通俗易懂]CDC CDC 是 Change Data Capture(变更数据获取)的简称。核心思想是,监测并捕获数据库的变动(包括数据或数据表的插入、更新以及删除等),将这些变更按发生的顺序完整记录下来,写入

    2023-06-19
    146
  • 设置系统环境变量与Python os.setenv的使用方法

    设置系统环境变量与Python os.setenv的使用方法系统环境变量是一组操作系统的参数,它们以名称-值对的方式定义。在Windows、Linux和Mac等操作系统中,系统环境变量通常用于配置系统级别的参数,如系统路径、默认程序等。可以通过设置系统环境变量来定制操作系统的行为,这些变量可以在任何时候调用。

    2024-03-13
    84
  • Python实现插入排序

    Python实现插入排序排序是计算机科学中最基本的问题之一,也是所有算法设计的基础。一个好的排序算法可以提高对数据的搜索和处理效率。其中,插入排序是一种简单而有效的排序算法,特别适用于少量元素的排序。

    2024-07-14
    47
  • 什么是用户画像——从零开始搭建实时用户画像(一)「建议收藏」

    什么是用户画像——从零开始搭建实时用户画像(一)「建议收藏」用户画像 简介 ​ 用户画像,作为一种勾画目标用户、联系用户诉求与设计方向的有效工具,用户画像在各领域得到了广泛的应用。 用户画像最初是在电商领域得到应用的,在大数据时代背景下,用户信息充斥在网络中,

    2023-03-03
    146
  • hadoop实战hdfs_hadoop使用

    hadoop实战hdfs_hadoop使用一些介绍 Hadoop 2和Hadoop 3的端口区别 Hadoop 3 HDFS集群架构 我的集群规划 | name | ip | role | | | | | | 61 | 192.168.3.6

    2023-01-31
    166
  • Python String长度函数:计算字符串长度

    Python String长度函数:计算字符串长度在Python中,字符串是一种很常用的数据类型,它是由一系列字符组成的序列。Python给我们提供了一个内置函数len(),用于计算字符串的长度。根据官方文档的介绍:len(s)函数返回对象(字符、字节、列表、字典等)的长度或元素个数。在本文中,我们聚焦在字符串上。

    2024-04-12
    82

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注