|
|
# 使用 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](https://kubernetes.github.io/ingress-nginx/deploy/)。
|
|
|
- 对集群中的一个节点(默认为 `master`)拥有文件系统访问权限,用于创建本地存储目录。
|
|
|
|
|
|
## 2. 部署步骤
|
|
|
|
|
|
### 步骤 1: 创建命名空间
|
|
|
|
|
|
我们建议将 DjangoBlog 相关的所有资源都部署在一个独立的命名空间中,便于管理。
|
|
|
|
|
|
```bash
|
|
|
# 创建一个名为 djangoblog 的命名空间
|
|
|
kubectl create namespace djangoblog
|
|
|
```
|
|
|
|
|
|
### 步骤 2: 配置持久化存储
|
|
|
|
|
|
此方案使用本地持久卷 (Local Persistent Volume)。您需要在集群的一个节点上(在 `pv.yaml` 文件中默认为 `master` 节点)创建用于数据存储的目录。
|
|
|
|
|
|
```bash
|
|
|
# 登录到您的 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` 的配置。
|
|
|
|
|
|
创建目录后,应用存储相关的配置文件:
|
|
|
|
|
|
```bash
|
|
|
# 应用 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`: 修改为您自己的数据库密码。
|
|
|
|
|
|
```bash
|
|
|
# 编辑 ConfigMap 文件
|
|
|
vim deploy/k8s/configmap.yaml
|
|
|
|
|
|
# 应用配置
|
|
|
kubectl apply -f deploy/k8s/configmap.yaml
|
|
|
```
|
|
|
|
|
|
### 步骤 4: 部署应用服务栈
|
|
|
|
|
|
现在,我们可以部署所有的核心服务了。
|
|
|
|
|
|
```bash
|
|
|
# 部署 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`):
|
|
|
|
|
|
```bash
|
|
|
kubectl get pods -n djangoblog -w
|
|
|
```
|
|
|
|
|
|
### 步骤 5: 暴露应用到外部
|
|
|
|
|
|
最后,通过应用 `Ingress` 规则来将外部流量引导至我们的 Nginx 服务。
|
|
|
|
|
|
```bash
|
|
|
# 应用 Ingress 规则
|
|
|
kubectl apply -f deploy/k8s/gateway.yaml
|
|
|
```
|
|
|
|
|
|
部署完成后,您可以通过 Ingress Controller 的外部 IP 地址来访问您的博客。执行以下命令获取地址:
|
|
|
|
|
|
```bash
|
|
|
kubectl get ingress -n djangoblog
|
|
|
```
|
|
|
|
|
|
### 步骤 6: 首次运行的初始化操作
|
|
|
|
|
|
与 Docker 部署类似,首次运行时,您需要进入 DjangoBlog 应用的 Pod 来执行数据库初始化和创建管理员账户。
|
|
|
|
|
|
```bash
|
|
|
# 首先,获取 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 的部署! |