minecraft added

This commit is contained in:
Tomás Limpinho
2026-03-05 12:15:42 +00:00
parent 46505df323
commit 8a49477449
10 changed files with 159 additions and 2 deletions

View File

@ -13,6 +13,6 @@ flaresolverr comes from https://github.com/FlareSolverr/FlareSolverr
jellyseer comes from https://hub.docker.com/r/fallenbagel/jellyseerr jellyseer comes from https://hub.docker.com/r/fallenbagel/jellyseerr
and https://docs.seerr.dev/extending-jellyseerr/database-config and https://docs.seerr.dev/extending-jellyseerr/database-config
decluttarr comes from https://github.com/ManiMatter/decluttarr decluttarr comes from https://github.com/ManiMatter/decluttarr
minecraft comes from https://www.civo.com/learn/deploying-minecraft-server-kubernetes
![logo](fenix-iac.png) ![logo](fenix-iac.png)

View File

@ -41,4 +41,5 @@
- lazylibrarian - lazylibrarian
- mangareader - mangareader
- bookshelf - bookshelf
- shelfarr - shelfarr
- minecraft

View File

@ -13,6 +13,8 @@ spec:
labels: labels:
app: mangareader app: mangareader
spec: spec:
securityContext:
fsGroup: 1013
imagePullSecrets: imagePullSecrets:
- name: regcred - name: regcred
containers: containers:

View File

@ -0,0 +1,42 @@
apiVersion: apps/v1
kind: Deployment
metadata:
name: minecraft
namespace: minecraft
spec:
replicas: 1
selector:
matchLabels:
app: minecraft
template:
metadata:
labels:
app: minecraft
spec:
securityContext:
fsGroup: 1013
imagePullSecrets:
- name: regcred
containers:
- name: minecraft
image: itzg/minecraft-bedrock-server
resources:
requests:
cpu: 500m
memory: 5Gi
ports:
- containerPort: 19132
name: UDP
env:
- name: EULA
value: "TRUE"
volumeMounts:
- name: data
mountPath: /data
volumes:
- name: data
persistentVolumeClaim:
claimName: minecraft-data-pvc

View File

@ -0,0 +1,4 @@
apiVersion: v1
kind: Namespace
metadata:
name: minecraft

View File

@ -0,0 +1,11 @@
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
name: minecraft-nfs-csi
namespace: minecraft
provisioner: nfs.csi.k8s.io
parameters:
server: 192.168.1.22
share: /mnt/fenix-main-nas-pool-0/data/Minecraft/TI0
allowVolumeExpansion: true
reclaimPolicy: Retain

View File

@ -0,0 +1,29 @@
apiVersion: v1
kind: PersistentVolume
metadata:
name: minecraft-config-pv
namespace: minecraft
spec:
capacity:
storage: 30Gi
storageClassName: minecraft-nfs-csi
accessModes:
- ReadWriteOnce
persistentVolumeReclaimPolicy: Retain
nfs:
server: 192.168.1.22
path: /mnt/fenix-main-nas-pool-0/data/Minecraft/TI0
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: minecraft-config-pvc
namespace: minecraft
spec:
storageClassName: minecraft-nfs-csi
accessModes:
- ReadWriteOnce
volumeName: minecraft-config-pv
resources:
requests:
storage: 30Gi

View File

@ -0,0 +1,12 @@
apiVersion: v1
kind: Service
metadata:
name: minecraft-service
namespace: stack-arr
spec:
ports:
- port: 19132
protocol: UDP
selector:
app: minecraft
type: ClusterIP

View File

@ -0,0 +1,52 @@
- name: Remover o diretório /tmp/stack-arr/minecraft/kubernetes-files
ansible.builtin.file:
path: /tmp/stack-arr/minecraft/kubernetes-files
state: absent
- name: Criar diretório temporário no remoto
file:
path: /tmp/stack-arr/minecraft/kubernetes-files
state: directory
mode: '0755'
- name: Copy file with owner and permissions
ansible.builtin.copy:
src: ../files
dest: /tmp/stack-arr/minecraft/kubernetes-files
owner: fenix
group: root
mode: '0644'
#- name: Obter várias notas do Bitwarden
# shell: |
# echo "unlock"
# BW_SESSION=$(bw unlock {{ bw_password }} --raw)
# echo "get item"
# bw get item "{{ item.id }}" --session $BW_SESSION | jq -r '.notes' > {{ item.dest }}
# loop:
# - { id: "iac.ansible.stackarr.minecraft.secret", dest: "/tmp/stack-arr/minecraft/kubernetes-files/files/minecraft-secret.yaml" }
# args:
# executable: /bin/bash
# environment:
# BW_PASSWORD: "{{ BW_PASSWORD }}"
- name: Listar conteúdo do diretório remoto
shell: ls -l /tmp/stack-arr/minecraft/kubernetes-files/files
register: resultado_ls
- name: Mostrar resultado do ls
debug:
var: resultado_ls.stdout_lines
- name: Aplicar o stolon
become: yes
become_user: fenix
shell: |
kubectl apply -f /tmp/stack-arr/minecraft/kubernetes-files/files/minecraft-namespace.yaml
kubectl apply -f /tmp/stack-arr/minecraft/kubernetes-files/files/
environment:
KUBECONFIG: /home/fenix/.kube/config

View File

@ -0,0 +1,4 @@
bw_password: "{{ lookup('env', 'BW_PASSWORD') }}"
VAULTWARDEN_LINK: "{{ lookup('env', 'VAULTWARDEN_LINK') }}"
BW_CLIENTID: "{{ lookup('env', 'BW_CLIENTID') }}"
BW_CLIENTSECRET : "{{ lookup('env', 'BW_CLIENTSECRET') }}"