CentOS 6.5 Ansible详细部署

简介:

一、ansible介绍

1、简介

     ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。ansible是基于模块工作的,本身没有批量部署的能力。真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架。主要包括:

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

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

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

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

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


2、基础架构

wKiom1Rsxz3ToUCAAAGROYAM3EI989.jpg

3、特性

(1)、no agents:不需要在被管控主机上安装任何客户端;

(2)、no server:无服务器端,使用时直接运行命令即可;

(3)、modules in any languages:基于模块工作,可使用任意语言开发模块;

(4)、yaml,not code:使用yaml语言定制剧本playbook;

(5)、ssh by default:基于SSH工作;

(6)、strong multi-tier solution:可实现多级指挥。


4、优点
(1)、轻量级,无需在客户端安装agent,更新时,只需在操作机上进行一次更新即可;
(2)、批量任务执行可以写成脚本,而且不用分发到远程就可以执行;
(3)、使用python编写,维护更简单,ruby语法过于复杂;
(4)、支持sudo。


5、任务执行流程

wKiom1Rsx2uQYJZ5AAJplY08vOQ976.jpg


二、Ansible基础安装与配置

1、安装ansible

为了快速部署,我们这里不使用编译安装,我们使用epel源里面的rpm包

# yum install ansible

2、配置hosts文件

# vim /etc/ansible/hosts

我们可以看到有好多事例,我们可以注释掉他们,或者删掉他们,我们这里注释掉他们,在vim模式下

