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

[经验分享] Ansible-playbook自动部署mysql的主从复制读写分离

[复制链接]

尚未签到

发表于 2018-7-30 08:19:52 | 显示全部楼层 |阅读模式
目录结构:  
Ansible-mysql-replication
  
├── group_vars
  
│   ├── all
  
│   ├── mysql-proxy
  
│   └── mysql-slave
  
├── hosts
  
├── mysql-replication.retry
  
├── mysql-replication.yml
  
└── roles
  
    ├── amoeba
  
    │   ├── files
  
    │   │   ├── amoeba-mysql-3.0.5-RC-distribution.zip
  
    │   │   └── jdk-7u79-linux-x64.tar.gz
  
    │   ├── handlers
  
    │   ├── tasks
  
    │   │   ├── jdk-7u79-linux-x64.tar.gz
  
    │   │   └── main.yaml
  
    │   └── templates
  
    │     ├── amoeba.xml
  
    │     ├── dbServers.xml
  
    │     ├── jvm.properties
  
    │     └── profile
  
    ├── base
  
    │   ├── files
  
    │   │   ├── epel-release-6-8.noarch.rpm
  
    │   │   ├── epel-release-latest-7.noarch.rpm
  
    │   │   └── remi-release-6.rpm
  
    │   └── tasks
  
    │       └── main.yaml
  
    ├── chpass
  
    │   └── tasks
  
    │       └── main.yaml
  
    ├── mysql-master
  
    │   ├── handlers
  
    │   │   └── main.yaml
  
    │   ├── tasks
  
    │   │   └── main.yaml
  
    │   └── templates
  
    │       └── server.cnf.j2
  
    └── mysql-slave
  
        ├── handlers
  
        │   └── main.yaml
  
        ├── tasks
  
        │   └── main.yml
  
        └── templates
  
            └── server.cnf.j2
  

  

  
mysql-replication.yml
  
---
  

  
- name: Base All Server
  
  hosts: all
  
  remote_user: root
  
  tags: base
  

  
  roles:
  
    - base
  

  
- name: Install mysql-master and configure mysqlmaster
  
  hosts: mysql-master
  
  remote_user: root
  
  tags: mysql-master
  

  
  roles:
  
    - mysql-master
  

  
- name: Install mysql-slave and start mysqlslave
  
  hosts: mysql-slave
  
  remote_user: root
  
  tags: mysql-slave
  

  
  roles:
  
    - mysql-slave
  

  
- name: Install Amoeba and configure
  
  hosts: mysql-proxy
  
  remote_user: root
  
  tags: mysql-proxy
  

  
  roles:
  
    - amoeba
  

  
- name: chnage mysql root pass
  
  hosts: mysql-master,mysql-slave
  
  remote_user: root
  
  tags: chpass
  

  
  roles:
  
    - mysql-conf
  

  

  
roles/amoeba/tasks/main.yml
  
---
  
- name: Install unzip
  
  yum: name=unzip state=installed
  

  
- name: unzip Amobea and Jave Package
  
  unarchive: src={{ item }} dest=/usr/local/
  
  with_items:
  
    - amoeba-mysql-3.0.5-RC-distribution.zip
  
    - jdk-7u79-linux-x64.tar.gz
  
  tags: unzip
  

  
- name: Copy  profile
  
  template: src=profile dest=/etc/profile
  
  tags: copy
  

  
- name: Source profile
  
  shell: source /etc/profile
  

  
- name: Copy Amoeba Template Configure File
  
  template: src={{ item }} dest=/usr/local/amoeba-mysql-3.0.5-RC/conf/
  
  with_items:
  
    - dbServers.xml
  
    - amoeba.xml
  

  
- name: Copy Amoeba jvm Configure File
  
  template: src=jvm.properties dest=/usr/local/amoeba-mysql-3.0.5-RC/jvm.properties
  

  
- name: Start Amoeba
  
  shell: /usr/local/amoeba-mysql-3.0.5-RC/bin/launcher &
  

  

  
roles\base\tasks\main.yaml
  
--
  

  
- name: Copy Centos6&&Crntos7 EPEL
  
  copy: src={{ item }} dest=/opt/
  
  with_items:
  
   - epel-release-6-8.noarch.rpm
  
   - remi-release-6.rpm
  
   - epel-release-latest-7.noarch.rpm
  

  
