Ansible流程控制

数据库操作问题:

  • 数据库的操作问题,python需要依耐的模块MySQL-python 。

数据库的操作

  1. # 设置root的密码在,root的密码设置之后,创建用户和创建数据库的操作都需要登陆使用
  2. - login_user: 'root'
  3. - login_password: '123'
  4. - login_host: 'localhost'
  5. # 三个字段登陆。
  6. - name: set root pas
  7. mysql_user:
  8. name: root
  9. password: "123"
  10. host: "localhost"
  11. priv: '*.*:ALL'
  12. state: present
  13. when: ansible_fqdn == "db01"
  14. - name: create database
  15. mysql_db:
  16. login_user: 'root'
  17. login_password: '123'
  18. login_host: 'localhost'
  19. name: wp_db
  20. state: present
  21. when: ansible_fqdn == "db01"
  22. - name: create admin
  23. mysql_user:
  24. login_user: 'root'
  25. login_password: '123'
  26. login_host: 'localhost'
  27. name: wp
  28. password: "123"
  29. host: "%"
  30. priv: '*.*:ALL'
  31. state: present
  32. when: ansible_fqdn == "db01"
  1. # 数据库有密码,想要操作数据库,得先连接数据库(登录数据库)
  2. login_user: root
  3. login_password: '123'
  4. login_host: localhost
  5. login_port: 3306

导出数据库

  1. [root@db01 ~]# mysqladmin -uroot password "123"
  2. [root@db01 ~]# mysqldump wp_db -uroot -p123 > wp_db.sql
  3. # 导出所有数据库
  4. [root@db01 ~]# mysqldump -A -uroot -p123 >backup.sql
  5. grant all on wp.* to wp_user@'localhost' identified by '111';

导入

  1. mysql -u用户名 -p 数据库名 < 数据库名.sql
  2. [root@db01 ~]# mysql -uroot -p123 < all_databases_backup.sql

判断语句

主机清单

  1. [web_group]
  2. web01 ansible_ssh_host=10.0.0.7
  3. web02 ansible_ssh_host=10.0.0.8

使用when,最大的好处就是,不用重复的收集主机变量,相对于使用多个play的方式。

  1. # web_group中有两台主机web01和web02,使用when语句,只有在web01上安装httpd
  2. [root@m01 ~/ansible]# vi when.yml
  3. - hosts: web_group
  4. tasks:
  5. - name: Install httpd
  6. yum:
  7. name: httpd
  8. state: present
  9. when: ansible_fqdn == "web01"
  10. # 主机名变量官方的推荐写法
  11. [root@m01 ~/ansible]# vi when.yml
  12. - hosts: web_group
  13. tasks:
  14. - name: Install httpd
  15. yum:
  16. name: httpd
  17. state: present
  18. when: ansible_facts['fqdn'] == "web01"
  19. # 此种方式表示的是,通过对不同主机操作系统的判断,来安装不同版本的apache
  20. [root@m01 ~/ansible]# cat when.yml
  21. - hosts: web_group
  22. tasks:
  23. - name: Install CentOS Httpd
  24. yum:
  25. name: httpd
  26. state: present
  27. when: ansible_distribution == "CentOS"
  28. - name: Install Ubuntu Httpd
  29. yum:
  30. name: apache2
  31. state: present
  32. when: ansible_facts['os_family'] == "Ubuntu"

还可以使用括号对条件进行分组,多条件的判断

  1. tasks:
  2. - name: "shut down CentOS 6 and Debian 7 systems"
  3. command: /sbin/shutdown -t now
  4. when: (ansible_facts['distribution'] == "CentOS" and ansible_facts['distribution_major_version'] == "6") or (ansible_facts['distribution'] == "Debian" and ansible_facts['distribution_major_version'] == "7")
  5. # 变量加上逻辑运算来判断,上面语句表示为操作系统为CentOS 6的和Debian 7版本的关机

