Merge pull request #3 from khuedoan/rocky-linux

Switch to Rocky Linux
This commit is contained in:
Khue Doan 2021-08-31 08:30:45 +00:00 committed by GitHub
commit 7667254d7b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
23 changed files with 133 additions and 202 deletions

View File

@ -8,9 +8,3 @@
gather_facts: no gather_facts: no
roles: roles:
- wake - wake
- name: Create Terraform state storage
hosts: metal[0]
gather_facts: no
roles:
- tfstate

View File

@ -1,6 +1,3 @@
iso_url: "https://builds.coreos.fedoraproject.org/prod/streams/testing/builds/34.20210808.2.0/x86_64/fedora-coreos-34.20210808.2.0-live.x86_64.iso" iso_url: "https://download.rockylinux.org/pub/rocky/8/isos/x86_64/Rocky-8.4-x86_64-minimal.iso"
iso_checksum: "sha256:8ec901fcb5bf9f05cf8046cbe7bce29e36600b7ec61165577c1b3c565b85425c" iso_checksum: "sha256:0de5f12eba93e00fefc06cdb0aa4389a0972a4212977362ea18bde46a1a1aa4f"
os_name: CoreOS
# TODO (optimize) Get timezone automatically from the controller
timezone: Asia/Ho_Chi_Minh timezone: Asia/Ho_Chi_Minh

View File

@ -0,0 +1,2 @@
*
!.gitignore

View File

@ -0,0 +1,2 @@
*
!.gitignore

View File

@ -0,0 +1,2 @@
*
!.gitignore

View File

@ -0,0 +1,2 @@
*
!.gitignore

View File

@ -0,0 +1,20 @@
option space pxelinux;
option pxelinux.magic code 208 = string;
option pxelinux.configfile code 209 = text;
option pxelinux.pathprefix code 210 = text;
option pxelinux.reboottime code 211 = unsigned integer 32;
option architecture-type code 93 = unsigned integer 16;
subnet 192.168.1.0 netmask 255.255.255.0 {
option routers 192.168.1.1;
range 192.168.1.2 192.168.1.254;
class "pxeclients" {
match if substring (option vendor-class-identifier, 0, 9) = "PXEClient";
next-server 192.168.1.12;
if option architecture-type = 00:07 {
filename "grubx64.efi";
}
}
}

View File

@ -0,0 +1,24 @@
version: "3"
services:
dhcp:
build: ./dhcp
volumes:
- ./data/pxe-config/dhcpd.conf:/etc/dhcp/dhcpd.conf
network_mode: host
tftp:
build: ./tftp
network_mode: host
volumes:
- ./data/pxe-config/grub.cfg:/var/lib/tftpboot/grub.cfg
- ./data/os/EFI/BOOT/grubx64.efi:/var/lib/tftpboot/grubx64.efi
- ./data/os/images/pxeboot/initrd.img:/var/lib/tftpboot/initrd.img
- ./data/os/images/pxeboot/vmlinuz:/var/lib/tftpboot/vmlinuz
http:
build: ./http
network_mode: host
volumes:
- ./data/os:/usr/share/nginx/html/os
- ./data/init-config/:/usr/share/nginx/html/init-config
environment:
NGINX_PORT: 80

View File

@ -0,0 +1,8 @@
set timeout=1
menuentry 'Rocky-8.4-x86_64-minimal (PXE)' {
linux vmlinuz \
ip=dhcp \
ks=http://192.168.1.12/init-config/${net_default_mac}.ks
initrd initrd.img
}

View File

