2023-08-13 09:45:59 +00:00
|
|
|
local kube = import "../../../kube/kube.libsonnet";
|
|
|
|
|
|
|
|
{
|
|
|
|
local top = self,
|
|
|
|
local cfg = self.cfg,
|
|
|
|
|
|
|
|
cfg:: {
|
|
|
|
name: "demo-next",
|
2023-08-15 16:07:28 +00:00
|
|
|
image: "registry.k0.hswaw.net/radex/next-bruh:v2",
|
2023-08-13 09:45:59 +00:00
|
|
|
domain: "demo-next.hs.radex.io",
|
|
|
|
},
|
|
|
|
|
|
|
|
ns: kube.Namespace("personal-radex"),
|
|
|
|
|
|
|
|
deployment: top.ns.Contain(kube.Deployment(cfg.name)) {
|
|
|
|
spec+: {
|
2023-08-15 16:07:28 +00:00
|
|
|
replicas: 1,
|
2023-08-13 09:45:59 +00:00
|
|
|
template+: {
|
|
|
|
spec+: {
|
2023-08-15 16:07:28 +00:00
|
|
|
volumes_: {
|
|
|
|
data: kube.PersistentVolumeClaimVolume(top.data),
|
|
|
|
},
|
2023-08-13 09:45:59 +00:00
|
|
|
containers_: {
|
|
|
|
default: kube.Container("default") {
|
|
|
|
image: cfg.image,
|
|
|
|
resources: {
|
|
|
|
requests: { cpu: "0.01", memory: "64M" },
|
|
|
|
limits: { cpu: "1", memory: "256M" },
|
|
|
|
},
|
2023-08-15 16:07:28 +00:00
|
|
|
env_: {
|
|
|
|
DATA_PATH: "/data",
|
|
|
|
},
|
2023-08-13 09:45:59 +00:00
|
|
|
ports_: {
|
|
|
|
http: { containerPort: 3000 },
|
|
|
|
},
|
2023-08-15 16:07:28 +00:00
|
|
|
volumeMounts_: {
|
|
|
|
data: { mountPath: '/data' },
|
|
|
|
}
|
2023-08-13 09:45:59 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
2023-08-15 16:07:28 +00:00
|
|
|
data: top.ns.Contain(kube.PersistentVolumeClaim("data")) {
|
|
|
|
spec+: {
|
|
|
|
storageClassName: "waw-hdd-redundant-3",
|
|
|
|
accessModes: [ "ReadWriteOnce" ],
|
|
|
|
resources: {
|
|
|
|
requests: {
|
|
|
|
storage: "1Gi",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2023-08-13 09:45:59 +00:00
|
|
|
service: top.ns.Contain(kube.Service(cfg.name)) {
|
|
|
|
target_pod:: top.deployment.spec.template,
|
|
|
|
},
|
|
|
|
|
|
|
|
ingress: top.ns.Contain(kube.Ingress(cfg.name)) {
|
|
|
|
metadata+: {
|
|
|
|
annotations+: {
|
|
|
|
"kubernetes.io/tls-acme": "true",
|
|
|
|
"cert-manager.io/cluster-issuer": "letsencrypt-prod",
|
|
|
|
"nginx.ingress.kubernetes.io/proxy-body-size": "0",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
spec+: {
|
|
|
|
tls: [ { hosts: [ cfg.domain ], secretName: cfg.name + "-tls" } ],
|
|
|
|
rules: [
|
|
|
|
{
|
|
|
|
host: cfg.domain,
|
|
|
|
http: {
|
|
|
|
paths: [
|
|
|
|
{ path: "/", backend: top.service.name_port },
|
|
|
|
],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|