Docker容器部署方法

1. 基础部署流程

准备 Dockerfile

复制代码
FROM node:18-alpine
WORKDIR /app
COPY package*.json ./
RUN npm install
COPY . .
EXPOSE 3000
CMD ["npm", "start"]

构建和运行容器

复制代码
# 构建镜像
docker build -t my-app .

# 运行容器
docker run -d -p 3000:3000 --name my-app-container my-app

# 查看运行中的容器
docker ps

# 查看日志
docker logs my-app-container

2. 使用 Docker Compose(推荐)

创建 docker-compose.yml

复制代码
version: '3.8'
services:
  web:
    build: .
    ports:
      - "3000:3000"
    environment:
      - NODE_ENV=production
    depends_on:
      - db
    
  db:
    image: postgres:13
    environment:
      POSTGRES_DB: myapp
      POSTGRES_USER: user
      POSTGRES_PASSWORD: password
    volumes:
      - db_data:/var/lib/postgresql/data

volumes:
  db_data:

运行命令:

复制代码
# 启动服务
docker-compose up -d

# 停止服务
docker-compose down

3. 生产环境部署最佳实践

多阶段构建

复制代码
# 构建阶段
FROM node:18-alpine AS builder
WORKDIR /app
COPY package*.json ./
RUN npm ci --only=production

# 运行阶段
FROM node:18-alpine
RUN addgroup -g 1001 -S nodejs
RUN adduser -S nextjs -u 1001
WORKDIR /app
COPY --from=builder --chown=nextjs:nodejs /app/node_modules ./node_modules
COPY --chown=nextjs:nodejs . .
USER nextjs
EXPOSE 3000
CMD ["npm", "start"]

使用 .dockerignore

复制代码
node_modules
npm-debug.log
.git
.env
Dockerfile
README.md

4. 容器编排部署

使用 Docker Swarm

复制代码
# 初始化 Swarm
docker swarm init

# 部署堆栈
docker stack deploy -c docker-compose.yml myapp

使用 Kubernetes

创建 deployment.yaml

复制代码
apiVersion: apps/v1
kind: Deployment
metadata:
  name: my-app
spec:
  replicas: 3
  selector:
    matchLabels:
      app: my-app
  template:
    metadata:
      labels:
        app: my-app
    spec:
      containers:
      - name: my-app
        image: my-app:latest
        ports:
        - containerPort: 3000
---
apiVersion: v1
kind: Service
metadata:
  name: my-app-service
spec:
  selector:
    app: my-app
  ports:
  - port: 80
    targetPort: 3000
  type: LoadBalancer

5. 环境特定配置

使用环境变量

复制代码
# 通过环境变量配置
docker run -d \
  -e DATABASE_URL=postgresql://user:pass@db:5432/myapp \
  -e REDIS_URL=redis://redis:6379 \
  my-app

配置文件挂载

复制代码
# 挂载配置文件
docker run -d \
  -v $(pwd)/config:/app/config \
  -p 3000:3000 \
  my-app

6. 监控和日志

复制代码
# 查看容器资源使用
docker stats

# 查看详细日志
docker logs -f my-app-container

# 进入容器调试
docker exec -it my-app-container sh

7. 持续集成/持续部署

GitHub Actions 示例

复制代码
name: Build and Deploy
jobs:
  build:
    runs-on: ubuntu-latest
    steps:
    - uses: actions/checkout@v2
    - name: Build Docker image
      run: docker build -t my-app .
    - name: Deploy to server
      run: |
        docker-compose pull
        docker-compose up -d

部署检查清单

  • Dockerfile 优化(多阶段构建、最小基础镜像)
  • 安全扫描镜像漏洞
  • 配置正确的资源限制
  • 设置日志轮转策略
  • 配置健康检查
  • 备份和恢复策略
  • 监控和告警设置
相关推荐
minhuan3 小时前
构建AI智能体:七十五、用扣子平台创建工作流:从自动化到智能化的进阶之路
运维·自动化·工作流构建·意图识别工作流
老实巴交的麻匪3 小时前
(八)学习、实践、理解 CI/CD 与 DevOps:持续集成 CI,从源代码到容器镜像
运维·云原生·自动化运维
ink@re4 小时前
Linux iptables:四表五链 + 实用配置
linux·运维·服务器
努力努力再努力wz4 小时前
【Linux进阶系列】:信号(下)
java·linux·运维·服务器·开发语言·数据结构·c++
☆璇5 小时前
【Linux】传输层协议UDP
linux·运维·udp
做运维的阿瑞5 小时前
Kubernetes网络通信与Pod基础详解:从架构图看K8s核心组件
云原生·容器·kubernetes
终焉代码5 小时前
【Linux】进程初阶(1)——基本进程理解
linux·运维·服务器·c++·学习·1024程序员节
Dreamboat-L6 小时前
从零开始在云服务器上部署Gitlab
运维·服务器·gitlab
wanhengidc9 小时前
云手机在网络游戏中的主要功能
运维·服务器·游戏·智能手机