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

[经验分享] MySQL数据库主从同步

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2017-3-6 10:08:28 | 显示全部楼层 |阅读模式
安装环境说明
系统环境:
[iyunv@~]# cat /etc/redhat-release
CentOS release 6.5 (Final)
[iyunv@~]# uname -r
2.6.32-431.el6.x86_64
数据库:
由于是模拟环境,主从库在同一台服务器上,服务器IP地址192.168.1.7
主库使用3306端口
从库使用3307端口
数据库数据目录/data
安装MySQL数据库服务
下载软件包
今天我们是用二进制安装包进行布署MySQL数据库服务,其它方式的安装布署方法请参考前面的文章
创建数据目录、软件安装目录
[iyunv@~]#mkdir /data{3306,3307} -p
[iyunv@~]#mkdri /application
解压软件
[iyunv@~]#tar zxf mysql-5.5.51-linux2.6-x86_64.tar.gz
[iyunv@~]#mv mysql-5.5.51-linux2.6-x86_64 /application/mysql-5.5.51
[iyunv@~]#ln -s /application/mysql-5.5.51 /application/mysql
创建用户
[iyunv@~]#groupadd mysql
[iyunv@~]#useradd -g mysql -M mysql
初始化数据库
[iyunv@~]#/application/mysql/scripts/mysql_install_db --basedir=/application/mysql --datadir=/data/3306/data --user=mysql
[iyunv@~]#/application/mysql/scripts/mysql_install_db --basedir=/application/mysql --datadir=/data/3307/data --user=mysql
创建配置文件
[iyunv@~]#vi /data/3306/my.cnf
[client]
port            = 3306
socket          = /data/3306/mysql.sock
[mysql]
no-auto-rehash
[mysqld]
user    = mysql
port    = 3306
socket  = /data/3306/mysql.sock
basedir = /application/mysql
datadir = /data/3306/data
open_files_limit    = 1024
back_log = 600
max_connections = 800
max_connect_errors = 3000
table_cache = 614
external-locking = FALSE
max_allowed_packet =8M
sort_buffer_size = 1M
join_buffer_size = 1M
thread_cache_size = 100
thread_concurrency = 2
query_cache_size = 2M
query_cache_limit = 1M
query_cache_min_res_unit = 2k
thread_stack = 192K
tmp_table_size = 2M
max_heap_table_size = 2M
long_query_time = 1
pid-file = /data/3306/mysql.pid
log-bin = /data/3306/mysql-bin
           #主从同步的关键点,从库上不需要开启
relay-log = /data/3306/relay-bin
relay-log-info-file = /data/3306/relay-log.info
binlog_cache_size = 1M
max_binlog_cache_size = 1M
max_binlog_size = 2M
expire_logs_days = 7
key_buffer_size = 16M
read_buffer_size = 1M
read_rnd_buffer_size = 1M
bulk_insert_buffer_size = 1M
lower_case_table_names = 1
skip-name-resolve
slave-skip-errors = 1032,1062
replicate-ignore-db=mysql
server-id = 1    #主库从库ID 不可相同
[mysqldump]
quick
max_allowed_packet = 2M
[mysqld_safe]
log-error=/data/3306/mysql3306.err
pid-file=/data/3306/mysqld.pid

数据库启动脚本:
[iyunv@~]#vi /data/3306/mysql
#!/bin/sh
port=3306
user="root"
pwd="123456"
Path="/application/mysql/bin"
sock="/data/${port}/mysql.sock"
start_mysql()
{
    if [ ! -e "$sock" ];then
      printf "Starting MySQL...\n"
      /bin/sh ${Path}/mysqld_safe --defaults-file=/data/${port}/my.cnf 2>&1 > /dev/null &
    else
      printf "MySQL is running...\n"
      exit
    fi
}
stop_mysql()
{
    if [ ! -e "$sock" ];then
       printf "MySQL is stopped...\n"
       exit
    else
       printf "Stoping MySQL...\n"
       ${Path}/mysqladmin -u ${user} -p${pwd} -S /data/${port}/mysql.sock shutdown
   fi
}
restart_mysql()
{
    printf "Restarting MySQL...\n"
    stop_mysql
    sleep 2
    start_mysql
}
case $1 in
start)
    start_mysql
;;
stop)
    stop_mysql
;;
restart)
    restart_mysql
