k8s安装powerjob

打印 上一主题 下一主题

主题 832|帖子 832|积分 2496

k8s安装powerjob
k8s安装powerjob

1、mysql
  1. mkdir -p ~/powerjob-yml
  2. kubectl create ns powerjob
复制代码
  1. cat > ~/powerjob-yml/powerjob-mysql.yml << 'EOF'
  2. apiVersion: v1
  3. kind: ConfigMap
  4. metadata:
  5.   name: powerjob-mysql-config
  6.   namespace: powerjob
  7. data:
  8.   my.cnf: |
  9.     [mysqld]
  10.     pid-file        = /var/run/mysqld/mysqld.pid
  11.     socket          = /var/run/mysqld/mysqld.sock
  12.     datadir         = /var/lib/mysql
  13.     secure-file-priv= NULL
  14.     # Custom config should go here
  15.     !includedir /etc/mysql/conf.d/
  16.     # 优化配置
  17.     # 设置最大连接数为 2500
  18.     max_connections = 2500
  19.     # 允许最多 100,000 个预处理语句同时存在(取值范围:0 - 1048576,默认16382)
  20.     max_prepared_stmt_count = 100000
  21.     # 设置字符集为 UTF-8
  22.     character-set-server=utf8mb4
  23.     collation-server=utf8mb4_general_ci
  24.     # 设置 InnoDB 引擎的缓冲区大小(InnoDB 缓冲池设置为内存的50%-75%)
  25.     innodb_buffer_pool_size=4G
  26.    
  27. ---
  28. apiVersion: apps/v1
  29. kind: StatefulSet
  30. metadata:
  31.   name: powerjob-mysql
  32.   namespace: powerjob
  33. spec:
  34.   serviceName: "powerjob-mysql-headless"
  35.   replicas: 1
  36.   selector:
  37.     matchLabels:
  38.       app: powerjob-mysql
  39.   template:
  40.     metadata:
  41.       labels:
  42.         app: powerjob-mysql
  43.     spec:
  44.       containers:
  45.       - name: powerjob-mysql
  46.         #image: mysql:8.0.28
  47.         image: ccr.ccs.tencentyun.com/huanghuanhui/mysql:8.0.28
  48.         imagePullPolicy: IfNotPresent
  49.         ports:
  50.         - name: powerjob-mysql
  51.           containerPort: 3306
  52.         env:
  53.         - name: MYSQL_ROOT_PASSWORD
  54.           value: "Powerjob@2024"
  55. #       resources:
  56. #         limits:
  57. #           cpu: 2
  58. #           memory: 4Gi
  59. #         requests:
  60. #           cpu: 2
  61. #           memory: 4Gi
  62.         livenessProbe:
  63.           exec:
  64.             command: ["mysqladmin", "ping", "-uroot", "-p${MYSQL_ROOT_PASSWORD}"]
  65.           initialDelaySeconds: 30
  66.           periodSeconds: 10
  67.           timeoutSeconds: 5
  68.         readinessProbe:
  69.           exec:
  70.             command: ["mysqladmin", "ping", "-uroot", "-p${MYSQL_ROOT_PASSWORD}"]
  71.           initialDelaySeconds: 5
  72.           periodSeconds: 2
  73.           timeoutSeconds: 1
  74.         volumeMounts:
  75.         - name: powerjob-mysql-data-pvc
  76.           mountPath: /var/lib/mysql
  77.         - name: powerjob-mysql-config
  78.           mountPath: /etc/mysql/my.cnf
  79.           subPath: my.cnf
  80.         - mountPath: /etc/localtime
  81.           name: localtime
  82.       volumes:
  83.       - name: powerjob-mysql-config
  84.         configMap:
  85.           name: powerjob-mysql-config
  86.       - name: localtime
  87.         hostPath:
  88.           path: /etc/localtime
  89.   volumeClaimTemplates:
  90.   - metadata:
  91.       name: powerjob-mysql-data-pvc
  92.     spec:
  93.       accessModes: ["ReadWriteOnce"]
  94.       storageClassName: cfs
  95.       resources:
  96.         requests:
  97.           storage: 100Gi
  98. ---
  99. apiVersion: v1
  100. kind: Service
  101. metadata:
  102.   name: powerjob-mysql-headless
  103.   namespace: powerjob
  104.   labels:
  105.     app: powerjob-mysql
  106. spec:
  107.   clusterIP: None
  108.   ports:
  109.   - port: 3306
  110.     name: powerjob-mysql
  111.     targetPort: 3306
  112.   selector:
  113.     app: powerjob-mysql
  114. ---
  115. apiVersion: v1
  116. kind: Service
  117. metadata:
  118.   name: powerjob-mysql
  119.   namespace: powerjob
  120.   labels:
  121.     app: powerjob-mysql
  122. spec:
  123.   type: NodePort
  124.   ports:
  125.   - port: 3306
  126.     targetPort: 3306
  127.     nodePort: 30336
  128.   selector:
  129.     app: powerjob-mysql
  130. EOF
复制代码
  1. kubectl apply -f ~/powerjob-yml/powerjob-mysql.yml
复制代码
  1. kubectl exec -it powerjob-mysql-0 -n powerjob -- mysql -pPowerjob@2024 -e "show databases;"
  2. kubectl exec -it powerjob-mysql-0 -n powerjob -- mysql -pPowerjob@2024 -e "select host,user from mysql.user;"
  3. kubectl exec -it powerjob-mysql-0 -n powerjob -- mysql -pPowerjob@2024 -e "alter user 'root'@'%' identified with mysql_native_password by 'Powerjob@2024';"
  4. kubectl exec -it powerjob-mysql-0 -n powerjob -- mysql -pPowerjob@2024 -e "flush privileges;"
  5. CREATE DATABASE IF NOT EXISTS `powerjob-product` DEFAULT CHARSET utf8mb4;
