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

相关推荐
Karoku066几秒前
【docker集群应用】Docker网络与资源控制
运维·数据库·docker·容器
夏子曦5 分钟前
java虚拟机——频繁发生Full GC的原因有哪些?如何避免发生Full GC
java·开发语言
gogo_hua6 分钟前
JVM系列之OOM观测准备
java·大数据·jvm
Jacket Li17 分钟前
Kubeadm 安装 Kubernetes 高可用集群 v1.30.0
云原生·容器·kubernetes
m0_6754470818 分钟前
Solon 拉取 maven 包很慢或拉不了,怎么办?
java·maven
武昌库里写JAVA22 分钟前
SpringCloud+SpringCloudAlibaba学习笔记
java·开发语言·算法·spring·log4j
爱编程的小生23 分钟前
SpringBoot Task
java·spring boot·后端
CoderJia程序员甲30 分钟前
重学SpringBoot3-异步编程完全指南
java·spring boot·后端·异步编程
小咖拉眯33 分钟前
第十六届蓝桥杯模拟赛第二期题解—Java
java·数据结构·算法·蓝桥杯·图搜索算法
扬子鳄00834 分钟前
Spring Boot自动配置机制
java·数据库·spring boot