;;
*)
    printf "Usage: /data/${port}/mysql {start|stop|restart}\n"
esac
备注:主从库配置文件与启动文件一样,只需修改端口与server-id即可完成配置
授权目录并增加启动文件可执行权限
[iyunv@~]#chown -R mysql.mysql /data
[iyunv@~]#find /data -name mysql -exex chmod +x {} \;
启动数据库
[iyunv@~]#/data/3306/mysql start
[iyunv@~]#/data/3307/mysql start
修改默认数据库密码
[iyunv@~]#mysqladmin -uroot password '123456' -S /data/3306/mysql.sock
[iyunv@~]#mysqladmin -uroot password '123456' -S /data/3307/mysql.sock
测试登陆,可以登陆两个数据库即可完成全部安装过程
配置主库
1)备份主库
mkdir /backup
登陆主库创建用步同户并授权
[iyunv@~]#mysql -uroot -p123456 -S /data/3306/mysql.sock
mysql> grant replication slave on *.* to rep@'192.168.1.%' identified by'123456';
Query OK, 0 rows affected (0.00 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
执行锁表操作
[iyunv@~]#/application/mysql/bin/mysql -uroot -p123456 -S /data/3306/mysql.sock -e "flush table with read lock;"
备份主库
[iyunv@~]#/application/mysql/bin/mysql -uroot -p123456 -S /data/3306/mysql.sock -e "show master status;" >/backup/mysql.log
[iyunv@~]#/application/mysql/bin/mysqldump -uroot -p123456 -S /data/3306/mysql.sock -A -B |gzip >/backup/mysql.sql.gz
解除锁表状态
[iyunv@~]#/application/mysql/bin/mysql -uroot -p123456 -S /data/3306/mysql.sock -e "unlock tables;"
备注:以上操作也可以登陆主库进行,但是需要注意的是,执行锁表操作后,需要另开启一个窗口进行数据备份,不可直接退出,防止有数据写入导致备份的数据不完整。最好是使用非交互式操作。
配置从库实现主从同步
将主库的备份文件解压并恢复数据库
[iyunv@backup ]#gzip -d mysql.sql.gz
[iyunv@backup ]#/application/mysql/bin/mysql -uroot -p123456 -S /data/3307/mysql.sock < mysql.sql
查看LOG日志
[iyunv@backup ]#cat mysql.log
+------------------+----------+--------------+-----------+
| File     | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+----------+----------+--------------+------------------+
| mysql-bin.000002 |      424 |              |                        |
+----------+----------+--------------+------------------+
登陆从库执行下面的操作
mysql> CHANGE MASTER TO
    -> MASTER_HOST='192.168.1.7',       #服务器IP
    -> MASTER_PORT=3306,                     #主库端口
    -> MASTER_USER='rep',                       #同步的用户
    -> MASTER_PASSWORD='123456',     #同步的用户密码
    -> MASTER_LOG_FILE=' mysql-bin.000002',   #binlog文件
    -> MASTER_LOG_POS=424;                   #位置点
mysql> start slave;             #开启同步
等待60S后查看同步状态
[iyunv@backup ]# mysql -S /data/3307/mysql.sock -e "show slave status\G"|egrep "Seconds_Behind_Master|_Running"
         Slave_IO_Running: Yes
         Slave_SQL_Running: Yes
         Seconds_Behind_Master: 0
只要出现上述情况说明主从同步成功
测试主从同步
主库创建一个数据库
[iyunv@backup ~]# mysql -S /data/3306/mysql.sock -e "create database tongbuku"
[iyunv@backup ~]# mysql -S /data/3306/mysql.sock -e "show databases"
+-----------------------------+
| Database                            |
+-----------------------------+
| information_schema         |
| mysql                                 |
| performance_schema       |
| test                                     |
| tongbuku                           |
+-----------------------------+
查看从库同步情况
[iyunv@backup ~]# mysql -S /data/3307/mysql.sock -e "show databases"
+-----------------------------+
| Database                            |
+-----------------------------+
| information_schema         |
| mysql                                 |
| performance_schema       |
| test                                     |
| tongbuku                           |
+-----------------------------+


运维网声明 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.yunweiku.com/thread-350343-1-1.html 上篇帖子: mysqlpump 备份文件压缩对比 下篇帖子: Mysql读写分离 数据库
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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