• ansible-3


    setup

    ansible_all_ipv4_addresses # ipv4的所有地址
    ansible_all_ipv6_addresses # ipv6的所有地址
    ansible_date_time # 获取到控制节点时间
    ansible_default_ipv4 # 默认的ipv4地址
    ansible_distribution # 系统
    ansible_distribution_major_version # 系统的大版本
    ansible_distribution_version # 系统的版本号
    ansible_domain #系统所在的域
    ansible_env #系统的环境变量
    ansible_hostname #系统的主机名
    ansible_fqdn #系统的全名
    ansible_machine #系统的架构
    ansible_memory_mb #系统的内存信息
    ansible_os_family # 系统的家族
    ansible_pkg_mgr # 系统的包管理工具
    ansible_processor_cores #系统的cpu的核数(每颗)
    ansible_processor_count #系统cpu的颗数
    ansible_processor_vcpus #系统cpu的总个数=cpu的颗数*CPU的核数
    ansible_python # 系统上的python
    ansible cache -m setup -a 'filter=*processor*' # 用来搜索

    条件判断

    • 不同的系统

    • 不同的版本

    • 不同的环境

    • 不同的用户

    - hosts: db
      remote_user: root
      tasks:
      - name: createfile
        copy: content="大弦嘈嘈如急雨" dest=/tmp/a.txt
        when: a=="3"
      - name: cratefile
        copy: content="小弦切切如私语" dest=/tmp/a.txt
        when: a=="4"
    ansible-playbook -e 'a="3"' p6.yml

    tags

    - hosts: web
      tasks:
      - name: installnginx
        yum: name=nginx
      - name: copyfile
        copy: src=/etc/nginx/nginx.conf dest=/etc/nginx/nginx.conf
        tags: copyfile
      - name: start
        service: name=nginx state=started
    ansible-playbook -t copyfile p7.yml 

    循环 with_item

    一次性创建多个

    - hosts: web
      tasks:
      - name: crateuser
        user: name={{item}}
        with_items:
        - alex20
        - alex21
        - alex22
    - hosts: web
      tasks:
      - name: crateuser
        user: name={{item}}
        with_items:
        - alex30
        - alex31
        - alex32
      - name: crategroup
        group: name={{item}}
        with_items:
        - wulaoshi20
        - wulaoshi21
        - wulaoshi22

    嵌套循环

    - hosts: web
      tasks:
      - name: crategroup
        group: name={{item}}
        with_items:
        - wulaoshi30
        - wulaoshi31
        - wulaoshi32
      - name: createuser
        user: name={{item.name}} group={{item.group}}
        with_items:
        - {'name':alex40,'group':wulaoshi30}
        - {'name':alex41,'group':wulaoshi31}
        - {'name':alex42,'group':wulaoshi32}

    template:

    jinja2

    - hosts: web
      tasks:
      - name: installredis
        yum: name=redis
      - name: copyfile
        template: src=/etc/redis.conf dest=/etc/redis.conf
      - name: start
        service: name=redis state=started
        
      配置文件: bind {{ ansible_default_ipv4.address }} 

    copy和tamplate的区别

    • copy模块不替代参数

    • template模块替代参数

    - hosts: web
      tasks:
      - name: installredis
        yum: name=redis
      - name: copyfile
        template: src=redis.conf dest=/etc/redis.conf
      - name: start
        service: name=redis state=started

    ps:写相对路径: 在当前目录下新建一个templates目录,然后把文件放在templates目录里面

    handlers

    修改配置文件

    - hosts: web
      tasks:
      - name: installredis
        yum: name=redis
      - name: copyfile
        template: src=redis.conf dest=/etc/redis.conf
        tags: copyfile
        notify: restart
      - name: start
        service: name=redis state=started
      handlers:
      - name: restart
        service: name=redis state=restarted

    roles

    • 目录清晰

    • 可以互相调用

    roles文件夹
    
    文件夹里面是要创建的每一个角色,每一个角色一个文件夹
    
    每一个角色里面都有tasks(必须的),templates,files,handlers,vars目录
    
    每个目录都要有main.yml文件,通过import_tasks来调用
    
    其中templates文件夹中的文件可以通过相对路径来调用
    
    其中files文件夹中的文件是否可以通过相对路径来调用

    一、什么场景下会用roles?

    假如我们现在有3个被管理主机,第一个要配置成httpd,第二个要配置成php服务器,第三个要配置成MySQL服务器。我们如何来定义playbook?

    第一个play用到第一个主机上,用来构建httpd,第二个play用到第二个主机上,用来构建php,第三个play用到第三个主机上,用来构建MySQL。这些个play定义在playbook中比较麻烦,将来也不利于模块化调用,不利于多次调。比如说后来又加进来一个主机,这个第4个主机既是httpd服务器,又是php服务器,我们只能写第4个play,上面写上安装httpd和php。这样playbook中的代码就重复了。

    为了避免代码重复,roles能够实现代码重复被调用。定义一个角色叫websrvs,第二个角色叫phpappsrvs,第三个角色叫dbsrvs。那么调用时如下来调用:

    hosts: host1
    role:
    - websrvs
    
    hosts: host2
    role:
    - phpappsrvs
            
    hosts: host3
    role:
    - dbsrvs
            
    hosts: host4
    role:
    - websrvs
    - phpappsrvs

     这样代码就可以重复利用了,每个角色可以被独立重复调用。下面举例说明使用方式。 

    二、roles示例

    假设有3台主机,172.16.7.151主机上安装MySQL,172.16.7.152上安装httpd,172.16.7.153上安装MySQL和httpd。我们建立两个角色websrvs和dbsrvs,然后应用到这几个主机上。 

    1. 创建roles的必需目录 

    [root@node1 opt]# mkdir -pv ansible_playbooks/roles/{websrvs,dbsrvs}/{tasks,files,templates,meta,handlers,vars}

    每个role下面有个目录叫meta,在里面可以新建文件main.yml,在文件中可以设置该role和其它role之前的关联关系。

    2. 配置角色

    (1)配置角色websrvs 

    [root@node1 opt]# cd ansible_playbooks/roles/
    [root@node1 roles]# cd websrvs/
    [root@node1 websrvs]# ls
    files  handlers  meta  tasks  templates  vars

    a. 将httpd配置文件上传到files目录下,我这里假设httpd.conf每台主机都是一样的,实际上应该用模板,先用一样的配置文件举例

    [root@node1 websrvs]# cp /etc/httpd/conf/httpd.conf files/

    直接复制的静态文件都放在files目录下。打算用模板文件的都放在templates目录下。 

    b.编写任务列表tasks

    [root@node1 websrvs]# vim tasks/main.yml
    - name: install httpd package
      yum: name=httpd
    - name: install configuration file
      copy: src=httpd.conf dest=/etc/httpd/conf
      tags:
      - conf
      notify:
      - restart httpd
    - name: start httpd
      service: name=httpd state=started

    c.由于上面的tasks中定义了notify,所以要定义handlers 

    [root@node1 websrvs]# vim handlers/main.yml
    - name: restart httpd
      service: name=httpd state=restarted

    如果需要定义变量,则在vars目录下创建main.yml文件,在文件中写入变量,以key:value的形式定义,比如: 

    http_port: 8080

    (2)配置角色dbsrvs 

    [root@node1 roles]# cd dbsrvs/
    [root@node1 dbsrvs]# ls
    files  handlers  meta  tasks  templates  vars

    a.将MySQL配置文件上传到files目录下。

    b.编写任务列表tasks 

    [root@node1 dbsrvs]# vim tasks/main.yml
    - name: install mysql-server package
      yum: name=mysql-server state=latest
    - name: install configuration file
      copy: src=my.cnf dest/etc/my.cnf
      tags:
      - conf
      notify:
      - restart mysqld
    - name:
      service: name=mysqld enabled=true state=started

    c.定义handlers 

    [root@node1 dbsrvs]# vim handlers/main.yml
    - name: restart mysqld
      service: name=mysqld state=restarted

    (3)定义playbook

    【注意】:要在roles目录同级创建playbook。 

    [root@node1 ansible_playbooks]# vim web.yml
    - hosts: 172.16.7.152
      roles:
      - websrvs 
    
    [root@node1 ansible_playbooks]# vim db.yml
    - hosts: 172.16.7.151
      roles:
      - dbsrvs 
    
    [root@node1 ansible_playbooks]# vim site.yml
    - hosts: 172.16.7.153
      roles:
      - websrvs
      - dbsrvs

    运行: 

    [root@node1 ansible_playbooks]# ansible-playbook web.yml
    [root@node1 ansible_playbooks]# ansible-playbook db.yml
    [root@node1 ansible_playbooks]# ansible-playbook site.yml

    当然也可以把这些内容写入同一个playbook中。playbook的名字可以自定义。

      

    防火墙

    setenforce 0 #用来临时关闭selinux
    iptables -F # 临时关闭防火墙
    /etc/selinux/config # 永久关闭

     

  • 相关阅读:
    IMail不能发送邮件的解决方法
    asp.net防止刷新重新提交触发后台事件的方法
    你的网站被“白名单”了吗?
    网站权限引起的504错误的问题
    asp.net Web Service请求因 HTTP 状态 400 失败: Bad Request的原因
    对现有数据库的表做分区的方法
    测试 Cookie在不同浏览器内容长度限制的测试
    Thinkphp框架中使用memcache缓存的方法
    替换手机号中间数字为*号或隐藏IP最后位
    linux mysql 操作命令
  • 原文地址:https://www.cnblogs.com/feifeifeisir/p/10415456.html
Copyright © 2020-2023  润新知