共计 5032 个字符,预计需要花费 13 分钟才能阅读完成。
一.ansible 介绍
常用的自动化运维工具
Puppet —基于 Ruby 开发,采用 C/S 架构,扩展性强,基于 SSL,远程命令执行相对较弱
SaltStack —基于 Python 开发,采用 C/S 架构,相对 puppet 更轻量级,配置语法使用 YMAL,使得配置 脚本更简单 Ansible —基于 Pythonparamiko 开发,分布式,无需客户端,轻量级,配置语法使用 YMAL 及 Jinja2 模板语言,更强的远程命令执行操作 其他 DevOps 请参看:https://github.com/geekwolf/sa-scripts/blob/master/devops.md
Ansible 是一个简单的自动化运维管理工具,可以用来自动化部署应用、配置、编排 task(持续 交付、无宕机更新等),采用 paramiko 协议库(fabric 也使用这个),通过 SSH 或者 ZeroMQ 等连 接主机,大概每 2 个月发布一个主版
Ansible 工作机制
Ansible 在管理节点将 Ansible 模块通过 SSH 协议(或者 Kerberos、LDAP)推送到被管理端执 行,执行完之后自动删除,可以使用 SVN 等来管理自定义模块及编排
由上面的图可以看到 Ansible 的组成由 5 个部分组成:
Ansible:核心引擎
Modules:包括 Ansible 自带的核心模块(core modules)及自定义模块 (custom modules);
核心模块:ansible 模块资源分发到远程节点使其执行特定任务或匹配一个特定的状态。
自定义模块:如果核心模块不足以完成某种功能,可以添加自定义模块。
Plugins:完成模块功能的补充,包括连接插件、邮件插件等
Playbooks:网上很多翻译为剧本,个人觉得理解为编排更为合理;定义 ansible 任务的配置文件,可以将多个任务定义在一个剧本中,由 ansible 自动执行,剧本执行支持多个任务,可以由控制主机运行多个任务,同时对多台远程主机进行管理。
Inventory:定义 Ansible 管理主机的清单
ansible 功能特性
- 应用代码自动化部署。
- 系统管理配置自动化。
- 支持持续交付自动化。
- 支持云计算、大数据平台(如 AWS、OpenStack、VMWare 等)环境。
- 轻量级,无需在客户端安装 agent,更新时只需在控制机上进行一次更新即可。
- 批量任务执行可以写成脚本,不用分发到远程就可以执行。
- 使用 Python 编写,维护更简单,Ruby 语法过于复杂。
- 支持非 root 用户管理操作,支持 sudo。
使用 Ansible 高效交付 Docker 容器 http://www.linuxidc.com/Linux/2015-10/124233.htm
使用 Ansible 批量管理远程服务器 http://www.linuxidc.com/Linux/2015-05/118080.htm
Ansible 安装配置与简单使用 http://www.linuxidc.com/Linux/2015-07/120399.htm
在 CentOS 7 中安装并使用自动化工具 Ansible http://www.linuxidc.com/Linux/2015-10/123801.htm
Ansible 和 Docker 的作用和用法 http://www.linuxidc.com/Linux/2014-11/109783.htm
Ansible 批量搭建 LAMP 环境 http://www.linuxidc.com/Linux/2014-10/108264.htm
Ansible:一个配置管理和 IT 自动化工具 http://www.linuxidc.com/Linux/2014-11/109365.htm
二. 安装 ansible
安装前准备:
1. 因为 ansible 是基于 python 的,所以先检查是否有 python,如果没有需要安装(注意版本,版本过低,也可能导致安装失败)。
2. 安装 ansible 前需要安装依赖包
yum -y install epel-release
……
ansible 安装:
yum -y install ansible
…….
安装完成后需要配置机组:
vim /etc/ansible/hosts
这里我的机组名为[ccdoop], 以下是我的另外 2 台机子的配置(本机为:test1:192.168.254.130)
test2 192.168.254.131
test3 192.168.254.132
到这里 ansible 就安装完成了。
测试:
ansible all -m ping
结果:成功!
注:由于本机只有一个组[ccdoop],故用 all,如果有多个机组,而你只想测试一个组的话可以把 all 替换为组名,如:
我的配置:
/etc/hosts:
/etc/ansible/hosts:
nglinx 安装包:
ansible 自动化安装 nginx:
1. 安装 ansible。
2. 创建目录结构:
mkdir -p /ansible/roles/nginx/{defaults,files,handlers,meta,tasks,templates,vars}
3.install_nginx.sh:
#!/bin/bash
yum -y install zlib zlib-devel openssl openssl-devel pcre-devel
groupadd -r nginx
useradd -s /sbin/nologin -g nginx -r nginx
cd /tmp
tar xf nginx-1.9.9.tar.gz;cd nginx-1.9.9
mkdir /var/run/nginx/;chown nginx.nginx /var/run/nginx/
./configure --prefix=/usr --sbin-path=/usr/sbin/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --pid-path=/var/run/nginx/nginx.pid --user=nginx --group=nginx --with-http_ssl_module
make && make install
sed "/^\s*index / i proxy_pass http://localhost:8080;" /etc/nginx/nginx.conf
/usr/sbin/nginx
sed
4.main.yml:
- name: copy nginx_tar_gz to client
copy: src=nginx-1.9.9.tar.gz dest=/tmp/nginx-1.9.9.tar.gz
- name: copy install_shell to client
copy: src=install_nginx.sh dest=/tmp/install_nginx.sh
- name: install nginx
shell: /bin/bash /tmp/install_nginx.sh
5.webservice.yml:
- hosts: Hadoop
remote_user: root
roles:
- nginx
6. 执行安装:
cd /ansible
ansible-playbook webservice.yml
安装成功!
7. 进入 test2 下检查:
到这里就全部结束了!
Ansible 的详细介绍:请点这里
Ansible 的下载地址:请点这里
本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-07/133465.htm
一.ansible 介绍
常用的自动化运维工具
Puppet —基于 Ruby 开发,采用 C/S 架构,扩展性强,基于 SSL,远程命令执行相对较弱
SaltStack —基于 Python 开发,采用 C/S 架构,相对 puppet 更轻量级,配置语法使用 YMAL,使得配置 脚本更简单 Ansible —基于 Pythonparamiko 开发,分布式,无需客户端,轻量级,配置语法使用 YMAL 及 Jinja2 模板语言,更强的远程命令执行操作 其他 DevOps 请参看:https://github.com/geekwolf/sa-scripts/blob/master/devops.md
Ansible 是一个简单的自动化运维管理工具,可以用来自动化部署应用、配置、编排 task(持续 交付、无宕机更新等),采用 paramiko 协议库(fabric 也使用这个),通过 SSH 或者 ZeroMQ 等连 接主机,大概每 2 个月发布一个主版
Ansible 工作机制
Ansible 在管理节点将 Ansible 模块通过 SSH 协议(或者 Kerberos、LDAP)推送到被管理端执 行,执行完之后自动删除,可以使用 SVN 等来管理自定义模块及编排
由上面的图可以看到 Ansible 的组成由 5 个部分组成:
Ansible:核心引擎
Modules:包括 Ansible 自带的核心模块(core modules)及自定义模块 (custom modules);
核心模块:ansible 模块资源分发到远程节点使其执行特定任务或匹配一个特定的状态。
自定义模块:如果核心模块不足以完成某种功能,可以添加自定义模块。
Plugins:完成模块功能的补充,包括连接插件、邮件插件等
Playbooks:网上很多翻译为剧本,个人觉得理解为编排更为合理;定义 ansible 任务的配置文件,可以将多个任务定义在一个剧本中,由 ansible 自动执行,剧本执行支持多个任务,可以由控制主机运行多个任务,同时对多台远程主机进行管理。
Inventory:定义 Ansible 管理主机的清单
ansible 功能特性
- 应用代码自动化部署。
- 系统管理配置自动化。
- 支持持续交付自动化。
- 支持云计算、大数据平台(如 AWS、OpenStack、VMWare 等)环境。
- 轻量级,无需在客户端安装 agent,更新时只需在控制机上进行一次更新即可。
- 批量任务执行可以写成脚本,不用分发到远程就可以执行。
- 使用 Python 编写,维护更简单,Ruby 语法过于复杂。
- 支持非 root 用户管理操作,支持 sudo。
使用 Ansible 高效交付 Docker 容器 http://www.linuxidc.com/Linux/2015-10/124233.htm
使用 Ansible 批量管理远程服务器 http://www.linuxidc.com/Linux/2015-05/118080.htm
Ansible 安装配置与简单使用 http://www.linuxidc.com/Linux/2015-07/120399.htm
在 CentOS 7 中安装并使用自动化工具 Ansible http://www.linuxidc.com/Linux/2015-10/123801.htm
Ansible 和 Docker 的作用和用法 http://www.linuxidc.com/Linux/2014-11/109783.htm
Ansible 批量搭建 LAMP 环境 http://www.linuxidc.com/Linux/2014-10/108264.htm
Ansible:一个配置管理和 IT 自动化工具 http://www.linuxidc.com/Linux/2014-11/109365.htm
二. 安装 ansible
安装前准备:
1. 因为 ansible 是基于 python 的,所以先检查是否有 python,如果没有需要安装(注意版本,版本过低,也可能导致安装失败)。
2. 安装 ansible 前需要安装依赖包
yum -y install epel-release
……
ansible 安装:
yum -y install ansible
…….
安装完成后需要配置机组:
vim /etc/ansible/hosts
这里我的机组名为[ccdoop], 以下是我的另外 2 台机子的配置(本机为:test1:192.168.254.130)
test2 192.168.254.131
test3 192.168.254.132
到这里 ansible 就安装完成了。
测试:
ansible all -m ping
结果:成功!
注:由于本机只有一个组[ccdoop],故用 all,如果有多个机组,而你只想测试一个组的话可以把 all 替换为组名,如: