栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

k3s启动java应用

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

k3s启动java应用

前言 pod
1.最小的部署单元,
2.一组容器的集合
3.一个pod中的容器共享网络命名空间
4.生命周期是短暂的
Controllers
1.Deployment:部署无状态应用
2.Statefulset:部署有状态应用
3.Replicaset:确保预期的Pod副本数量
4.Daemonset:	确保node运行同一个pod
5.Job:一次性任务
6.Cronjob:定时任务
更高级层次对象,部署和管理pod
Service
防止Pod失联,找到你需要Pod
定义一组Pod的负载均衡访问策略
Label
标签,附加到某个资源上,用于关联对象,查询和筛选
Namespaces
Namespaces:命名空间,将对象进行逻辑上隔离或者资源隔离
流程

制作项目镜像

制作docker镜像,可以用docker images查看到即可,我的dockerfile文件如下所示:

FROM openjdk:1.8
MAINTAINER wt
ADD follow-1.0.0-SNAPSHOT.jar follow.jar
#配置时区 
ENV TZ=Asia/Shanghai
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
EXPOSE 8080
ENTRYPOINT ["java","-jar","/follow.jar","--spring.profiles.active=${ACTIVE}"]

创建pod
create  deployment  follow  --image=follow --dry-run -o yaml > follow.yaml
kubectl apply -f  follow.yaml


这里要注意下,containerPort:8080 必须跟dockerfile中暴露的端口一致,不然访问不到

创建svc
kubectl expose deployment follow --port=80 --target-port=8080 --type=NodePort -o yaml --dry-run > svc.yaml
kubectl apply -f  svc.yaml

检查pod、svc是否创建成功
 kubectl  get pod,svc

通过 Ingress 访问集群内部容器服务

安装参考:k8s 部署 Nginx Ingress Controller
有几点需要注意下:
1、下载yaml文件,可以直接去ingress-nginx下载,有两个yaml文件都要下载下来,service-nodeport
.yaml在baremetal目录下,mandatory.yaml在static目录下

对service-nodeport.yaml稍微更改下:

kubectl apply -f  service-nodeport.yaml
kubectl -n ingress-nginx get all

出现下图所示,说明安装成功

2、service-nodeport.yaml如果不创建,启动nginx-controller是会报err services “ingress-nginx” not found

3、启动nginx-controller时,如果出现1 node(s) didn’t have free ports for the requested pod ports,说明端口被占用,可以适当修改端口,然后执行

kubectl replace --force -f mandatory.yaml

创建项目的ingress
kubectl apply -f  ingress-follow.yaml
kubectl get ingress

出现下图所示,说明ingress配置成功

host填你自己的项目域名即可,在浏览器上项目域名加你的首页即可访问成功

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/865893.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号