设为首页 收藏本站
查看: 2529|回复: 1

[经验分享] Linux轻量级自动运维工具-Ansible浅析

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2017-2-7 10:35:32 | 显示全部楼层 |阅读模式
本帖最后由 uikyhtr 于 2017-2-7 10:38 编辑

Ansible是什么?
1478412814319243.jpg

ansible架构图
wKiom1gkIHTi70jUAAMuMRDGwdQ519.jpg
ansible特性  
    模块化:调用特定的模块,完成特定的任务;
    基于Python语言研发,由Paramiko, PyYAML和Jinja2三个核心库实现;
    部署简单:agentless;
    支持自定义模块,使用任意编程语言;
    强大的playbook机制;
    幂等性;

安装及程序环境:
    程序:
        ansible
        ansible-playbook
        ansible-doc
    配置文件:
        /etc/ansible/ansible.cfg
    主机清单:
        /etc/ansible/hosts
    插件目录:
        /usr/share/ansible_plugins/

安装ansible
1478413524203275.jpg
安装依赖包
1478413562650844.jpg


ansible命令的使用:
    Usage: ansible <host-pattern> [options]
    常用选项:
        -m MOD_NAME  
        -a MOD_ARGS

配置Host Inventory:
    /etc/ansible/hosts
    [group_id]
    HOST_PATTERN1
    HOST_PATTERN2

示例:
首先对此文件进行备份操作,以防后面需要用到默认配置文件
1478414053665511.jpg
进入到/etc/ansible/hosts文件,此处绿色光标以下的内容是没有用的,都是示例,可以删除掉,然后添加我们下面实验操作用到的主机。
1478414031109078.jpg
添加一组websrvs服务器,以用于下面的测试
1478414503353711.jpg
测试主机连通性
这里报错是因为实验用的主机交换其他两台主机的公钥/私钥的原因导致的
1478414654155685.jpg
实验SSH免密码登陆设置
生成私钥和公钥 ssh-keygen -t rsa -P ''
1478415062152713.jpg
复制公钥文件问authorized_keys
1478415258632844.jpg
把公钥传送到其他主机
1478415974897470.jpg
在68的主机上面可以看见公钥已经传送过来了,并且确认文件的权限是否正确
1478416216197947.jpg
重复以上操作把公钥发送给69的主机
1478416056808842.jpg
然后重新执行ansible的ping模块命令查看该两台主机的连通性
可以发现此时已经成功,那么下面就开始介绍ansilbe的其他模块
1478416115495130.jpg
最后记得利用ansible同步一下所有主机的时间,以免某主机的时间有错误,后面看日志起来会造成混乱
1478417838569312.jpg

ansible模块:
    获取模块列表:ansible-doc -l
    获取指定模块的使用帮助:ansible-doc -s MOD_NAME

常用模块:

ping模块:探测目标主机是否存活;
1478416472629983.jpg

示例:测试所有的主机的连通性
1478416524736391.jpg

command模块:在远程主机执行命令;
1478416624294957.jpg
示例1:让所有主机同步时间
此处没有给出指定的-m command命令,是因为ansible的模块默认就是command
1478417920780974.jpg

示例2:让每一台主机都执行uname -r命令
1478416825351039.jpg

示例3:在主机上面都创建一个用户
1478416931727401.jpg
查看两台主机是否已经创建该用户
1478417019505451.jpg
1478417004291200.jpg
1478416965697207.jpg
查看用户信息:
wKioL1gkIHSyX2eMAAAu7SwDCwM654.jpg
帮这两个用户改密码,此处需要注意的是,虽然用下面的命令看似执行成功,但是当我们验证的时候,就会发现密码错误了,这是因为ansible的command模块并不支持管道等输出,所以下面介绍另外一个ansible的模块shell
1478417204960991.jpg
1478417286630843.jpg

shell模块:在远程主机上调用shell解释器运行命令,支持shell的各种功能,例如管道等
注意:command和shell模块的核心参数直接为命令本身;而其它模块的参数通常为“key=value”格式;
1478417416705751.jpg

示例:批量修改其他主机的特定用户的密码
1478417538598521.jpg
此时可以发现已经可以登陆成功
1478417567911983.jpg

copy模块:复制文件到远程主机
用法:
    (1) 复制文件
        -a "src=\'#\'"   "
    (2) 给定内容生成文件
        -a "content=  dest=  "

        其它参数:mode, owner, group, ...