:%s/^\([^[:space:]#]\)/#\1/g

然后添加我们需要操作的主机,假设我就管理这两台主机。

1
2
3
[webserver]
10.0.0.16
10.0.0.13

3、配置主机无密钥登录

# ssh-copy-id -i ~/.ssh/id_rsa.pub 10.0.0.16

1
2
3
4
root@10.0.0.16's password: 
Now try logging into the machine, with  "ssh '10.0.0.16'" , and check  in :
   . ssh /authorized_keys
to  make  sure we haven 't added extra keys that you weren' t expecting.


三、案例测试


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


1、对所管辖的主机进行Ping操作

# ansible all -m ping

1
2
3
4
5
6
7
8
9
10.0.0.13 | success >> {
     "changed" false
     "ping" "pong"
}
 
10.0.0.16 | success >> {
     "changed" false
     "ping" "pong"
}

2、查看两台主机的时间

# ansible all -a 'date'

1
2
3
4
5
10.0.0.16 | success | rc=0 >>
Tue Nov 17 15:57:16 CST 2015
 
10.0.0.13 | success | rc=0 >>
Tue Nov 17 15:57:17 CST 2015

注:完整命令是ansible all -m command -a 'date',-m command默认可以省略

3、复制文件

    命令ansible-doc -l可以查看很多可以操作的模块,具体查看某个模块操作用ansible-doc -s module,例如ansible-doc -s copy

# ansible webserver -m copy -a "src=/root/cmdline-jmxclient-0.10.3.jar dest=/root"

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
10.0.0.13 | success >> {
     "changed" true
     "checksum" "98650e89f3c174b68971098618c2126b6cc1ab8b"
     "dest" "/root/cmdline-jmxclient-0.10.3.jar"
     "gid" : 0, 
     "group" "root"
     "md5sum" "ea665f2c562fc6aca3578cae46520b6d"
     "mode" "0644"
     "owner" "root"
     "size" : 20124, 
     "src" "/root/.ansible/tmp/ansible-tmp-1447747792.14-265823444157691/source"
     "state" "file"
     "uid" : 0
}
 
10.0.0.16 | success >> {
     "changed" true
     "checksum" "98650e89f3c174b68971098618c2126b6cc1ab8b"
     "dest" "/root/cmdline-jmxclient-0.10.3.jar"
     "gid" : 0, 
     "group" "root"
     "md5sum" "ea665f2c562fc6aca3578cae46520b6d"
     "mode" "0644"
     "owner" "root"
     "size" : 20124, 
     "src" "/root/.ansible/tmp/ansible-tmp-1447747792.15-265197722191280/source"
     "state" "file"
     "uid" : 0
}






     本文转自 wzlinux 51CTO博客,原文链接:http://blog.51cto.com/wzlinux/1713543,如需转载请自行联系原作者




相关文章
|
7月前
|
监控 前端开发 Linux
centos7系统安装部署zabbix5.0
【9月更文挑战第23天】在CentOS 7系统上部署Zabbix 5.0的步骤包括:安装MariaDB数据库及必要软件包,配置Zabbix仓库,设置数据库并导入Zabbix数据库架构,配置Zabbix服务器与前端参数,启动相关服务,并通过浏览器访问Web界面完成安装向导。
556 0
|
7月前
|
Oracle Java 关系型数据库
CentOS 7.6操作系统部署JDK实战案例
这篇文章介绍了在CentOS 7.6操作系统上通过多种方式部署JDK的详细步骤,包括使用yum安装openjdk、基于rpm包和二进制包安装Oracle JDK,并提供了配置环境变量的方法。
374 80
|
5月前
|
Oracle 关系型数据库 MySQL
Centos7下图形化部署单点KFS同步工具并将Oracle增量同步到KES
Centos7下图形化部署单点KFS同步工具并将Oracle增量同步到KES
Centos7下图形化部署单点KFS同步工具并将Oracle增量同步到KES
|
9月前
|
Linux 虚拟化 数据安全/隐私保护
部署05-VMwareWorkstation中安装CentOS7 Linux操作系统, VMware部署CentOS系统第一步,下载Linux系统,/不要忘, CentOS -7-x86_64-DVD
部署05-VMwareWorkstation中安装CentOS7 Linux操作系统, VMware部署CentOS系统第一步,下载Linux系统,/不要忘, CentOS -7-x86_64-DVD
|
7月前
|
存储 Kubernetes 负载均衡
CentOS 7.9二进制部署K8S 1.28.3+集群实战
本文详细介绍了在CentOS 7.9上通过二进制方式部署Kubernetes 1.28.3+集群的全过程,包括环境准备、组件安装、证书生成、高可用配置以及网络插件部署等关键步骤。
1120 4
CentOS 7.9二进制部署K8S 1.28.3+集群实战
|
6月前
|
存储 Linux 开发者
虚拟机centos7.9一键部署docker
本文介绍了如何在 CentOS 7.9 虚拟机上安装 Docker 社区版 (Docker-ce-20.10.20)。通过使用阿里云镜像源,利用 `wget` 下载并配置 Docker-ce 的 YUM 仓库文件,然后通过 `yum` 命令完成安装。安装后,通过 `systemctl` 设置 Docker 开机自启并启动 Docker 服务。最后,使用 `docker version` 验证安装成功,并展示了客户端与服务器的版本信息。文中还提供了列出所有可用 Docker-ce 版本的命令。
441 0
虚拟机centos7.9一键部署docker
|
7月前
|
Linux pouch 容器
CentOS7部署阿里巴巴开源的pouch容器管理工具实战
关于如何在CentOS 7.6操作系统上安装和使用阿里巴巴开源的Pouch容器管理工具的实战教程。
182 2
|
8月前
|
机器学习/深度学习 文字识别 Linux
百度飞桨(PaddlePaddle) - PP-OCRv3 文字检测识别系统 基于 Paddle Serving快速使用(服务化部署 - CentOS 7)
百度飞桨(PaddlePaddle) - PP-OCRv3 文字检测识别系统 基于 Paddle Serving快速使用(服务化部署 - CentOS 7)
220 1
百度飞桨(PaddlePaddle) - PP-OCRv3 文字检测识别系统 基于 Paddle Serving快速使用(服务化部署 - CentOS 7)
|
7月前
|
Kubernetes Linux API
CentOS 7.6使用kubeadm部署k8s 1.17.2测试集群实战篇
该博客文章详细介绍了在CentOS 7.6操作系统上使用kubeadm工具部署kubernetes 1.17.2版本的测试集群的过程,包括主机环境准备、安装Docker、配置kubelet、初始化集群、添加节点、部署网络插件以及配置k8s node节点管理api server服务器。
229 0
CentOS 7.6使用kubeadm部署k8s 1.17.2测试集群实战篇
|
8月前
|
Linux 数据安全/隐私保护 虚拟化
centos7部署openVPN
centos7部署openVPN
1301 1