如何使用ansible在CentOS 6.5上安装nginx

问题描述 投票:1回答:2

我是使用ansible的新手,我正在尝试建立一个简单的Hello world playbook。到目前为止,我有一切都在互相交谈,但我似乎无法自动化nginx安装。我已经尝试了几种变体,我似乎无法找到yum使用ansible安装nginx的任何文档。

我的剧本看起来像这样:(抱歉格式化)。它贯穿EPEL发布安装,似乎永远挂在nginx安装上。

---
- hosts: webserver
  tasks:
      - name: Install EPEL release for nginx
        yum: name=epel-release state=present

      - name: Install nginx web server
        yum: name=nginx state=installed update_cache=true
        notify:
          - start nginx

      - name: Upload the default index.html file
        copy: src=html_files/index.html dest=/usr/share/nginx/www/ mode=0644

  handlers:
      - name: start nginx
        service: name=nginx enables=yes state=started

任何帮助将不胜感激。

如果我将第8行更改为:

yum: name=http://nginx.org/packages/centos/6/noarch/RPMS/nginx-release-centos-6-0.el6.ngx.noarch.rpm state=present

它运行正常。

失败任务的Playbook输出:

TASK: [Install nginx web server] **********************************************
<54.67.19.159> ESTABLISH CONNECTION FOR USER: root
<54.67.19.159> REMOTE_MODULE yum name=nginx state=latest update_cache=true
<54.67.19.159> EXEC ssh -C -tt -vvv -o ControlMaster=auto -o ControlPersist=60s -o ControlPath="/Users/username/.ansible/cp/ansible-ssh-%h-%p-%r" -o IdentityFile="/Users/username/.ssh/pemfile.pem" -o KbdInteractiveAuthentication=no -o PreferredAuthentications=gssapi-with-mic,gssapi-keyex,hostbased,publickey -o PasswordAuthentication=no -o User=root -o ConnectTimeout=10 54.67.19.159 /bin/sh -c 'mkdir -p $HOME/.ansible/tmp/ansible-tmp-1427534955.48-246337214944853 && chmod a+rx $HOME/.ansible/tmp/ansible-tmp-1427534955.48-246337214944853 && echo $HOME/.ansible/tmp/ansible-tmp-1427534955.48-246337214944853'
<54.67.19.159> PUT /var/folders/l0/5f3qkrxd1sn976dzb5sfkk640000gn/T/tmpczLCV7 TO /root/.ansible/tmp/ansible-tmp-1427534955.48-246337214944853/yum
<54.67.19.159> EXEC ssh -C -tt -vvv -o ControlMaster=auto -o ControlPersist=60s -o ControlPath="/Users/username/.ansible/cp/ansible-ssh-%h-%p-%r" -o IdentityFile="/Users/username/.ssh/pemfile.pem" -o KbdInteractiveAuthentication=no -o PreferredAuthentications=gssapi-with-mic,gssapi-keyex,hostbased,publickey -o PasswordAuthentication=no -o User=root -o ConnectTimeout=10 54.67.19.159 /bin/sh -c 'LANG=en_US.UTF-8 LC_CTYPE=en_US.UTF-8 /usr/bin/python -tt /root/.ansible/tmp/ansible-tmp-1427534955.48-246337214944853/yum; rm -rf /root/.ansible/tmp/ansible-tmp-1427534955.48-246337214944853/ >/dev/null 2>&1'
nginx ansible centos6.5
2个回答
1
投票

首先尝试使用ssh登录连接到主机而不使用密码。并改变

 service: name=nginx enables=yes state=started 

 service: name=nginx enabled=yes state=started

0
投票

@ shilpa的回答是正确的。扩大...

你的问题不在于安装,而在于启动服务。你的处理程序中有语法错误。

说明:此处您有一个安装服务的任务,然后通知您的处理程序

  - name: Install nginx web server
    yum:
      name: nginx
      state: installed
      update_cache: yes
    notify:
      - start nginx

但是你的处理程序有一个无效的属性,enables。它需要阅读,enabled。所以上面的任务就完成了。该服务已安装但空闲。处理程序已通知但可能生成错误(或noop)。

更正样本:

- name: short line lengths make easier to catch mistakes
  service:
    name: nginx
    enabled: yes
    state: started

在学习ansible时,我建议您检查模块页面以查找您编写的每个任务,或者使用linter来帮助您在编写代码时检查代码。

参考:

我还建议在yum one上使用通用的package module。祝你好运,编码愉快。

© www.soinside.com 2019 - 2024. All rights reserved.