wKiom1gkIHajZ8iEAADyMWQ1AyY128.jpg

示例:复制文件到其他主机
此处创建一个测试文件
1478418152625799.jpg
复制文件到其他主机
下面红色的报错信息是,如果要传送文件,该主机的指定目录需要存在,如果不存在,就是提示错误
1478418373370502.jpg
创建对应的目录
1478418439799625.jpg
重新传送文件,已经没有错误提示,但是此处也可以看见,如果文件已经存在,则原文件会被覆盖掉,并且此处也没有任何提示覆盖文件的信息,所以操作的时候就需要注意了,以免覆盖掉重要的文件
wKioL1gkIHbQHJqSAABylh01cow712.jpg
验证文件
1478418510158034.jpg

file模块:设置文件的属性
用法:
    (1) 创建目录:
        -a "path=  state=directory"
    (2) 创建链接文件:
        -a "path=  src=\'#\'" /p>
    (3) 删除文件:
        -a "path=  state=absent“
1478418659518061.jpg

示例:修改文件的权限和属主
1478419051749539.jpg
验证文件
1478419095467529.jpg

示例:创建文件的软连接
1478419703405705.jpg
验证文件
1478419728687249.jpg
设置文件的状态为absent(即删除文件)
1478419817445047.jpg
验证
1478419829153869.jpg

fetch模块:从远程主机拿文件
1478419909117563.jpg

示例:从10.1.156.69主机拿一个文件
1478420300192517.jpg
当抓去一堆文件的时候,也会创建对应的ip地址的目录,以区分文件
wKiom1gkIHejPGQFAABgH1YRIeU605.jpg

cron模块:管理计划任务条目
用法:   
    -a ""
        minute=
        hour=
        day=
        month=
        weekday=
        job=
        name=
        user=

        state={present|absent}
1478420441270711.jpg

示例:创建一个同步时间的计划任务,每5分钟同步一下服务器的时间
1478420827246947.jpg
验证任务
wKioL1gkIHeSyRwDAAAi0bDJqEE784.jpg

示例:删除计划任务
1478421009684827.jpg
验证
1478421022421552.jpg

hostname模块:管理主机名
用法:
    name=
1478421141557439.jpg

示例:修改主机名
1478421197538161.jpg
wKiom1gkIHfgQ_rFAAA0dPBivBo724.jpg

yum模块:使用yum命令完成程序包管理
用法:
    -a ""
        (1) name=  state={present|latest}
        (2) name=  state=absent
1478421620431860.jpg    
示例:安装指定包
此实验,首先,确定主机的yum源是可用的,否则实验会失败
1478421996901899.jpg
安装samba包
1478422165242693.jpg
验证
1478422200772134.jpg
删除samba安装包
1478422237709251.jpg
已经没有安装的字眼了
1478422258671914.jpg

service模块:服务管理
用法:  
-a ""
    name=
    state=
        started
        stopped
        restarted
    enabled=
    runlevel=
1478422358326097.jpg

示例:开启主机的httpd服务
首先我们确认httpd服务是关闭的
1478422495689830.jpg
开启httpd服务,并且设置为开机启动
1478422648597534.jpg
验证,80端口已经开启
wKioL1gkIHiisGGAAABqabB9VCA447.jpg

group模块:增加或删除组
用法:
    -a ""
        name=
        state=
        system=
        gid=
1478423074519820.jpg

示例:添加一个组
1478423193942082.jpg
验证
1478423376572824.jpg
删除组
1478423407821893.jpg
验证
1478423420742380.jpg

user模块:用户管理
使用格式:
    name= : 创建的用户名
    state= : present新增,absent删除
    force= : 删除用户的时候删除家目录
    system= : 创建系统用户
    uid= : 指定UID
    shell= : 指定shell
    home= : 指定用户家目录
wKiom1gkIHjjg5LvAADlgS8pUPI524.jpg

示例:增加一个系统用户
1478423630786911.jpg
验证
1478423665135091.jpg
删除用户
1478423732901065.jpg

setup模块:收集主机里面的各种信息
1478423789266467.jpg

示例:收集所有主机的信息
1478423913352743.jpg

YAML:一种数据序列化工具的语言格式   
    YAML is a data serialization format designed for human readability and  interaction with scripting languages.
