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

相关推荐
光军oi1 小时前
全栈开发杂谈————关于websocket若干问题的大讨论
java·websocket·apache
weixin_419658311 小时前
Spring 的统一功能
java·后端·spring
小许学java2 小时前
Spring AI-流式编程
java·后端·spring·sse·spring ai
haogexiaole2 小时前
Java高并发常见架构、处理方式、api调优
java·开发语言·架构
EnCi Zheng3 小时前
@ResponseStatus 注解详解
java·spring boot·后端
wdfk_prog3 小时前
闹钟定时器(Alarm Timer)初始化:构建可挂起的定时器基础框架
java·linux·数据库
怎么没有名字注册了啊3 小时前
C++后台进程
java·c++·算法
z日火3 小时前
Java 泛型
java·开发语言
简色4 小时前
题库批量(文件)导入的全链路优化实践
java·数据库·mysql·mybatis·java-rabbitmq
程序员飞哥4 小时前
如何设计多级缓存架构并解决一致性问题?
java·后端·面试