1

我是使用 ansible 的新手,我正在尝试设置一个简单的 Hello World 剧本。到目前为止,我的一切都在互相交谈,但我似乎无法自动化 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

它运行良好。

失败任务的剧本输出:

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'
4

2 回答 2

1

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

 service: name=nginx enables=yes state=started 

进入

 service: name=nginx enabled=yes state=started
于 2017-05-19T09:33:50.953 回答
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 模块。祝你好运,编码愉快。

于 2017-05-19T19:07:06.163 回答