在Windows上通过Docker Desktop启用Kubernetes并安装kubectl,构建本地集群;2. 使用Spring Boot创建Java应用,编写Dockerfile并构建镜像;3. 通过deployment.yaml和service.yaml部署应用,暴露NodePort 30080,浏览器访问localhost:30080验证服务运行。

在Windows系统下搭建Kubernetes环境用于Java云原生开发,是现代后端开发的重要技能。虽然Kubernetes原生运行在Linux上,但借助Docker Desktop和Minikube等工具,可以在Windows上快速构建本地测试环境。下面是一个实用、清晰的配置教程,帮助你从零开始部署并运行Java应用。
安装必要工具
要运行Kubernetes,需先准备以下核心组件:
- Docker Desktop for Windows:提供容器运行时支持,并内置Kubernetes集群功能。
- Minikube(可选):轻量级Kubernetes本地集群工具,适合学习和测试。
- kubectl:Kubernetes命令行工具,用于管理集群。
- Java JDK 17+ 和 Maven:用于构建Java云原生应用。
- IDE(如IntelliJ IDEA或VS Code):编写和调试代码。
下载地址:
- Docker Desktop: https://www.php.cn/link/2997607ae9ee935528ee27423a5b6e30
- Minikube: https://www.php.cn/link/42cf125df2e054b2a12810263cda40b0
- kubectl: 可通过Chocolatey安装:choco install kubernetes-cli,或从官网下载二进制文件。
启用Docker Desktop中的Kubernetes
Docker Desktop集成了Kubernetes支持,启用后即可一键启动本地集群。
立即学习“Java免费学习笔记(深入)”;
- 安装并启动Docker Desktop。
- 右键任务栏Docker图标 → Settings → Kubernetes。
- 勾选“Enable Kubernetes”,点击“Apply & Restart”。
- 等待几分钟,直到状态显示“Kubernetes is running”。
- 打开终端执行 kubectl cluster-info,确认连接成功。
此时你已拥有一个单节点Kubernetes集群,kubectl config current-context 应返回 docker-desktop 或 docker-for-desktop。
编写并打包Java云原生应用
以Spring Boot为例,创建一个简单的REST服务:
- 使用Spring Initializr生成项目,包含Web依赖。
- 编写一个简单接口,例如返回 "Hello from Kubernetes"。
- 在项目根目录创建 Dockerfile:
FROM openjdk:17-jdk-slim COPY target/myapp.jar /app.jar EXPOSE 8080 ENTRYPOINT ["java", "-jar", "/app.jar"]
- 使用Maven打包:mvn clean package。
- 构建镜像:docker build -t my-java-app:latest .
- 验证镜像:docker images | grep my-java-app
部署Java应用到Kubernetes
创建Kubernetes资源配置文件来部署你的Java服务。
- 创建 deployment.yaml:
apiVersion: apps/v1
kind: Deployment
metadata:
name: java-app
spec:
replicas: 2
selector:
matchLabels:
app: java-app
template:
metadata:
labels:
app: java-app
spec:
containers:
- name: java-app
image: my-java-app:latest
ports:
- containerPort: 8080
- 创建 service.yaml 实现外部访问:
apiVersion: v1
kind: Service
metadata:
name: java-app-service
spec:
type: NodePort
selector:
app: java-app
ports:
- protocol: TCP
port: 8080
targetPort: 8080
nodePort: 30080
- 应用配置:
kubectl apply -f service.yaml
- 查看Pod状态:kubectl get pods,确保两个Pod处于Running状态。
- 访问服务:浏览器打开 http://localhost:30080 即可看到Java应用响应。
基本上就这些。整个流程涵盖了环境准备、应用构建、容器化和Kubernetes部署,适合本地开发和测试。对于生产环境,建议使用远程集群(如EKS、AKS或阿里云ACK),但在学习阶段,Windows + Docker Desktop方案足够高效。