1478428151280219.jpg
    数据结构:
        key:value

        - item1
        - item2
        - item3

        例如{name:jerry, age:21}

PlayBook

核心元素:
    Tasks:任务,由模块定义的操作的列表;
    Variables:变量
    Templates:模板,即使用了模板语法的文本文件;
    Handlers:由特定条件触发的Tasks;
    Roles:角色;

    playbook的基础组件:
        Hosts:运行指定任务的目标主机;
        remote_user:在远程主机以哪个用户身份执行;
            sudo_user:非管理员需要拥有sudo权限;
        tasks:任务列表
            模块,模块参数:
                格式:
                    (1) action: module arguments
                    (2) module: arguments

运行playbook,使用ansible-playbook命令
    (1) 检测语法
        ansible-playbook  --syntax-check  /path/to/playbook.yaml
    (2) 测试运行
        ansible-playbook -C /path/to/playbook.yaml
            --list-hosts
            -list-tasks
            --list-tags
    (3) 运行
        ansible-playbook  /path/to/playbook.yaml
            -t TAGS, --tags=TAGS
            --skip-tags=SKIP_TAGS
            --start-at-task=START_AT

示例1:定义一个playbook任务来新增用户和组
定义一个yaml的模板
1478428888100463.jpg
1478429295143789.jpg
查查语法有没有错误,没有提示即表示语法应该没有问题。
1478429308321178.jpg
测试运行看看,-C表示仅测试跑一边,但是不会实际操作
1478429455911321.jpg
也可以单独测试某些特定的选项
查看仅影响的主机
1478429532351016.jpg
查看运行哪些任务
1478429571929036.jpg
查看哪个任务打标了,这里并没有任何任务打标记,后面再演示
1478429589189837.jpg
以上没有错误,开始正式运行该任务
1478429711681032.jpg
验证
1478429802768510.jpg

示例2:定义一个playbook任务来修改文件端口
1478430257662896.jpg
此步骤里面有安装httpd的安装包,其实此处有点多余,因为测试的两台主机均已经安装该服务,此处添加上去是为了演示效果,因为当生产环境中,假如存在一台服务器没有该安装包,那么次处就能帮我们安装上去,不然的话,漏了这一步,到后面查原因也挺麻烦的
1478430513996335.jpg
检查语法问题
1478430528955457.jpg
先从一台主机上面把httpd.conf文件拷问来编辑
1478430623315577.jpg
修改httpd.conf文件
比如修改端口为8080,其他都为默认配置
1478430683945468.jpg
首先备份好各自主机里面的配置文件,以防后面出错
1478431338439939.jpg
检查备份是否成功
1478431534297800.jpg
测试运行web.yml,看看有没有问题,没有问题的话就正常运行
1478501152635472.jpg
执行改文件
1478501246552419.jpg
验证服务器端口打开没有,可以看见8080端口已经打开,实验成功。
1478432054899296.jpg

Handlers的使用:由特定条件触发的Tasks;
格式:  
    tasks:
     - name: TASK_NAME
       module: arguments
       notify: HANDLER_NAME
       handlers:
     - name: HANDLER_NAME
       module: arguments

示例:参照上面的例子继续修改apache的端口
修改端口号为8090
1478432449933681.jpg
修改原来的web.yml脚本实现操作
1478433429635157.jpg
检测语法
1478432761510389.jpg
测试运行,可以看出,当复制文件过去的时候,会触发到restart httpd service的handlers任务,所以任务就重启了,而不是启动
1478501354346172.jpg
正式运行
1478501443439146.jpg

验证结果,8090端口已经打开,实验成功
1478501492372154.jpg

tags:给指定的任务定义一个调用标识;
使用格式:
    - name: NAME
        module: arguments
        tags: TAG_ID

示例:执行特定的tags
修改文件的端口为8088
1478502033780846.jpg
在此前的配置文件上面插入一个标签instconf
1478501876675446.jpg
检查语法
1478502010791646.jpg
此处可以查看到该yml脚本有一个标签,影响着websrvs组
1478502134226318.jpg
测试运行
wKioL1gkIHmBf8LGAABgfzcepIg965.jpg
正式运行一下,指定以instconf的标签运行,所以此处不会显示器其他多余的信息,包括安装httpd包和启动httpd服务
1478502257546906.jpg
验证该结果
1478502420463453.jpg
此处也可以对同一个文件标记多个标签同时执行
1478502484965708.jpg
测试运行,因为此处已经安装了httpd包和文件已经复制过去,所以都是绿色,此处就演示到这里,其他步骤可以参考上面的操作
1478502528626685.jpg

