เพลย์บุ๊ค Ansible ไม่ทำงานพยายามเรียกใช้สร้างและกำหนดค่าด้วยสวิตช์ที่ซับซ้อน


10

นี่คือการติดตาม-on นี้คำถาม ฉันพยายามใช้ Ansible เพื่อจัดเตรียม Vagrant VM VM กำลังเรียกใช้ CentOS 6.4 ฉันใช้เพลย์ลิสต์แบบ ansible (ตัวย่อ) ต่อไปนี้:

- hosts: default
  vars:
    home: '/home/vagrant'
    curl_version: '7_19_7'
    curl_url: 'https://github.com/bagder/curl/archive/curl-{{ curl_version }}.tar.gz'
    curl_dir: '{{ home }}/curl-curl-{{ curl_version }}'

  # user: vagrant
  remote_user: vagrant
  sudo: yes

  tasks:

  - name: Ensure required packages and installed and up to date - pt1
    yum: pkg={{ item }} state=present
    with_items:
      - make
      - gcc
      - etc...

  # Lots more yum tasks in here

  - name: Ensure CURL source downloaded
    get_url: url={{ curl_url }} dest=/home/vagrant/curl-{{ curl_version }}.tar

  - name: Extract CURL source
    command: tar -zxf {{ home }}/curl-{{ curl_version }}.tar creates={{ curl_dir }}

  - name: Copy ssh patch over
    copy: src=./files/ssh.c.patch dest={{ home }}/ssh.c.patch

  - name: Patch CURL with openssl
    shell: patch -t {{ curl_dir }}/lib/ssh.c {{ home }}/ssh.c.patch chdir={{ curl_dir }}/lib
    when: path_file_result.changed

  - name: Build CURL with openssl
    command: 'chdir={{ curl_dir }} "{{ item }}"'
    with_items:
      - ./buildconf
      - ./configure --with-gssapi --with-libidn --with-libssh2 --prefix=/usr --without-nss
      - make
      - make install
      - ldconfig

