mirror of
https://gitea.fenix-dev.com/fenix-gitea-admin/iac-ansible-private.git
synced 2026-05-14 08:35:22 +00:00
lidarr ollama ui, soulseek
This commit is contained in:
91
roles/soulseek/files/soulseek-deployment.yaml
Normal file
91
roles/soulseek/files/soulseek-deployment.yaml
Normal file
@ -0,0 +1,91 @@
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: soulseek
|
||||
namespace: stack-arr
|
||||
spec:
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
app: soulseek
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: soulseek
|
||||
spec:
|
||||
imagePullSecrets:
|
||||
- name: regcred
|
||||
initContainers:
|
||||
- name: init-tun
|
||||
image: busybox
|
||||
command:
|
||||
- sh
|
||||
- -c
|
||||
- |
|
||||
mkdir -p /dev/net
|
||||
[ -c /dev/net/tun ] || mknod /dev/net/tun c 10 200
|
||||
chmod 0666 /dev/net/tun
|
||||
securityContext:
|
||||
privileged: true
|
||||
containers:
|
||||
- name: vpn
|
||||
image: ghcr.io/wfg/openvpn-client
|
||||
securityContext:
|
||||
capabilities:
|
||||
add:
|
||||
- NET_ADMIN
|
||||
env:
|
||||
- name: VPN_CONFIG_FILE
|
||||
value: "vpn.conf"
|
||||
- name: KILL_SWITCH
|
||||
value: "off"
|
||||
volumeMounts:
|
||||
- name: vpn-config
|
||||
mountPath: /data/vpn
|
||||
- name: tun-device # ← mount host tun device
|
||||
mountPath: /dev/net/tun
|
||||
- name: slskd
|
||||
image: slskd/slskd
|
||||
securityContext:
|
||||
capabilities:
|
||||
add:
|
||||
- NET_ADMIN
|
||||
ports:
|
||||
- containerPort: 5030
|
||||
name: webui
|
||||
- containerPort: 5031
|
||||
name: https
|
||||
- containerPort: 50300
|
||||
name: communication
|
||||
env:
|
||||
- name: SLSKD_FLAGS_NO_SQLITE_POOLING
|
||||
value: "true"
|
||||
- name: TZ
|
||||
value: 'Etc/UTC'
|
||||
- name: UID
|
||||
value: "1013"
|
||||
- name: GID
|
||||
value: "1013"
|
||||
volumeMounts:
|
||||
- name: app
|
||||
mountPath: /app
|
||||
- name: media
|
||||
mountPath: /data
|
||||
volumes:
|
||||
- name: app
|
||||
persistentVolumeClaim:
|
||||
claimName: soulseek-app-pvc
|
||||
- name: media
|
||||
persistentVolumeClaim:
|
||||
claimName: soulseek-media-pvc
|
||||
- name: vpn-config
|
||||
persistentVolumeClaim:
|
||||
claimName: soulseek-vpn-config-pvc
|
||||
- name: tun-device
|
||||
hostPath:
|
||||
path: /dev/net/tun
|
||||
type: CharDevice
|
||||
|
||||
|
||||
|
||||
|
||||
24
roles/soulseek/files/soulseek-nfs-csi.yaml
Normal file
24
roles/soulseek/files/soulseek-nfs-csi.yaml
Normal file
@ -0,0 +1,24 @@
|
||||
apiVersion: storage.k8s.io/v1
|
||||
kind: StorageClass
|
||||
metadata:
|
||||
name: soulseek-nfs-csi
|
||||
namespace: stack-arr
|
||||
provisioner: nfs.csi.k8s.io
|
||||
parameters:
|
||||
mountOptions: "nolock,soft,intr"
|
||||
server: 192.168.1.22
|
||||
share: /mnt/fenix-main-nas-pool-0/data/k8s-Volumes/k8s-cluster-iac-deployed/stack-arr/soulseek
|
||||
allowVolumeExpansion: true
|
||||
reclaimPolicy: Retain
|
||||
---
|
||||
apiVersion: storage.k8s.io/v1
|
||||
kind: StorageClass
|
||||
metadata:
|
||||
name: soulseek-media-nfs-csi
|
||||
namespace: stack-arr
|
||||
provisioner: nfs.csi.k8s.io
|
||||
parameters:
|
||||
server: 192.168.1.22
|
||||
share: /mnt/fenix-main-nas-pool-0/data/Filmes_e_Series/Downloads
|
||||
allowVolumeExpansion: true
|
||||
reclaimPolicy: Retain
|
||||
94
roles/soulseek/files/soulseek-pvcs.yaml
Normal file
94
roles/soulseek/files/soulseek-pvcs.yaml
Normal file
@ -0,0 +1,94 @@
|
||||
apiVersion: v1
|
||||
kind: PersistentVolume
|
||||
metadata:
|
||||
name: soulseek-app-pv
|
||||
namespace: stack-arr
|
||||
spec:
|
||||
capacity:
|
||||
storage: 6Gi
|
||||
storageClassName: soulseek-nfs-csi
|
||||
accessModes:
|
||||
- ReadWriteOnce
|
||||
persistentVolumeReclaimPolicy: Retain
|
||||
mountOptions:
|
||||
- nolock
|
||||
- nfsvers=3
|
||||
nfs:
|
||||
server: 192.168.1.22
|
||||
path: /mnt/fenix-main-nas-pool-0/data/k8s-Volumes/k8s-cluster-iac-deployed/stack-arr/soulseek/config
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: PersistentVolumeClaim
|
||||
metadata:
|
||||
name: soulseek-app-pvc
|
||||
namespace: stack-arr
|
||||
spec:
|
||||
storageClassName: soulseek-nfs-csi
|
||||
accessModes:
|
||||
- ReadWriteOnce
|
||||
volumeName: soulseek-app-pv
|
||||
resources:
|
||||
requests:
|
||||
storage: 6Gi
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: PersistentVolume
|
||||
metadata:
|
||||
name: soulseek-media-pv
|
||||
namespace: stack-arr
|
||||
spec:
|
||||
capacity:
|
||||
storage: 500Gi
|
||||
storageClassName: soulseek-media-nfs-csi
|
||||
accessModes:
|
||||
- ReadWriteOnce
|
||||
persistentVolumeReclaimPolicy: Retain
|
||||
nfs:
|
||||
server: 192.168.1.22
|
||||
path: /mnt/fenix-main-nas-pool-0/data/Filmes_e_Series/Downloads
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: PersistentVolumeClaim
|
||||
metadata:
|
||||
name: soulseek-media-pvc
|
||||
namespace: stack-arr
|
||||
spec:
|
||||
storageClassName: soulseek-media-nfs-csi
|
||||
accessModes:
|
||||
- ReadWriteOnce
|
||||
volumeName: soulseek-media-pv
|
||||
resources:
|
||||
requests:
|
||||
storage: 500Gi
|
||||
---
|
||||
|
||||
apiVersion: v1
|
||||
kind: PersistentVolume
|
||||
metadata:
|
||||
name: soulseek-vpn-config-pv
|
||||
namespace: stack-arr
|
||||
spec:
|
||||
capacity:
|
||||
storage: 10Gi
|
||||
storageClassName: soulseek-nfs-csi
|
||||
accessModes:
|
||||
- ReadWriteOnce
|
||||
persistentVolumeReclaimPolicy: Retain
|
||||
nfs:
|
||||
server: 192.168.1.22
|
||||
path: /mnt/fenix-main-nas-pool-0/data/k8s-Volumes/k8s-cluster-iac-deployed/stack-arr/soulseek/vpn/config
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: PersistentVolumeClaim
|
||||
metadata:
|
||||
name: soulseek-vpn-config-pvc
|
||||
namespace: stack-arr
|
||||
spec:
|
||||
storageClassName: soulseek-nfs-csi
|
||||
accessModes:
|
||||
- ReadWriteOnce
|
||||
volumeName: soulseek-vpn-config-pv
|
||||
resources:
|
||||
requests:
|
||||
storage: 10Gi
|
||||
---
|
||||
25
roles/soulseek/files/soulseek-service.yaml
Normal file
25
roles/soulseek/files/soulseek-service.yaml
Normal file
@ -0,0 +1,25 @@
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: soulseek-service
|
||||
namespace: stack-arr
|
||||
spec:
|
||||
ports:
|
||||
- port: 5030
|
||||
targetPort: 5030
|
||||
selector:
|
||||
app: soulseek
|
||||
type: ClusterIP
|
||||
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: soulseek-communication-service
|
||||
namespace: stack-arr
|
||||
spec:
|
||||
ports:
|
||||
- port: 50300
|
||||
targetPort: 50300
|
||||
selector:
|
||||
app: soulseek
|
||||
type: ClusterIP
|
||||
BIN
roles/soulseek/files/teste.txt
Normal file
BIN
roles/soulseek/files/teste.txt
Normal file
Binary file not shown.
BIN
roles/soulseek/files/testeq.txt
Normal file
BIN
roles/soulseek/files/testeq.txt
Normal file
Binary file not shown.
37
roles/soulseek/tasks/main.yml
Normal file
37
roles/soulseek/tasks/main.yml
Normal file
@ -0,0 +1,37 @@
|
||||
- name: Remover o diretório /tmp/stack-arr/soulseek/kubernetes-files
|
||||
ansible.builtin.file:
|
||||
path: /tmp/stack-arr/soulseek/kubernetes-files
|
||||
state: absent
|
||||
|
||||
- name: Criar diretório temporário no remoto
|
||||
file:
|
||||
path: /tmp/stack-arr/soulseek/kubernetes-files
|
||||
state: directory
|
||||
mode: '0755'
|
||||
|
||||
- name: Copy file with owner and permissions
|
||||
ansible.builtin.copy:
|
||||
src: ../files
|
||||
dest: /tmp/stack-arr/soulseek/kubernetes-files
|
||||
owner: fenix
|
||||
group: root
|
||||
mode: '0644'
|
||||
|
||||
|
||||
- name: Listar conteúdo do diretório remoto
|
||||
shell: ls -l /tmp/stack-arr/soulseek/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/soulseek/kubernetes-files/files/
|
||||
environment:
|
||||
KUBECONFIG: /home/fenix/.kube/config
|
||||
4
roles/soulseek/vars/main.yml
Normal file
4
roles/soulseek/vars/main.yml
Normal 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') }}"
|
||||
Reference in New Issue
Block a user