复制代码
2、mongodb
  1. cat > ~/powerjob-yml/powerjob-mongodb.yml << 'EOF'
  2. apiVersion: apps/v1
  3. kind: StatefulSet
  4. metadata:
  5.   name: powerjob-mongodb
  6.   namespace: powerjob
  7. spec:
  8.   serviceName: "powerjob-mongodb-headless"
  9.   replicas: 1
  10.   selector:
  11.     matchLabels:
  12.       app: powerjob-mongodb
  13.   template:
  14.     metadata:
  15.       labels:
  16.         app: powerjob-mongodb
  17.     spec:
  18.       containers:
  19.       - name: powerjob-mongodb
  20.         image: ccr.ccs.tencentyun.com/huanghuanhui/mongo:7.0.8
  21.         ports:
  22.         - containerPort: 27017
  23.           name: mongodb
  24.         volumeMounts:
  25.         - name: powerjob-mongodb-data-pvc
  26.           mountPath: /data/db
  27.         - name: localtime
  28.           mountPath: /etc/localtime
  29.       volumes:
  30.       - name: localtime
  31.         hostPath:
  32.           path: /etc/localtime
  33.   volumeClaimTemplates:
  34.   - metadata:
  35.       name: powerjob-mongodb-data-pvc
  36.     spec:
  37.       accessModes: ["ReadWriteOnce"]
  38.       storageClassName: cfs
  39.       resources:
  40.         requests:
  41.           storage: 100Gi
  42. ---
  43. apiVersion: v1
  44. kind: Service
  45. metadata:
  46.   name: powerjob-mongodb-headless
  47.   namespace: powerjob
  48.   labels:
  49.     app: powerjob-mongodb
  50. spec:
  51.   clusterIP: None
  52.   ports:
  53.   - port: 27017
  54.     name: powerjob-mongodb
  55.     targetPort: 27017
  56.   selector:
  57.     app: powerjob-mongodb
  58. ---
  59. apiVersion: v1
  60. kind: Service
  61. metadata:
  62.   name: powerjob-mongodb
  63.   namespace: powerjob
  64.   labels:
  65.     app: powerjob-mongodb
  66. spec:
  67.   type: NodePort
  68.   ports:
  69.   - port: 27017
  70.     targetPort: 27017
  71.     nodePort: 30277
  72.   selector:
  73.     app: powerjob-mongodb
  74. EOF
复制代码
  1. kubectl apply -f ~/powerjob-yml/powerjob-mongodb.yml
复制代码
3、powerjob
  1. cat > ~/powerjob-yml/powerjob.yml << 'EOF'
  2. apiVersion: apps/v1
  3. kind: StatefulSet
  4. metadata:
  5.   name: powerjob-server
  6.   namespace: powerjob
  7. spec:
  8.   serviceName: "powerjob-server-headless"
  9.   replicas: 1
  10.   selector:
  11.     matchLabels:
  12.       app: powerjob-server
  13.   template:
  14.     metadata:
  15.       labels:
  16.         app: powerjob-server
  17.     spec:
  18.       containers:
  19.       - name: powerjob-server
  20.         image: ccr.ccs.tencentyun.com/huanghuanhui/powerjob-server:4.3.9
  21.         ports:
  22.         - containerPort: 7700
  23.           name: http
  24.         - containerPort: 10086
  25.           name: agent
  26.         - containerPort: 10010
  27.           name: admin
  28.         env:
  29.         - name: TZ
  30.           value: "Asia/Shanghai"
  31.         - name: JVMOPTIONS
  32.           value: ""
  33.         - name: PARAMS
  34.           value: "--spring.profiles.active=product --spring.datasource.core.jdbc-url=jdbc:mysql://powerjob-mysql-headless:3306/powerjob-product?useUnicode=true&characterEncoding=UTF-8 --spring.datasource.core.username=root --spring.datasource.core.password=Powerjob@2024 --spring.data.mongodb.uri=mongodb://powerjob-mongodb-headless:27017/powerjob-product"
  35.         volumeMounts:
  36.         - name: powerjob-data-pvc
  37.           mountPath: /root/powerjob/server
  38.         - name: m2-repo
  39.           mountPath: /root/.m2
  40.       volumes:
  41.       - name: m2-repo
  42.         emptyDir: {}
  43.   volumeClaimTemplates:
  44.   - metadata:
  45.       name: powerjob-data-pvc
  46.     spec:
  47.       accessModes: ["ReadWriteOnce"]
  48.       storageClassName: cfs
  49.       resources:
  50.         requests:
  51.           storage: 100Gi
  52. ---
  53. apiVersion: v1
  54. kind: Service
  55. metadata:
  56.   name: powerjob-server
  57.   namespace: powerjob
  58.   labels:
  59.     app: powerjob-server
  60. spec:
  61.   type: NodePort
  62.   ports:
  63.   - name: http
  64.     port: 7700
  65.     targetPort: http
  66.     nodePort: 30077
  67.   - name: agent
  68.     port: 10086
  69.     targetPort: agent
  70.     nodePort: 30086
  71.   - name: admin
  72.     port: 10010
  73.     targetPort: admin
  74.     nodePort: 30110
  75.   selector:
  76.     app: powerjob-server
  77. EOF
复制代码
  1. kubectl apply -f ~/powerjob-yml/powerjob.yml
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

麻花痒

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表