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 优化(多阶段构建、最小基础镜像)
  • 安全扫描镜像漏洞
  • 配置正确的资源限制
  • 设置日志轮转策略
  • 配置健康检查
  • 备份和恢复策略
  • 监控和告警设置
相关推荐
怜淇1 天前
docker拉取openjdk8:jre失败
java·docker·容器
@22061 天前
银河麒麟系统离线环境下用docke方式部署(Postgres、Nginx、Redis、JDK)
运维·数据库·redis·nginx
小蜗的房子1 天前
Oracle 19C RAC Public IP单网卡改为bond模式操作指南
运维·网络·数据库·sql·tcp/ip·oracle·oracle rac
sun0077001 天前
androd和qnx判断实网卡还是虚网卡
运维·服务器·网络
口嗨农民工1 天前
live555 sample基本解读
运维·服务器
海盗12341 天前
VMware 中 CentOS 7 无法使用 yum 安装 wget 的完整解决方案
linux·运维·centos
kida_yuan1 天前
【Linux】在树莓派上搭建自建 Git 服务(基于 GitLab)- 实战笔记与运维清单
运维·gitlab·树莓派
lph0091 天前
mqtt broker (mosquitto)创建服务器、订阅与发布
运维·服务器
by————组态1 天前
睿控(Ricon)组态
运维·前端·物联网·信息可视化·组态·组态软件