166 lines
3.9 KiB
YAML
166 lines
3.9 KiB
YAML
---
|
|
apiVersion: codemowers.cloud/v1beta1
|
|
kind: MysqlDatabaseClass
|
|
metadata:
|
|
name: shared
|
|
annotations:
|
|
kubernetes.io/description: "Shared MySQL cluster"
|
|
spec:
|
|
reclaimPolicy: Retain
|
|
shared: true
|
|
replicas: 3
|
|
routers: 2
|
|
storageClass: mysql
|
|
podSpec:
|
|
containers:
|
|
- name: mariadb
|
|
image: mariadb:10.9.7@sha256:198c7a5fea3d7285762042a628fe8f83f0a7ccef559605b4cc9502e65210880b
|
|
imagePullPolicy: IfNotPresent
|
|
nodeSelector:
|
|
dedicated: storage
|
|
tolerations:
|
|
- effect: NoSchedule
|
|
key: dedicated
|
|
operator: Equal
|
|
value: storage
|
|
---
|
|
apiVersion: codemowers.cloud/v1beta1
|
|
kind: MysqlDatabaseClass
|
|
metadata:
|
|
name: dedicated
|
|
annotations:
|
|
kubernetes.io/description: "Dedicated MySQL cluster"
|
|
spec:
|
|
reclaimPolicy: Retain
|
|
replicas: 3
|
|
routers: 2
|
|
storageClass: mysql
|
|
podSpec:
|
|
containers:
|
|
- name: mariadb
|
|
image: mariadb:10.9.7@sha256:198c7a5fea3d7285762042a628fe8f83f0a7ccef559605b4cc9502e65210880b
|
|
imagePullPolicy: IfNotPresent
|
|
nodeSelector:
|
|
dedicated: storage
|
|
tolerations:
|
|
- effect: NoSchedule
|
|
key: dedicated
|
|
operator: Equal
|
|
value: storage
|
|
---
|
|
apiVersion: codemowers.cloud/v1beta1
|
|
kind: MysqlDatabaseClass
|
|
metadata:
|
|
name: external
|
|
annotations:
|
|
kubernetes.io/description: "External MySQL cluster"
|
|
spec:
|
|
reclaimPolicy: Retain
|
|
shared: true
|
|
---
|
|
apiVersion: v1
|
|
kind: ConfigMap
|
|
metadata:
|
|
name: phpmyadmin
|
|
namespace: mysql-clusters
|
|
data:
|
|
config.user.inc.php: |
|
|
<?php
|
|
for ($i = 1; isset($hosts[$i - 1]); $i++) {
|
|
$cfg['Servers'][$i]['ssl'] = true;
|
|
}
|
|
---
|
|
apiVersion: apps/v1
|
|
kind: Deployment
|
|
metadata:
|
|
name: phpmyadmin
|
|
namespace: mysql-clusters
|
|
spec:
|
|
# phpMyAdmin session handling is not really compatible with more replicas
|
|
replicas: 1
|
|
selector:
|
|
matchLabels:
|
|
app: phpmyadmin
|
|
template:
|
|
metadata:
|
|
labels:
|
|
app: phpmyadmin
|
|
spec:
|
|
containers:
|
|
- name: phpmyadmin
|
|
image: phpmyadmin/phpmyadmin
|
|
volumeMounts:
|
|
- name: config
|
|
mountPath: /etc/phpmyadmin/config.user.inc.php
|
|
subPath: config.user.inc.php
|
|
ports:
|
|
- name: web
|
|
containerPort: 80
|
|
protocol: TCP
|
|
env:
|
|
- name: PMA_HOSTS
|
|
value: mysql-cluster-shared.mysql-clusters,mysql-cluster.authelia,mysql-cluster.etherpad,mariadb.authelia,mariadb.nextcloud,172.20.36.1
|
|
- name: PMA_PORTS
|
|
value: 6446,6446,6446,3306,3306,3306
|
|
- name: PMA_ABSOLUTE_URI
|
|
value: https://phpmyadmin.k-space.ee/
|
|
- name: UPLOAD_LIMIT
|
|
value: 10G
|
|
volumes:
|
|
- name: config
|
|
configMap:
|
|
name: phpmyadmin
|
|
---
|
|
apiVersion: codemowers.io/v1alpha1
|
|
kind: OIDCGWMiddlewareClient
|
|
metadata:
|
|
name: phpmyadmin
|
|
spec:
|
|
displayName: phpMyAdmin
|
|
uri: 'https://phpmyadmin.k-space.ee'
|
|
headerMapping:
|
|
email: Remote-Email
|
|
groups: Remote-Groups
|
|
name: Remote-Name
|
|
user: Remote-Username
|
|
---
|
|
apiVersion: networking.k8s.io/v1
|
|
kind: Ingress
|
|
metadata:
|
|
name: phpmyadmin
|
|
namespace: mysql-clusters
|
|
annotations:
|
|
kubernetes.io/ingress.class: traefik
|
|
traefik.ingress.kubernetes.io/router.entrypoints: websecure
|
|
traefik.ingress.kubernetes.io/router.tls: "true"
|
|
external-dns.alpha.kubernetes.io/target: traefik.k-space.ee
|
|
traefik.ingress.kubernetes.io/router.middlewares: mysql-clusters-phpmyadmin@kubernetescrd
|
|
spec:
|
|
rules:
|
|
- host: phpmyadmin.k-space.ee
|
|
http:
|
|
paths:
|
|
- pathType: Prefix
|
|
path: "/"
|
|
backend:
|
|
service:
|
|
name: phpmyadmin
|
|
port:
|
|
number: 80
|
|
tls:
|
|
- hosts:
|
|
- "*.k-space.ee"
|
|
---
|
|
apiVersion: v1
|
|
kind: Service
|
|
metadata:
|
|
name: phpmyadmin
|
|
namespace: mysql-clusters
|
|
spec:
|
|
selector:
|
|
app: phpmyadmin
|
|
ports:
|
|
- protocol: TCP
|
|
port: 80
|
|
targetPort: 80
|