Compare commits
6 Commits
f39804e621
...
487e41c058
Author | SHA1 | Date | |
---|---|---|---|
487e41c058 | |||
ce799cceaa | |||
12eabe1351 | |||
4a21c792e1 | |||
9dd76a9161 | |||
ec6106c73e |
@ -42,28 +42,50 @@ en1:
|
|||||||
skylab_cluster:
|
skylab_cluster:
|
||||||
address: 10.42.101.10/24
|
address: 10.42.101.10/24
|
||||||
interface: bond0
|
interface: bond0
|
||||||
|
skylab_networking:
|
||||||
|
hostname: pegasus.skylab.enp.one
|
||||||
|
dns: [10.42.101.1]
|
||||||
|
gateway: 10.42.101.1/24
|
||||||
|
interfaces:
|
||||||
|
eno1:
|
||||||
|
bond: bond0
|
||||||
|
eno2:
|
||||||
|
bond: bond0
|
||||||
|
bond0:
|
||||||
|
type: bond
|
||||||
|
addresses:
|
||||||
|
- 10.42.101.100/24
|
||||||
|
- 192.168.255.255/32
|
||||||
|
dhcp: false
|
||||||
|
bond0.99:
|
||||||
|
type: vlan
|
||||||
|
addresses: [192.168.42.10/24]
|
||||||
|
dhcp: false
|
||||||
|
|
||||||
saturn: # remus
|
saturn: # remus
|
||||||
ansible_host: 10.42.101.110
|
ansible_host: 10.42.101.110
|
||||||
skylab_description: Operational Node
|
skylab_description: Operational Node
|
||||||
skylab_cluster:
|
skylab_cluster:
|
||||||
address: 10.42.101.110/24
|
address: 10.42.101.11/24
|
||||||
interface: bond0
|
interface: bond0
|
||||||
skylab_networking:
|
skylab_networking:
|
||||||
hostname: saturn.skylab.enp.one
|
hostname: saturn.skylab.enp.one
|
||||||
dns: [10.42.101.1]
|
dns: [10.42.101.1]
|
||||||
gateway: 10.42.101.1/24
|
gateway: 10.42.101.1/24
|
||||||
interfaces:
|
interfaces:
|
||||||
|
eno1:
|
||||||
|
bond: bond0
|
||||||
|
eno2:
|
||||||
|
bond: bond0
|
||||||
bond0:
|
bond0:
|
||||||
type: bond
|
type: bond
|
||||||
members: [eno1, eno2]
|
|
||||||
addresses:
|
addresses:
|
||||||
- 10.42.101.11/24
|
|
||||||
- 10.42.101.110/24
|
- 10.42.101.110/24
|
||||||
|
- 192.168.255.255/32
|
||||||
dhcp: false
|
dhcp: false
|
||||||
bond0.99:
|
bond0.99:
|
||||||
type: vlan
|
type: vlan
|
||||||
address: 192.168.42.20/24
|
addresses: [192.168.42.20/24]
|
||||||
dhcp: false
|
dhcp: false
|
||||||
|
|
||||||
orion: # romulus
|
orion: # romulus
|
||||||
@ -77,16 +99,19 @@ en1:
|
|||||||
dns: [10.42.101.1]
|
dns: [10.42.101.1]
|
||||||
gateway: 10.42.101.1/24
|
gateway: 10.42.101.1/24
|
||||||
interfaces:
|
interfaces:
|
||||||
|
eno1:
|
||||||
|
bond: bond0
|
||||||
|
eno2:
|
||||||
|
bond: bond0
|
||||||
bond0:
|
bond0:
|
||||||
type: bond
|
type: bond
|
||||||
members: [eno1, eno2]
|
|
||||||
addresses:
|
addresses:
|
||||||
- 10.42.101.12/24
|
|
||||||
- 10.42.101.120/24
|
- 10.42.101.120/24
|
||||||
|
- 192.168.255.255/32
|
||||||
dhcp: false
|
dhcp: false
|
||||||
bond0.99:
|
bond0.99:
|
||||||
type: vlan
|
type: vlan
|
||||||
address: 192.168.42.30/24
|
addresses: [192.168.42.30/24]
|
||||||
dhcp: false
|
dhcp: false
|
||||||
|
|
||||||
en2:
|
en2:
|
||||||
|
@ -19,8 +19,6 @@
|
|||||||
- name: Configure common settings
|
- name: Configure common settings
|
||||||
hosts: linux
|
hosts: linux
|
||||||
gather_facts: false
|
gather_facts: false
|
||||||
vars_files:
|
|
||||||
- vars/packages.yaml
|
|
||||||
tasks:
|
tasks:
|
||||||
- name: Set hostname
|
- name: Set hostname
|
||||||
become: true
|
become: true
|
||||||
@ -28,14 +26,13 @@
|
|||||||
name: "{{ skylab_networking.hostname | default(inventory_hostname) }}"
|
name: "{{ skylab_networking.hostname | default(inventory_hostname) }}"
|
||||||
use: systemd
|
use: systemd
|
||||||
|
|
||||||
- name: Install global bash config
|
- name: Disable case-sensitive tab-completion
|
||||||
become: true
|
become: true
|
||||||
ansible.builtin.copy:
|
ansible.builtin.lineinfile:
|
||||||
src: global.sh
|
line: set completion-ignore-case On
|
||||||
dest: /etc/profile.d/ZZ-skylab-global.sh
|
path: /etc/inputrc
|
||||||
owner: root
|
state: present
|
||||||
group: "{{ ansible_user }}"
|
create: true
|
||||||
mode: 0644
|
|
||||||
|
|
||||||
- name: Install EPEL repository config
|
- name: Install EPEL repository config
|
||||||
when: ansible_distribution == "Rocky"
|
when: ansible_distribution == "Rocky"
|
||||||
@ -52,13 +49,7 @@
|
|||||||
state: present
|
state: present
|
||||||
key: https://archive.fedoraproject.org/pub/epel/RPM-GPG-KEY-EPEL-{{ ansible_distribution_major_version }}
|
key: https://archive.fedoraproject.org/pub/epel/RPM-GPG-KEY-EPEL-{{ ansible_distribution_major_version }}
|
||||||
|
|
||||||
- name: Install universal packages
|
|
||||||
when: ansible_distribution == "Rocky"
|
|
||||||
become: true
|
|
||||||
ansible.builtin.dnf:
|
|
||||||
name: "{{ skylab_packages_global + skylab_packages_rocky }}"
|
|
||||||
state: present
|
|
||||||
update_cache: true
|
|
||||||
|
|
||||||
|
|
||||||
- import_playbook: update.yaml
|
- import_playbook: update.yaml
|
||||||
|
@ -30,6 +30,23 @@
|
|||||||
name: "*"
|
name: "*"
|
||||||
state: latest
|
state: latest
|
||||||
|
|
||||||
|
- name: Install global bash config
|
||||||
|
become: true
|
||||||
|
ansible.builtin.copy:
|
||||||
|
src: global.sh
|
||||||
|
dest: /etc/profile.d/ZZ-skylab-global.sh
|
||||||
|
owner: root
|
||||||
|
group: "{{ ansible_user }}"
|
||||||
|
mode: 0644
|
||||||
|
|
||||||
|
- name: Install universal packages
|
||||||
|
when: ansible_distribution == "Rocky"
|
||||||
|
become: true
|
||||||
|
ansible.builtin.dnf:
|
||||||
|
name: "{{ skylab_packages_global + skylab_packages_rocky }}"
|
||||||
|
state: present
|
||||||
|
update_cache: true
|
||||||
|
|
||||||
- name: Update unix accounts
|
- name: Update unix accounts
|
||||||
hosts: linux
|
hosts: linux
|
||||||
tags:
|
tags:
|
||||||
|
@ -2,7 +2,7 @@ function _parse_git_branch() {
|
|||||||
git branch 2> /dev/null | sed -e '/^[^*]/d' -e 's/* \(.*\)/ (\1)/'
|
git branch 2> /dev/null | sed -e '/^[^*]/d' -e 's/* \(.*\)/ (\1)/'
|
||||||
}
|
}
|
||||||
|
|
||||||
export PS1="\[\e[0;97m\]\[\e[37m\e[1m\]\u\[\e[1;94m\]@\[\e[94m\]\H\[\e[0;33m\]\$(_parse_git_branch) \[\e[37m\]\w\[\e[33m\] \[\e[0;97m\]$\[\e[0m\] "
|
export PS1="\[\e[0;97m\]\[\e[37m\e[1m\]\u\[\e[1;94m\]@\[\e[94m\]\H\[\e[37m\]:\w\[\e[33m\]\[\e[0;33m\]\$(_parse_git_branch) \[\e[37m\]\[\e[0;97m\]$\[\e[0m\] "
|
||||||
export rc=/home/$USERNAME/.bashrc
|
export rc=/home/$USERNAME/.bashrc
|
||||||
export VIRTUALENV_DIR=/home/$USERNAME/.venvs
|
export VIRTUALENV_DIR=/home/$USERNAME/.venvs
|
||||||
|
|
||||||
|
@ -1 +0,0 @@
|
|||||||
%wheel ALL=(ALL) NOPASSWD: ALL
|
|
@ -4,3 +4,7 @@
|
|||||||
|
|
||||||
- name: Configure SSH server
|
- name: Configure SSH server
|
||||||
ansible.builtin.import_tasks: sshd.yaml
|
ansible.builtin.import_tasks: sshd.yaml
|
||||||
|
|
||||||
|
- name: Configure network settings
|
||||||
|
when: skylab_networking is defined
|
||||||
|
ansible.builtin.include_tasks: networkd.yaml
|
||||||
|
99
roles/server/tasks/networkd.yaml
Normal file
99
roles/server/tasks/networkd.yaml
Normal file
@ -0,0 +1,99 @@
|
|||||||
|
---
|
||||||
|
- name: Install systemd-networkd on Rocky
|
||||||
|
become: true
|
||||||
|
ansible.builtin.dnf:
|
||||||
|
name: systemd-networkd
|
||||||
|
state: present
|
||||||
|
|
||||||
|
- name: Ensure network config directory exists
|
||||||
|
ansible.builtin.file:
|
||||||
|
path: /etc/systemd/network
|
||||||
|
state: directory
|
||||||
|
owner: root
|
||||||
|
group: root
|
||||||
|
mode: 0644
|
||||||
|
|
||||||
|
- name: Create network files
|
||||||
|
become: true
|
||||||
|
ansible.builtin.template:
|
||||||
|
src: network.j2
|
||||||
|
dest: /etc/systemd/network/{{ item.key }}.network
|
||||||
|
mode: 0644
|
||||||
|
owner: root
|
||||||
|
group: "{{ ansible_user }}"
|
||||||
|
loop: "{{ skylab_networking.interfaces | dict2items }}"
|
||||||
|
|
||||||
|
- name: Create netdev files
|
||||||
|
become: true
|
||||||
|
when: item.kind is defined
|
||||||
|
ansible.builtin.template:
|
||||||
|
src: netdev.j2
|
||||||
|
dest: /etc/systemd/network/{{ item.key }}.netdev
|
||||||
|
mode: 0644
|
||||||
|
owner: root
|
||||||
|
group: "{{ ansible_user }}"
|
||||||
|
loop: "{{ skylab_networking.interfaces | dict2items }}"
|
||||||
|
|
||||||
|
- name: Fetch existing network config directory contents
|
||||||
|
become: true
|
||||||
|
changed_when: false
|
||||||
|
ansible.builtin.command:
|
||||||
|
cmd: /usr/bin/ls /etc/systemd/network
|
||||||
|
register: _network_config_dir_raw
|
||||||
|
|
||||||
|
- name: Remove legacy network config files
|
||||||
|
become: true
|
||||||
|
when: item.strip().replace('.netdev', '').replace('.network', '') not in skylab_networking.interfaces
|
||||||
|
ansible.builtin.file:
|
||||||
|
path: /etc/systemd/network/{{ item }}
|
||||||
|
state: absent
|
||||||
|
loop: "{{ _network_config_dir_raw.stdout.split(' ') }}"
|
||||||
|
|
||||||
|
- name: Configure fallback DNS
|
||||||
|
become: true
|
||||||
|
ansible.builtin.lineinfile:
|
||||||
|
path: /etc/systemd/resolved.conf
|
||||||
|
create: false
|
||||||
|
line: FallbackDNS=
|
||||||
|
|
||||||
|
- name: Enable systemd-networkd
|
||||||
|
become: true
|
||||||
|
ansible.builtin.systemd:
|
||||||
|
name: "{{ item }}"
|
||||||
|
enabled: true
|
||||||
|
loop:
|
||||||
|
- systemd-networkd
|
||||||
|
- systemd-networkd-wait-online
|
||||||
|
- systemd-resolved
|
||||||
|
|
||||||
|
- name: Disable NetworkManager
|
||||||
|
become: true
|
||||||
|
ansible.builtin.systemd:
|
||||||
|
name: "{{ item }}"
|
||||||
|
enabled: false
|
||||||
|
loop:
|
||||||
|
- NetworkManager
|
||||||
|
- NetworkManager-wait-online
|
||||||
|
|
||||||
|
- name: Start systemd-resolved to enable symlink creation
|
||||||
|
become: true
|
||||||
|
ansible.builtin.systemd:
|
||||||
|
name: systemd-resolved
|
||||||
|
state: started
|
||||||
|
|
||||||
|
- name: Link system resolv.conf to systemd-resolved
|
||||||
|
become: true
|
||||||
|
ansible.builtin.file:
|
||||||
|
dest: /etc/resolv.conf
|
||||||
|
src: /run/systemd/resolve/resolv.conf
|
||||||
|
state: link
|
||||||
|
force: true
|
||||||
|
setype: net_conf_t
|
||||||
|
|
||||||
|
- name: Link systemd-resolved to multi-user target
|
||||||
|
become: true
|
||||||
|
ansible.builtin.file:
|
||||||
|
dest: /etc/systemd/system/multi-user.target.wants/systemd-resolved.service
|
||||||
|
src: /usr/lib/systemd/system/systemd-resolved.service
|
||||||
|
state: link
|
||||||
|
force: true
|
@ -3,7 +3,7 @@
|
|||||||
when: ansible_distribution == "Rocky" or ansible_distribution == "CentOS"
|
when: ansible_distribution == "Rocky" or ansible_distribution == "CentOS"
|
||||||
become: true
|
become: true
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
src: wheel-group-no-sudo-password
|
content: "%wheel ALL=(ALL) NOPASSWD: ALL"
|
||||||
dest: /etc/sudoers.d/30-wheel
|
dest: /etc/sudoers.d/30-wheel
|
||||||
owner: root
|
owner: root
|
||||||
group: "{{ ansible_user }}"
|
group: "{{ ansible_user }}"
|
||||||
|
@ -3,9 +3,9 @@
|
|||||||
### ### ### ### ### ### ### ### ### ###
|
### ### ### ### ### ### ### ### ### ###
|
||||||
### ######## ####### ### ######### #######
|
### ######## ####### ### ######### #######
|
||||||
####### ### ### ### ### ### ### ### ###
|
####### ### ### ### ### ### ### ### ###
|
||||||
### ### ### ##### ### ### ### #######
|
### ### ### #### ### ### ### #######
|
||||||
### ###
|
### ###
|
||||||
###### #########
|
###### /////////////////// ######### /////////////
|
||||||
|
|
||||||
✨ {{ skylab_description }} @{{ skylab_location }}
|
✨ {{ skylab_description }} @{{ skylab_location }}
|
||||||
{{ ' ' }}
|
{{ ' ' }}
|
||||||
|
18
roles/server/templates/netdev.j2
Normal file
18
roles/server/templates/netdev.j2
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
# ANSIBLE MANAGED FILE - DO NOT MANUALLY EDIT
|
||||||
|
#
|
||||||
|
[NetDev]
|
||||||
|
Name={{ item.key }}
|
||||||
|
type={{ item.value.type }}
|
||||||
|
|
||||||
|
{% if item.value.type.lower() == 'bond' %}
|
||||||
|
[Bond]
|
||||||
|
Mode={{ item.value.bond_mode | default('balance-rr') }}
|
||||||
|
PrimaryReselectPolicy=always
|
||||||
|
MIIMonitorSec=1s
|
||||||
|
{% endif %}
|
||||||
|
{% if item.value.type.lower() == 'vlan' %}
|
||||||
|
[VLAN]
|
||||||
|
Id={{ item.key.partition('.')[2] }}
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
# EOF
|
32
roles/server/templates/network.j2
Normal file
32
roles/server/templates/network.j2
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
# ANSIBLE MANAGED FILE - DO NOT EDIT
|
||||||
|
#
|
||||||
|
[Match]
|
||||||
|
Name={{ item.key }}
|
||||||
|
|
||||||
|
[Network]
|
||||||
|
DHCP={{ "Yes" if item.value.dhcp | default(false) else "No" }}
|
||||||
|
IPv6AcceptRA=No
|
||||||
|
{% if item.value.dns is defined %}
|
||||||
|
{% for server in item.value.dns %}
|
||||||
|
DNS={{ server }}
|
||||||
|
{% endfor %}
|
||||||
|
{% endif %}
|
||||||
|
{% if item.value.bond is defined %}
|
||||||
|
Bond={{ item.value.bond }}
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
{% if item.value.dhcp | default(false) %}
|
||||||
|
Gateway={{ item.value.gateway | ansible.netcommon.ipaddr('address') }}
|
||||||
|
{% for address in item.value.addresses %}
|
||||||
|
Address={{ address | ansible.netcommon.ipaddr('host/prefix') }}
|
||||||
|
{% endfor %}
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
|
||||||
|
{% for interface in skylab_networking.interfaces.keys() %}
|
||||||
|
{% if interface.startswith(item.key) and interface.partition('.')[2] | number %}
|
||||||
|
VLAN={{ interface }}
|
||||||
|
{% endif %}
|
||||||
|
{% endfor %}
|
||||||
|
|
||||||
|
# EOF
|
Reference in New Issue
Block a user