百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 网站模板(百分百源码网)>电脑软件>服务器> linux 主动化运维工具ansible的运用细致教程
分享本文到:

linux 主动化运维工具ansible的运用细致教程

发布时间:05/16 来源:未知 浏览: 关键词:

一、ansible简介

1.ansible

ansible是新涌现的主动化运维工具,基于Python研发。糅合了众多老牌运维工具的长处实现了批量操纵系统配置、批量程序的部署、批量运转下令等功能。仅需在治理工作站上安装ansible程序配置被管控主机的IP信息,被管控的主机无客户端。ansible利用程序存在于epel(第三方社区)源,依赖于许多python组件。主要包括:

(1)、连贯插件connection plugins:负责和被监控端实现通讯;

(2)、host inventory:指定操纵的主机,是一个配置文件里面定义监控的主机;

(3)、各种模块中心模块、command模块、自定义模块;

(4)、借助于插件完成记载日志邮件等功能;

(5)、playbook:剧本施行多个任务时,非必需可以让节点一次性运转多个任务。

参考站点:http://www.ansible.com.cn

2.ansible特性

模块化设计,调用特定的模块来完成特定任务,自身是中心组件,短小精悍;

基于Python说话实现,由Paramiko(python的一个可并发连贯ssh主机功能库), PyYAML和Jinja2(模板化)三个要害模块实现;

部署简略,agentless无客户端工具;

主从模式工作;

支撑自定义模块功能;

支撑playbook剧本,陆续任务按前后设置次序完成;

奢望每个下令拥有幂等性:

3.ansible架构

ansible core:ansible本身中心模块
host inventory:主机库,定义可管控的主机列表
connection plugins:连贯插件,个别默许基于ssh协定连贯
modules:core modules(自带模块)、custom modules(自定义模块)
playbooks:剧本,按照所设定编排的次序施行完成安排任务

4.配置文件:

(1)ansible利用程序的主配置文件:/etc/ansible/ansible.cfg
(2) Host Inventory定义管控主机:/etc/ansible/hosts

遵循INI格调;中括号中的字符是组名;一个主机可同时属于多个组;

示例:

复制代码 代码如下:

# Ex 1: Ungrouped hosts, specify before any groupheaders.直接在任何组的头部前面指定,不属于任何组的主机
green.example.com
blue.example.com
192.168.100.1
192.168.100.10
# Ex 2: A collection of hosts belonging to the'webservers' group;一批主机属于一个组,例如定义为'webservers'的组
[webservers]
alpha.example.org
beta.example.org
192.168.1.100
192.168.1.110

注意:默许是以root会员施行,但是基于ssh连贯操纵要屡次输入密码,为利便可以运用基于ssh密钥方式进行认证

二、ansible利用程序下令

1.ansible-doc下令:获取模块列表,及模块运用格局;

复制代码 代码如下:

ansible-doc -l:获取列表
ansible-doc -s module_name:获取指定模块的运用信息

2.ansible下令格局

复制代码 代码如下:

ansible <host-pattern> [-f forks] [-m module_name] [-a args]
<host-pattern>

<host-pattern>

指明管控主机,以模式情势表示或者直接给定IP,必须事先定义在文件中;all设置所有

 [-f forks]

指明每批管控多少主机,默许为5个主机一批次

[-m module_name]

运用何种模块治理操纵,所有的操纵都需要通过模块来指定

[-a args]

指明模块专用参数;args个别为key=value格局

注意:command模块的参数非为kv格局,而是直接给出要施行的下令即可;

注意:command模块的参数非为kv格局,而是直接给出要施行的下令即可;

注意:<host-pattern>默许读取/etc/ansible/hosts,也可以指明自定义文件途径

-iPATH, --inventory=PATH:指明运用的host inventory文件途径;

常用模块(module_name):

1)command:默许模块,可省略。在长途主机上进行操纵下令

-a 'COMMAND'

注意:comand模块的参数非key=value格局,直接给出要施行的下令

[root@localhost ~]# ansible all -m command -a 'ifconfig'

2)user:
-a 'name= state={present(新建)|absent(删除)} force=(是否强迫操纵删除家目录) system= uid= shell= home='
[root@localhost ~]# ansible all -m user -a 'name=ansible state=present'

3)group:
-a 'name= state={present|absent} gid= system=(系统组)'
[root@localhost ~]# ansible all -m group -a 'name=mygroup state=presentsystem=true'

