k8s服务StatefulSet部署模板

java 服务StatefulSet部署模板

复制代码
vim templates-test.yaml

apiVersion: apps/v1
kind: StatefulSet
metadata:
  labels:
    app: ${app_labels}
  name: ${app_name}
  namespace: ${app_namespace}
spec:
  replicas: ${app_replicas_count}
  selector:
    matchLabels:
      app: ${app_labels}
  template:
      labels:
        app: ${app_labels}
    spec:
      containers:
        - env:
            - name: JAVA_OPTS
              value: ${java_opts}
          image: ${app_docker_image}
          imagePullPolicy: Always
          livenessProbe:
            failureThreshold: 5
            httpGet:
              path: /actuator/health
              port: ${app_port}
              scheme: HTTP
            initialDelaySeconds: 120
            periodSeconds: 10
            successThreshold: 1
            timeoutSeconds: 5
          name: ${app_name}
          ports:
            - containerPort: ${app_port}
              name: http
              protocol: TCP
          readinessProbe:
            failureThreshold: 5
            httpGet:
              path: /actuator/health
              port: ${app_port}
              scheme: HTTP
            initialDelaySeconds: 120
            periodSeconds: 60
            successThreshold: 1
            timeoutSeconds: 5
          resources:
            limits:
              cpu: ${app_cpu_limit}
              memory: {app_memory_limit}
          terminationMessagePath: /dev/termination-log
          terminationMessagePolicy: File
      dnsPolicy: ClusterFirst
      imagePullSecrets:
        - name: harbor
      restartPolicy: Always
      schedulerName: default-scheduler
      securityContext: {}
      terminationGracePeriodSeconds: 30
  updateStrategy:
    rollingUpdate:
      partition: 0
    type: RollingUpdate
---
apiVersion: v1
kind: Service
metadata:
  labels:
    app: ${app_labels}
  name: ${app_service_name}
  namespace: ${app_namespace}
spec:
  clusterIP: None
  ports:
    - name: ${app_service_name}
      port: ${app_port}
      protocol: TCP
      targetPort: ${app_port}
  selector:
    app: ${app_labels}
  sessionAffinity: None
  type: ClusterIP
status:
  loadBalancer: {}

涉及到的变量

复制代码
 ${app_labels}
 ${app_name}
 ${app_namespace}
 ${app_replicas_count}
 ${java_opts}
 ${app_docker_image}
 ${app_port}
 ${app_cpu_limit}
 {app_memory_limit}
${app_service_name}

测试示例

设置环境变量

复制代码
export app_labels=test-lable
export app_name=test-name
export app_namespace=test-ns
export app_replicas_count=1
export java_opts="-xms=100mi -xms=100mi -xms=100mi"
export app_docker_image=docker.io/library/openjdk:8-jdk-alpine
export app_port=10000
export app_cpu_limit=1
export app_memory_limit=1000mi
export app_service_name=test-svc-name

执行替换

复制代码
  envsubst \'\${app_name},\${app_namespace},\${app_labels},\${app_replicas_count},\${java_opts}\,\${app_docker_image}\,\${app_port}\,\${app_cpu_limit}\,\${app_memory_limit}\,\${app_service_name}\' < /root/test/templates-test.yaml > /root/test/templates-new.yaml

查看新文件 templates-new.yaml

相关推荐
wjy6_12 分钟前
Rocky Linux 9.5 基于kubeadm部署k8s
linux·运维·kubernetes
杰克逊的日记25 分钟前
SkyWalking的工作原理和搭建过程
云原生·监控·skywalking
意倾城1 小时前
Docker常见命令解读
docker·容器
我没有开挂7 小时前
旧 docker 版本通过 nvkind 搭建虚拟多节点 gpu 集群的坑
运维·docker·容器
小鸡,啄米7 小时前
centos9安装docker 配置docker代理
运维·docker·容器
oceanweave8 小时前
【K8S学习之生命周期钩子】详细了解 postStart 和 preStop 生命周期钩子
学习·kubernetes
小锋学长生活大爆炸14 小时前
【教程】Docker更换存储位置
运维·docker·容器
gnufre15 小时前
Kubernetes 1.28 无 Docker 运行时环境下的容器化构建实践:Kaniko + Jenkins 全链路详解
kubernetes·jenkins·kaniko
Akamai中国17 小时前
分布式AI推理的成功之道
人工智能·分布式·云原生·云计算·云服务·云平台·云主机
川石教育18 小时前
测试工程师如何学会Kubernetes(k8s)容器知识
云原生·容器·kubernetes·kubernetes容器·kubernetes教程