Compare commits
2 Commits
471452483d
...
5898246ac1
| Author | SHA1 | Date | |
|---|---|---|---|
| 5898246ac1 | |||
|
|
ffb5d9066f |
148
kubernetes-templates/semaphoreui.yml
Normal file
148
kubernetes-templates/semaphoreui.yml
Normal file
@@ -0,0 +1,148 @@
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Namespace
|
||||
metadata:
|
||||
name: semaphore
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: PersistentVolumeClaim
|
||||
metadata:
|
||||
name: semaphore-data-pvc
|
||||
namespace: semaphore
|
||||
spec:
|
||||
accessModes:
|
||||
- ReadWriteMany
|
||||
storageClassName: nfs-storage
|
||||
resources:
|
||||
requests:
|
||||
storage: 5Gi
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Secret
|
||||
metadata:
|
||||
name: semaphore-secrets
|
||||
namespace: semaphore
|
||||
type: Opaque
|
||||
data:
|
||||
db-password: c2VYbk42RGt1cFJaN0Y=
|
||||
admin-password: QmxhY2tzdGFyMkBob21l
|
||||
access-key-encryption: NHZKMm1LMnBMNW5COHhSMnpRN3dFM3RZNnVJMG9QOWE=
|
||||
id_ed25519: b3BlbnNzaC1rZXktdjEAAAAABG5vbmUAAAAEbm9uZQAAAAAAAAABAAAAMwAAAAtzc2gtZWQyNTUxOQAAACDnDP06snc4Ci73FOImgNk3Mblsno53hj6XD2SK15dZbAAAAJgel/2wHpf9sAAAAAtzc2gtZWQyNTUxOQAAACDnDP06snc4Ci73FOImgNk3Mblsno53hj6XD2SK15dZbAAAAEBThqcrsWeeUZzEyWVZbhDiJdOEBFXJH85sa1Cc+WWCI+cM/TqydzgKLvcU4iaA2TcxuWyejneGPpcPZIrXl1lsAAAADmtod2V6aUBEQVJLU1VOAQIDBAUGBw==
|
||||
id_ed25519.pub: c3NoLWVkMjU1MTkgQUFBQUMzTnphQzFsWkRJMU5URTVBQUFBSU9jTS9UcXlkemdLTHZjVTRpYUEyVGN4dVd5ZWpuZUdQcGNSWklyWGwx bHMgS2h3ZXppQERBUktTVU4K
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: ConfigMap
|
||||
metadata:
|
||||
name: semaphore-configs
|
||||
namespace: semaphore
|
||||
data:
|
||||
SEMAPHORE_DB_USER: "semaphore_user"
|
||||
SEMAPHORE_DB_HOST: "192.168.1.170"
|
||||
SEMAPHORE_DB_NAME: "semaphore"
|
||||
SEMAPHORE_ADMIN_USERNAME: "khwezi"
|
||||
SEMAPHORE_ADMIN_EMAIL: "khwezi@litecharms.co.za"
|
||||
SEMAPHORE_SCHEDULE_TIMEZONE: "Africa/Johannesburg"
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: semaphore
|
||||
namespace: semaphore
|
||||
labels:
|
||||
app: semaphore
|
||||
spec:
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
app: semaphore
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: semaphore
|
||||
spec:
|
||||
affinity:
|
||||
nodeAffinity:
|
||||
requiredDuringSchedulingIgnoredDuringExecution:
|
||||
nodeSelectorTerms:
|
||||
- matchExpressions:
|
||||
- key: node-role.kubernetes.io/control-plane
|
||||
operator: DoesNotExist
|
||||
securityContext:
|
||||
runAsUser: 1001
|
||||
fsGroup: 1001
|
||||
containers:
|
||||
- name: semaphore
|
||||
image: semaphoreui/semaphore:latest
|
||||
ports:
|
||||
- containerPort: 3000
|
||||
name: http
|
||||
resources:
|
||||
requests:
|
||||
cpu: "200m"
|
||||
memory: "512Mi"
|
||||
limits:
|
||||
cpu: "1"
|
||||
memory: "1Gi"
|
||||
env:
|
||||
- name: SEMAPHORE_DB_DIALECT
|
||||
value: "postgres"
|
||||
- name: SEMAPHORE_DB_PORT
|
||||
value: "5432"
|
||||
- name: SEMAPHORE_DB_USER
|
||||
valueFrom: { configMapKeyRef: { name: semaphore-configs, key: SEMAPHORE_DB_USER } }
|
||||
- name: SEMAPHORE_DB_HOST
|
||||
valueFrom: { configMapKeyRef: { name: semaphore-configs, key: SEMAPHORE_DB_HOST } }
|
||||
- name: SEMAPHORE_DB
|
||||
valueFrom: { configMapKeyRef: { name: semaphore-configs, key: SEMAPHORE_DB_NAME } }
|
||||
- name: SEMAPHORE_ADMIN
|
||||
valueFrom: { configMapKeyRef: { name: semaphore-configs, key: SEMAPHORE_ADMIN_USERNAME } }
|
||||
- name: SEMAPHORE_ADMIN_NAME
|
||||
valueFrom: { configMapKeyRef: { name: semaphore-configs, key: SEMAPHORE_ADMIN_USERNAME } }
|
||||
- name: SEMAPHORE_ADMIN_EMAIL
|
||||
valueFrom: { configMapKeyRef: { name: semaphore-configs, key: SEMAPHORE_ADMIN_EMAIL } }
|
||||
- name: SEMAPHORE_SCHEDULE_TIMEZONE
|
||||
valueFrom: { configMapKeyRef: { name: semaphore-configs, key: SEMAPHORE_SCHEDULE_TIMEZONE } }
|
||||
- name: SEMAPHORE_DB_PASS
|
||||
valueFrom: { secretKeyRef: { name: semaphore-secrets, key: db-password } }
|
||||
- name: SEMAPHORE_ADMIN_PASSWORD
|
||||
valueFrom: { secretKeyRef: { name: semaphore-secrets, key: admin-password } }
|
||||
- name: SEMAPHORE_ACCESS_KEY_ENCRYPTION
|
||||
valueFrom: { secretKeyRef: { name: semaphore-secrets, key: access-key-encryption } }
|
||||
volumeMounts:
|
||||
- name: semaphore-tmp
|
||||
mountPath: /tmp/semaphore
|
||||
- name: ssh-keys-volume
|
||||
mountPath: /home/semaphore/.ssh/id_ed25519
|
||||
subPath: id_ed25519
|
||||
- name: ssh-keys-volume
|
||||
mountPath: /home/semaphore/.ssh/id_ed25519.pub
|
||||
subPath: id_ed25519.pub
|
||||
volumes:
|
||||
- name: semaphore-tmp
|
||||
persistentVolumeClaim:
|
||||
claimName: semaphore-data-pvc
|
||||
- name: ssh-keys-volume
|
||||
secret:
|
||||
secretName: semaphore-secrets
|
||||
defaultMode: 384
|
||||
items:
|
||||
- key: id_ed25519
|
||||
path: id_ed25519
|
||||
- key: id_ed25519.pub
|
||||
path: id_ed25519.pub
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: semaphore-service
|
||||
namespace: semaphore
|
||||
spec:
|
||||
type: NodePort
|
||||
selector:
|
||||
app: semaphore
|
||||
ports:
|
||||
- name: http
|
||||
protocol: TCP
|
||||
port: 3000
|
||||
targetPort: 3000
|
||||
nodePort: 31011
|
||||
Reference in New Issue
Block a user