171 lines
3.2 KiB
Markdown
171 lines
3.2 KiB
Markdown
|
|
# Nginx 配置说明
|
|||
|
|
|
|||
|
|
## 配置文件
|
|||
|
|
|
|||
|
|
- `nginx.conf` - 主配置文件
|
|||
|
|
|
|||
|
|
## 功能特性
|
|||
|
|
|
|||
|
|
1. **前端静态文件服务** - 服务 React 构建后的静态文件
|
|||
|
|
2. **API 代理** - 将 `/api` 请求代理到后端服务器 (localhost:3001)
|
|||
|
|
3. **SPA 路由支持** - 支持 React Router 的客户端路由
|
|||
|
|
4. **静态资源缓存** - 优化静态资源加载性能
|
|||
|
|
5. **健康检查** - `/health` 端点用于健康检查
|
|||
|
|
|
|||
|
|
## 部署步骤
|
|||
|
|
|
|||
|
|
### 1. 构建前端
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
cd frontend
|
|||
|
|
npm run build
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
构建输出在 `frontend/dist/` 目录
|
|||
|
|
|
|||
|
|
### 2. 配置 Nginx
|
|||
|
|
|
|||
|
|
编辑 `nginx.conf` 文件,修改以下配置:
|
|||
|
|
|
|||
|
|
- `server_name`: 改为您的域名
|
|||
|
|
- `root`: 改为前端构建文件的绝对路径
|
|||
|
|
- `upstream backend`: 确保后端服务器地址正确
|
|||
|
|
|
|||
|
|
### 3. 安装配置文件
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
# 复制配置文件到 nginx 配置目录
|
|||
|
|
sudo cp nginx/nginx.conf /etc/nginx/sites-available/ai-learning-platform
|
|||
|
|
|
|||
|
|
# 创建符号链接
|
|||
|
|
sudo ln -s /etc/nginx/sites-available/ai-learning-platform /etc/nginx/sites-enabled/
|
|||
|
|
|
|||
|
|
# 测试配置
|
|||
|
|
sudo nginx -t
|
|||
|
|
|
|||
|
|
# 重新加载 nginx
|
|||
|
|
sudo systemctl reload nginx
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 4. 启动后端服务
|
|||
|
|
|
|||
|
|
确保后端服务在 3001 端口运行:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
cd backend
|
|||
|
|
npm run build
|
|||
|
|
npm start
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
或者使用 PM2 管理:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
pm2 start backend/dist/index.js --name ai-learning-backend
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## 配置说明
|
|||
|
|
|
|||
|
|
### 前端路径
|
|||
|
|
|
|||
|
|
默认配置假设前端构建文件在:
|
|||
|
|
```
|
|||
|
|
/var/www/ai-learning-platform/frontend/dist
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
请根据实际部署路径修改 `root` 指令。
|
|||
|
|
|
|||
|
|
### 后端代理
|
|||
|
|
|
|||
|
|
API 请求会被代理到:
|
|||
|
|
```
|
|||
|
|
http://localhost:3001
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
如果需要修改,编辑 `upstream backend` 部分。
|
|||
|
|
|
|||
|
|
### 静态资源缓存
|
|||
|
|
|
|||
|
|
静态资源(JS、CSS、图片等)会缓存 1 年,提高性能。
|
|||
|
|
|
|||
|
|
### SPA 路由支持
|
|||
|
|
|
|||
|
|
`try_files $uri $uri/ /index.html;` 确保所有路由都返回 `index.html`,支持 React Router。
|
|||
|
|
|
|||
|
|
## HTTPS 配置(可选)
|
|||
|
|
|
|||
|
|
如果需要 HTTPS,取消注释配置文件中的 HTTPS 部分,并:
|
|||
|
|
|
|||
|
|
1. 获取 SSL 证书(Let's Encrypt 免费证书)
|
|||
|
|
2. 修改证书路径
|
|||
|
|
3. 重新加载 nginx
|
|||
|
|
|
|||
|
|
### 使用 Let's Encrypt
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
# 安装 certbot
|
|||
|
|
sudo apt-get install certbot python3-certbot-nginx
|
|||
|
|
|
|||
|
|
# 获取证书
|
|||
|
|
sudo certbot --nginx -d yourdomain.com
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## 性能优化
|
|||
|
|
|
|||
|
|
### Gzip 压缩
|
|||
|
|
|
|||
|
|
在 nginx 主配置文件中添加:
|
|||
|
|
|
|||
|
|
```nginx
|
|||
|
|
gzip on;
|
|||
|
|
gzip_vary on;
|
|||
|
|
gzip_min_length 1024;
|
|||
|
|
gzip_types text/plain text/css text/xml text/javascript application/x-javascript application/xml+rss application/json;
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 缓存优化
|
|||
|
|
|
|||
|
|
静态资源已配置长期缓存,生产环境建议使用 CDN。
|
|||
|
|
|
|||
|
|
## 监控和日志
|
|||
|
|
|
|||
|
|
- 访问日志:`/var/log/nginx/ai-learning-access.log`
|
|||
|
|
- 错误日志:`/var/log/nginx/ai-learning-error.log`
|
|||
|
|
|
|||
|
|
## 故障排查
|
|||
|
|
|
|||
|
|
### 检查 nginx 状态
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
sudo systemctl status nginx
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 查看错误日志
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
sudo tail -f /var/log/nginx/ai-learning-error.log
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 测试配置
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
sudo nginx -t
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 重新加载配置
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
sudo systemctl reload nginx
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## Docker 部署(可选)
|
|||
|
|
|
|||
|
|
如果使用 Docker,可以创建 `Dockerfile.nginx`:
|
|||
|
|
|
|||
|
|
```dockerfile
|
|||
|
|
FROM nginx:alpine
|
|||
|
|
COPY nginx/nginx.conf /etc/nginx/conf.d/default.conf
|
|||
|
|
COPY frontend/dist /usr/share/nginx/html
|
|||
|
|
EXPOSE 80
|
|||
|
|
CMD ["nginx", "-g", "daemon off;"]
|
|||
|
|
```
|