4)cron:
-a 'name= state= minute= hour= day= month= weekday= job='
[root@localhost ~]# ansible all -m cron -a 'name='Time' state=presentminute='*/5' job='/usr/sbin/ntpdate 172.168.0.1 &> /dev/null''

5)ping:

无参数

[root@localhost ~]# ansible all -m ping

6)file:文件治理
-a 'path= mode= owner= group= state={file|directory|link|hard|touch|absent} src=(link,链接至何处)'
[root@localhost ~]# ansible all -m file -a 'path=/tmp/testdirstate=directory'
[root@localhost ~]# ansible all -m file -a 'path=/tmp/test.txt state=touchmod=600 owner=user1'

7)copy:

-a 'dest=(长途主机上途径) src=(当地主机途径) content=(直接指明内容) owner= group= mode='
[root@localhosttmp]# ansible web -m copy -a 'src=/etc/yum.repos.d/aliyun.repodest=/etc/yum.repos.d/'

8)template

-a 'dest= src=\'#\'" content= owner= group= mode='

9)yum:

-a 'name= conf_file=(指明配置文件) state={present|latest|absent} enablerepo= disablerepo='
[root@localhost ~]# ansible all -m yum 'name=httpd state=present'

10)service:

-a 'name= state={started|stopped|restarted} enabled=(是否开机主动启动) runlevel='
[root@localhost ~]# ansible all -m service -a 'name=httpd state=started'

11)shell:

-a 'COMMAND' 运转shell下令
[root@localhost ~]# ansible all -m shell -a echo "123456789" |passwd --stdin user1'

12)script:

-a '/PATH/TO/SCRIPT'运转脚本
[root@localhost ~]# ansible all -m script -a '/tmp/a.sh'

13)setup:获取指定主机的facts变量;

三、Playbooks剧本

1.playbook组织格局:YAML说话格局

playbooks是ansible更强大的配置治理组件,实现基于文本文件编排施行的多个任务,且屡次反复施行

(1)YAML简介

YAML:YAML Ain't Markup Language; Yet Another Markup Language;

相似于半构造化数据,声明式配置;可读性较高的用来表达材料序列的格局,易于与脚本说话交互
官方站点:http://www.yaml.org

(2)语法格局

1)任何书记构造都用缩进来标识,可以嵌套
2)每一行是一个键值数据key:value,冒号隔开。若想在一行标识需要用{ }和,分隔格局
3)列表用 - 标识

2.inventory参数:主机库ssh参数设置

ansible基于ssh连贯inventory中指定的长途主机时,将以此处的参数指定的属性进行;

ansible_ssh_port

指定ssh端口

ansible_ssh_user

指定ssh会员

ansible_ssh_pass

指定ssh会员登录是认证密码,明文密码不平安

ansible_sudo_pass

指明sudo时候的密码

实例:

[websrvs]

192.168.0.101 ansible_ssh_port=22 ansible_ssh_user=root ansible_ssh_pass=xuding
192.168.0.102

注意:在/etc/ansible/hosts中直接定义连贯时候的密码不平安,个别倡议基于ssh的密钥认证方式实现

3.playbooks

(1)中心元素

Tasks任务、Variables变量、Templates模板、Handlers处置器、Roles角色

(2)playbooks中定义任务:

- name: task description 注释描述信息
module_name: module_args 声明模块:定义ansible模块参数


(3)ansible-playbook施行下令:

ansible-playbook <filename.yml> ... [options]


4.playbook--- 变量

(1)变量命名:字母、数字和下划线组成,仅能以字母开头;

(2)变量品种:

1)facts:由长途主机发回的主机特有的属性信息,这些信息被保留在ansible变量中;不必声明,可直接调用;

2)自定义变量:
通过下令行通报:ansible-playbook test.yml --extra-vars "host=www user=test"
通过roles通报

3)主机变量:定义在inventory中的主机之后的变量;直接通报给单个主机的变量

实例:

复制代码 代码如下:

[root@localhost ~]# vim /etc/ansible/hosts中直接定义在主机之后
[web]
192.168.0.101 host=mail
192.168.0.102
192.168.0.103

4)组变量:定义在inventory中的组上的变量(例如在默许的文件/etc/ansible/hosts上编辑)

复制代码 代码如下:

[group_name:vars]
var1=value
var2=value

注意:组名要事先存在,实例如下:

复制代码 代码如下:

