feat: Add nix cache
This commit is contained in:
@@ -0,0 +1,31 @@
|
||||
apiVersion: networking.k8s.io/v1
|
||||
kind: Ingress
|
||||
metadata:
|
||||
annotations:
|
||||
cert-manager.io/cluster-issuer: letsencrypt-production
|
||||
nginx.ingress.kubernetes.io/backend-protocol: HTTP
|
||||
nginx.ingress.kubernetes.io/enable-cors: "true"
|
||||
nginx.ingress.kubernetes.io/proxy-buffer-size: 128k
|
||||
nginx.ingress.kubernetes.io/ssl-redirect: "true"
|
||||
oceanbox.io/expose: internal
|
||||
labels:
|
||||
app.kubernetes.io/component: nix-cache
|
||||
name: nix-cache
|
||||
namespace: ncps
|
||||
spec:
|
||||
ingressClassName: nginx
|
||||
rules:
|
||||
- host: cache.oceanbox.io
|
||||
http:
|
||||
paths:
|
||||
- backend:
|
||||
service:
|
||||
name: nix-cache
|
||||
port:
|
||||
name: http-web
|
||||
path: /
|
||||
pathType: ImplementationSpecific
|
||||
tls:
|
||||
- hosts:
|
||||
- cache.oceanbox.io
|
||||
secretName: cache.oceanbox.io-tls
|
||||
@@ -0,0 +1,33 @@
|
||||
{{- if .Values.clusterConfig.argo.enabled }}
|
||||
apiVersion: argoproj.io/v1alpha1
|
||||
kind: Application
|
||||
metadata:
|
||||
name: ncps
|
||||
namespace: argocd
|
||||
annotations:
|
||||
argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
|
||||
finalizers:
|
||||
- resources-finalizer.argocd.argoproj.io
|
||||
spec:
|
||||
destination:
|
||||
namespace: ncps
|
||||
server: 'https://kubernetes.default.svc'
|
||||
sources:
|
||||
- repoURL: {{ .Values.clusterConfig.manifests }}
|
||||
targetRevision: HEAD
|
||||
path: values/ncps/manifests
|
||||
project: sys
|
||||
syncPolicy:
|
||||
managedNamespaceMetadata:
|
||||
labels:
|
||||
component: sys
|
||||
syncOptions:
|
||||
- CreateNamespace=true
|
||||
- ApplyOutOfSyncOnly=true
|
||||
# - ServerSideApply=true
|
||||
{{- if .Values.ncps.autosync }}
|
||||
automated:
|
||||
prune: true
|
||||
# selfHeal: false
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
@@ -0,0 +1,13 @@
|
||||
apiVersion: v1
|
||||
kind: PersistentVolumeClaim
|
||||
metadata:
|
||||
name: nix-cache
|
||||
labels:
|
||||
app: nix-cache
|
||||
tier: proxy
|
||||
spec:
|
||||
accessModes:
|
||||
- ReadWriteOnce
|
||||
resources:
|
||||
requests:
|
||||
storage: 20Gi
|
||||
@@ -0,0 +1,62 @@
|
||||
apiVersion: apps/v1
|
||||
kind: StatefulSet
|
||||
metadata:
|
||||
name: nix-cache
|
||||
labels:
|
||||
app: nix-cache
|
||||
tier: proxy
|
||||
spec:
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
app: nix-cache
|
||||
tier: proxy
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: nix-cache
|
||||
tier: proxy
|
||||
spec:
|
||||
initContainers:
|
||||
- image: alpine:latest
|
||||
name: create-directories
|
||||
args:
|
||||
- /bin/sh
|
||||
- -c
|
||||
- "mkdir -m 0755 -p /storage/var && mkdir -m 0700 -p /storage/var/ncps && mkdir -m 0700 -p /storage/var/ncps/db"
|
||||
volumeMounts:
|
||||
- name: nix-cache-persistent-storage
|
||||
mountPath: /storage
|
||||
- image: kalbasit/ncps:latest # NOTE: It's recommended to use a tag here, but we live dangerously
|
||||
name: migrate-database
|
||||
args:
|
||||
- /bin/dbmate
|
||||
- --url=sqlite:/storage/var/ncps/db/db.sqlite
|
||||
- migrate
|
||||
- up
|
||||
volumeMounts:
|
||||
- name: nix-cache-persistent-storage
|
||||
mountPath: /storage
|
||||
containers:
|
||||
- image: kalbasit/ncps:latest # NOTE: It's recommended to use a tag here!
|
||||
name: nix-cache
|
||||
args:
|
||||
- /bin/ncps
|
||||
- serve
|
||||
- --cache-hostname=cache.oceanbox.io # TODO: Setup ingress
|
||||
- --cache-data-path=/storage
|
||||
- --cache-database-url=sqlite:/storage/var/ncps/db/db.sqlite
|
||||
- --upstream-cache=https://cache.nixos.org
|
||||
- --upstream-cache=https://nix-community.cachix.org
|
||||
- --upstream-public-key=cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY=
|
||||
- --upstream-public-key=nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs=
|
||||
ports:
|
||||
- containerPort: 8501
|
||||
name: http-web
|
||||
volumeMounts:
|
||||
- name: nix-cache-persistent-storage
|
||||
mountPath: /storage
|
||||
volumes:
|
||||
- name: nix-cache-persistent-storage
|
||||
persistentVolumeClaim:
|
||||
claimName: nix-cache
|
||||
@@ -0,0 +1,15 @@
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: nix-cache
|
||||
labels:
|
||||
app: nix-cache
|
||||
tier: proxy
|
||||
spec:
|
||||
type: ClusterIP
|
||||
ports:
|
||||
- name: http-web
|
||||
port: 8501
|
||||
selector:
|
||||
app: nix-cache
|
||||
tier: proxy
|
||||
Reference in New Issue
Block a user