-
Notifications
You must be signed in to change notification settings - Fork 0
/
hydra.yaml
173 lines (173 loc) · 3.66 KB
/
hydra.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
apiVersion: v1
kind: Service
metadata:
name: ingress-loadbalancer-hydra
namespace: ingress
annotations:
metallb.universe.tf/loadBalancerIPs: 10.100.0.249
spec:
selector:
name: nginx-ingress-microk8s
type: LoadBalancer
ports:
- name: https
protocol: TCP
port: 443
targetPort: 443
---
apiVersion: v1
kind: Service
metadata:
name: hydra-service
namespace: downloads
spec:
ports:
- name: hydra-web-port
port: 443
protocol: TCP
targetPort: containerport
selector:
app: hydra
type: NodePort
---
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: hydra-ingress
namespace: downloads
annotations:
cert-manager.io/cluster-issuer: letsencrypt-prod
ingress.kubernetes.io/ssl-redirect: "true"
spec:
rules:
- host: hydra.cynexia.net
http:
paths:
- backend:
service:
name: hydra-service
port:
name: hydra-web-port
path: /
pathType: Prefix
tls:
- hosts:
- hydra.cynexia.net
secretName: hydra.cynexia.net
---
apiVersion: v1
kind: PersistentVolume
metadata:
name: hydra-config-longhorn-pv
namespace: downloads
spec:
accessModes:
- ReadWriteOnce
storageClassName: longhorn
capacity:
storage: 30Gi
csi:
driver: driver.longhorn.io
fsType: ext4
volumeHandle: hydra-config
persistentVolumeReclaimPolicy: Retain
volumeMode: Filesystem
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: hydra-config-longhorn-pvc
namespace: downloads
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 30Gi
storageClassName: longhorn
volumeName: hydra-config-longhorn-pv
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: hydra
namespace: downloads
spec:
selector:
matchLabels:
app: hydra
progressDeadlineSeconds: 600
replicas: 1
revisionHistoryLimit: 10
strategy:
type: Recreate
template:
metadata:
labels:
app: hydra
spec:
containers:
- env:
- name: PGID
value: "1999"
- name: PUID
value: "1999"
- name: TZ
value: Europe/London
image: linuxserver/nzbhydra2:latest
imagePullPolicy: Always
securityContext:
allowPrivilegeEscalation: false
# dropping capabilities seems to be incompatible with longhorn
capabilities:
add:
- CHOWN
- SETGID
- SETUID
- FOWNER
- DAC_OVERRIDE
- DAC_READ_SEARCH
drop:
- ALL
privileged: false
readOnlyRootFilesystem: false
startupProbe:
failureThreshold: 15
httpGet:
path: /
port: containerport
scheme: HTTP
periodSeconds: 30
successThreshold: 1
timeoutSeconds: 1
livenessProbe:
httpGet:
path: /
port: containerport
scheme: HTTP
failureThreshold: 2
periodSeconds: 10
name: hydra
ports:
- containerPort: 5076
name: containerport
protocol: TCP
readinessProbe:
failureThreshold: 6
httpGet:
path: /
port: 5076
scheme: HTTP
initialDelaySeconds: 90
periodSeconds: 15
successThreshold: 2
timeoutSeconds: 2
volumeMounts:
- mountPath: /config
name: config
restartPolicy: Always
terminationGracePeriodSeconds: 30
volumes:
- name: config
persistentVolumeClaim:
claimName: hydra-config-longhorn-pvc