ansible简介及使用

2019-10-14  本文已影响0人  b2652f0882fe

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的内容,更多有关ansibleModule可以参考这里,这里面已经封装很多常用功能,例如文中提到的执行<code>shell</code>,上传文件synchronize,还有很多其他功能,可以参考文档,添加执行参数即可。

上一篇 下一篇

猜你喜欢

热点阅读