ansible简介
ansible
是一款自动化IT工具,并且不需要agent
,ansible
主要通过SSH和远程主机通讯,配置采用易读yml
的方式,本文主要简单介绍ansible
在日常开发中的应用。
ansible
的官方使用文档还是比较详细的,详见这里,这里也有中文版的。
ansible安装和配置
安装
官方文档详细介绍了各个平台的安装方式,本文简单介绍在Mac下面的安装
# 安装pip
$ sudo easy_install pip
# 这个版本目前在用的
$ sudo pip install ansible==2.2.1.0
# 或者通过以下命令安装最新版本
$ sudo pip install ansible
安装完毕,即可在终端中验证
$ ansible --version
ansible 2.2.1.0
配置
在上述安装完毕后,ansible
已经可以使用了;
ansible
默认读取/etc/ansible/hosts
作为服务器目录,可以通过环境变量NSIBLE_INVENTORY
修改为其他位置,也可以在执行ansible
命令的时候通过参数-i <path>
指定文件位置。
举例说明修改环境变量,添加以下内容到~/.bash_profile
...
export ANSIBLE_INVENTORY=~/ansible_hosts
~/ansible_hosts
文件示例:
cat ~/ansible_hosts
localhost ansible_connection=local
TOOLS ansible_host=10.224.244.82
一般这些服务器都已经配过密钥,可以无密码登录,如果采用密码登录,可以通过ansible_ssh_pass
指定
192.168.1.10 ansible_connection=ssh ansible_ssh_user=vagrant ansible_ssh_pass=vagrant
使用样例
远程部署
由于公司一些要策略要求,只能在远程服务器上面部署和调试,日常开发需要不断部署开发中的代码,使用ansible
就可以让这些繁琐的步骤变得简单。这里采用在playbook
(一系列的task组成,一个task可以具体做一件事情,例如执行一个shell
命令)中添加hosts
的方式,因为大家的远程地址不一样,这样在使用时只要修改远程服务器名即可。
---
- hosts: localhost
vars:
hosts:
- name: "dev1"
ip: "192.168.1.1"
- name: "dev2"
ip: "192.168.1.2"
tasks:
- name: add host
add_host:
name: "{{item.name}}"
ansible_host: "{{item.ip}}"
with_items: "{{hosts}}"
- name: mvn clean package
shell: mvn clean install -Dmaven.test.skip=true
args:
chdir: "{{playbook_dir}}"
- hosts: dev1
remote_user: root
tasks:
- name: copy jar to remote server
synchronize:
src: "{{playbook_dir}}/target/xxx/WEB-INF/lib"
dest: "/opt/apache-tomcat_1/webapps/xxx/WEB-INF"
recursive: yes
delete: yes
保存文件名playbook.yml
在和工程文件pom.xml
平级下,执行ansible-playbook playbook.yml
即可完成编辑和上传的步骤,如果需要在添加其他额外的任务,可以继续拓展playbook
的内容,更多有关ansible
的Module
可以参考这里,这里面已经封装很多常用功能,例如文中提到的执行<code>shell</code>,上传文件synchronize
,还有很多其他功能,可以参考文档,添加执行参数即可。