Add snipe-it
This commit is contained in:
parent
d6374f72ca
commit
35b9d46c34
5 changed files with 188 additions and 0 deletions
73
k8s/snipeit/database.yaml
Normal file
73
k8s/snipeit/database.yaml
Normal file
|
@ -0,0 +1,73 @@
|
|||
# Headless service for stable DNS entries of StatefulSet members.
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: mysql
|
||||
spec:
|
||||
ports:
|
||||
- name: mysql
|
||||
port: 3306
|
||||
clusterIP: None
|
||||
selector:
|
||||
app: mysql
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: StatefulSet
|
||||
metadata:
|
||||
name: mysql
|
||||
spec:
|
||||
selector:
|
||||
matchLabels:
|
||||
app: mysql
|
||||
serviceName: mysql
|
||||
replicas: 1
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: mysql
|
||||
spec:
|
||||
containers:
|
||||
- name: mysql
|
||||
image: mysql:8
|
||||
envFrom:
|
||||
- secretRef:
|
||||
name: mysql
|
||||
env:
|
||||
- name: MYSQL_ALLOW_EMPTY_PASSWORD
|
||||
value: "1"
|
||||
- name: MYSQL_USER
|
||||
value: snipe
|
||||
- name: MYSQL_DATABASE
|
||||
value: snipe
|
||||
ports:
|
||||
- name: mysql
|
||||
containerPort: 3306
|
||||
volumeMounts:
|
||||
- name: data
|
||||
mountPath: /var/lib/mysql
|
||||
subPath: mysql
|
||||
resources:
|
||||
requests:
|
||||
cpu: 500m
|
||||
memory: 500Mi
|
||||
livenessProbe:
|
||||
exec:
|
||||
command: ["mysqladmin", "ping"]
|
||||
initialDelaySeconds: 30
|
||||
periodSeconds: 10
|
||||
timeoutSeconds: 5
|
||||
readinessProbe:
|
||||
exec:
|
||||
# Check we can execute queries over TCP (skip-networking is off).
|
||||
command: ["mysql", "-h", "127.0.0.1", "-e", "SELECT 1"]
|
||||
initialDelaySeconds: 5
|
||||
periodSeconds: 2
|
||||
timeoutSeconds: 1
|
||||
volumeClaimTemplates:
|
||||
- metadata:
|
||||
name: data
|
||||
spec:
|
||||
accessModes: ["ReadWriteOnce"]
|
||||
resources:
|
||||
requests:
|
||||
storage: 10Gi
|
34
k8s/snipeit/ingress.yaml
Normal file
34
k8s/snipeit/ingress.yaml
Normal file
|
@ -0,0 +1,34 @@
|
|||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: snipe
|
||||
spec:
|
||||
selector:
|
||||
app: snipe
|
||||
ports:
|
||||
- port: 80
|
||||
targetPort: 80
|
||||
---
|
||||
apiVersion: networking.k8s.io/v1
|
||||
kind: Ingress
|
||||
metadata:
|
||||
name: snipe
|
||||
labels:
|
||||
name: snipe
|
||||
annotations:
|
||||
cert-manager.io/cluster-issuer: letsencrypt
|
||||
spec:
|
||||
tls:
|
||||
- hosts: [snipe.herzfeld.casa]
|
||||
secretName: snipe.herzfeld.casa
|
||||
rules:
|
||||
- host: snipe.herzfeld.casa
|
||||
http:
|
||||
paths:
|
||||
- pathType: Prefix
|
||||
path: "/"
|
||||
backend:
|
||||
service:
|
||||
name: snipe
|
||||
port:
|
||||
number: 80
|
30
k8s/snipeit/kustomization.yaml
Normal file
30
k8s/snipeit/kustomization.yaml
Normal file
|
@ -0,0 +1,30 @@
|
|||
apiVersion: kustomize.config.k8s.io/v1beta1
|
||||
kind: Kustomization
|
||||
namespace: snipeit
|
||||
resources:
|
||||
- namespace.yaml
|
||||
- database.yaml
|
||||
- statefulset.yaml
|
||||
- ingress.yaml
|
||||
- secrets.yaml
|
||||
configMapGenerator:
|
||||
- name: snipe-config
|
||||
literals:
|
||||
- MYSQL_DATABASE=snipe
|
||||
- MYSQL_USER=snipe
|
||||
- DB_CONNECTION=mysql
|
||||
- DB_HOST=mysql
|
||||
- APP_URL=https://snipe.herzfeld.casa
|
||||
- APP_TIMEZONE=US/Pacific
|
||||
- APP_LOCALE=en-US
|
||||
- MAIL_MAILER=smtp
|
||||
- MAIL_HOST=mx1.janky.email
|
||||
- MAIL_PORT=587
|
||||
- MAIL_ENV_FROM_ADDR=snipe@herzfeld.casa
|
||||
- MAIL_ENV_FROM_NAME=Herzfeld Stuff Management
|
||||
- MAIL_ENV_ENCRYPTION=tls
|
||||
- MAIL_USERNAME=snipe@herzfeld.casa
|
||||
- MAIL_TLS_VERIFY_PEER=true
|
||||
- ENABLE_HSTS=true
|
||||
- APP_TRUSTED_PROXIES=10.42.0.0/24
|
||||
- SECURE_COOKIES=true
|
4
k8s/snipeit/namespace.yaml
Normal file
4
k8s/snipeit/namespace.yaml
Normal file
|
@ -0,0 +1,4 @@
|
|||
apiVersion: v1
|
||||
kind: Namespace
|
||||
metadata:
|
||||
name: snipeit
|
47
k8s/snipeit/statefulset.yaml
Normal file
47
k8s/snipeit/statefulset.yaml
Normal file
|
@ -0,0 +1,47 @@
|
|||
apiVersion: apps/v1
|
||||
kind: StatefulSet
|
||||
metadata:
|
||||
name: snipe
|
||||
spec:
|
||||
selector:
|
||||
matchLabels:
|
||||
app: snipe
|
||||
serviceName: snipe
|
||||
replicas: 1
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: snipe
|
||||
spec:
|
||||
securityContext:
|
||||
fsGroup: 33
|
||||
fsGroupChangePolicy: "OnRootMismatch"
|
||||
containers:
|
||||
- name: snipe
|
||||
image: snipe/snipe-it:latest
|
||||
ports:
|
||||
- containerPort: 80
|
||||
name: web
|
||||
volumeMounts:
|
||||
- name: storage
|
||||
mountPath: /var/lib/snipeit
|
||||
- name: logs
|
||||
mountPath: /var/www/html/storage/logs
|
||||
envFrom:
|
||||
- configMapRef:
|
||||
name: snipe-config
|
||||
- secretRef:
|
||||
name: mysql
|
||||
- secretRef:
|
||||
name: snipe
|
||||
volumes:
|
||||
- name: logs
|
||||
emptyDir: {}
|
||||
volumeClaimTemplates:
|
||||
- metadata:
|
||||
name: storage
|
||||
spec:
|
||||
accessModes: [ "ReadWriteOnce" ]
|
||||
resources:
|
||||
requests:
|
||||
storage: 5Gi
|
Loading…
Reference in a new issue