Ansible流程控制

数据库操作问题:

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

数据库的操作

 # 设置root的密码在,root的密码设置之后,创建用户和创建数据库的操作都需要登陆使用

  - login_user: 'root'
- login_password: '123'
- login_host: 'localhost'
# 三个字段登陆。 - name: set root pas
mysql_user:
name: root
password: "123"
host: "localhost"
priv: '*.*:ALL'
state: present
when: ansible_fqdn == "db01" - name: create database
mysql_db:
login_user: 'root'
login_password: '123'
login_host: 'localhost'
name: wp_db
state: present
when: ansible_fqdn == "db01" - name: create admin
mysql_user:
login_user: 'root'
login_password: '123'
login_host: 'localhost'
name: wp
password: "123"
host: "%"
priv: '*.*:ALL'
state: present
when: ansible_fqdn == "db01"
# 数据库有密码,想要操作数据库,得先连接数据库(登录数据库)
login_user: root
login_password: '123'
login_host: localhost
login_port: 3306

导出数据库

[root@db01 ~]# mysqladmin -uroot password "123"

[root@db01 ~]# mysqldump wp_db -uroot -p123 > wp_db.sql

# 导出所有数据库
[root@db01 ~]# mysqldump -A -uroot -p123 >backup.sql grant all on wp.* to wp_user@'localhost' identified by '111';

导入

mysql -u用户名 -p 数据库名 < 数据库名.sql

[root@db01 ~]# mysql -uroot -p123 < all_databases_backup.sql

判断语句

主机清单

[web_group]
web01 ansible_ssh_host=10.0.0.7
web02 ansible_ssh_host=10.0.0.8

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

# web_group中有两台主机web01和web02,使用when语句,只有在web01上安装httpd
[root@m01 ~/ansible]# vi when.yml
- hosts: web_group
tasks:
- name: Install httpd
yum:
name: httpd
state: present
when: ansible_fqdn == "web01" # 主机名变量官方的推荐写法
[root@m01 ~/ansible]# vi when.yml
- hosts: web_group
tasks:
- name: Install httpd
yum:
name: httpd
state: present
when: ansible_facts['fqdn'] == "web01" # 此种方式表示的是,通过对不同主机操作系统的判断,来安装不同版本的apache
[root@m01 ~/ansible]# cat when.yml
- hosts: web_group
tasks:
- name: Install CentOS Httpd
yum:
name: httpd
state: present
when: ansible_distribution == "CentOS" - name: Install Ubuntu Httpd
yum:
name: apache2
state: present
when: ansible_facts['os_family'] == "Ubuntu"

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

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

也可以指定多条件为列表

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

判断语句的模糊匹配

- hosts: all
tasks:
- name: Install Rsync Server
yum:
name: rsync
state: present
when: ansible_fqdn == 'backup' or ansible_fqdn == 'nfs' - name: Configure Rsync Conf
copy:
src: /root/ansible/rsync/rsyncd.conf
dest: /etc/rsyncd.conf
when: ansible_fqdn == 'backup' - name: Install Nginx
yum:
name: nginx
state: present
when: ansible_fqdn is match 'web*'
# 模糊匹配,表示主机名是web开头的才安装nginx

条件运算

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

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

[root@m01 ~/ansible]# cat yum.yml
- hosts: web01
tasks:
- name: YUM install
yum:
name: "{{ var_packages }}"
state: present
vars:
var_packages:
- /root/nginx_php/mod_php71w-7.1.33-1.w7.x86_64.rpm
- /root/nginx_php/nginx-1.18.0-1.el7.ngx.x86_64.rpm
- /root/nginx_php/php71w-cli-7.1.33-1.w7.x86_64.rpm
- /root/nginx_php/php71w-common-7.1.33-1.w7.x86_64.rpm
- /root/nginx_php/php71w-devel-7.1.33-1.w7.x86_64.rpm
- /root/nginx_php/php71w-embedded-7.1.33-1.w7.x86_64.rpm
- /root/nginx_php/php71w-fpm-7.1.33-1.w7.x86_64.rpm
- /root/nginx_php/php71w-gd-7.1.33-1.w7.x86_64.rpm
- /root/nginx_php/php71w-mbstring-7.1.33-1.w7.x86_64.rpm
- /root/nginx_php/php71w-mcrypt-7.1.33-1.w7.x86_64.rpm
- /root/nginx_php/php71w-mysqlnd-7.1.33-1.w7.x86_64.rpm
- /root/nginx_php/php71w-opcache-7.1.33-1.w7.x86_64.rpm
- /root/nginx_php/php71w-pdo-7.1.33-1.w7.x86_64.rpm
- /root/nginx_php/php71w-pear-1.10.4-1.w7.noarch.rpm
- /root/nginx_php/php71w-pecl-igbinary-2.0.5-1.w7.x86_64.rpm
- /root/nginx_php/php71w-pecl-memcached-3.0.4-1.w7.x86_64.rpm
- /root/nginx_php/php71w-pecl-mongodb-1.5.3-1.w7.x86_64.rpm
- /root/nginx_php/php71w-pecl-redis-3.1.6-1.w7.x86_64.rpm
- /root/nginx_php/php71w-process-7.1.33-1.w7.x86_64.rpm
- /root/nginx_php/php71w-xml-7.1.33-1.w7.x86_64.rpm

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

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

