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

[经验分享] mysql 基于 ssl 的主从复制

[复制链接]

尚未签到

发表于 2018-10-3 12:42:41 | 显示全部楼层 |阅读模式
  1、创建证书中心
  创建证书颁发机构,首先要生成ca自己的私钥,如下:
  cd /etc/pki/CA
  (umask 077;openssl genrsa -out /etc/pki/CA/private/cakey.pem 2048)
  生成自签证书,由于需要输入大量用户信息(在私有的CA上创建证书要注意所有的用户信息需要一致,从国家到部门都要相同,否则会造成证书无法使用)
  生成自签名证书
  openssl req -new -x509 -key /etc/pki/CA/private/cakey.pem -out /etc/pki/CA/cacert.pem -days 3650
  -x509是创建自签证书是需要的参数,在创建其他证书时不能加该参数
  然后创建ca所需文件,如下:
  cd /etc/pki/CA
  touch index.txt
  echo 01 > serial
  2、为master服务器创建证书
  服务器的名称必须固定,在申请证书时要输入服务器的通用名称,此通用名称必须与服务器外网申请的域名相同。
  创建私钥
  mkdir /home/mysql/
  cd /home/mysql
  (umask 077;openssl genrsa -out master.key 2048)
  生成证书申请文件
  openssl req -new -key master.key -out master.csr
  在证书服务器上对master的证书进行签发
  cd /etc/pki/CA
  openssl ca -in /home/mysql/master.csr -out /home/mysql/master.crt -days 365
  3、创建slave服务器证书
  (umask 077;openssl genrsa -out slave.key 2048)
  openssl req -new -key slave.key -out slave.csr
  将slave服务器的证书申请文件复制到证书服务器上进行签发
  opessl ca -in slave.csr -out slave.crt -days 356
  4、×××权限和mysql配置文件
  将ca的证书cacert.pem复制到master、slave服务器的相应目录下
  cd /home/mysql
  cp /etc/pki/CA/cacert.pem ./
  chown -R mysql:mysql /home/mysql
  chmod 600 /home/mysql/*.key
  修改master服务器的/etc/my.cnf配置文件:
  vim /etc/my.cnf
  [mysqld]
  ssl_ca                  = /home/mysql/cacrt.pem
  ssl_cert                = /home/mysql/master.crt
  ssl_key                 = /home/mysql/master.key
  修改slave服务器配置
  vim /etc/my.cnf
  [client]
  ssl_ca                  = /home/mysql/cacrt.pem
  ssl_cert                = /home/mysql/slave.crt
  ssl_key                 = /home/mysql/slave.key
  
  5、在主服务器上创建复制用户

  > grant replication slave on *.* to 'repl'@‘192.168.%'>  > flush privileges;
  查看主服务器当前二进制位置
  mysql> show master status ;
  +————————-+————+———————+————————–+————————–+
  | File                            | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
  +————————-+————+———————+————————–+————————–+
  | mysql-bin.000007 |     1015   |                              |                                    |                                    |
  +————————-+————+———————+————————–+—————————+
  1 row in set (0.00 sec)
  6、在从服务器上开始复制
  change master to
  master_host=‘192.168.0.66',
  master_user='repl',
  master_password='repl',
  master_log_file='mysql-bin.000007',
  master_log_pos=1015,
  master_ssl=1,
  master_ssl_ca='/home/mysql/cacrt.pem',
  master_ssl_cert='/home/mysql/slave.crt',
  master_ssl_key='/home/mysql/slave.key';
  start slave;
  show slave status;
  
  7 排错
  导致lave_IO_Running 为connecting 的原因主要有以下 3 个方面:

  •   网络不通
  •   密码不对
  •   pos不对
  解决步骤:

  •   对于第一个问题,一般情况下都是可以排除的,也是最容易排除的。
  •   在主库上修改用来复制的用户的密码。
  •   在做chang to 的时候注意log_pos 是否跟此时主机的相同
  在主机上 show master status \G ;可以查看到
  8 线上实例
  服务器端配置如下:
  [ec2-user@vps1 ~]$ cat /etc/my.cnf
  [mysqld]
  datadir=/var/lib/mysql
  socket=/var/lib/mysql/mysql.sock
  # Disabling symbolic-links is recommended to prevent assorted security risks
  symbolic-links=0
  # Settings user and group are ignored when systemd is used.
  # If you need to run mysqld under a different user or group,
  # customize your systemd unit file for mysqld according to the
  # instructions in http://fedoraproject.org/wiki/Systemd
  skip_name_resolve
  open_files_limit=8192
  #ssl configure
  ssl_ca=/home/mysql/cacert.crt
  ssl_cert=/home/mysql/mysql.crt
  ssl_key=/home/mysql/mysql.key
  log-bin=mysql-bin
  expire_logs_days=5
  server-id=1
  replicate-ignore-db=mysql
  replicate-ignore-db=zabbix
  slow_query_log_file=/var/log/mysql/slow.log
  log_queries_not_using_indexes=1
  long_query_time=5
  innodb_file_per_table=1
  innodb_buffer_pool_size=64M
  log_slave_updates
  relay-log=relay-bin
  relay-log-space-limit=512000000
  slave-net-timeout=360
  [mysql]
  default_character_set=utf8
  [mysqld_safe]
  log-error=/var/log/mysqld.log
  pid-file=/var/run/mysqld/mysqld.pid
  [ec2-user@vps1 ~]$ ll /home/mysql/
  总用量 16
  -rw-r--r-- 1 mysql mysql 1318 6月  23 06:09 cacert.crt
  -rw-r--r-- 1 mysql mysql 3715 6月  23 06:05 mysql.crt
  -rw-r--r-- 1 mysql mysql  651 6月  23 06:03 mysql.csr
  -rw------- 1 mysql mysql  891 6月  23 06:02 mysql.key
  [ec2-user@vps1 ~]$
  slave端配置如下:
  [ec2-user@vps2 ~]$ cat /etc/my.cnf
  [mysqld]
  datadir=/var/lib/mysql
  socket=/var/lib/mysql/mysql.sock
  # Disabling symbolic-links is recommended to prevent assorted security risks
  symbolic-links=0
  # Settings user and group are ignored when systemd is used.
  # If you need to run mysqld under a different user or group,
  # customize your systemd unit file for mysqld according to the
  # instructions in http://fedoraproject.org/wiki/Systemd
  skip_name_resolve
  open_files_limit=8192
  #ssl configure
  ssl_ca=/home/mysql/cacert.crt
  ssl_cert=/home/mysql/mysql.crt
  ssl_key=/home/mysql/mysql.key
  log-bin=mysql-bin
  expire_logs_days=5
  server-id=2
  replicate-ignore-db=mysql
  replicate-ignore-db=zabbix
  slow_query_log_file=/var/log/mysql/slow.log
  log_queries_not_using_indexes=1
  long_query_time=5
  innodb_file_per_table=1
  innodb_buffer_pool_size=64M
  log_slave_updates
  relay-log=relay-bin
  relay-log-space-limit=512000000
  slave-net-timeout=360
  [mysql]
  default_character_set=utf8
  [mysqld_safe]
  log-error=/var/log/mysqld.log
  pid-file=/var/run/mysqld/mysqld.pid
  [client]
  ssl_ca=/home/mysql/cacert.crt
  ssl_cert=/home/mysql/mysql.crt
  ssl_key=/home/mysql/mysql.key
  [ec2-user@vps2 ~]$
  mysql> show slave status \G
  *************************** 1. row ***************************
  Slave_IO_State: Waiting for master to send event
  Master_Host: 192.168.0.66
  Master_User: repl
  Master_Port: 3306
  Connect_Retry: 60
  Master_Log_File: mysql-bin.000001
  Read_Master_Log_Pos: 259

  >
  >
  >  Slave_IO_Running: Yes
  Slave_SQL_Running: Yes
  Replicate_Do_DB:
  Replicate_Ignore_DB: mysql,zabbix
  Replicate_Do_Table:
  Replicate_Ignore_Table:
  Replicate_Wild_Do_Table:
  Replicate_Wild_Ignore_Table:
  Last_Errno: 0
  Last_Error:
  Skip_Counter: 0
  Exec_Master_Log_Pos: 259

  >  Until_Condition: None
  Until_Log_File:
  Until_Log_Pos: 0
  Master_SSL_Allowed: Yes
  Master_SSL_CA_File: /home/mysql/cacert.crt
  Master_SSL_CA_Path:
  Master_SSL_Cert: /home/mysql/mysql.crt
  Master_SSL_Cipher:
  Master_SSL_Key: /home/mysql/mysql.key
  Seconds_Behind_Master: 0
  Master_SSL_Verify_Server_Cert: No
  Last_IO_Errno: 0
  Last_IO_Error:
  Last_SQL_Errno: 0
  Last_SQL_Error:
  Replicate_Ignore_Server_Ids:
  Master_Server_Id: 1
  1 row in set (0.00 sec)
  mysql>


运维网声明 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-609598-1-1.html 上篇帖子: 从机上的MySQL备份脚本 下篇帖子: mysql高可用方案之集群(cluster)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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