Variables:变量
    类型:
        内建:
            (1) facts
        自定义:
            (1) 命令行传递;
                -e VAR=VALUE
            (2) 在hosts Inventory中为每个主机定义专用变量值;
                (a) 向不同的主机传递不同的变量 ;
                    IP/HOSTNAME variable_name=value
                (b) 向组内的所有主机传递相同的变量 ;
                    [groupname:vars]
                    variable_name=value
            (3) 在playbook中定义
                vars:
                    - var_name: value
                    - var_name: value
            (4) Inventory还可以使用参数:
                用于定义ansible远程连接目标主机时使用的属性,而非传递给playbook的变量;
                    ansible_ssh_host
                    ansible_ssh_port
                    ansible_ssh_user
                    ansible_ssh_pass
                    ansible_sudo_pass
                    ...
            (5) 在角色调用时传递
                roles:
                    - { role: ROLE_NAME, var: value, ...}

                    变量调用:
                    {{ var_name }}

示例1:利用命令行传递变量来安装不同的包
1478502834517778.jpg
此处{{ pkgname }}表示为一个变量
1478503000378980.jpg
检查一下语法,居然报错了,什么情况?仔细看了即便发现是漏了空格
1478503355802217.jpg
加上空格
1478503430184822.jpg
再次检查,还是还是有报错的情况,各位不要慌,因为这只是因为还没有给变量赋值才会报的错,所以此处报错是很正常
1478503455272548.jpg
给变量赋值再跑一遍,此时就不会报错
1478503598884882.jpg
修改一下变量,发现也是正常的,此处68因为已经安装过vsftpd所以就不会执行,所以并不会changed
1478503659636191.jpg

示例2:在playbook中定义变量
wKioL1gkIHnBuTALAAAozq6ayVs575.jpg
测试,也没有问题的
1478503993197457.jpg
思考?假如同时利用-e的参数传递一个变量的参数的话会怎么样?

测试结果如下,是-e传递的变量参数的优先级更高,这样的话能避免传递参数的时候,因为文本里面定义的优先级更高而出错?
wKiom1gkIHqBcDf7AABug0ybaoM290.jpg

示例3:在hosts Inventory中为每个主机定义专用变量值
1478504845983265.jpg
1478504654166937.jpg
删除掉文档里面原有的变量
1478504724440575.jpg
测试,没有问题
1478504759169046.jpg

示例4:在hosts Inventory中为每个主机定义专用变量值的第二种方法
1478504849339930.jpg
1478504955478972.jpg
测试,也是可以的
1478504979526781.jpg

Templates:模板,文本文件,内部嵌套有模板语言脚本(使用Jinja2模板语言编写)
1478507366696204.jpg
   Jinja2 is a template engine written in pure Python. It provides a Django inspired non-XML syntax but supports inline expressions and an optional sandboxed environment.
1478505748837127.jpg

    语法:
        字面量:
            字符串:使用单引号或双引号;
            数字:整数、浮点数;
            列表:[item1, item2, ...]
            元组:(item1, item2, ...)
        字典:{key1:value1, key2:value2, ...}
布尔型:true/false

    算术运算:
    +, -, *, /, //, %, **

    比较操作:
    ==, !=, >, <, >=, <=

    逻辑运算:and, or, not

    执行模板文件中的脚本,并生成结果数据流,需要使用template模块;
    template:
    -a " "
    src=
    dest=
    mode=
    onwer=
    group=

    注意:此模板不能在命令行使用,而只能用于playbook;

