Mercurial > code > home > repos > infra
view system.py @ 133:706d861f6d95
move boot.config setup to system.py
author | drewp@bigasterisk.com |
---|---|
date | Wed, 21 Dec 2022 13:45:10 -0800 |
parents | 168bc1c44e6f |
children | 5558d8481ddf |
line wrap: on
line source
import os from pyinfra import host from pyinfra.facts.server import LinuxDistribution from pyinfra.facts.files import FindFiles from pyinfra.facts.server import Arch from pyinfra.operations import apt, files, server, systemd is_pi = host.get_fact(LinuxDistribution)['name'] in ['Debian', 'Raspbian GNU/Linux'] TZ = 'America/Los_Angeles' server.hostname(hostname=host.name) def timezone(): files.link(path='/etc/localtime', target=f'/usr/share/zoneinfo/{TZ}') files.replace(path='/etc/timezone', text='.*', replace=TZ) def apt_sources(): if host.get_fact(Arch) == 'x86_64': server.shell(commands=['dpkg --add-architecture i386']) files.template(src='templates/sources.list.j2', dest='/etc/apt/sources.list.j2') if host.get_fact(FindFiles, '/etc/apt/sources.list.d/', quote_path=True): raise SystemExit(f"new files in {host.name} /etc/apt/sources.list.d/ - please remove") apt.packages(update=True, cache_time=86400, packages=['tzdata'], force=True, _env={ 'TZ': TZ, 'LANG': 'en_US.UTF-8', 'DEBIAN_FRONTEND': 'noninteractive' }) def fstab(): fstab_file = f'files/fstab/{host.name}' if os.path.exists(fstab_file): files.put(src=fstab_file, dest='/etc/fstab') def pi_tmpfs(): for line in [ 'tmpfs /var/log tmpfs defaults,noatime,mode=0755 0 0', 'tmpfs /tmp tmpfs defaults,noatime 0 0', ]: files.line(path="/etc/fstab", line=line, replace=line) # stop SD card corruption (along with some mounts in fstab) apt.packages(packages=['dphys-swapfile'], present=False) # don't try to get aufs-dkms on rpi-- https://github.com/docker/for-linux/issues/709 def podman_inecure_registry(): files.template(src='templates/kube/podman_registries.conf.j2', dest='/etc/containers/registries.conf.d/bang.conf') def no_sleep(): server.shell(commands=['systemctl mask sleep.target suspend.target hibernate.target hybrid-sleep.target']) def nfs_server(): apt.packages(packages=['nfs-kernel-server']) files.template(src='templates/bang_exports.j2', dest='/etc/exports') # sudo zfs set sharenfs="rw=10.5.0.0/16" stor6 def smaller_journals(): files.line(name='shorter systemctl log window, for disk space', path='/etc/systemd/journald.conf', line='MaxFileSec', replace="MaxFileSec=7day") for port in [80, 443]: files.template(src="templates/webforward.service.j2", dest=f"/etc/systemd/system/web_forward_{port}.service", port=port) systemd.service(service=f'web_forward_{port}', enabled=True, restarted=True) def zfs_metrics(): files.put(src='files/zfs_metrics/zfs_space_metrics.sh', dest='/opt/zfs_metrics/zfs_space_metrics.sh') files.put(src='files/zfs_metrics/zfs.mtail', dest='/opt/zfs_metrics/zfs.mtail') files.put(src='files/zfs_metrics/zfs_space_metrics.service', dest=f'/etc/systemd/system/zfs_space_metrics.service') systemd.service(service=f'zfs_space_metrics', enabled=True, restarted=True, daemon_reload=True) timezone() apt_sources() fstab() if not is_pi: files.line(path='/etc/update-manager/release-upgrades', line="^Prompt=", replace="Prompt=normal") if is_pi and host.name != 'pipe': pi_tmpfs() files.template(src='templates/boot_config.txt.j2', dest='/boot/config.txt') if not is_pi: podman_inecure_registry() if host.name in ['bang', 'pipe']: no_sleep() if host.name == 'bang': nfs_server() zfs_metrics() if host.name == 'prime': smaller_journals()