• Ansible流程控制


    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
    # 再配合判断语句的使用来实现对不同主机配置文件的推送
    
  • 相关阅读:
    正则表达式(十四)——找出某一个网页内部的所有的邮箱
    正则表达式(十三)——分组
    正则表达式(十二)——字符串的替换
    正则表达式(十一)——find和lookingAt
    查看隐藏文件夹
    SpringBoot 热部署
    oracle dmp文件泵导入
    python -爬虫-pycrul安装问题
    阿里云https tomcat配置
    jar包下载
  • 原文地址:https://www.cnblogs.com/gshelldon/p/13375508.html
Copyright © 2020-2023  润新知