循环语句

[root@m01 ~/ansible]# cat yum.yml
- hosts: web01
tasks:
- name: YUM install
yum:
name: /root/nginx_php/{{ item }}
state: present
with_items:
- mod_php71w-7.1.33-1.w7.x86_64.rpm
- nginx-1.18.0-1.el7.ngx.x86_64.rpm
- php71w-cli-7.1.33-1.w7.x86_64.rpm
- php71w-common-7.1.33-1.w7.x86_64.rpm
- php71w-devel-7.1.33-1.w7.x86_64.rpm
- php71w-embedded-7.1.33-1.w7.x86_64.rpm
- php71w-fpm-7.1.33-1.w7.x86_64.rpm
- php71w-gd-7.1.33-1.w7.x86_64.rpm
- php71w-mbstring-7.1.33-1.w7.x86_64.rpm
- php71w-mcrypt-7.1.33-1.w7.x86_64.rpm
- php71w-mysqlnd-7.1.33-1.w7.x86_64.rpm
- php71w-opcache-7.1.33-1.w7.x86_64.rpm
- php71w-pdo-7.1.33-1.w7.x86_64.rpm
- php71w-pear-1.10.4-1.w7.noarch.rpm
- php71w-pecl-igbinary-2.0.5-1.w7.x86_64.rpm
- php71w-pecl-memcached-3.0.4-1.w7.x86_64.rpm
- php71w-pecl-mongodb-1.5.3-1.w7.x86_64.rpm
- php71w-pecl-redis-3.1.6-1.w7.x86_64.rpm
- php71w-process-7.1.33-1.w7.x86_64.rpm
- php71w-xml-7.1.33-1.w7.x86_64.rpm
# 通过循环的方式来安装包

字典循环

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

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. Windows安装完ADFS后卸载ADFS清除ADFS数据库

    ADFS卸载后不会卸载掉之前ADFS配置后留下来的数据库,所以如果有必要去删掉这个数据库的话需要找到对应的路径去将数据库删除掉. 具体路径为C:/windows/wid/data/adfsartifa ...

  2. 中小型前端团队代码规范工程化最佳实践 - ESLint

    前言 There are a thousand Hamlets in a thousand people's eyes. 一千个程序员,就有一千种代码风格.在前端开发中,有几个至今还在争论的代码风格差 ...

  3. Java后端进阶-JVM参数调优

    package com.study.performance; import org.springframework.boot.SpringApplication; import org.springf ...

  4. 记一次xss漏洞挖掘

    博客园在整改中,无法更新文章,难受啊... 记录一次react的xss漏洞发现,比较有意思: 某个站: 直接输入<xxx>,直接把我跳转到了404,猜测可能做了一些验证: 尝试多重编码,发 ...

  5. Powershell免杀

    Powershell免杀 0x01 前言 前几天搞一个站的时候,进入内网,想让内网一台机子powershell上线.然后被杀软拦截了,极其的不讲武德,想着找我极强的朋友们白嫖个免杀的方法. 后面还是没 ...

  6. 【OOM】记录一次生产上的OutOfMemory解决过程

    一.项目架构 SpringCloud  Dalston.SR1 + SpringBoot 1.5.9 + Mysql +Redis + RabbitMQ 所有的业务模块的应用服务都部署在同一个服务器, ...

  7. hdu4503 概率

    题意: 湫湫系列故事--植树节                                         Time Limit: 1000/500 MS (Java/Others) Memory ...

  8. POJ1236 强连通 (缩点后度数的应用)

    题意:       一些学校有一个发送消息的体系,现在给你一些可以直接发送消息的一些关系(单向)然后有两个问题 (1) 问你至少向多少个学校发送消息可以让所有的学校都得到消息 (2) 问至少加多少条边 ...

  9. POJ 2516 基础费用流

    题意       有n个顾客,m个供应商,k种货物,给你顾客对于每种货物的要求个数,和供应商对于每种货物的现有量,以及供应每种货物的时候供应商和顾客之间的运输单价,问你满足所有顾客的前提下的最小运输费 ...

  10. POJ2337 欧拉路径字典序输出

    题意:       给一些单词,问是否可以每个单词只用一次,然后连接在一起(不一定要成环,能连接在一起就行). 思路:       这个题目的入手点比较好想,其实就是问欧拉路径,先说下解题步骤,然后在 ...