也可以指定多条件为列表

  1. tasks:
  2. - name: "shut down CentOS 6 systems"
  3. command: /sbin/shutdown -t now
  4. when:
  5. - ansible_facts['distribution'] == "CentOS"
  6. - ansible_facts['distribution_major_version'] == "6"
  7. # 表示CentOs 6的操作系统关闭。

判断语句的模糊匹配

  1. - hosts: all
  2. tasks:
  3. - name: Install Rsync Server
  4. yum:
  5. name: rsync
  6. state: present
  7. when: ansible_fqdn == 'backup' or ansible_fqdn == 'nfs'
  8. - name: Configure Rsync Conf
  9. copy:
  10. src: /root/ansible/rsync/rsyncd.conf
  11. dest: /etc/rsyncd.conf
  12. when: ansible_fqdn == 'backup'
  13. - name: Install Nginx
  14. yum:
  15. name: nginx
  16. state: present
  17. when: ansible_fqdn is match 'web*'
  18. # 模糊匹配,表示主机名是web开头的才安装nginx

条件运算

  1. tasks:
  2. - shell: echo "only on Red Hat 6, derivatives, and later"
  3. when: ansible_facts['os_family'] == "RedHat" and ansible_facts['lsb']['major_release']|int >= 6
  4. # 多条件,操作系统是RedHat且版本大于6的打印,数学运算比较的是整形,所以要在后面使用"|int",把字符型转为整形

通过变量的方式来安装本地的rpm包

  1. [root@m01 ~/ansible]# cat yum.yml
  2. - hosts: web01
  3. tasks:
  4. - name: YUM install
  5. yum:
  6. name: "{{ var_packages }}"
  7. state: present
  8. vars:
  9. var_packages:
  10. - /root/nginx_php/mod_php71w-7.1.33-1.w7.x86_64.rpm
  11. - /root/nginx_php/nginx-1.18.0-1.el7.ngx.x86_64.rpm
  12. - /root/nginx_php/php71w-cli-7.1.33-1.w7.x86_64.rpm
  13. - /root/nginx_php/php71w-common-7.1.33-1.w7.x86_64.rpm
  14. - /root/nginx_php/php71w-devel-7.1.33-1.w7.x86_64.rpm
  15. - /root/nginx_php/php71w-embedded-7.1.33-1.w7.x86_64.rpm
  16. - /root/nginx_php/php71w-fpm-7.1.33-1.w7.x86_64.rpm
  17. - /root/nginx_php/php71w-gd-7.1.33-1.w7.x86_64.rpm
  18. - /root/nginx_php/php71w-mbstring-7.1.33-1.w7.x86_64.rpm
  19. - /root/nginx_php/php71w-mcrypt-7.1.33-1.w7.x86_64.rpm
  20. - /root/nginx_php/php71w-mysqlnd-7.1.33-1.w7.x86_64.rpm
  21. - /root/nginx_php/php71w-opcache-7.1.33-1.w7.x86_64.rpm
  22. - /root/nginx_php/php71w-pdo-7.1.33-1.w7.x86_64.rpm
  23. - /root/nginx_php/php71w-pear-1.10.4-1.w7.noarch.rpm
  24. - /root/nginx_php/php71w-pecl-igbinary-2.0.5-1.w7.x86_64.rpm
  25. - /root/nginx_php/php71w-pecl-memcached-3.0.4-1.w7.x86_64.rpm
  26. - /root/nginx_php/php71w-pecl-mongodb-1.5.3-1.w7.x86_64.rpm
  27. - /root/nginx_php/php71w-pecl-redis-3.1.6-1.w7.x86_64.rpm
  28. - /root/nginx_php/php71w-process-7.1.33-1.w7.x86_64.rpm
  29. - /root/nginx_php/php71w-xml-7.1.33-1.w7.x86_64.rpm

