【k8s】k8s的yaml文件解释,如何部署一个java.jar包

前言:

k8s的yaml文件解释,如何部署一个java,jar包
YAML语法格式:

  • 大小写敏感;
  • 使用缩进表示层级关系;不支持Tab键制表符缩进,只使用空格缩进;
  • 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可,通常开头缩进两个空格;
  • 字符后缩进一个空格,如冒号,逗号,短横杆(-) 等
  • “—” 表示YAML格式,一个文件的开始,用于分隔文件; 可以将创建多个资源写在同一个 yaml 文件中,用 —
    隔开,就不用写多个 yaml 文件了。
  • "#” 表示注释;

在这里插入图片描述


一、具体的yaml

1.常用字段说明

apiVersion          #API版本
kind                #资源类型
metadata            #资源元数据
spec                #资源规格
replicas            #副本数量
selector            #标签选择器
template            #pod模板
metadata            #pod元数据
sepc                #pod规格
containers          #容器配置

2.详细的yaml文件

apiVersion: apps/v1
kind: Deployment
metadata:
  name: java
  namespace: sjbz
spec:
  selector:
    matchLabels:
      app: java
  replicas: 1
  template:
    metadata:
      labels:
        app: java
    spec:
      nodeSelector:
          name: "node-2"
      containers:
      - name: java
        image: user-center:sjbz
        env:
        - name: TZ
          value: Asia/Shanghai
        imagePullPolicy: Never
        ports:
        - containerPort: 8080
---
apiVersion: v1
kind: Service
metadata:
  name: java
  namespace: sjbz
spec:
  selector:
    app: java
  ports:
  - protocol: TCP
    port: 8080
    targetPort: 8080
    nodePort: 3314
  type: NodePort

二、具体解释

2.Deployment解释:

apiVersion: apps/v1         #指定使用的Kubernetes API版本,用于Deployment
kind: Deployment            #定义资源类型为Deployment
metadata:                  #元数据部分,包含Deployment的名称和所属命名空间
 name: java                 #定义Pod名称,在同一个namespace空间中必须是唯一的
 namespace: sjbz            #Pod所属的命名空间
spec:                      #规定Deployment的规范
  selector:                #选择器用于标识此Deployment控制的Pod
   matchLabels:            #匹配标签的条件,此处为app: java
    app: java               #匹配上面的标签
replicas: 1:               #指定要创建的Pod副本数
template:                  #定义创建Pod的模板
 metadata:                 #模板的元数据
  labels:                  #Pod的标签,此处为app: java
   app: java                #匹配上面的标签,需与上面的标签定义的app保持一致
 spec:                     #定义Pod的规范
  nodeSelector:            #Node选择器,使用标签来选择具体的Node
    name: "node-2"          #选择具有name: "node-2"标签的Node作为Pod的调度目标
  containers:              #容器列表
 - name: java               #容器的名称
   image: user-center:sjbz  #使用的镜像
   env:                    #环境变量列表
  - name: TZ                #环境变量的名称
    value: Asia/Shanghai    #环境变量的值,设置时区为亚洲/上海
   imagePullPolicy: Never   #指定不从远程仓库拉取镜像,而是使用本地已有镜像
   ports:                  #容器暴露的端口列表
  - containerPort: 8080     #容器监听的端口号

2.Service的部分解释:

apiVersion: v1            #必选,指定使用的Kubernetes API版本,用于Service
kind: Service             #必选,定义资源类型为Service
metadata:                #必选,元数据部分,包含Service的名称和所属命名空间
 name: java
 namespace: sjbz
spec:                     #规定Service的规范
 selector:                #选择器用于标识此Service关联的Pod
  app: java:              #匹配标签的条件,与Deployment中的标签匹配
ports:                    #定义Service暴露的端口
- protocol:                #TCP:端口协议为TCP
  port: 8080               #Service监听的端口号
  targetPort: 8080         #指定转发请求到Pod的哪个端口
  nodePort: 3314           #如果Service的类型为NodePort,则会将请求转发到节点上的该端口
type: NodePort             #Service的类型为NodePort,允许通过节点的IP和指定的端口访问Service

总结

这个配置文件实现了在命名空间sjbz中创建一个名为java的Deployment和Service。Deployment使用标签选择器控制一个副本具有app: java的Pod,并在具有`name: "node-2

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Kubernetes (k8s) 是一个开源容器编排平台,而 Spring Cloud 是一组用于构建分布式系统的服务网格和微服务架构工具。将 Spring Cloud 应用部署Kubernetes 上通常包括以下几个步骤: 1. **创建 Docker 映像**: 首先,你需要有一个打包好的 Spring Boot 应用程序,并将其打包为 Docker 映像。这通常包含应用代码、依赖和运行环境。 2. **配置 Dockerfile**: 在 Dockerfile 中指定基础镜像、依赖、启动命令以及暴露的端口等信息。例如: ```Dockerfile FROM openjdk:8-jdk-alpine VOLUME /tmp COPY target/my-app.jar app.jar EXPOSE 8080 ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"] ``` 3. **编写 Kubernetes 配置文件**: 使用 YAML 或者 JSON 格式(如 deployment.yaml)定义应用程序的部署描述符,包括副本数、服务选择、资源请求/限制等。 ```yaml apiVersion: apps/v1 kind: Deployment metadata: name: my-spring-cloud-app spec: replicas: 3 selector: matchLabels: app: my-spring-cloud-app template: metadata: labels: app: my-spring-cloud-app spec: containers: - name: my-app image: your-docker-image-name:latest ports: - containerPort: 8080 ``` 4. **应用到 k8s 集群**: 将配置文件上传到集群,然后使用 `kubectl apply` 命令部署Kubernetes,例如: ``` kubectl apply -f deployment.yaml ``` 5. **配置负载均衡和服务发现**: 可以使用 Spring Cloud Netflix 家族的 Eureka 或 Hystrix 进行服务注册与发现,或使用 Istio 等服务网格解决方案。在 k8s 中,可以选择基于 ClusterIP 的 Service 或者 ingress controller 来提供外部访问。 6. **监控和日志管理**: 设置日志收集和监控策略,比如 Prometheus 和 Grafana 对于 metrics,还有日志服务如 Elasticsearch + Kibana。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

搞什么滚去学习

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值