Ansible常用模块以及案例
常用模块
- file模块: 对目标主机创建目录或者文件,并赋予权限
- name: create a file
file: 'path=/root/aaa.txt state=touch mode=0755 owner=foo group=foo'
- copy模块:实现ansible到目标机之间的文件传输
- name: copy a file
copy: 'remote_src=no src=roles/testbiox/foo.sh dest=/root/foo.sh mode=0644 force=yes'
- stat模块: 获取远程文件的状态信息
- name: check fool.sh exists
stat: 'path=/root/fool.sh'
register: script_stat
- debug模块: 打印执行输出
- debug: msg=fool.sh exists
when: script_stat.stat.exists
- command/shell: 用来执行shell主机命令
- name: run a script
command: "sh /root/foo.sh"
- name: run the scripts
shell: "echo 'test' > /root/foo.txt"
- template: 实现ansible服务端到目标主机的jinja2模板传送
- name: transport template jinja2
template: src=roles/testbox/templates/nginx.conf.j2 dest=/etc/nginx/nginx.conf
- package: 调用yum/apt命令
- name: yum install package
yum: pkg=nginx state=latest
- name: yum install package
apt: pkg=nginx state=latest
- service模块: 管理init服务
- name: start nginx service
service: name=nginx state=started
案例
综合上述的所有模块
- 目标机的初始化工作
[root@centos7-node5 ~]# rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
[root@centos7-node5 ~]# useradd foo
[root@centos7-node5 ~]# useradd deploy
[root@centos7-node5 ~]# mkdir /etc/nginx
- ansible主机的工作
[root@centos7-node3 ~]# su - deploy
[deploy@centos7-node3 ~]$ source .py3-a2.5-env/bin/activate
(.py3-a2.5-env) [deploy@centos7-node3 ~]$ source /home/deploy/.py3-a2.5-env/ansible/hacking/env-setup -q
(.py3-a2.5-env) [deploy@centos7-node3 ~]$ cd test_playbooks/
(.py3-a2.5-env) [deploy@centos7-node3 test_playbooks]$ mkdir roles/testbox/files
(.py3-a2.5-env) [deploy@centos7-node3 test_playbooks]$ vim roles/testbox/files/foo.sh
echo "test scripts"
(.py3-a2.5-env) [deploy@centos7-node3 test_playbooks]$ vim inventory/testenv #追加
server_name=localhost
port=80
user=deploy
work_process=2
max_open_file=65505
root=/www
- playbook
(.py3-a2.5-env) [deploy@centos7-node3 test_playbooks]$ mkdir roles/testbox/tempaltes
(.py3-a2.5-env) [deploy@centos7-node3 test_playbooks]$ vim roles/testbox/tempaltes/nginx.conf.j2
user {{ user }};
worker_processes {{ worker_processes }};
error_log /var/log/nginx/error.log;
pid /var/run/nginx.pid;
events {
worker_connections {{ max_open_file }};
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
tcp_nopush on;
keepalive_timeout 65;
server {
listen {{ port }} default_server;
server_name {{ server_name }};
location / {
root {{ root }};
index index.html index.htm;
}
error_page 404 /404.html;
location = /404.html {
root /usr/share/nginx/html;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
}
}
- yaml文件
(.py3-a2.5-env) [deploy@centos7-node3 ~]$ vim test_playbooks/roles/testbox/tasks/main.yaml
- name: Print server name and user to remote testbox
shell: "echo 'Currently {{ user }} is logging {{ servername }}' >> {{output}}"
- name: create a file
file: 'path=/root/foo.txt state=touch mode=0755 owner=foo group=foo'
- name: copy a file to remote
copy: 'remote_src=no src=roles/testbox/files/foo.sh dest=/root/foo.sh mode=0644 force=yes'
- name: check if foo.sh exists
stat: 'path=/root/foo.sh'
register: script_stat
- debug: msg="foo.sh exists"
when: script_stat.stat.exists
- name: run the script
command: 'sh /root/foo.sh'
- name: write the nginx config file
template: src=roles/testbox/templates/nginx.conf.j2 dest=/etc/nginx/nginx.conf
- name: yum install nginx latest
yum: pkg=nginx state=latest
- name: service enable nginx
service: name=nginx state=started
- 执行任务
(.py3-a2.5-env) [deploy@centos7-node3 test_playbooks]$ ansible-playbook -i inventory/testenv deploy.yml