在k8s集群部署(Java)项目

一、容器交付流程

开发代码 - 持续交付/集成 - 应用部署 - 运维

二、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
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值