- name: Install ELEP for Centos6
  
  yum: name=/opt/{{ item }} state=installed
  
  with_items:
  
   - epel-release-6-8.noarch.rpm
  
   - remi-release-6.rpm
  
  when: ansible_distribution_major_version == "6"
  

  
- name: Install ELEP for Centos6
  
  yum: name=/opt/epel-release-latest-7.noarch.rpm state=installed
  
  when: ansible_distribution_major_version == "7"
  

  
- name: Install MariaDB package
  
  yum: name={{ item }} state=installed
  
  with_items:
  
    - mariadb-server
  
    - mysql
  
    - MySQL-python
  

  
- name: Create MariaDB log file
  
  file: path=/var/log/mysqld.log state=touch owner=mysql group=mysql mode=0755
  

  
- name: Create MariaDB PID directory
  
  file: path=/var/run/mysqld state=directory owner=mysql group=mysql mode=0755
  

  
- name: Start mariadb
  
  service: name=mariadb state=started enabled=yes
  
  when: ansible_distribution_major_version == "7"
  

  
- name: Start mariadb
  
  service: name=mysql state=started enabled=yes
  
  when: ansible_distribution_major_version == "6"
  

  

  

  
roles\mysql-master\tasks\main.yaml
  

  
- name: Create mysql configure file
  
  template: src=server.cnf.j2 dest=/etc/my.cnf.d/server.cnf
  
  notify:
  
    - restart mariadb
  

  
#- name: Change root login_password
  
#  shell: /usr/bin/mysqladmin -uroot  password "mysql"
  

  
- name: Create Replication User
  
  mysql_user: name={{ dbuser }} password={{ dbuserpass }}  priv=*.*:ALL host={{ item }} state=present
  
  with_items:
  
    - '%'
  
    - 'localhost'
  

  

  

  
roles\mysql-master\handlers\main.yaml
  

  
---
  

  
- name: restart mariadb
  
  service: name=mariadb state=started enabled=yes
  
  when: ansible_distribution_major_version == "7"
  

  
- name: restart mariadb
  
  service: name=mysql state=started enabled=yes
  
  when: ansible_distribution_major_version == "6"
  

  

  

  
roles\mysql-slave\handlers\main.yaml
  

  
---
  

  
- name: restart mariadb
  
  service: name=mariadb state=started enabled=yes
  
  when: ansible_distribution_major_version == "7"
  

  
- name: restart mariadb
  
  service: name=mysql state=started enabled=yes
  
  when: ansible_distribution_major_version == "6"
  

  

  

  
roles\mysql-slave\tasks\main.yml
  

  
---
  

  
- name: Create mysql configure file
  
  template: src=server.cnf.j2 dest={{ mycnf_pwd }}
  
  notify:
  
    - restart mariadb
  

  
- name: Get Mysql-master Status
  
  mysql_replication: mode=getmaster
  
  delegate_to: "{{ master_host }}"
  
  register: master
  

  
- name: Configure replication on the slave.
  
  mysql_replication:
  
        mode=changemaster
  
        master_host={{ master_host }}
  
        master_user={{ dbuser }}
  
        master_password={{ dbuserpass }}
  
        master_log_file={{ master.File }}
  
        master_log_pos={{ master.Position }}
  

  
- name: Start slave
  
  mysql_replication:
  
        mode=startslave
  

  

  
roles\mysql-conf\tasks\main.yaml
  

  
--
  
- name: Create Mysql-Proxy User
  
  mysql_user: name={{ mysqluser }} password={{ mysqlpass }} priv=*.*:ALL,GRANT host={{ item }} state=present
  
  with_items:
  
    - '%'
  
    - 'localhost'
  

  
- name: Change master&slave mysql root password
  
  shell: /usr/bin/mysqladmin -uroot  password "{{ root_pass }}"
  

  

  
host:
  

  
[mysql-master]
  
172.17.0.2
  
[mysql-slave]
  
172.17.0.6
  
[mysql-proxy]
  
172.17.0.8
  

  

  

  

  
在host文件中定义mysql主服务器,从服务器,以及转发服务器ip
  
在templates放入配置文件模板
  
ansible-playbook -i host mysql-replication.yml
  

  
完整剧本请访问https://github.com/chulinx/Ansible-playbook/tree/master/Ansible-mysql-replication

运维网声明 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-543308-1-1.html 上篇帖子: ansible自动部署集群服务 下篇帖子: ansible debug模块学习笔记
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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