通过注册变量的方式来控制流程

  1. [root@m01 ~/ansible]# vi create.yml
  2. - hosts: web01
  3. tasks:
  4. - name: register var
  5. shell: "ls /root/nginx_php"
  6. register: directory_info
  7. ignore_errors: yes
  8. # 忽略错误
  9. - name: create web01
  10. shell: "mv /root/nginx_php /root/web01"
  11. when: directory_info.rc == 0
  12. # 通过注册变量的方式来判断文件是否存在,然后做出相应的动作。

循环语句

  1. [root@m01 ~/ansible]# cat yum.yml
  2. - hosts: web01
  3. tasks:
  4. - name: YUM install
  5. yum:
  6. name: /root/nginx_php/{{ item }}
  7. state: present
  8. with_items:
  9. - mod_php71w-7.1.33-1.w7.x86_64.rpm
  10. - nginx-1.18.0-1.el7.ngx.x86_64.rpm
  11. - php71w-cli-7.1.33-1.w7.x86_64.rpm
  12. - php71w-common-7.1.33-1.w7.x86_64.rpm
  13. - php71w-devel-7.1.33-1.w7.x86_64.rpm
  14. - php71w-embedded-7.1.33-1.w7.x86_64.rpm
  15. - php71w-fpm-7.1.33-1.w7.x86_64.rpm
  16. - php71w-gd-7.1.33-1.w7.x86_64.rpm
  17. - php71w-mbstring-7.1.33-1.w7.x86_64.rpm
  18. - php71w-mcrypt-7.1.33-1.w7.x86_64.rpm
  19. - php71w-mysqlnd-7.1.33-1.w7.x86_64.rpm
  20. - php71w-opcache-7.1.33-1.w7.x86_64.rpm
  21. - php71w-pdo-7.1.33-1.w7.x86_64.rpm
  22. - php71w-pear-1.10.4-1.w7.noarch.rpm
  23. - php71w-pecl-igbinary-2.0.5-1.w7.x86_64.rpm
  24. - php71w-pecl-memcached-3.0.4-1.w7.x86_64.rpm
  25. - php71w-pecl-mongodb-1.5.3-1.w7.x86_64.rpm
  26. - php71w-pecl-redis-3.1.6-1.w7.x86_64.rpm
  27. - php71w-process-7.1.33-1.w7.x86_64.rpm
  28. - php71w-xml-7.1.33-1.w7.x86_64.rpm
  29. # 通过循环的方式来安装包

字典循环

  1. - hosts: web_group
  2. tasks:
  3. - name: copy conf and code
  4. copy:
  5. src: "{{ item.src }}"
  6. dest: "{{ item.dest }}"
  7. mode: "{{ item.mode }}"
  8. with_items:
  9. - { src: "./httpd.conf", dest: "/etc/httpd/conf/", mode: "0644" }
  10. - { src: "./upload_file.php", dest: "/var/www/html/", mode: "0600" }
  11. # 利用列表和字典组合,会循环的访问列表里面的字典,并取出里面的key
  12. # 再配合判断语句的使用来实现对不同主机配置文件的推送

