摘要:容器化部署已成为企业级微服务架构的主流部署方式,Docker负责容器打包与运行,Kubernetes(K8s)负责容器编排与运维,两者结合实现微服务的高效部署、弹性伸缩、故障自愈,大幅提升运维效率。本文基于Docker 26.0、K8s 1.30,详细讲解Docker镜像构建、容器管理、K8s核心组件(Pod、Deployment、Service、Ingress)、微服务部署流程、运维监控、故障排查等核心知识点,结合实战场景(Spring Boot微服务容器化部署),附完整配置文件与命令案例,帮助后端开发者、运维工程师快速掌握容器化部署与微服务运维技巧,提升系统的稳定性与可扩展性,适合Docker、K8s入门与进阶学习。
一、前言:Docker+K8s的核心价值与应用场景
在微服务架构中,传统部署方式(虚拟机部署)存在环境不一致、部署效率低、资源利用率低、扩展困难等问题,而Docker+K8s的容器化部署方式完美解决了这些痛点。
Docker作为容器化技术的核心,将应用及其依赖打包成容器,实现"一次构建,到处运行",保证开发、测试、生产环境的一致性;K8s作为容器编排工具,负责容器的调度、伸缩、负载均衡、故障自愈,实现微服务的自动化运维。本文聚焦Docker+K8s的实战运用,帮助开发者与运维工程师快速掌握容器化部署与运维技巧。
二、核心基础:Docker实战(镜像构建与容器管理)
2.1 Docker安装(CentOS 8)
bash
# 1. 卸载旧版本Docker(若有)
yum remove docker docker-client docker-client-latest docker-common docker-latest docker-latest-logrotate docker-logrotate docker-engine
# 2. 安装依赖
yum install -y yum-utils device-mapper-persistent-data lvm2
# 3. 设置Docker仓库(阿里云)
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
# 4. 安装Docker CE(社区版)
yum install -y docker-ce docker-ce-cli containerd.io
# 5. 启动Docker服务
systemctl start docker
systemctl enable docker # 设置开机自启
# 6. 验证Docker安装成功
docker --version # 查看Docker版本
docker run hello-world # 运行测试容器
2.2 Docker镜像构建与优化
Docker镜像是容器的模板,包含应用及其依赖,构建高效、轻量化的镜像是容器化部署的关键。本文以Spring Boot微服务为例,讲解镜像构建与优化技巧。
dockerfile
# 1. 基础版Dockerfile(Spring Boot微服务)
# 基础镜像(Java 17)
FROM openjdk:17-jdk-slim
# 工作目录
WORKDIR /app
# 复制jar包到容器
COPY target/spring-boot-demo-1.0.0.jar app.jar
# 暴露端口
EXPOSE 8080
# 启动命令
ENTRYPOINT ["java", "-jar", "app.jar"]
# 2. 优化版Dockerfile(分层构建+轻量化)
# 构建阶段(使用Maven镜像构建jar包)
FROM maven:3.8.8-openjdk-17 AS build
WORKDIR /app
# 复制pom.xml和源码
COPY pom.xml .
COPY src ./src
# 构建jar包(跳过测试)
RUN mvn clean package -DskipTests
# 运行阶段(使用轻量化基础镜像)
FROM openjdk:17-jre-slim
WORKDIR /app
# 从构建阶段复制jar包
COPY --from=build /app/target/spring-boot-demo-1.0.0.jar app.jar
# 暴露端口