Compare commits

..

6 Commits

Author SHA1 Message Date
487e41c058
Add networkd configuration to server role
Update inventory with necessary networking settings
2021-11-06 00:37:32 -04:00
ce799cceaa
Simplify sudoers config by using copy content parameter
Delete unneded file
2021-11-06 00:37:31 -04:00
12eabe1351
Move tasks from update to provision
Move global bashrc and universal package install from update to provision playbooks
2021-11-06 00:37:31 -04:00
4a21c792e1
Add task to disable case sensitive tab completion 2021-11-06 00:37:31 -04:00
9dd76a9161
Update motd to fix malformed y 2021-11-06 00:37:31 -04:00
ec6106c73e
Update ps1 to fix path formatting 2021-11-05 23:46:46 -04:00
11 changed files with 215 additions and 30 deletions

View File

@ -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:

View File

@ -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

View File

@ -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:

View File

@ -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

View File

@ -1 +0,0 @@
%wheel ALL=(ALL) NOPASSWD: ALL

View File

@ -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

View 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

View File

@ -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 }}"

View File

@ -3,9 +3,9 @@
### ### ### ### ### ### ### ### ### ### ### ### ### ### ### ### ### ### ### ###
### ######## ####### ### ######### ####### ### ######## ####### ### ######### #######
####### ### ### ### ### ### ### ### ### ####### ### ### ### ### ### ### ### ###
### ### ### ##### ### ### ### ####### ### ### ### #### ### ### ### #######
### ### ### ###
###### ######### ###### /////////////////// ######### /////////////
✨ {{ skylab_description }} @{{ skylab_location }} ✨ {{ skylab_description }} @{{ skylab_location }}
{{ ' ' }} {{ ' ' }}

View 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

View 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