目录

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

本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
RedCong18 分钟前
k8s之Service类型详解
云原生·容器·kubernetes
许墨の小蝴蝶25 分钟前
k8s创建一个pod,查看状态和详细信息,进入pod,以及删除这个pod
kubernetes
孔令飞1 小时前
22 | 如何继续提升 Go 开发技术?
人工智能·ai·云原生·golang·kubernetes
spongeB2 小时前
使用docker 创建MongoDB副本集配置完整指南
mongodb·docker·容器
程序员Linc2 小时前
RK3588芯片NPU的使用:Windows11 Docker中运行MobileNet模型以及部署到开发板进行目标检测
目标检测·docker·容器·rk3588·rknn-toolkit2·mobilenet
阿里云大数据AI技术3 小时前
用友畅捷通基于阿里云 MaxCompute 搭建智能数仓的落地实践
大数据·云原生·数据分析
三次握手四次挥手3 小时前
Docker全方位指南
运维·docker·容器
在下千玦3 小时前
#在docker中启动mysql之类的容器时,没有挂载的数据...在后期怎么把数据导出外部
mysql·docker·容器
诡异森林。7 小时前
Docker--Docker镜像制作的注意事项
运维·docker·容器
小诸葛的博客7 小时前
bookie重启后报错
kubernetes