[websrvs]
192.168.0.101
192.168.0.102
[websrvs:vars]
host=mail

变量运用示例:

复制代码 代码如下:

[root@localhost~]# vim useradd.yml
- hosts: websrvs
remote_user: root
vars:
username: testuser
password: xuding
tasks:
-name: add user
user: name={{ username }} state=present
-name: set password
shell: /bin/echo {{ password }} |/usr/bin/passwd --stdin {{ username }}

注释:

1) {{ }} 调用变量
2) #ansible-playbook /PATH/TO/SOME_YAML_FILE { -eVARS|--extra-vars=VARS} 变量的从新赋值调用要领

复制代码 代码如下:

[root@localhost ~]# ansible-playbookuseradd.yml --extra-vars "username=ubuntu"

5.playbook--- tasks

(1)前提测试:

在某task背面增加when子句即可实现前提测试功能;when语句支撑Jinja2语法;
实例:当时RedHat系列系统时候调用yum安装

tasks:

复制代码 代码如下:

-name: install web server package
yum: name=httpd state=present
when: ansible_os_family == "RedHat"

(2)迭代:item

在task中调用内置的item变量;在某task背面运用with_items语句来定义元素列表;

tasks:

复制代码 代码如下:

-name: add four users
user: name={{ item }} state=present
with_items:
-testuser1
-testuser2
-testuser3
-testuser4

注意:迭代中,列表中的每个元素可认为字典格局;

实例:

复制代码 代码如下:

-name: add two users
user: name={{ item.name }} state=present groups={{ item.groups }}
with_items:
- { name: 'testuser5', groups: 'wheel' }
- { name: 'testuser6', groups: 'root' }

6.playbook--- handlers:处置器;触发器

只要其关注的前提知足时,才会被触发施行的任务;
实例:配置文件产生转变触发重新启动服务

复制代码 代码如下:

-hosts: websrvs
remote_user: root
tasks:
-name: install httpd
yum:name=httpd state=present
-name: install config file
copy: src=/root/httpd.confdest=/etc/httpd/conf/httpd.conf
notify: restart httpd
-name: start httpd service
service: name=httpd state=started
handlers:
-name: restart httpd
service: name=httpd state=restarted

7.playbook模板

templates:
用于生成文本文件(配置文件);模板文件中可运用jinja2表达式,表达式要定义在{{}},也可以简略地仅施行变量替代;

roles:

复制代码 代码如下:

roles用于实现“代码复用”;
roles以特定的条理型格局组织起来的playbook元素(variables,tasks, templates, handlers);
可被playbook以role的名字直接进行调用;
用法:在roles/下创立[group_name]子目录,并非全部都要新建;例如:
/etc/ansible/roles/(在/etc/ansible/ansible.cfg定义roles目录)
webserver/
files/:此角色中用到的所有文件均放置于此目录中;
templates/:Jinja2模板文件寄存位置;
tasks/:任务列表文件;可以有多个,但至少有一个叫做main.yml的文件;
handlers/:处置器列表文件;可以有多个,但至少有一个叫做main.yml的文件;
vars/:变量字典文件;可以有多个,但至少有一个叫做main.yml的文件;
meta/:此角色的特别设定及依赖关系;

 ansible与saltstack对照

    前一段工夫用了saltstack,免不得要谈一下他们的优缺陷。两者都是安装和运用都非常利便的批量治理软件。

1、salt要安装agent;ansible不需要,通过ssh连贯,省掉装agent的事。

2、salt在server端要启进程;ansible不需要,但这都无所谓差不多。

3、salt与ansible都有模块,可运用任意说话开发模块。

4、salt与ansible都运用yaml说话格局编写剧本。

    ansible因为走的是ssh,所以它有认证的历程,以及加密码的历程,这使得ansible非常慢,不适用于大规模环境(指上千台)。

    为何我放弃salt呢,首先服务器不多(百台左右),其次,salt的master端与minion端TCP连贯经常断开,导致有时施行下令时会漏机器,这简直让我忍无可忍。据说最新版的salt好了许多,但因为企业系统是定制的,安装软件特殊费事(15M的系统,解决依赖就是个大题目),我还是选中了ansible。

以上所述是小编给大家介绍的主动化运维工具ansible的运用细致教程,但愿对大家有所帮忙。

热门标签:dede模板 / destoon模板 / dedecms模版 / 织梦模板
责任编辑:g6LMP
打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有152人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助



订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板