设为首页 收藏本站
查看: 654|回复: 0

[经验分享] MariaDB主从搭建与测试

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-12-24 08:19:10 | 显示全部楼层 |阅读模式
(一) 安装相同版本的MariaDB。 这里我使用yum 安装
1) master:
rpm --import http://yum.mariadb.org/RPM-GPG-KEY-MariaDB

echo '# MariaDB 10.0 CentOS repository list - created 2014-03-15 08:00 UTC
# http://mariadb.org/mariadb/repositories/
[mariadb]
name = MariaDB
baseurl = http://yum.mariadb.org/10.0/centos6-amd64
gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
gpgcheck=1'>>/etc/yum.repos.d/MariaDB.repo

yum clean all

#Installing MariaDB with YUM##########################################################
yum -y install MariaDB-server MariaDB-client

#加入启动项###########################################################################
chkconfig --levels 235 mysql on

#start MariaDB########################################################################
/etc/init.d/mysql start

#设置mysql密码及相关设置##############################################################
mysql_secure_installation

#移动mysql配置文件
cp -p /etc/my.cnf /etc/my.cnf.bak
mv /etc/my.cnf /data/conf/
ln -s /data/conf/my.cnf /etc/

#移动mysql数据库
cp -rp /var/lib/mysql /var/lib/mysql-bak
mv /var/lib/mysql /data/
ln -s /data/mysql /var/lib/

# 添加防火墙规则
/sbin/iptables -I INPUT -p tcp --dport 3306 -j ACCEPT
/etc/rc.d/init.d/iptables save
/etc/init.d/iptables restart

2) slave 执行同样的操作

(二) 主服务器上设置一个远程用户允许从服务器通过此用户访问主服务器上的数据
MariaDB [(none)]> GRANT REPLICATION SLAVE ON *.* TO 'slave'@'192.168.3.133' IDENTIFIED BY '123456'; (允许用户slave通过192.168.3.133 复制当前master上的数据)
MariaDB [(none)]> FLUSH PRIVILEGES;
(三) 修改主数据库的配置文件my.cnf,开启BINLOG,并设置server-id的值(server_id值可以是整数型的数字(1 ~ 2^31-1), 在同一个复制组(replicating group)中的每台服务器的server_id都必须是唯一的),修改之后必须重启Mysql服务
[iyunv@localhost ~]# vi /data/conf/my.cnf
log-bin=/data/mysql/mysql-bin.log
server-id       = 1
binlog-ignore-db=mysql,information_schema,performance_schema  (忽略同步的数据库)
binlog-do-db=masterslavetest (需要复制的数据库名,如果复制多个数据库,重复设置这个选项即可)
replicate-ignore-db=mysql,information_schema,performance_schema(忽略同步的数据库)
replicate-do-db=masterslavetest (需要复制的数据库名,如果复制多个数据库,重复设置这个选项即可)

# 平滑加载mysql配置文件
[iyunv@localhost mysql]# service mysql reload
# 查看主服务器当前二进制日志名和偏移量,确定当前点, 主要是方便从服务器复制数据。
MariaDB [(none)]> show master status\G;
# 重置master
MariaDB [(none)]> reset master;

(四) 主服务器上增加数据库,添加数据表,插入数据。然后对我们主服务器进行锁表操作。查看当前主服务器上查看当前点的偏移量。我们从当前时间点开始把数据同步到从服务器
master:
MariaDB [(none)]> create database masterslavetest;  (主服务器添加数据库。等下我们就是用这个数据库来进行主从同步实验)
MariaDB [(none)]> use masterslavetest;
MariaDB [masterslavetest]> create table t1(id int,name varchar(20));
MariaDB [masterslavetest]> insert into  t1 values(1,'name1');
MariaDB [masterslavetest]>  flush tables with read lock;  (为了防止数据不同步,我们对主服务器进行读锁)
Query OK, 0 rows affected (0.00 sec)
MariaDB [masterslavetest]> show master status\G;  (# 主服务器上查看当前点的偏移量)
*************************** 1. row ***************************
            File: mysql-bin.000001
        Position: 779
    Binlog_Do_DB:
Binlog_Ignore_DB: mysql,information_schema,performance_schema
1 row in set (0.00 sec)

ERROR: No query specified
(五) 导出主服务器上的数据
[iyunv@localhost mysql]# mysqldump -u root -p masterslavetest > /root/masterslavet
(六)
1)配置从服务器
[iyunv@localhost ~]# vi /data/conf/my.cnf
log-bin=/data/mysql/mysql-bin.log
server-id       = 100 (和主服务器不能相同)
binlog-ignore-db=mysql,information_schema,performance_schema  (忽略同步的数据库)
binlog-do-db=masterslavetest (需要复制的数据库名,如果复制多个数据库,重复设置这个选项即可)
replicate-ignore-db=mysql,information_schema,performance_schema(忽略同步的数据库)
replicate-do-db=masterslavetest (需要复制的数据库名,如果复制多个数据库,重复设置这个选项即可)
后面四项和主服务器配置相同

2)重启从服务器
3)在从服务器上指定主服务器和同步点
MariaDB [(none)]> change master to master_host='192.168.3.132',master_user='slave',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=779;

4)开启slave
MariaDB [masterslavetest]> start slave;
5) 查看slave状态
MariaDB [masterslavetest]> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.3.132
                  Master_User: slave
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000002
          Read_Master_Log_Pos: 536
               Relay_Log_File: localhost-relay-bin.000002
                Relay_Log_Pos: 706
        Relay_Master_Log_File: mysql-bin.000002
             Slave_IO_Running: Yes  (这里几项是yes 表示成功)
            Slave_SQL_Running: Yes
              Replicate_Do_DB: masterslavetest




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-38522-1-1.html 上篇帖子: mysql利用CPU多核 下篇帖子: MySQL/ACCESS导出一句话拿WebShell后门命令
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表