4.9 KiB
使用 Kubernetes 部署 DjangoBlog
本文档将指导您如何在 Kubernetes (K8s) 集群上部署 DjangoBlog 应用。我们提供了一套完整的 .yaml 配置文件,位于 deploy/k8s 目录下,用于部署一个包含 DjangoBlog 应用、Nginx、MySQL、Redis 和 Elasticsearch 的完整服务栈。
架构概览
本次部署采用的是微服务化的云原生架构:
- 核心组件: 每个核心服务 (DjangoBlog, Nginx, MySQL, Redis, Elasticsearch) 都将作为独立的
Deployment运行。 - 配置管理: Nginx 的配置文件和 Django 应用的环境变量通过
ConfigMap进行管理。注意:敏感信息(如密码)建议使用Secret进行管理。 - 服务发现: 所有服务都通过
ClusterIP类型的Service在集群内部暴露,并通过服务名相互通信。 - 外部访问: 使用
Ingress资源将外部的 HTTP 流量路由到 Nginx 服务,作为整个博客应用的统一入口。 - 数据持久化: 采用基于节点本地路径的
local-storage方案。这需要您在指定的 K8s 节点上手动创建存储目录,并通过PersistentVolume(PV) 和PersistentVolumeClaim(PVC) 进行静态绑定。
1. 环境准备
在开始之前,请确保您已具备以下环境:
- 一个正在运行的 Kubernetes 集群。
kubectl命令行工具已配置并能够连接到您的集群。- 集群中已安装并配置好 Nginx Ingress Controller。
- 对集群中的一个节点(默认为
master)拥有文件系统访问权限,用于创建本地存储目录。
2. 部署步骤
步骤 1: 创建命名空间
我们建议将 DjangoBlog 相关的所有资源都部署在一个独立的命名空间中,便于管理。
# 创建一个名为 djangoblog 的命名空间
kubectl create namespace djangoblog
步骤 2: 配置持久化存储
此方案使用本地持久卷 (Local Persistent Volume)。您需要在集群的一个节点上(在 pv.yaml 文件中默认为 master 节点)创建用于数据存储的目录。
# 登录到您的 master 节点
ssh user@master-node
# 创建所需的存储目录
sudo mkdir -p /mnt/local-storage-db
sudo mkdir -p /mnt/local-storage-djangoblog
sudo mkdir -p /mnt/resource/
sudo mkdir -p /mnt/local-storage-elasticsearch
# 退出节点
exit
注意: 如果您希望将数据存储在其他节点或使用不同的路径,请务必修改 deploy/k8s/pv.yaml 文件中 nodeAffinity 和 local.path 的配置。
创建目录后,应用存储相关的配置文件:
# 应用 StorageClass
kubectl apply -f deploy/k8s/storageclass.yaml
# 应用 PersistentVolume (PV)
kubectl apply -f deploy/k8s/pv.yaml
# 应用 PersistentVolumeClaim (PVC)
kubectl apply -f deploy/k8s/pvc.yaml
步骤 3: 配置应用
在部署应用之前,您需要编辑 deploy/k8s/configmap.yaml 文件,修改其中的敏感信息和个性化配置。
强烈建议修改以下字段:
DJANGO_SECRET_KEY: 修改为一个随机且复杂的字符串。DJANGO_MYSQL_PASSWORD和MYSQL_ROOT_PASSWORD: 修改为您自己的数据库密码。
# 编辑 ConfigMap 文件
vim deploy/k8s/configmap.yaml
# 应用配置
kubectl apply -f deploy/k8s/configmap.yaml
步骤 4: 部署应用服务栈
现在,我们可以部署所有的核心服务了。
# 部署 Deployments (DjangoBlog, MySQL, Redis, Nginx, ES)
kubectl apply -f deploy/k8s/deployment.yaml
# 部署 Services (为 Deployments 创建内部访问端点)
kubectl apply -f deploy/k8s/service.yaml
部署需要一些时间,您可以运行以下命令检查所有 Pod 是否都已成功运行 (STATUS 为 Running):
kubectl get pods -n djangoblog -w
步骤 5: 暴露应用到外部
最后,通过应用 Ingress 规则来将外部流量引导至我们的 Nginx 服务。
# 应用 Ingress 规则
kubectl apply -f deploy/k8s/gateway.yaml
部署完成后,您可以通过 Ingress Controller 的外部 IP 地址来访问您的博客。执行以下命令获取地址:
kubectl get ingress -n djangoblog
步骤 6: 首次运行的初始化操作
与 Docker 部署类似,首次运行时,您需要进入 DjangoBlog 应用的 Pod 来执行数据库初始化和创建管理员账户。
# 首先,获取 djangoblog pod 的名称
kubectl get pods -n djangoblog | grep djangoblog
# 进入其中一个 Pod (将 [pod-name] 替换为上一步获取到的名称)
kubectl exec -it [pod-name] -n djangoblog -- bash
# 在 Pod 内部执行以下命令:
# 创建超级管理员账户 (请按照提示操作)
python manage.py createsuperuser
# (可选) 创建测试数据
python manage.py create_testdata
# (可选,如果启用了 ES) 创建索引
python manage.py rebuild_index
# 退出 Pod
exit
至此,您已成功在 Kubernetes 集群上完成了 DjangoBlog 的部署!