示例:利用templates模板来设置nginx的定义cpu的数量
首先利用ansible命令获取当前系统系统的cpu数量
wKioL1gkIHqw-5OkAAAXtZFvDtg377.jpg
首先备份一下默认的文件
1478506755537498.jpg
首先在下面的主机传送一个配置文件过来
1478506991334902.jpg
编辑该文件,修改此处为上面利用ansible的setup模块获取的名称
1478507190429112.jpg
重命名该文件为Jinja2格式后缀的文件
1478507669660631.jpg
新建一个playbook文件,为了演示,建立一个ngxsrvs组,虽然看上去都一样。。。
1478508496714336.jpg
建立playbook文档
1478507816668813.jpg
1478511247833666.jpg
此处为了演示效果,此处把原来的nginx包卸载掉
1478508667781245.jpg
确认安装包卸载掉,并且服务没在线
1478509133859614.jpg
检查playbook的文件有没语法错误
1478508792842369.jpg
测试运行,此处报错是因为找不到nginx的服务,所以应该是没有问题的
1478511341883500.jpg
正式运行,没有问题
1478511350720045.jpg
查看一下端口是否已经打开
1478511490723766.jpg
重点检查一下cpu的变量是否有改变,这里可以看到,跟我们ansible_processor_vcpus的值是一样,这样符合我们预期,此处就展示完毕
1478511550513881.jpg
1478511658271831.jpg

条件测试:when语句:在tasks中使用,Jinja2的语法格式;

示例:利用Ansible条件测试在CentOS_6和CentOS_7的启动服务
这边首先增加一台ip为10.1.156.70的CentOS7的主机
1478512428330231.jpg
然后我们利用setup模块的命令
1478517519942387.jpg
在7的上面可以找到该行
1478517471264965.jpg
在6的上面可以找到该行
1478517565237326.jpg
根据以上的信息,我们就可以创建一个基于条件判断的playbook文件test.yml
1478516682375220.jpg
1478519096623917.jpg
为了演示效果,实验前把CentOS6的nginx先卸载掉,此处70的报错只是因为ssh缺少那边没有提供公钥文件,此处就不再演示
1478517111552445.jpg
检查playbook语法有没有问题
1478517982272530.jpg
测试运行,没有报错,可以看出当执行service nginx start命令时候,只有CentOS6的主机执行了命令,不过开始那里提示有skipping信息是为什么?CentOS7开始也提示有skipping信息?但是后面确实是执行成功了,下面正式运行该playbook看看效果。
1478518732937204.jpg
正式运行,似乎没有报什么错误
1478519157952753.jpg
看看服务是否已经开启,此处可见80端口已经开发,应该是没有问题的,此处就不浏览主页做测试了
1478519221985614.jpg

循环:迭代,需要重复执行的任务;
    对迭代项的引用,固定变量名为"item”,使用with_item属性给定要迭代的元素;
        元素:列表
           字符串
           字典

基于字符串列表给出元素示例:
示例:基于列表的方式安装多个安装包
1478519724966129.jpg
1478519892171323.jpg
检查语法
1478519930277369.jpg
测试运行,没有报错(这里就以69和70两台不同的版本的CentOS来做测试)
1478520011529875.jpg
正式运行,69的机器报错了,看了一下原因,是下载php-mbstring的时候出错了,此处原因应该是虚拟挂载CentOS6.8的cd1导致的,挂载cd2应该就解决此问题,不过部分安装包应该是在cd1里面,所以小伙伴们最好找一个安全包都全的yum仓库
1478520359869927.jpg
重新配置好yum仓库,并且把先前安装的先卸载掉,以配置实验
1478520673902198.jpg
此处可以看出来,由于69主机刚报错了一个,所以所有的包都没有安装,7上面倒是都已经安装过了
1478520705631927.jpg
重新运行脚本,没有报错了
1478521542144536.jpg
验证,发现已经安装上了,此处就不再看其他安装包的安装情况了,应该没有大问题
1478521614443077.jpg


基于字典列表给元素示例:
示例:创建指定的用户并属于指定的组
1478521924960660.jpg
1478574166887849.jpg
检查语法
1478574178905565.jpg
测试运行,没有提示有任何变化?
1478574242161778.jpg
正式运行,可以看见创建了对应的用户和组
wKiom1gkIHuDcuJ_AADoihq2pss913.jpg
验证,符合我们预期
1478574686837873.jpg

