Remove cloud server configuration files and references and add dynmamic
dns Shit
This commit is contained in:
99
config/ansible/tasks/servers/dynamic-dns.yml
Normal file
99
config/ansible/tasks/servers/dynamic-dns.yml
Normal file
@@ -0,0 +1,99 @@
|
||||
---
|
||||
- name: Dynamic DNS setup
|
||||
block:
|
||||
- name: Create environment file for dynamic DNS
|
||||
ansible.builtin.template:
|
||||
src: "{{ playbook_dir }}/templates/dynamic-dns.env.j2"
|
||||
dest: "{{ ansible_user_dir }}/.local/bin/dynamic-dns.env"
|
||||
mode: "0600"
|
||||
|
||||
- name: Create dynamic DNS wrapper script
|
||||
ansible.builtin.copy:
|
||||
dest: "{{ ansible_user_dir }}/.local/bin/dynamic-dns-update.sh"
|
||||
mode: "0755"
|
||||
content: |
|
||||
#!/bin/bash
|
||||
|
||||
# Load environment variables
|
||||
source {{ ansible_user_dir }}/.local/bin/dynamic-dns.env
|
||||
|
||||
# Change to the directory containing the binary
|
||||
cd {{ ansible_user_dir }}/.local/bin
|
||||
|
||||
# Run dynamic DNS update (binary compiled by utils.yml)
|
||||
dynamic-dns-cf -record "vleeuwen.me,mvl.sh,mennovanleeuwen.nl" 2>&1 | logger -t dynamic-dns
|
||||
|
||||
- name: Setup cron job for dynamic DNS updates (fallback)
|
||||
ansible.builtin.cron:
|
||||
name: "Dynamic DNS Update"
|
||||
minute: "*/15"
|
||||
job: "{{ ansible_user_dir }}/.local/bin/dynamic-dns-update.sh"
|
||||
user: "{{ ansible_user }}"
|
||||
state: present
|
||||
ignore_errors: true
|
||||
tags: [cron]
|
||||
|
||||
- name: Create systemd user directory
|
||||
ansible.builtin.file:
|
||||
path: "{{ ansible_user_dir }}/.config/systemd/user"
|
||||
state: directory
|
||||
mode: "0755"
|
||||
|
||||
- name: Create dynamic DNS systemd timer
|
||||
ansible.builtin.copy:
|
||||
dest: "{{ ansible_user_dir }}/.config/systemd/user/dynamic-dns.timer"
|
||||
mode: "0644"
|
||||
content: |
|
||||
[Unit]
|
||||
Description=Dynamic DNS Update Timer
|
||||
Requires=dynamic-dns.service
|
||||
|
||||
[Timer]
|
||||
OnCalendar=*:0/15
|
||||
Persistent=true
|
||||
|
||||
[Install]
|
||||
WantedBy=timers.target
|
||||
|
||||
- name: Create dynamic DNS systemd service
|
||||
ansible.builtin.copy:
|
||||
dest: "{{ ansible_user_dir }}/.config/systemd/user/dynamic-dns.service"
|
||||
mode: "0644"
|
||||
content: |
|
||||
[Unit]
|
||||
Description=Dynamic DNS Update
|
||||
After=network-online.target
|
||||
Wants=network-online.target
|
||||
|
||||
[Service]
|
||||
Type=oneshot
|
||||
ExecStart={{ ansible_user_dir }}/.local/bin/dynamic-dns-update.sh
|
||||
EnvironmentFile={{ ansible_user_dir }}/.local/bin/dynamic-dns.env
|
||||
|
||||
[Install]
|
||||
WantedBy=default.target
|
||||
|
||||
- name: Reload systemd user daemon
|
||||
ansible.builtin.systemd:
|
||||
daemon_reload: true
|
||||
scope: user
|
||||
|
||||
- name: Enable and start dynamic DNS timer
|
||||
ansible.builtin.systemd:
|
||||
name: dynamic-dns.timer
|
||||
enabled: true
|
||||
state: started
|
||||
scope: user
|
||||
|
||||
- name: Display setup completion message
|
||||
ansible.builtin.debug:
|
||||
msg: |
|
||||
Dynamic DNS setup complete!
|
||||
- Systemd timer: systemctl --user status dynamic-dns.timer
|
||||
- Check logs: journalctl --user -u dynamic-dns.service -f
|
||||
- Manual run: ~/.local/bin/dynamic-dns-update.sh
|
||||
- Domains: vleeuwen.me, mvl.sh, mennovanleeuwen.nl
|
||||
|
||||
when: inventory_hostname == 'mennos-cachyos-desktop'
|
||||
tags:
|
||||
- dynamic-dns
|
||||
@@ -70,7 +70,7 @@
|
||||
|
||||
- name: Include JuiceFS Redis tasks
|
||||
ansible.builtin.include_tasks: services/redis/redis.yml
|
||||
when: inventory_hostname == 'mennos-cloud-server'
|
||||
when: inventory_hostname == 'mennos-cachyos-desktop'
|
||||
|
||||
- name: Enable and start JuiceFS service
|
||||
ansible.builtin.systemd:
|
||||
|
||||
@@ -18,6 +18,11 @@
|
||||
tags:
|
||||
- juicefs
|
||||
|
||||
- name: Include Dynamic DNS tasks
|
||||
ansible.builtin.include_tasks: dynamic-dns.yml
|
||||
tags:
|
||||
- dynamic-dns
|
||||
|
||||
- name: System performance optimizations
|
||||
ansible.posix.sysctl:
|
||||
name: "{{ item.name }}"
|
||||
@@ -46,10 +51,6 @@
|
||||
|
||||
vars:
|
||||
services:
|
||||
- name: uptime-kuma
|
||||
enabled: true
|
||||
hosts:
|
||||
- mennos-cloud-server
|
||||
- name: gitea
|
||||
enabled: true
|
||||
hosts:
|
||||
|
||||
@@ -28,14 +28,7 @@
|
||||
}
|
||||
{% endif %}
|
||||
|
||||
{% if inventory_hostname == 'mennos-cloud-server' %}
|
||||
status.vleeuwen.me status.mvl.sh {
|
||||
import country_block
|
||||
reverse_proxy uptime-kuma:3001
|
||||
tls {{ caddy_email }}
|
||||
}
|
||||
|
||||
{% elif inventory_hostname == 'mennos-cachyos-desktop' %}
|
||||
{% if inventory_hostname == 'mennos-cachyos-desktop' %}
|
||||
git.mvl.sh {
|
||||
import country_block
|
||||
reverse_proxy gitea:3000
|
||||
@@ -213,5 +206,4 @@ drive.mvl.sh drive.vleeuwen.me {
|
||||
|
||||
tls {{ caddy_email }}
|
||||
}
|
||||
|
||||
{% endif %}
|
||||
|
||||
@@ -5,7 +5,7 @@ services:
|
||||
ports:
|
||||
- "6379:6379"
|
||||
volumes:
|
||||
- /mnt/services/redis-data:/data
|
||||
- /mnt/services/redis:/data
|
||||
command: ["redis-server", "--appendonly", "yes", "--requirepass", "{{ REDIS_PASSWORD }}"]
|
||||
environment:
|
||||
- TZ=Europe/Amsterdam
|
||||
|
||||
@@ -1,22 +0,0 @@
|
||||
services:
|
||||
uptime-kuma:
|
||||
image: louislam/uptime-kuma:latest
|
||||
restart: unless-stopped
|
||||
volumes:
|
||||
- {{ uptime_kuma_data_dir }}:/app/data
|
||||
- /var/run/docker.sock:/var/run/docker.sock:ro
|
||||
environment:
|
||||
- PUID=1000
|
||||
- PGID=100
|
||||
- TZ=Europe/Amsterdam
|
||||
ports:
|
||||
- "3001:3001"
|
||||
extra_hosts:
|
||||
- "host.docker.internal:host-gateway"
|
||||
networks:
|
||||
- caddy_network
|
||||
|
||||
networks:
|
||||
caddy_network:
|
||||
external: true
|
||||
name: caddy_default
|
||||
@@ -1,31 +0,0 @@
|
||||
---
|
||||
- name: Deploy Uptime Kuma service
|
||||
block:
|
||||
- name: Set Uptime Kuma directories
|
||||
ansible.builtin.set_fact:
|
||||
uptime_kuma_service_dir: "{{ ansible_env.HOME }}/services/uptime-kuma"
|
||||
uptime_kuma_data_dir: "/mnt/object_storage/services/uptime-kuma"
|
||||
|
||||
- name: Create Uptime Kuma directory
|
||||
ansible.builtin.file:
|
||||
path: "{{ uptime_kuma_service_dir }}"
|
||||
state: directory
|
||||
mode: "0755"
|
||||
|
||||
- name: Deploy Uptime Kuma docker-compose.yml
|
||||
ansible.builtin.template:
|
||||
src: docker-compose.yml.j2
|
||||
dest: "{{ uptime_kuma_service_dir }}/docker-compose.yml"
|
||||
mode: "0644"
|
||||
register: uptime_kuma_compose
|
||||
|
||||
- name: Stop Uptime Kuma service if config changed
|
||||
ansible.builtin.command: docker compose -f "{{ uptime_kuma_service_dir }}/docker-compose.yml" down --remove-orphans
|
||||
when: uptime_kuma_compose.changed
|
||||
|
||||
- name: Start Uptime Kuma service
|
||||
ansible.builtin.command: docker compose -f "{{ uptime_kuma_service_dir }}/docker-compose.yml" up -d
|
||||
when: uptime_kuma_compose.changed or uptime_kuma_start | default(false) | bool
|
||||
tags:
|
||||
- services
|
||||
- uptime_kuma
|
||||
Reference in New Issue
Block a user