k8s 部署java应用 基于ingress+jar包
k8 集群ingress的访问模式
先部署一个namespace 命名空间
vim namespace.yaml
kind: Namespace
apiVersion: v1
metadata:
name: ingress-test
labels:
env: ingress-test
在部署deployment deployment是pod层一层封装。可以实现多节点部署 资源分配 回滚部署等方式。
部署的时候需要系统上面有名字为 devops-api 的镜像 这个是jar包打成的镜像
vim devopsApi-Deployment.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: devops-api
namespace: ingress-test
labels:
app: devops-api
spec:
replicas: 1
template:
metadata:
name: devops-api
labels:
app: devops-api
spec:
containers:
- name: devops-api
image: devops-api:latest
imagePullPolicy: IfNotPresent
ports:
- containerPort: 8000
restartPolicy: Always
selector:
matchLabels:
app: devops-api
部署Service层 Service 绑定外部IP 是可以提供外部访问的
IP:端口 的方式可以访问
vim devops-svc.yaml
apiVersion: v1
kind: Service
metadata:
name: devops-svc
namespace: ingress-test
labels:
app: devops-svc
spec:
selector:
app: devops-api
ports:
- name: http
port: 8000
targetPort: 8000
protocol: TCP
externalIPs:
- 192.168.217.129
Ingress
ingress 定义路由规则, 基于http第七层应用层访问 URL的方式访问 比如 ingress 定义一个/demo的规则 则这个规则下必须有对应的服务或接口数据。。没有则报404错误
vim devopsApi-igrs.yaml
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
namespace: ingress-test
name: devops-api
spec:
ingressClassName: nginx
rules:
- host: k1.devops.com
http:
paths:
- path: /demo #修改之后可以重新部署 /api/hello/admin
pathType: Prefix
backend:
service:
name: devops-api
port:
number: 8000
在普通模式下 http://localhost:8000/demo 假设这个接口 url在后端服务必须有返回数据
很容易在这个地方犯迷糊。。
kubeclt apply -f devopsApi-igrs.yaml
修改配置之后
kubeclt replace -f devopsApi-igrs.yaml