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

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

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-8-25 09:46:00 | 显示全部楼层 |阅读模式

目录结构:
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/Ansib ... e-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-262720-1-1.html 上篇帖子: ansible自动部署集群服务 下篇帖子: ansible debug模块学习笔记 mysql
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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