File: ssh_setup.yml

package info (click to toggle)
check-pgbackrest 2.4-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,396 kB
  • sloc: perl: 972; sh: 488; python: 145; makefile: 33
file content (118 lines) | stat: -rw-r--r-- 3,951 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
---
- name: Ensure the localhost keys directory exists
  file:
    state: directory
    path: "{{ cluster_dir }}/keys"
  delegate_to: localhost

- name: Generate {{ pgbackrest_user }} SSH keys
  community.crypto.openssh_keypair:
    path: "{{ cluster_dir }}/keys/id_pgbackrest"
  delegate_to: localhost
  when: inventory_hostname in repository_server

- name: Generate db hosts SSH keys
  community.crypto.openssh_keypair:
    path: "{{ cluster_dir }}/keys/id_postgres"
  delegate_to: localhost
  when: inventory_hostname in pgbackrest_servers

- name: Authorise SSH connection from {{ pgbackrest_user }}
  authorized_key:
    user: "{{ postgres_user }}"
    key: "{{ lookup('file', cluster_dir+'/keys/id_pgbackrest.pub') }}"
  when: inventory_hostname in pgbackrest_servers and repository_server|length > 0

- name: Authorise SSH connection between db hosts
  authorized_key:
    user: "{{ postgres_user }}"
    key: "{{ lookup('file', cluster_dir+'/keys/id_postgres.pub') }}"
  when: inventory_hostname in pgbackrest_servers

- name: Authorise SSH connection to {{ pgbackrest_user }}
  authorized_key:
    user: "{{ pgbackrest_user }}"
    key: "{{ lookup('file', cluster_dir+'/keys/id_postgres.pub') }}"
  when: inventory_hostname in repository_server

- name: Ensure that .ssh exists on db hosts
  file:
    path: "~{{ postgres_user }}/.ssh"
    state: directory
    mode: '0700'
  become_user: "{{ postgres_user }}"
  become: yes
  when: inventory_hostname in pgbackrest_servers

- name: Install keypair on db hosts
  copy:
    src: "{{ item.src }}"
    dest: "{{ item.dest }}"
    mode: "{{ item.mode }}"
  with_items:
    - src: "{{ cluster_dir }}/keys/id_postgres"
      dest: "~{{ postgres_user }}/.ssh/id_rsa"
      mode: '0600'
    - src: "{{ cluster_dir }}/keys/id_postgres.pub"
      dest: "~{{ postgres_user }}/.ssh/id_rsa.pub"
      mode: '0640'
  become_user: "{{ postgres_user }}"
  become: yes
  when: inventory_hostname in pgbackrest_servers

- name: Ensure that .ssh exists on repo host
  file:
    path: "~{{ pgbackrest_user }}/.ssh"
    state: directory
    mode: '0700'
  become_user: "{{ pgbackrest_user }}"
  become: yes
  when: inventory_hostname in repository_server

- name: Install keypair on repo host
  copy:
    src: "{{ item.src }}"
    dest: "{{ item.dest }}"
    mode: "{{ item.mode }}"
  with_items:
    - src: "{{ cluster_dir }}/keys/id_pgbackrest"
      dest: "~{{ pgbackrest_user }}/.ssh/id_rsa"
      mode: '0600'
    - src: "{{ cluster_dir }}/keys/id_pgbackrest.pub"
      dest: "~{{ pgbackrest_user }}/.ssh/id_rsa.pub"
      mode: '0640'
  become_user: "{{ pgbackrest_user }}"
  become: yes
  when: inventory_hostname in repository_server

- name: Test SSH connection from repo host
  shell: "/usr/bin/ssh {{ssh_args}} {{ user }}@{{ host }} uname -a"
  vars:
    host: "{{ hostvars[item].private_ip }}"
    user: "{{ hostvars[item].pg_owner }}"
    ssh_args: "-o ConnectTimeout=10 -o BatchMode=yes -o StrictHostKeyChecking=no"
  loop: "{{ pgbackrest_servers }}"
  become_user: "{{ pgbackrest_user }}"
  become: yes
  when: inventory_hostname in repository_server

- name: Test SSH connection to repo host
  shell: "/usr/bin/ssh {{ssh_args}} {{ user }}@{{ host }} uname -a"
  vars:
    host: "{{ hostvars[pgbackrest_repo_host].private_ip }}"
    user: "{{ pgbackrest_user }}"
    ssh_args: "-o ConnectTimeout=10 -o BatchMode=yes -o StrictHostKeyChecking=no"
  become_user: "{{ postgres_user }}"
  become: yes
  when: inventory_hostname in pgbackrest_servers and repository_server|length > 0

- name: Test SSH connection to db hosts
  shell: "/usr/bin/ssh {{ssh_args}} {{ user }}@{{ host }} uname -a"
  vars:
    host: "{{ hostvars[item].private_ip }}"
    user: "{{ hostvars[item].pg_owner }}"
    ssh_args: "-o ConnectTimeout=10 -o BatchMode=yes -o StrictHostKeyChecking=no"
  loop: "{{ pgbackrest_servers }}"
  become_user: "{{ postgres_user }}"
  become: yes
  when: inventory_hostname in pgbackrest_servers