From efd7bc1f9c27e4b7e84681a930778e4ddf3354bd Mon Sep 17 00:00:00 2001 From: Alexandre Chouinard Date: Thu, 5 Dec 2019 07:43:56 -0500 Subject: [PATCH] add option to propagate binaries without access to internet (#126) * add option to propagate binaries without access to internet Same as cloudalchemy/ansible-alertmanager#83 and cloudalchemy/ansible-prometheus#239 but for Node exporter. * Fix typo * Fix molecule/alternative/prepare.yml * Fix molecule/alternative/prepare.yml again :D * Fix _checksum not being defined * Use double quotes for consistency * Fix typo... * Fix c/p error --- README.md | 1 + defaults/main.yml | 1 + molecule/alternative/playbook.yml | 1 + molecule/alternative/prepare.yml | 36 +++++++++++++++++-- tasks/install.yml | 58 +++++++++++++++++++------------ tasks/preflight.yml | 25 +++++++------ 6 files changed, 87 insertions(+), 35 deletions(-) diff --git a/README.md b/README.md index 12f34ef..214f0ba 100644 --- a/README.md +++ b/README.md @@ -24,6 +24,7 @@ All variables which can be overridden are stored in [defaults/main.yml](defaults | Name | Default Value | Description | | -------------- | ------------- | -----------------------------------| | `node_exporter_version` | 0.18.1 | Node exporter package version. Also accepts latest as parameter. | +| `node_exporter_binaries_local_dir` | "" | Allows to use local packages instead of ones distributed on github. As parameter it takes a directory where `node_exporter` binary is stored on host on which ansible is ran. This overrides `node_exporter_version` parameter | | `node_exporter_web_listen_address` | "0.0.0.0:9100" | Address on which node exporter will listen | | `node_exporter_system_group` | "node-exp" | System group used to run node_exporter | | `node_exporter_system_user` | "node-exp" | System user used to run node_exporter | diff --git a/defaults/main.yml b/defaults/main.yml index 605468c..723ffff 100644 --- a/defaults/main.yml +++ b/defaults/main.yml @@ -1,5 +1,6 @@ --- node_exporter_version: 0.18.1 +node_exporter_binary_local_dir: "" node_exporter_web_listen_address: "0.0.0.0:9100" node_exporter_system_group: "node-exp" diff --git a/molecule/alternative/playbook.yml b/molecule/alternative/playbook.yml index 9c9ffe1..238fbbd 100644 --- a/molecule/alternative/playbook.yml +++ b/molecule/alternative/playbook.yml @@ -5,6 +5,7 @@ roles: - ansible-node-exporter vars: + node_exporter_binary_local_dir: "/tmp/node_exporter-linux-amd64" node_exporter_system_group: "root" node_exporter_system_user: "root" node_exporter_textfile_dir: "" diff --git a/molecule/alternative/prepare.yml b/molecule/alternative/prepare.yml index 5358b3b..2f75da1 100644 --- a/molecule/alternative/prepare.yml +++ b/molecule/alternative/prepare.yml @@ -1,5 +1,37 @@ --- - name: Prepare - hosts: all + hosts: localhost gather_facts: false - tasks: [] + vars: + go_arch: amd64 + node_exporter_version: 0.18.1 + tasks: + - name: Download node_exporter binary to local folder + become: false + get_url: + url: "https://github.com/prometheus/node_exporter/releases/download/v{{ node_exporter_version }}/node_exporter-{{ node_exporter_version }}.linux-{{ go_arch }}.tar.gz" + dest: "/tmp/node_exporter-{{ node_exporter_version }}.linux-{{ go_arch }}.tar.gz" + register: _download_binary + until: _download_binary is succeeded + retries: 5 + delay: 2 + run_once: true + check_mode: false + + - name: Unpack node_exporter binary + become: false + unarchive: + src: "/tmp/node_exporter-{{ node_exporter_version }}.linux-{{ go_arch }}.tar.gz" + dest: "/tmp" + creates: "/tmp/node_exporter-{{ node_exporter_version }}.linux-{{ go_arch }}/node_exporter" + run_once: true + check_mode: false + + - name: link to node_exporter binaries directory + become: false + file: + src: "/tmp/node_exporter-{{ node_exporter_version }}.linux-amd64" + dest: "/tmp/node_exporter-linux-amd64" + state: link + run_once: true + check_mode: false diff --git a/tasks/install.yml b/tasks/install.yml index b28c84d..8b6d1b2 100644 --- a/tasks/install.yml +++ b/tasks/install.yml @@ -27,34 +27,46 @@ home: / when: node_exporter_system_user != "root" -- name: Download node_exporter binary to local folder - become: false - get_url: - url: "https://github.com/prometheus/node_exporter/releases/download/v{{ node_exporter_version }}/node_exporter-{{ node_exporter_version }}.linux-{{ go_arch }}.tar.gz" - dest: "/tmp/node_exporter-{{ node_exporter_version }}.linux-{{ go_arch }}.tar.gz" - checksum: "sha256:{{ node_exporter_checksum }}" - register: _download_binary - until: _download_binary is succeeded - retries: 5 - delay: 2 - delegate_to: localhost - check_mode: false +- block: + - name: Download node_exporter binary to local folder + become: false + get_url: + url: "https://github.com/prometheus/node_exporter/releases/download/v{{ node_exporter_version }}/node_exporter-{{ node_exporter_version }}.linux-{{ go_arch }}.tar.gz" + dest: "/tmp/node_exporter-{{ node_exporter_version }}.linux-{{ go_arch }}.tar.gz" + checksum: "sha256:{{ node_exporter_checksum }}" + register: _download_binary + until: _download_binary is succeeded + retries: 5 + delay: 2 + delegate_to: localhost + check_mode: false + + - name: Unpack node_exporter binary + become: false + unarchive: + src: "/tmp/node_exporter-{{ node_exporter_version }}.linux-{{ go_arch }}.tar.gz" + dest: "/tmp" + creates: "/tmp/node_exporter-{{ node_exporter_version }}.linux-{{ go_arch }}/node_exporter" + delegate_to: localhost + check_mode: false -- name: Unpack node_exporter binary - become: false - unarchive: - src: "/tmp/node_exporter-{{ node_exporter_version }}.linux-{{ go_arch }}.tar.gz" - dest: "/tmp" - creates: "/tmp/node_exporter-{{ node_exporter_version }}.linux-{{ go_arch }}/node_exporter" - delegate_to: localhost - check_mode: false + - name: Propagate node_exporter binaries + copy: + src: "/tmp/node_exporter-{{ node_exporter_version }}.linux-{{ go_arch }}/node_exporter" + dest: "/usr/local/bin/node_exporter" + mode: 0755 + owner: root + group: root + notify: restart node_exporter + when: not ansible_check_mode + when: node_exporter_binary_local_dir | length == 0 -- name: Propagate node_exporter binaries +- name: propagate locally distributed node_exporter binary copy: - src: "/tmp/node_exporter-{{ node_exporter_version }}.linux-{{ go_arch }}/node_exporter" + src: "{{ node_exporter_binary_local_dir }}/node_exporter" dest: "/usr/local/bin/node_exporter" mode: 0755 owner: root group: root + when: node_exporter_binary_local_dir | length > 0 notify: restart node_exporter - when: not ansible_check_mode diff --git a/tasks/preflight.yml b/tasks/preflight.yml index c1b60db..5f44b01 100644 --- a/tasks/preflight.yml +++ b/tasks/preflight.yml @@ -66,17 +66,22 @@ - name: "Set node_exporter version to {{ _latest_release.json.tag_name[1:] }}" set_fact: node_exporter_version: "{{ _latest_release.json.tag_name[1:] }}" - when: node_exporter_version == "latest" + when: + - node_exporter_version == "latest" + - node_exporter_binary_local_dir | length == 0 delegate_to: localhost run_once: true -- name: Get checksum list from github - set_fact: - _checksums: "{{ lookup('url', 'https://github.com/prometheus/node_exporter/releases/download/v' + node_exporter_version + '/sha256sums.txt', wantlist=True) | list }}" - run_once: true +- block: + - name: Get checksum list from github + set_fact: + _checksums: "{{ lookup('url', 'https://github.com/prometheus/node_exporter/releases/download/v' + node_exporter_version + '/sha256sums.txt', wantlist=True) | list }}" + run_once: true -- name: "Get checksum for {{ go_arch }} architecture" - set_fact: - node_exporter_checksum: "{{ item.split(' ')[0] }}" - with_items: "{{ _checksums }}" - when: "('linux-' + go_arch + '.tar.gz') in item" + - name: "Get checksum for {{ go_arch }} architecture" + set_fact: + node_exporter_checksum: "{{ item.split(' ')[0] }}" + with_items: "{{ _checksums }}" + when: + - "('linux-' + go_arch + '.tar.gz') in item" + when: node_exporter_binary_local_dir | length == 0