@ -1,77 +1,34 @@
- name: Gather network facts
ansible.builtin.setup:
gather_subset:
- network
- name: Create build directory
file:
path: "{{ item }}"
state: directory
loop:
- "{{ role_path }}/build"
- "{{ role_path }}/files/images"
- "{{ role_path }}/build/mnt"
- name: Download ISO - name: Download ISO
get_url: get_url:
url: "{{ iso_url }}" url: "{{ iso_url }}"
dest: "{{ role_path }}/files/images/{{ iso_url | basename }}" dest: "{{ role_path }}/files/data/iso/{{ iso_url | basename }}"
checksum: "{{ iso_checksum }}" checksum: "{{ iso_checksum }}"
register: iso register: iso
- name: Extract the ISO - name: Extract the ISO
command: command:
cmd: "xorriso -osirrox on -indev {{ iso.dest }} -extract / {{ role_path }}/build/mnt" cmd: "xorriso -osirrox on -indev {{ iso.dest }} -extract / {{ role_path }}/files/data/os"
creates: "{{ role_path }}/build/mnt/.treeinfo" creates: "{{ role_path }}/files/data/os/.treeinfo"
- name: Extract bootloader
iso_extract:
image: "{{ role_path }}/build/mnt/images/efiboot.img"
dest: "{{ role_path }}/build/mnt/EFI/fedora"
files:
- EFI/fedora/grubx64.efi
- name: Copy configs
copy:
src: "{{ role_path }}/templates/"
dest: "{{ role_path }}/build"
- name: Render DHCP config - name: Render DHCP config
template: template:
src: dhcp/dhcpd.conf.j2 src: dhcpd.conf.j2
dest: "{{ role_path }}/build/dhcp/dhcpd.conf" dest: "{{ role_path }}/files/data/pxe-config/dhcpd.conf"
- name: Render GRUB config - name: Render GRUB config
template: template:
src: tftp/tftpboot/grub.cfg.j2 src: grub.cfg.j2
dest: "{{ role_path }}/build/tftp/tftpboot/grub.cfg" dest: "{{ role_path }}/files/data/pxe-config/grub.cfg"
- name: Render machine specific Butane config - name: Render machine specific init config
template: template:
src: http/ignition/ignition.yaml.j2 src: kickstart.ks.j2
dest: "{{ role_path }}/build/http/ignition/{{ hostvars[item]['mac'] }}.yaml" dest: "{{ role_path }}/files/data/init-config/{{ hostvars[item]['mac'] }}.ks"
loop: "{{ groups['metal'] }}"
- name: Render Ignition config from Butane config
docker_container:
name: butane
image: quay.io/coreos/butane:release
auto_remove: yes
volumes:
- "{{ role_path }}/build/http/ignition:/local/src"
working_dir: /local/src
command:
- --pretty
- --strict
- "{{ hostvars[item]['mac'] }}.yaml"
- --output
- "{{ hostvars[item]['mac'] }}.json"
loop: "{{ groups['metal'] }}" loop: "{{ groups['metal'] }}"
- name: Start ephemeral PXE server - name: Start ephemeral PXE server
docker_compose: docker_compose:
project_src: "{{ role_path }}/build" project_src: "{{ role_path }}/files"
state: present state: present
restarted: yes restarted: yes
build: yes build: yes
recreate: always

View File

@ -1,25 +0,0 @@
version: "3"
services:
dhcp:
build: ./dhcp
volumes:
- ./dhcp/dhcpd.conf:/etc/dhcp/dhcpd.conf
network_mode: host
tftp:
build: ./tftp
network_mode: host
volumes:
- ./tftp/tftpboot/grub.cfg:/var/lib/tftpboot/grub.cfg
- ./mnt/EFI/fedora/grubx64.efi:/var/lib/tftpboot/grubx64.efi
- ./mnt/images/ignition.img:/var/lib/tftpboot/ignition.img
- ./mnt/images/pxeboot/initrd.img:/var/lib/tftpboot/initrd.img
- ./mnt/images/pxeboot/vmlinuz:/var/lib/tftpboot/vmlinuz
http:
build: ./http
network_mode: host
volumes:
- ./mnt:/usr/share/nginx/html/CoreOS
- ./http/ignition/:/usr/share/nginx/html/ignition
environment:
NGINX_PORT: 80

View File

@ -0,0 +1,8 @@
set timeout=1
menuentry '{{ iso_url | basename | splitext | first }} (PXE)' {
linux vmlinuz \
ip=dhcp \
ks=http://{{ ansible_default_ipv4.address }}/init-config/${net_default_mac}.ks
initrd initrd.img
}

View File