角色:roles
以特定的层级目录结构进行组织的tasks、variables、handlers、templates、files等;
    role_name/
        files/:存储由copy或script等模块调用的文件;
    tasks/:此目录中至少应该有一个名为main.yml的文件,用于定义各task;其它的文件需要由main.yml进行“包含”调用;
    handlers/:此目录中至少应该有一个名为main.yml的文件,用于定义各handler;其它的文件需要由main.yml进行“包含”调用;
    vars/:此目录中至少应该有一个名为main.yml的文件,用于定义各variable;其它的文件需要由main.yml进行“包含”调用;
    templates/:存储由template模块调用的模板文本;
    meta/:此目录中至少应该有一个名为main.yml的文件,定义当前角色的特殊设定及其依赖关系;其它的文件需要由main.yml进行“包含”调用;
    default/:此目录中至少应该有一个名为main.yml的文件,用于设定默认变量;

    在playbook中调用角色的方法:
    - hosts: HOSTS
      remote_user: USERNAME
  roles:
      - ROLE1
  - ROLE2
      - { role: ROLE3, VARIABLE: VALUE, ...}
      - { role: ROLE4, when: CONDITION }

示例:创建对应的服务目录下面的模版
1478575635793657.jpg
首先创建对应的目录
1478586562817390.jpg
确认一下目录是否正确
wKiom1gh3ejhIKBvAAA2batR0j0822.jpg
首先准备一个安装包,放到nginx/file/目录下面
wKioL1gh3enidnkZAAB6yx6ud1Y983.jpg
新建一个nginx的task模板
wKioL1gh3emzYPS-AAAKSDnmHsg772.jpg
大家可以发现此处的模板跟之前的不一样,比如说,开头没有了定义主机、用户、和task等,此处的task会自行查找/etc/ansible/roles/nginx/task/main.yml的任务(此处文件本身也是在task目录下面)。再比如说,该处指定的copy命令的src=FILENAME也是相对路径,其绝对路径为/etc/ansible/roles/nginx/file/FILENAME。又比如说定义了notify但是这里并没有handlers,是因为此处定义了的notify的名字会自行去查看该目录下面即/etc/ansible/roles/nginx/handlers/main.yml里面的handlers。还有template那里,大家有没发现也是用的相对路径,此处绝对路径为在/etc/ansible/roles/nginx/template/nginx.conf.j2。所以大家清楚了吗?
wKiom1gh3eqy1Kj0AABhRVW7C6c768.jpg
接着是定义/etc/ansible/roles/nginx/handlers/main.yml
wKioL1gh3eqR45_PAAAIo5Yu-28487.jpg
此处的文件就是用来承上面的notify里面为什么没有定义的handlers的原因,因为已经定义在../handlers/main.yml里面了。
wKiom1gh3evA69w7AAAcvXG5Fi8693.jpg
复制nginx.conf文件到templates目录下面为nginx.conf.j2
wKioL1gh3evjYeLlAAAVyrzQQWU000.jpg
编辑里面定义的cpu数量,之前是2,所以此处我们也可以利用算数表达式来控制cpu的数量,比如此处-1,到时候看到的cpu数量应该是为1。
wKiom1gh3ezRH34cAABzaEB-fcw592.jpg
再复制/etc/nginx/conf.d/default.conf到nginx/templates/default.conf.j2
wKioL1gh3ezhy1HkAAAa6gHfAIQ857.jpg
然后编辑此文件
wKiom1gh3eyB6IxNAAAJ0A1kt3A162.jpg
编辑原来的端口号为一个变量值ngxport
wKiom1gh3eyjDf-wAAAbDBO2Zu4142.jpg
此时需要重新编辑task/main.yml文件
wKioL1gh3ezBcyFLAAAInSd4Igg446.jpg
主要添加一下内容
wKioL1gh3e3i48LUAAB_YhKKK5g683.jpg
此时我们就可以定义变量文件了
wKiom1gh3e3g8erMAAAagLxDN2E310.jpg
比如说定义ngxport的变量为8888
wKioL1gh3e6QAIa6AAAJ4Sfa0JQ356.jpg
此时所有的元素暂时都足够了,meta和default的文件夹在此处暂时用不上,然后我们在/etc/ansible/目录下面创建一个nginx.yml的文件
wKiom1gh3e6zraSvAAAZRsKoMy0567.jpg
注意此处的roles里面的nginx要在/etc/ansible.cfg文件里面有对应的设定
wKiom1gh3e-iXd_xAAAVHCjpmF8423.jpg
编辑查看ansible.cfg文件
wKioL1gh3e-S6tixAAAG_bLGHBc312.jpg
可以看见系统默认的roles路径也是在此处,所以我们去掉#号来启用它
wKiom1gh3e_Dxxv2AAAUK24gQRk489.jpg
修改成如下
wKioL1gh3e-SUtCqAAAQSqxoU_o237.jpg
以上都准备好了以后,检查一下nginx.yml语法,暂时并没有报错
wKiom1gh3fDAZMyPAAAPjHLJ5jM670.jpg
然后测试运行,可以看见此处报错了,看了一下报错的原因,是因为找不到/tmp/nginx安装包,因为只是测试运行,并没有传送安装包到目标主机上面,所以此处报错是正常的可以不予理会。
wKiom1gh5oSSdCfAAACvZ5shbJc752.jpg
下面正式运行该脚本,此处报错了,原因看了一下,nginx安装包是el7版本的,在centos6上面并不能安装。以及handlers出问题了。
wKioL1gh5oTwk3e3AADfiKk80Jw724.jpg
此处修改一下tasks/main.yml,以下红色内容为修改部分,意思就是,CentOS7系统从远程复制的安装包安装,CentOS6则直接从yum仓库源安装,6和7的nginx的配置文件应该是一样的,暂时先这么操作实验看看结果,并且先把CentOS7系统的nginx安装包删除掉,以重新演示效果。notify处的语法错误,此处补上。
wKiom1gh3fLTZ8ntAACrNvajpcs257.jpg
修改完以上的内容,重新测试运行
可以看出来此处还是有报错内容,
第一个报错内容为找不到安装包,此处是正常的,因为安装包还是传过去(上一次运行的时候传送过去的安装包我已经删掉了,所以此处需要重传)
第二个报错内容为找不到nginx服务,此处也是正常的,因为nginx安装包还没有安装
wKioL1gh3fKiszGjAACSHj0m9w0131.jpg
正常重新运行一下nginx.yml脚本看看,发现已经没有报错的地方了
wKiom1gh3fOASNc7AABtyOYAraQ124.jpg
验证结果,发现8888端口已经打开

