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

相关推荐
test猿4 分钟前
hive为什么建表,表存储什么
java
喝醉酒的小白40 分钟前
几种K8s运维管理平台对比说明
运维·容器·kubernetes
程序猿零零漆1 小时前
SpringCloud系列教程:微服务的未来(二十)Seata快速入门、部署TC服务、微服务集成Seata
java·spring·spring cloud·微服务
明 庭1 小时前
通过 Docker 部署 pSQL 服务器的教程
服务器·docker·容器
我的K84092 小时前
Spring Boot基本项目结构
java·spring boot·后端
码农小苏242 小时前
K个不同子数组的数目--滑动窗口--字节--亚马逊
java·数据结构·算法
CodeClimb3 小时前
【华为OD-E卷 - 最大矩阵和 100分(python、java、c++、js、c)】
java·c++·python·华为od·矩阵
独自破碎E3 小时前
【4】阿里面试题整理
java·开发语言·算法·排序算法·动态规划
customer0810 小时前
【开源免费】基于SpringBoot+Vue.JS体育馆管理系统(JAVA毕业设计)
java·vue.js·spring boot·后端·开源
Miketutu11 小时前
Spring MVC消息转换器
java·spring