Ansible流程控制的更多相关文章

  1. ansible 流程控制

    ansible 流程控制 使用when判断主机名 - hosts: rsync_server tasks: - name: Install rsyncd Server yum: name: rsync ...

  2. Ansible--04 ansible 流程控制

    ansible 流程控制 playbook 条件语句 不管是 shell 还是各大编程预言中,流程控制,条件判断都是必不可少的,在我们使用 Ansible的过程中,条件判断的使用频率都非常高. 例如: ...

  3. ansible-playbook流程控制-loops循环使用

    1. ansible-playbook流程控制-loops循环使用    有时你想要多次重复任务.在计算机编程中,这称为循环.common ansible循环包括使用文件模块更改多个文件和/或目录的所 ...

  4. 自动化运维工具之Puppet变量、正则表达式、流程控制、类和模板

    前文我们了解了puppet的file.exec.cron.notify这四种核心资源类型的使用以及资源见定义通知/订阅关系,回顾请参考https://www.cnblogs.com/qiuhom-18 ...

  5. 第10章 Shell编程(4)_流程控制

    5. 流程控制 5.1 if语句 (1)格式: 格式1 格式2 多分支if if [ 条件判断式 ];then #程序 else #程序 fi if [ 条件判断式 ] then #程序 else # ...

  6. Shell命令和流程控制

    Shell命令和流程控制 在shell脚本中可以使用三类命令: 1)Unix 命令: 虽然在shell脚本中可以使用任意的unix命令,但是还是由一些相对更常用的命令.这些命令通常是用来进行文件和文字 ...

  7. PHP基础知识之流程控制的替代语法

    PHP 提供了一些流程控制的替代语法,包括 if,while,for,foreach 和 switch. 替代语法的基本形式是把左花括号({)换成冒号(:),把右花括号(})分别换成 endif;,e ...

  8. Python黑帽编程2.4 流程控制

    Python黑帽编程2.4  流程控制 本节要介绍的是Python编程中和流程控制有关的关键字和相关内容. 2.4.1 if …..else 先上一段代码: #!/usr/bin/python # - ...

  9. 使用yield进行异步流程控制

    现状 目前我们对异步回调的解决方案有这么几种:回调,deferred/promise和事件触发.回调的方式自不必说,需要硬编码调用,而且有可能会出现复杂的嵌套关系,造成"回调黑洞" ...

随机推荐

  1. [Fundamental of Power Electronics]-PART I-1.引言-1.2 1.3 电力电子技术的几个应用、本书内容

    1.2 电力电子技术的几个应用 高效开关变换器面临的功率范围从 (1)小于1瓦(电池供电的便携式设备内的DC-DC转换器)到(2)计算机及办公设备中的几十,几百,数千瓦到(3)变速电机驱动器中上千瓦及 ...

  2. lms框架分布式事务使用简介

    lms框架的分布式事务解决方案采用的TCC事务模型.在开发过程中参考和借鉴了hmily.使用AOP的编程思想,在rpc通信过程中通过拦截器的方式对全局事务或是分支事务进行管理和协调. 本文通过lms. ...

  3. Elasticsearch核心技术与实战,性能是真牛

    Elasticsearch 是一款非常强大的开源搜索及分析引擎.结合 Kibana.Logstash和Beats,Elasticsearch 还被广泛运用在大数据近实时分析,包括日志分析.指标监控.信 ...

  4. RedHat 7.6 安装 Mysql 8.0.17

    # 查看是否安装mysql rpm -qa | grep -i mysql # 如果有,需要卸载旧版本Mysql及相关依赖包 rpm -e MySQL-client-*** # 查看开机启动服务列表状 ...

  5. 小程序使用 Promise.all 完成文件异步上传

    小程序使用 Promise.all 完成文件异步上传 extends [微信小程序开发技巧总结(二) -- 文件的选取.移动.上传和下载 - Kindear - 博客园 (cnblogs.com)] ...

  6. Mysql 事务特性和隔离级别

    事务的特性 原子性(Atomicity) 一个事务(transaction)中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节.事务在执行过程中发生错误,会被回滚(Rollback)到 ...

  7. 【网络协议】OSI七层模型 和TCP/IP五层模型

    OSI(Open System Interconnection)七层模型 TCP/IP 五层模型

  8. PAT 乙级 -- 1001 -- 害死人不偿命的(3n+1)猜想

    题目: 卡拉兹(Callatz)猜想: 对任何一个自然数n,如果它是偶数,那么把它砍掉一半:如果它是奇数,那么把(3n+1)砍掉一半.这样一直反复砍下去,最后一定在某一步得到n=1.卡拉兹在1950年 ...

  9. PHP版本差异备忘录

    5.2版本 默认开启了GPC [之后的版本默认不开启] 在声明为static方法时,无需在方法前面加入static关键 [以后的版本强制增加static关键字]

  10. Kafka Rebalance机制和选举策略总结

    自建博客地址:https://www.bytelife.net,欢迎访问! 本文为博客同步发表文章,为了更好的阅读体验,建议您移步至我的博客 本文作者: Jeffrey 本文链接: https://w ...