wKiom1gh3fPxfUY5AABjMup2cp8262.jpg
cpu数量的设置也跟我们之前配置的是一样的,实验到此结束
wKioL1gh3fOD3PN5AABOsc0_alU085.jpg

示例2:根据以上内容,修改端口号
当我们写好模板以后,需要修改端口号,也是非常容易的,而且我们也可以通过在nginx.yml上面通过roles传递变量
wKioL1gh3fTDetEmAAAIqXzHVuc444.jpg
例如像以下这样子操作
wKiom1gh3fSgHKsvAAAbDYBWmOw977.jpg
测试运行一下看看有没有错误,可以看见在复制配置文件和重启服务那里有了变化,这符合我们预期
wKioL1gh3fTDwlx_AABk0dBf3JM321.jpg
正式运行一下看看,能正常运行
wKiom1gh3fWj4yYAAABngmTyaRc501.jpg
验证端口号是否修改成功,看到8080端口,表示操作没有问题
wKiom1gh3o6j8dJvAACVYpIAo2o403.jpg
以上是运行成功了,但是细心的同学会发现,这样所有程序都跑一遍也麻烦,所以我们可以用之前了解到的标签来执行特定的操作即可,也可以直接传递相应的变量。

wKiom1gh3o6hkelVAAAXbFIRWc4996.jpg
直接传递参数测试运行,好像没有问题
wKioL1gh3o-BXu6lAAC-g4d95TA909.jpg
正式运行
wKioL1gh3o-yYhJlAACCO5h3dhk243.jpg
查看端口号是否正确,此处可以看见是我们定义的8099端口,测试成功
wKiom1gh3pDB84EVAABek65quNQ459.jpg

示例:实现httpd不同主机不同的端口号
首先先把定义的端口号先屏蔽掉
wKiom1gh3pDwcdFvAAAKf2CkbyY574.jpg
wKioL1gh3pDz6rCXAAAPqLP016k526.jpg
编辑/etc/ansible/hosts文件
wKioL1gh3pHTmd_zAAAGvVR_PRM237.jpg
定义对应的端口号,然后测试
wKiom1gh3pHy1QlSAAAMPwJ23l0354.jpg
然后记得把nginx.yml文件里面也改回来
wKioL1gh3pGjFwVyAAAQiRjh70k420.jpg
这里直接运行就不先做测试了,不过一般同学们还是做好测试工作比较好,本人比较懒O.O
wKiom1gh3pLiOoQGAAC1cEUTsMg500.jpg
验证端口号,也符合我们预期
wKioL1gh3pLxVYA3AACZTswYv8U154.jpg