@ -1,79 +0,0 @@
variant: fcos
version: 1.3.0
passwd:
users:
- name: root
ssh_authorized_keys:
- {{ ssh_public_key }}
storage:
files:
# Set hostname
- path: /etc/hostname
mode: 0644
contents:
inline: {{ hostvars[item]['inventory_hostname'] }}
# Set static IP
- path: /etc/NetworkManager/system-connections/{{ network_interface }}.nmconnection
mode: 0600
contents:
inline: |
[connection]
id={{ network_interface }}
type=ethernet
interface-name={{ network_interface }}
permissions=
[ipv4]
address1={{ (hostvars[item]['ansible_host'] + '/' + ansible_default_ipv4.netmask) | ansible.netcommon.ipaddr('host/prefix') }},{{ ansible_default_ipv4.gateway }}
dns={{ dns_server }};
dns-search=
method=manual
# Make audit logs less verbose
- path: /etc/sysctl.d/20-silence-audit.conf
contents:
inline: |
kernel.printk=4
# Fix flannel support
- path: /etc/systemd/network/50-flannel.link
contents:
inline: |
[Match]
OriginalName=flannel*
[Link]
MACAddressPolicy=none
links:
# Set timezone
- path: /etc/localtime
target: /usr/share/zoneinfo/{{ timezone }}
systemd:
units:
# iSCSI for Longhorn distributed block storage
- name: iscsid.service
enabled: true
{% if item == "metal0" %}
# Terraform state backend
- name: tfstate.service
enabled: true
contents: |
[Unit]
Description=Run etcd for Terraform state backend
After=network-online.target
Wants=network-online.target
[Service]
ExecStartPre=-/usr/bin/docker kill tfstate
ExecStartPre=-/usr/bin/docker rm tfstate
ExecStart=/usr/bin/docker run --name tfstate \
--volume tfstate:/bitnami/etcd/data \
--env ALLOW_NONE_AUTHENTICATION=yes \
--publish 23799:2379 \
--restart always \
bitnami/etcd
ExecStop=/usr/bin/docker stop tfstate
Restart=always
[Install]
WantedBy=multi-user.target
{% endif %}

View File

@ -0,0 +1,51 @@
#version=RHEL8
# Do not use graphical install
text
# Keyboard layouts
keyboard --xlayouts='us'
# System language
lang en_US.UTF-8
# Partition clearing information
clearpart --all --drives={{ disk }}
# Partitioning
ignoredisk --only-use={{ disk }}
autopart
# Network information
network --bootproto=static --device={{ network_interface }} --ip={{ hostvars[item]['ansible_host'] }} --gateway={{ ansible_default_ipv4.gateway }} --nameserver={{ dns_server }} --netmask={{ ansible_default_ipv4.netmask }} --ipv6=auto --hostname={{ hostvars[item]['inventory_hostname'] }} --activate
# Use network installation
repo --name="Minimal" --baseurl=http://{{ ansible_default_ipv4.address }}/os/Minimal
url --url="http://{{ ansible_default_ipv4.address }}/os"
# Disable Setup Agent on first boot
firstboot --disable
# Do not configure the X Window System
skipx
# Enable NTP
services --enabled="chronyd"
# System timezone
timezone {{ timezone }} --isUtc
# Create user (locked by default)
user --groups=wheel --name=admin
# Add SSH key
sshkey --username=root "{{ ssh_public_key }}"
# Disable SELinux
selinux --disabled
# Disable firewall
firewall --disabled
%packages
@^minimal-environment
iscsi-initiator-utils
%end
# Enable iSCSI for Kubernetes storage
services --enable=iscsid
reboot

View File

@ -1,11 +0,0 @@
set timeout=1
menuentry '{{ os_name }} (Live)' {
linux vmlinuz \
ip=dhcp \
ignition.platform.id=metal \
coreos.live.rootfs_url=http://{{ ansible_default_ipv4.address }}/{{ os_name }}/images/pxeboot/rootfs.img \
coreos.inst.install_dev=/dev/{{ disk }} \
coreos.inst.ignition_url=http://{{ ansible_default_ipv4.address }}/ignition/${net_default_mac}.json
initrd initrd.img ignition.img
}

View File

@ -1 +0,0 @@
etcd_port: 23799

View File

@ -1,11 +0,0 @@
- name: Wait for etcd
wait_for:
port: 23799
host: '{{ ansible_ssh_host }}'
connection: local
- name: Generate Terraform backend config
delegate_to: localhost
template:
src: backend.tfvars.j2
dest: "{{ playbook_dir }}/../cluster/backend.tfvars"

View File

@ -1,5 +0,0 @@
endpoints = [
{% for host in ansible_play_hosts %}
"{{ hostvars[host].ansible_host }}:{{ etcd_port }}",
{% endfor %}
]

View File

@ -4,9 +4,5 @@
delegate_to: localhost delegate_to: localhost
- name: Wait for the servers to comes up - name: Wait for the servers to comes up
wait_for: wait_for_connection:
host: '{{ ansible_host }}'
port: 22
search_regex: OpenSSH
timeout: 600 timeout: 600
delegate_to: localhost