Vagrant ใช้งานได้ดีและเพลย์บุ๊ค Ansible ทำงานได้สำเร็จจนถึงภารกิจสุดท้าย 'Build CURL with openssl' ซึ่งล้มเหลวเช่นนี้:

    TASK: [Build CURL with openssl] *********************************************** 
    changed: [default] => (item=./buildconf) => {"changed": true, "cmd": ["./buildconf"], "delta": "0:00:10.709817", "end": "2014-02-07 02:26:44.802652", "item": "./buildconf", "rc": 0, "start": "2014-02-07 02:26:34.092835", "stderr": "configure.ac:78: installing `./compile'
    configure.ac:73: installing `./config.guess'
    configure.ac:73: installing `./config.sub'
    configure.ac:65: installing `./missing'
    Makefile.am: installing `./depcomp'
    configure.ac:137: installing `./config.guess'
    configure.ac:137: installing `./config.sub'
    docs/examples/Makefile.am: installing `./depcomp'", "stdout": "buildconf: autoconf version 2.63 (ok)
    buildconf: autom4te version 2.63 (ok)
    buildconf: autoheader version 2.63 (ok)
    buildconf: automake version 1.11.1 (ok)
    buildconf: aclocal version 1.11.1 (ok)
    buildconf: libtool version 2.2.6 (ok)
    buildconf: libtoolize found
    buildconf: GNU m4 version 1.4.13 (ok)
    buildconf: running libtoolize
    buildconf: running aclocal
    buildconf: running aclocal hack to convert all mv to mv -f
    buildconf: running autoheader
    buildconf: cp lib/curl_config.h.in src/curl_config.h.in
    buildconf: running autoconf
    buildconf: running in ares
    buildconf: running automake
    buildconf: OK"}

    failed: [default] => (item=./configure --with-gssapi --with-libidn --with-libssh2 --prefix=/usr --without-nss) => {"cmd": ["./configure --with-gssapi --with-libidn --with-libssh2 --prefix=/usr --without-nss"], "failed": true, "item": "./configure --with-gssapi --with-libidn --with-libssh2 --prefix=/usr --without-nss", "rc": 2}
    msg: [Errno 2] No such file or directory
    failed: [default] => (item=make) => {"changed": true, "cmd": ["make"], "delta": "0:00:00.001828", "end": "2014-02-07 02:26:45.003968", "item": "make", "rc": 2, "start": "2014-02-07 02:26:45.002140"}
    stderr: make: *** No targets specified and no makefile found.  Stop.
    failed: [default] => (item=make install) => {"cmd": ["make install"], "failed": true, "item": "make install", "rc": 2}
    msg: [Errno 2] No such file or directory
    changed: [default] => (item=ldconfig) => {"changed": true, "cmd": ["ldconfig"], "delta": "0:00:00.009685", "end": "2014-02-07 02:26:46.096829", "item": "ldconfig", "rc": 0, "start": "2014-02-07 02:26:46.087144", "stderr": "", "stdout": ""}

FATAL: all hosts have already failed -- aborting

ดังนั้น./buildconfขั้นตอนการทำงาน แต่ขั้นตอนที่ดูเหมือนว่าจะล้มเหลวด้วย./configure --with-gssapi --with-libidn --with-libssh2 --prefix=/usr --without-nss [Errno 2] No such file or directoryฉันคิดว่านี่เป็นเพราะมันพยายามที่จะเรียกใช้ทั้งสตริงเหมือนว่ามันเป็นคำสั่งเดียว?

หากฉันเปลี่ยนเป็นใช้shellแทนcommandฉันจะได้รับสิ่งนี้แทน:

failed: [default] => (item=./configure --with-gssapi --with-libidn --with-libssh2 --prefix=/usr --without-nss) => {"changed": true, "cmd": " \"./configure --with-gssapi --with-libidn --with-libssh2 --prefix=/usr --without-nss\" ", "delta": "0:00:00.001171", "end": "2014-02-07 02:31:34.862373", "item": "./configure --with-gssapi --with-libidn --with-libssh2 --prefix=/usr --without-nss", "rc": 127, "start": "2014-02-07 02:31:34.861202"}
stderr: /bin/sh: ./configure --with-gssapi --with-libidn --with-libssh2 --prefix=/usr --without-nss: No such file or directory

ฉันได้ตรวจสอบแล้วว่างานทั้งหมดจนถึงจุดทำงานและไฟล์จะถูกดาวน์โหลดและแยกไปยังสถานที่ที่คาดไว้และแพทช์ทำงาน ( ดูที่นี่ )

หลังจากงานล้มเหลว (หรือถ้าคุณใส่ความคิดเห็น) หากคุณ SSH ลงใน VM ที่ถูกกำหนดค่าและรันขั้นตอนการบิลด์เดียวกันทั้งหมดด้วยตัวคุณเอง - โดยใช้ค่าที่แน่นอนจาก playbook มันทำงานได้

ฉันยังค่อนข้างใหม่กับ Ansible และฉันไม่แน่ใจว่าทำไมสิ่งนี้ไม่ทำงาน ผมทำอะไรผิดหรือเปล่า? มีวิธีการจัดรูปแบบหรืออ้างอิงconfigureคำสั่งนั้นแตกต่างกันอย่างไรเพื่อให้ตีความได้อย่างถูกต้องหากเป็นปัญหา ฉันควรใช้rawสิ่งนี้หรือไม่? หรืออย่างอื่น?

คำตอบ:


14

ทางออกคือการเปลี่ยนแปลงนี้:

shell: 'chdir={{ curl_dir }} "{{ item }}"'

สำหรับสิ่งนี้:

shell: "{{ item }}"
args:
  chdir: "{{ curl_dir }}"

ขณะนี้เอกสารสำหรับโมดูลเชลล์ระบุถึงความยุ่งยากในการจัดรูปแบบ งานสร้างที่เสร็จสมบูรณ์ในขณะนี้มีลักษณะดังนี้:

- name: Build CURL with openssl
  shell: "{{ item }}"
  args:
    chdir: "{{ curl_dir }}"
  with_items:
    - ./buildconf
    - ./configure --with-gssapi --with-libidn --with-libssh2 --prefix=/usr --without-nss
    - make
    - make install
    - ldconfig
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.