首页 > 解决方案 > 无法在 ansible awx_task 容器中运行 npm 命令

问题描述

我一直在使用 ansible core 并且扩大了我的团队,因此对 ansible awx 的需求变得更加紧迫。我已经为此工作了一个星期,我认为是时候大声呼救了。

我们有一个使用ansible用一些变量替换angularjs应用程序的baseurl的过程,并在我们编译它之前设置了一些设置(目前正在考虑使用像TeamCity这样的构建服务器来做这件事的不同方式,但现在我们正在尝试起来使用ansible awx)。

ansible core 从 git 分支版本中检查代码,替换变量并将其压缩到 s3 等。

知道这一点后,ansible awx 主机配置了 nvm,然后安装了节点并.nvm映射到/home/awx/.nvm 我也将 bashrc 映射到/home/awx/.bashrc. 当我登录到 awx_task 容器时docker exec -it awx_task /bin/bash,我看到以下内容:

[root@awx ~]# npm --version
 5.5.1
[root@awx ~]# echo $PATH /home/awx/.nvm/versions/node/v8.9.3/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
[root@awx ~]# env
NVM_DIR=/home/awx/.nvm
LANG=en_US.UTF-8
HOSTNAME=awx
NVM_CD_FLAGS=
DO_ANSIBLE_HOME=/opt/do_ansible_awx_home
PWD=/home/awx
HOME=/home/awx
affinity:container==eb57afe832eaa32472812d0cd8b614be6df213d8e866f1d7b04dfe109a887e44
TERM=xterm
NVM_BIN=/home/awx/.nvm/versions/node/v8.9.3/bin
SHLVL=1
LANGUAGE=en_US:en
PATH=/home/awx/.nvm/versions/node/v8.9.3/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin                                                                                                                                      

LESSOPEN=||/usr/bin/lesspipe.sh %s
_=/usr/bin/env

[root@awx ~]# cat /home/awx/.bashrc
# .bashrc

# User specific aliases and functions

alias rm='rm -i'
alias cp='cp -i'
alias mv='mv -i'

# Source global definitions
if [ -f /etc/bashrc ]; then
        . /etc/bashrc
fi
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh"

所有卷映射等都是使用安装程序角色模板和任务完成的,因此在多次 docker restart 和重新安装运行 ansible awx 安装程序手册后,上面的输出是相同的。但是在执行使用 npm 的剧本期间,它似乎有一个不同的环境PATH: /var/lib/awx/venv/ansible/bin:/var/lib/awx/venv/awx/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin

AWX 作业执行截图

在这一点上,我不确定我是否未能正确配置路径或其他容器,如 awx_web 也应该配置等。

我还注意到了 envNVM_BIN并修改了 npm playbook 以包含 npm 可执行文件的路径:

  - name: Running install to build npm modules
    npm:
      path: "{{ bps_git_checkout_folder }}"
      executable: "{{ lookup('env','NVM_BIN') }}/npm"

它甚至在执行期间都没有显示,因此指向不同的路径和正在加载的环境变量。

在此处输入图像描述

如果您能对我做错的事情有所了解,我将不胜感激。

提前致谢

编辑:在实施@sergei 建议后,我使用了额外的变量npm_bin: /home/awx/.nvm/versions/node/v8.9.3/bin

我已将任务更改为:

   - name: Running install to build npm modules
     npm:
       path: "{{ bps_git_checkout_folder }}"
       executable: "{{ npm_bin }}/npm"

但它产生了这样的结果:

 <127.0.0.1> ESTABLISH LOCAL CONNECTION FOR USER: root
 <127.0.0.1> EXEC /bin/sh -c 'echo ~root && sleep 0'
 <127.0.0.1> EXEC /bin/sh -c '( umask 77 && mkdir -p "` echo /root/.ansible/tmp/ansible-tmp-1579790680.4419668-165048670233209 `" && echo 
 ansible-tmp-1579790680.4419668-165048670233209="` echo /root/.ansible/tmp/ansible-tmp-1579790680.4419668-165048670233209 `" ) && 
 sleep 0'
 Using module file /usr/lib/python3.6/site-packages/ansible/modules/packaging/language/npm.py
 <127.0.0.1> PUT /var/lib/awx/.ansible/tmp/ansible-local-10173xtu81x_o/tmpd40htayd TO /root/.ansible/tmp/ansible-tmp-1579790680.4419668-165048670233209/AnsiballZ_npm.py
 <127.0.0.1> EXEC /bin/sh -c 'chmod u+x /root/.ansible/tmp/ansible-tmp-1579790680.4419668-165048670233209/ /root/.ansible/tmp/ansible-tmp-1579790680.4419668-165048670233209/AnsiballZ_npm.py && sleep 0'
 <127.0.0.1> EXEC /bin/sh -c '/usr/libexec/platform-python /root/.ansible/tmp/ansible-tmp-1579790680.4419668-165048670233209/AnsiballZ_npm.py && sleep 0'
 <127.0.0.1> EXEC /bin/sh -c 'rm -f -r /root/.ansible/tmp/ansible-tmp-1579790680.4419668-165048670233209/ > /dev/null 2>&1 && sleep 0'
 The full traceback is:
 Traceback (most recent call last):
 File "/root/.ansible/tmp/ansible-tmp-1579790680.4419668-165048670233209/AnsiballZ_npm.py", line 114, in <module>
 _ansiballz_main()
 File "/root/.ansible/tmp/ansible-tmp-1579790680.4419668-165048670233209/AnsiballZ_npm.py", line 106, in _ansiballz_main
 invoke_module(zipped_mod, temp_path, ANSIBALLZ_PARAMS)
 File "/root/.ansible/tmp/ansible-tmp-1579790680.4419668-165048670233209/AnsiballZ_npm.py", line 49, in invoke_module