示例:在同一个yml配置文件里面运行两个服务模板程序
这里以memcached为例,首先复制memcached的配置文件到对应的templates目录下来为.j2的文件
wKiom1gh3pPTkV9_AAARNmQkwTY257.jpg
memcached服务是依靠设置内存参数来定义的,所以我们得首先用ansible来确认系统的内存变量参数值是什么,并且通过以下图可以看见两个系统参数都是一致的。
wKiom1gh3pPhAlqGAAA1aE_tcEU191.jpg
编辑memcached.j2文件
wKioL1gh3pOAt_UpAAAKVRHS4XQ043.jpg
定义变量参数
wKioL1gh3pOx8zNDAAAU21BI8so812.jpg 改成 wKiom1gh3pTga1iEAAAiXUFhKDE785.jpg
开始定义memcached的任务文件
wKioL1gh3rfh_GgVAAAKsO_W_-Q428.jpg
wKiom1gh3rfywvEfAAA8YyR8d4g143.jpg
定义handlers文件
wKiom1gh3rfBJGCpAAAJx7BiHKQ619.jpg
wKioL1gh3rfQZEboAAAVlOoADTw970.jpg
把memcached定义在ngnix.yml文件一同运行
wKioL1gh3rixJRYdAAAH9nfM0F4281.jpg
wKiom1gh3rjAPIHzAAAU4RLfst0531.jpg
测试运行,只是安装包还没有安装,提示的错误都问题不大,是正常的
wKioL1gh3rmy8bDWAADLFjwiYME698.jpg
正式运行
wKiom1gh3rnj7Lc2AACvHibqAMc945.jpg
验证服务是否开启,且是否设置好预期可用内存
可以看见11211端口已经打开
wKiom1gh3rrgkWUHAACUK1366jU036.jpg
查看可用内存,原来的数值是970~980多,这里200多,符合除以4的预期效果
wKioL1gh3rrDnxM_AABR4BZqpXM915.jpg

示例:根据不同的系统安装mysql包
首先定义一个tasks的模板
wKioL1gh3ruSPe5-AAAKfS02kdY697.jpg
wKiom1gh3rvj69RkAAB_TqavCPY371.jpg
定义一个yaml调用角色脚本
wKioL1gh3rvBth2wAAAHa1iUZrI219.jpg
wKiom1gh3rySDdhFAAASsFZvSVk600.jpg
设置hosts文件添加dbsrvs组
wKiom1gh3rzSv0DoAAAGvGLbykg234.jpg
wKioL1gh3rygXSO1AABCX8RPcuk934.jpg
测试语法
wKiom1gh3r3QQRX3AAAOoMBtPwk961.jpg
测试运行调用角色脚本db.yml,应该没有大问题
wKioL1gh3r3CpFwLAADeAX4mxNo572.jpg
正式运行,没有报任何错误
wKiom1gh3r7BGdVMAADWeE63Y4c380.jpg
验证服务是否已经开启
可以看见mysql和mariadb服务均已经开启
wKioL1gh3r6RlpkSAABTA24tSOw766.jpg

写在最后,关于ansible的能最多控制几台主机
此处是在配置文件里面定义的,默认是5台主机,如果把主机的控制的主机调大,估计也要相对应性能的主机当ansible服务器
wKiom1gh6JHj3ZutAAAC5HIIxFM700.jpg
wKioL1gh6JGhjQfoAAATcbyCzqs264.jpg

至此,本博文已经完结,下面总结几个小点:

1、 ansible的playbook.yml文件要求的格式比较严格,有时候少了几个空格,或者空格位置不妥当的时候,系统均默认此格式为错误,所以需要小心
2、 有时候输入错了ansibile不能识别的错误,用- - syntax-check 或者 –check 测试文件的时候并不会提示有任何提示,需要实际运行才能会报错。
3、 有一次写playbook.yml文件的时候,检查过是没有问题,但是测试一直出问题,后来把所有重写一遍就好,也可能是哪里错了自己没看见。



运维网声明 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-338708-1-1.html 上篇帖子: ansible-playbook 使用详解 下篇帖子: ansible一键部署lnvamp Linux
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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