在k8s集群部署(Java)项目
一、容器交付流程开发代码 - 持续交付/集成 - 应用部署 - 运维二、k8s部署Java项目流程制作镜像 - 推送到镜像仓库 - 控制器部署镜像 - 对外暴露应用 - 运维1、准备java项目,把java进行打包(jar包或者war包)(1)需要使用两个依赖环境java环境 - jdkmaven环境(2)把java项目(springboot)打成war包重要事情 :编写dockerfile//d
·
一、容器交付流程
开发代码 - 持续交付/集成 - 应用部署 - 运维
二、k8s部署Java项目流程
制作镜像 - 推送到镜像仓库 - 控制器部署镜像 - 对外暴露应用 - 运维
1、准备java项目,把java进行打包(jar包或者war包)
(1)需要使用两个依赖环境
- java环境 - jdk
- maven环境
(2)把java项目(springboot)打成war包
重要事情 :编写dockerfile
//dockerfile
FROM openjdk:8-jdk-alpine
VOLUME /tmp
ADD ./target/demojenkins.jar demojenkins.jar
ENTRYPOINT ["java","-jar","/demojenkins.jar", "&"]
# 通过maven打包
//在项目中打开cmd.exe
mvn clean package
//打包完成会在项目下边生成一个jar包
2、制作镜像
# 制作镜像
docker build -t Java-demo-01:latest .
# 查看镜像
docker image
# 测试:本地启动制作好的镜像是否可以正常访问
//启动镜像
docker run -d -p 8111:8111 Java-demo-01:latest -t
//查看8118端口占用的进程
netstat -tunlp | grep 8111
//查看进程
ps -ef | grep demo
//通过浏览器访问
3、上传镜像到镜像服务器(阿里云)
阿里云 - 容器镜像服务控制台 - 申请 - 创建命名空间 - 创建镜像仓库 - 使用推送命令推送
# 登录镜像服务器
# 为镜像添加版本号
# 推送镜像到服务器
4、部署镜像,对外暴露应用
# 创建deployment类型的pod的yaml文件
kubectl create deployment javademo1 --image=Java项目镜像地址(在阿里云服务器找):镜像版本 --dry-run -o yaml > javademo1.yaml
# 执行yaml文件
kubectl apply -f javademo1.yaml
# 查看创建成功的pod
kubectl get pods -o wide
# 扩容副本
kubectl scale deployment Javademo1 --replicas=3
# 对外暴露端口(两种方式:service、ingress)
//service方式
kubectl expose deployment javademo1 --port=8111 --target-port=8111 --type=NodePort
# 查看对外暴露的应用
kubectl get svc
更多推荐
已为社区贡献6条内容
所有评论(0)