imp.load_module('__main__', mod, module, MOD_DESC)
 File "/usr/lib64/python3.6/imp.py", line 235, in load_module
 return load_source(name, filename, file)
 File "/usr/lib64/python3.6/imp.py", line 170, in load_source
 module = _exec(spec, sys.modules[name])
 File "<frozen importlib._bootstrap>", line 618, in _exec
 File "<frozen importlib._bootstrap…
 PLAY RECAP 
 *********************************************************************
 localhost                  : ok=5    changed=4    unreachable=0 failed=1    skipped=0    rescued=0    ignored=0   

我也尝试过直接使用 shell 模块:

  - name: Running npm install 
    shell: "{{ npm_bin }}/npm install"
    args:
    chdir: "{{ bps_git_checkout_folder }}"

这反而产生了这个:

 <127.0.0.1> ESTABLISH LOCAL CONNECTION FOR USER: root
 <127.0.0.1> EXEC /bin/sh -c 'echo ~root && sleep 0'
 <127.0.0.1> EXEC /bin/sh -c '( umask 77 && mkdir -p "` echo /root/.ansible/tmp/ansible-tmp-1579791187.453365-253173616238218 `" && echo 
 ansible-tmp-1579791187.453365-253173616238218="` echo /root/.ansible/tmp/ansible-tmp-1579791187.453365-253173616238218 `" ) && 
 sleep 0'
 Using module file /usr/lib/python3.6/site- packages/ansible/modules/commands/command.py
 <127.0.0.1> PUT /var/lib/awx/.ansible/tmp/ansible-local-10395h1ga8fw3/tmpepeig729 TO /root/.ansible/tmp/ansible-tmp-1579791187.453365-253173616238218/AnsiballZ_command.py
 <127.0.0.1> EXEC /bin/sh -c 'chmod u+x /root/.ansible/tmp/ansible-tmp-1579791187.453365-253173616238218/ /root/.ansible/tmp/ansible-tmp-1579791187.453365-253173616238218/AnsiballZ_command.py && sleep 0'
 <127.0.0.1> EXEC /bin/sh -c '/usr/libexec/platform-python /root/.ansible/tmp/ansible-tmp-1579791187.453365-253173616238218/AnsiballZ_command.py && sleep 0'
 <127.0.0.1> EXEC /bin/sh -c 'rm -f -r /root/.ansible/tmp/ansible-tmp-1579791187.453365-253173616238218/ > /dev/null 2>&1 && sleep 0'
fatal: [localhost]: FAILED! => {
    "changed": true,
    "cmd": "/home/awx/.nvm/versions/node/v8.9.3/bin/npm install",
    "delta": "0:00:00.005528",
    "end": "2020-01-23 14:53:07.928843",
    "invocation": {
        "module_args": {
            "_raw_params": "/home/awx/.nvm/versions/node/v8.9.3/bin/npm install",
            "_uses_shell": true,
            "argv": null,
            "chdir": "/opt/do_ansible_awx_home/gh/deployments/sandbox/bps",
            "creates": null,
            "executable": null,
            "removes": null,
            "stdin": null,
            "stdin_add_newline": true,
            "strip_empty_ends": true,
            "warn": true
        }
     },
     "msg": "non-zero return code",
     "rc": 127,
     …
     PLAY RECAP 
   *********************************************************************
   localhost                  : ok=5    changed=4    unreachable=0 failed=1    skipped=0    rescued=0    ignored=0   

没有真正看出这里有什么问题。如果有人可以分享一些关于此的信息,将不胜感激。

标签: dockerpathansibleansible-awx

解决方案


你的包裹在哪里?在主机还是在容器内?所有执行都在任务容器中。

如果您的 npm 文件位于“主机”而不是容器中,那么您必须引用容器所在的主机来引用路径。


推荐阅读