112 lines
3.2 KiB
YAML
112 lines
3.2 KiB
YAML
---
|
|
- name: Fix Nomad Podman Driver Configuration
|
|
hosts: nomadlxc,hcp
|
|
become: yes
|
|
vars:
|
|
nomad_user: nomad
|
|
|
|
tasks:
|
|
- name: Stop Nomad service
|
|
systemd:
|
|
name: nomad
|
|
state: stopped
|
|
|
|
- name: Install Podman driver plugin if missing
|
|
block:
|
|
- name: Check if plugin exists
|
|
stat:
|
|
path: /opt/nomad/data/plugins/nomad-driver-podman
|
|
register: plugin_exists
|
|
|
|
- name: Download and install Podman driver plugin
|
|
block:
|
|
- name: Download Nomad Podman driver
|
|
get_url:
|
|
url: "https://releases.hashicorp.com/nomad-driver-podman/0.6.1/nomad-driver-podman_0.6.1_linux_amd64.zip"
|
|
dest: "/tmp/nomad-driver-podman.zip"
|
|
mode: '0644'
|
|
|
|
- name: Extract Podman driver
|
|
unarchive:
|
|
src: "/tmp/nomad-driver-podman.zip"
|
|
dest: "/tmp"
|
|
remote_src: yes
|
|
|
|
- name: Install Podman driver
|
|
copy:
|
|
src: "/tmp/nomad-driver-podman"
|
|
dest: "/opt/nomad/data/plugins/nomad-driver-podman"
|
|
owner: "{{ nomad_user }}"
|
|
group: "{{ nomad_user }}"
|
|
mode: '0755'
|
|
remote_src: yes
|
|
|
|
- name: Clean up temporary files
|
|
file:
|
|
path: "{{ item }}"
|
|
state: absent
|
|
loop:
|
|
- "/tmp/nomad-driver-podman.zip"
|
|
- "/tmp/nomad-driver-podman"
|
|
when: not plugin_exists.stat.exists
|
|
|
|
- name: Update Nomad configuration with correct plugin name and socket path
|
|
replace:
|
|
path: /etc/nomad.d/nomad.hcl
|
|
regexp: 'plugin "podman" \{'
|
|
replace: 'plugin "nomad-driver-podman" {'
|
|
|
|
- name: Update socket path to system socket
|
|
replace:
|
|
path: /etc/nomad.d/nomad.hcl
|
|
regexp: 'socket_path = "unix:///run/user/1001/podman/podman.sock"'
|
|
replace: 'socket_path = "unix:///run/podman/podman.sock"'
|
|
|
|
- name: Add plugin_dir configuration if missing
|
|
lineinfile:
|
|
path: /etc/nomad.d/nomad.hcl
|
|
line: 'plugin_dir = "/opt/nomad/data/plugins"'
|
|
insertafter: 'data_dir = "/opt/nomad/data"'
|
|
state: present
|
|
|
|
- name: Ensure Podman socket is enabled and running
|
|
systemd:
|
|
name: podman.socket
|
|
enabled: yes
|
|
state: started
|
|
|
|
- name: Start Nomad service
|
|
systemd:
|
|
name: nomad
|
|
state: started
|
|
|
|
- name: Wait for Nomad to be ready
|
|
wait_for:
|
|
port: 4646
|
|
host: localhost
|
|
delay: 10
|
|
timeout: 60
|
|
|
|
- name: Wait for plugins to load
|
|
pause:
|
|
seconds: 20
|
|
|
|
- name: Check driver status
|
|
shell: |
|
|
export NOMAD_ADDR=http://localhost:4646
|
|
nomad node status -self | grep -A 10 "Driver Status"
|
|
register: driver_status
|
|
failed_when: false
|
|
|
|
- name: Display driver status
|
|
debug:
|
|
var: driver_status.stdout_lines
|
|
|
|
- name: Check for Podman driver in logs
|
|
shell: journalctl -u nomad -n 30 --no-pager | grep -E "(podman|plugin)" | tail -10
|
|
register: plugin_logs
|
|
failed_when: false
|
|
|
|
- name: Display plugin logs
|
|
debug:
|
|
var: plugin_logs.stdout_lines |