Ansible

优点

一款自动运维工具,实现批量系统配置,批量程序部署,批量运行命令。且备操作的机器无需安装客户端。

重点

  • 安装基本概念
  • playbook(剧本),批量执行大量人物

安装

部署客户机和控制端的本地解析

vim /etc/hosts
#编辑完成后将文件传给所有的机器
scp /etc/hosts ipaddress:/etc

yum 安装ansible管理端

配置

  • /etc/hosts解析过的名字放入到ansible的hosts
    /etc/ansible/hosts
    
  • 测试连通性 ansible localhost -m ping
  • 简洁输出参数 -o 使输出的信息放在一行显示
  • 测试主机(ansible的本质是检测ssh能否连接,并不是真的在ping目标机器)

组和密码

组即是在/etc/ansible/hosts/中,想要放入一个组的几个客户机名字前写入一行[],在中括号内键入组名。

组中可以省略写入的行数,如果客户端的机器是有一部分相同(以host为例)且后面的内容按照数字顺序排列的,则可以使用host[1:n]来表示.
如果这一批的账号密码相同的话,以这种方式省略显示时,可以在一段的后面进行批量账密设置:

ansible_ssh_user='*'
ansible_ssh_pass='*'
ansible_ssh_port='*'

也可以在组的后面使用一下书写方式同意给予组的变量:

[group:vars]
ansible_ssh_user='*'
ansible_ssh_pass='*'
ansible_ssh_port='*'

组嵌套,子组和父组的设置:

[web1]

[web2]

[webserver:children]
web1
web2

Ad-Hoc点对点模式 模块化使用

信息收集模块 setup

ansible host3 -m setup -a 'filter = ***'
#不使用filter时会显示全部的信息

文件模块 file

ansible host3 -m file -a 'path=/tmp/text state=touch mode=777'
#创建文件
ansible host3 -m file -a 'path=/tmp/dir state=directory mode=777'
#创建目录

软件包管理 yum

ansible host3 -m yum -a 'name="httpd" state=latest'

服务模式 service

ansible host3 -m service -a 'name="httpd" state=started enble=yes'
#state中使用过去式  enble确认开机启动状态

用户模式user

ansible host3 -m user -a 'name=* state=present'
#添加用户
ansible host3 -m user -a 'name=* state=absent'
#删除用户
echo 1 | openssl passwd -1 stdin
ansible -m user -a 'name=* password=* '
#添加密码时要先使用加密之后才能使用,此处使用1作为密码
ansible webserver -m user -a 'name=* shell=/sbin/noglogin append=yes'
#控制登录的shell

复制模块copy

ansible -m copy -a 'src=*  dest=*  owner=*  group=*  mode=*  backup=*'
#src源文件,dest目标文件,backup为是否备份,如果等于yes,如果两个文件完全相同不会有操作,但是略有不同则会创建一个新文件

Shell模式

ansible -m shell -a ' '
#参数中可以输入任何的shell命令,但是打开如vim等软件的操作会不好使

Role-角色扮演

YAML 语言使用

在ansible中,playbook使用yaml语言进行编写,实现对集群的大批量更改和大量命令一起顺序执行,其书写的yaml语言格式如下

-hosts: webservers    #1
  tasts:              #2
  - name: install apache    #3
    yum: name=httpd state=present
  - name: transport conf
    copy: src=./httpd.conf dest=/etc/httpd/conf/httpd.conf
  - name: start apache
    service: name=httpd state=started

#1 第一行是一对特殊的k-v对,用来确定备操作的机器
#2 tasts,命令。执行的命令写于此字典内。前输入两个空格
#3 -引导k-v对,每一个冒号后都要有一个空格的存在

此实验是使用apache作为典型,在执行playbook之前,先对apache的配置文件在当前目录下进行了想要的修改,然后再通过ansible来将其传递给想要操作的集群中的每一台机器。

触发器handlers

识别判断条件,在判断条件触发时,执行handlers内的操作

-hosts: webservers
  tasts:
  - name: install apache
    yum: name=httpd state=present
  - name: transport
    copy: src=./httpd.conf dest=/etc/httpd/conf/httpd.conf
    notify: restart     #1
  - name: start apache
    service: name=httpd state=started
  handlers:
  - name: restart       #2
    service: name=httpd state=restarted

#1此处为handlers的判断条件,关键词为notify,其后接的名字要和handlers内的#2处的name相同

执行playbook

ansible-playbook apache.yaml 
#其后可接参数实现不同的操作
ansible-playbook apache.yaml --syntax-check   #语法校验
ansible-playbook apache.yaml --list-hosts     #列出备操作的主机
ansible-playbook apache.yaml --list-tasks     #查看执行的任务

Role模块化

  • 使用Role模块化可以使代码组织结构可读,代码复用,层次清晰.以下实验使用nginx作为模型,来进行操作。

创建目录结构

tree roles
roles
├── nginx
│   ├── files
│   │   └── index.html
│   ├── handlers
│   │   └── main.yaml
│   ├── tasks
│   │   └── main.yaml
│   ├── templates
│   │   └── nginx.conf.j2
│   └── vars
│       └── main.yaml
└── site.yaml

使用Roles的模块化必须拥有如上的目录结构,可以通过如下命令创建

mkdir roles/nginx/{files,handlers,tasks,templates,vars} -p
touch roles/nginx/site.yaml roles/nginx/{handlers,tasks,vars}/main.yaml
echo 'balabalabala' > roles/nginx/files/index.html
#在本机有nginx服务的前提下
cp /etc/nginx/nginx.conf roles/nginx/templates/nginx.conf.j2

编写

tasks/main.yaml中写入自己想要执行的命令的全部,如下

---     #1
- name: install nginx
  yum: name={{ item }} state=latest   #2
  with_items:
  - epel-release
  - nginx

- name: copy index.html
  copy: src=index.html dest=/usr/share/nginx/html/index.html

- name: copy nginx.conf template
  template: src=nginx.conf.j2 dest=/etc/nginx/nginx.conf    #3
  notify: restart nginx

- name: make nginx run
  service: name=nginx state=start enabled=yes

  #1 在role的模块化中,使用---作为开始。
  #2 在ansible中调用变量要使用{{ }}将变量引用起来。
  #3 在ansible中,若配置文件存在变量,在不同机器上运行时想得到不同的结果,则可用template来进行类复制操作。

对template(模板) roles/nginx/templates/nginx.conf.j2中的两个参数添加变量:

worker_process {{ ansible_processor_cores }}    #调用内部变量
workdr_connections {{ worker_connections }}     #调用自定变量

将自定义的变量写入 roles/nginx/vars/main.yaml

worker_connection: 10240             #键值对形式存在

将触发器写入到roles/nginx/handlers/main.yaml

---
- name: restart nginx
  service: name=nginx state=restarted

将需要操作的机器和roles名写入roles/site.yaml

- hosts: host1
  roles:
  - nginx

执行的时候是将上述的文件进行操作

ansible-playbook site.yaml  --syntax-check    #语法测试
ansible_playbook site.yaml
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349