Eu escrevi um manual que clona do git três repositórios e os compila da fonte.
Sempre que provisiono uma máquina que usa este playbook, os repos são clonados, não importa se a cópia local do repo já está atualizada.
Eu gostaria que o git clone acontecesse apenas na primeira vez e nas demais vezes quando eu executar o playbook, eu quero que o Ansible pule esta etapa.
Eu li sobre "fatos locais" nos documentos do Ansible, mas estou tendo dificuldade para entender como isso deve ser implementado.
Este é o manual que escrevi:
---
- name: Install required packages
apt: name={{item}} state=installed
with_items:
- "librdkafka-dev"
- "libyajl-dev"
- "librdkafka1"
- "cmake"
sudo: yes
tags: kafkacat
- name: Git clone kafkacat
git: repo=git://github.com/company/kafkacat.git
dest={{ kafkacat_installdir }} accept_hostkey=yes force=yes
tags: kafkacat
- name: Git clone librdkafka
git: repo=git://github.com/company/librdkafka.git
dest={{ kafkacat_installdir }}/librdkafka force=yes version={{ librdkafka_git_version }}
tags: kafkacat
- name: Git clone yajl
git: repo=git://github.com/company/yajl
dest={{ kafkacat_installdir }}/yajl force=yes version={{ yajl_git_version }}
tags: kafkacat
- name: librdkafka compilation (configure)
command: chdir={{ kafkacat_installdir }}/librdkafka {{ kafkacat_installdir }}/librdkafka/configure
tags: kafkacat
- name: librdkafka compilation (make)
command: chdir={{ kafkacat_installdir }}/librdkafka make
tags: kafkacat
- name: librdkafka compilation (make install)
command: chdir={{ kafkacat_installdir }}/librdkafka make DESTDIR={{ kafkacat_installdir }}/tmp-bootstrap install
tags: kafkacat
- name: yajl compilation (configure)
command: chdir={{ kafkacat_installdir }}/yajl {{ kafkacat_installdir }}/yajl/configure
tags: kafkacat
- name: yajl compilation (make)
command: chdir={{ kafkacat_installdir }}/yajl make
tags: kafkacat
- name: yajl compilation (make install)
command: chdir={{ kafkacat_installdir }}/yajl make DESTDIR={{ kafkacat_installdir }}/tmp-bootstrap install
tags: kafkacat
- name: Set vagrant user & group as the owner of the folder
file: path={{ kafkacat_installdir }} owner={{ kafkacat_owner }} group={{ kafkacat_group }} state=directory recurse=yes
sudo: yes
tags: kafkacat
- name: kafkacat compilation (configure)
command: chdir={{ kafkacat_installdir }} {{ kafkacat_installdir }}/configure --enable-json --enable-static
environment: env
tags: kafkacat
#- debug: var=env
- name: kafkacat compilation (make)
command: chdir={{ kafkacat_installdir }} make
environment: env
tags: kafkacat
#- debug: var=env
- name: kafkacat compilation (make install)
command: chdir={{ kafkacat_installdir }} make install
sudo: yes
tags: kafkacat
Sua ajuda é muito apreciada.
Você pode criar verificações e saltos personalizados com o módulo stat
Você pode querer fazer algo assim: