单机部署kubernetes环境下Overleaf-基于MicroK8s的Overleaf应用部署指南

在本文中,我们将探讨如何使用MicroK8s在本地或云环境中快速部署Overleaf应用。MicroK8s是一个轻量级的Kubernetes发行版,它为开发者提供了一个简单的方式来部署和管理容器化应用。

需要使用Kompose转换Overleaf官方Docker Compose配置得到适用于kubernetes的部署格式

脚本和配置文件:GitHub - mcxiaoxiao/latexhub: Overleaf deployment for microk8s environment. An out-of-the-box solution that can be deployed directly on a single machine.

创建命名空间

我们为Overleaf应用创建一个单独的命名空间,以便于管理和隔离资源。

复制代码
microk8s kubectl create namespace overleaf

添加Helm仓库

接下来,我们添加Bitnami的Helm仓库,提供MongoDB和Redis

复制代码
microk8s helm repo add bitnami https://charts.bitnami.com/bitnami
microk8s helm search repo bitnami

部署MongoDB和Redis

使用Helm部署MongoDB和Redis服务,并应用预先配置的values.yaml文件来定制部署。

复制代码
microk8s helm install mongo bitnami/mongodb --namespace overleaf --values ./mongo/values.yaml
microk8s helm install redis bitnami/redis --namespace overleaf --values ./redis/values.yaml

启用Ingress(可选)

为了使Overleaf应用可从外部访问,我们需要启用Ingress。

复制代码
microk8s enable ingress

配置持久卷

我们定义了三个PersistentVolumes(PVs),分别提供5Gi和10Gi的存储空间,这些存储空间使用hostPath类型,适用于测试环境,但在生产环境中,我们推荐使用更可靠的存储解决方案。

复制代码
microk8s kubectl apply -f overleaf-storageclass.yaml
microk8s kubectl apply -f overleaf-pv.yaml

部署Overleaf应用

最后,我们部署Overleaf应用,并配置相关的PersistentVolumeClaims(PVCs)和其他必要的资源。

复制代码
microk8s kubectl apply -n overleaf -f ./overleaf/overleaf-pvc.yaml -f ./overleaf/overleaf-variables.yaml -f ./overleaf/overleaf-deployment.yaml -f ./overleaf/overleaf-service.yaml

访问应用

如果您需要通过HTTPS访问应用,可以获取证书并创建相应的secret。然后,取消注释并应用Ingress配置以暴露应用。

复制代码
# microk8s kubectl create secret tls overleaf-tls-secret --cert=/tlskeys/public.crt --key=/tlskeys/private.key --namespace=overleaf
# microk8s kubectl apply -f tls-ingress.yaml

此时查看所有命名空间pods转发overleaf的80端口(没有配置ingress)或者直接进入ip/域名,访问/launchpad可以设置管理员邮箱密码

开箱即用,欢迎star⭐~

GitHub - mcxiaoxiao/latexhub: Overleaf deployment for microk8s environment. An out-of-the-box solution that can be deployed directly on a single machine.

相关推荐
阿里云云原生1 小时前
阿里云 AI 网关支持 DeepSeek V4
云原生
阿里云云原生1 小时前
从可观测到可理解:用 UModel 构建 Agent 原生的代码知识图谱
云原生
阿里云云原生2 小时前
OpenClaw、Hermes合用?来自500+社区互动的真实看法
云原生
AI攻城狮5 小时前
开源工具也有山寨陷阱:一个假 Hermes Agent 网站如何收割不明真相的用户
云原生
阿里云云原生5 小时前
人机共跑半马,赛场之外的具身智能规模化运维大考
云原生
宁静@星空5 小时前
007-Docker构建 jar 包成镜像
docker·容器·jar
A-刘晨阳7 小时前
K8s之负载均衡
linux·运维·容器·kubernetes·负载均衡
米高梅狮子8 小时前
11.Quota and Limits、健康检查和认证与授权
云原生·容器·架构·kubernetes·自动化
AI攻城狮9 小时前
把 Markdown 笔记变成可问答的知识图谱:本地 Graph RAG 工具 Kwipu 实测
云原生
虎头金猫9 小时前
监控机不在被监控的机器上,Prometheus怎么跨网络把数据拉过来
运维·服务器·开发语言·网络·云原生·开源·prometheus