欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何把Spring Cloud Data Flow部署在Kubernetes上

 更新時間:2020年08月03日 09:21:44   作者:南瓜慢說  
這篇文章主要介紹了把Spring Cloud Data Flow部署在Kubernetes上,再跑個任務試試,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

1 前言

Spring Cloud Data Flow在本地跑得好好的,為什么要部署在Kubernetes上呢?主要是因為Kubernetes能提供更靈活的微服務管理;在集群上跑,會更安全穩(wěn)定、更合理利用物理資源。

Spring Cloud Data Flow入門簡介請參考:Spring Cloud Data Flow初體驗,以Local模式運行

2 部署Data Flow到Kubernetes

以簡單為原則,我們依然是基于Batch任務,不部署與Stream相關的組件。

2.1 下載GitHub代碼

我們要基于官方提供的部署代碼進行修改,先把官方代碼clone下來:

$ git clone https://github.com/spring-cloud/spring-cloud-dataflow.git

我們切換到最新穩(wěn)定版本的代碼版本:

$ git checkout v2.5.3.RELEASE

2.2 創(chuàng)建權限賬號

為了讓Data Flow Server有權限來跑任務,能在Kubernetes管理資源,如新建Pod等,所以要創(chuàng)建對應的權限賬號。這部分代碼與源碼一致,不需要修改:

(1)server-roles.yaml

kind: Role
apiVersion: rbac.authorization.k8s.io/v1
metadata:
 name: scdf-role
rules:
 - apiGroups: [""]
 resources: ["services", "pods", "replicationcontrollers", "persistentvolumeclaims"]
 verbs: ["get", "list", "watch", "create", "delete", "update"]
 - apiGroups: [""]
 resources: ["configmaps", "secrets", "pods/log"]
 verbs: ["get", "list", "watch"]
 - apiGroups: ["apps"]
 resources: ["statefulsets", "deployments", "replicasets"]
 verbs: ["get", "list", "watch", "create", "delete", "update", "patch"]
 - apiGroups: ["extensions"]
 resources: ["deployments", "replicasets"]
 verbs: ["get", "list", "watch", "create", "delete", "update", "patch"]
 - apiGroups: ["batch"]
 resources: ["cronjobs", "jobs"]
 verbs: ["create", "delete", "get", "list", "watch", "update", "patch"]

(2)server-rolebinding.yaml

kind: RoleBinding
apiVersion: rbac.authorization.k8s.io/v1beta1
metadata:
 name: scdf-rb
subjects:
- kind: ServiceAccount
 name: scdf-sa
roleRef:
 kind: Role
 name: scdf-role
 apiGroup: rbac.authorization.k8s.io

(3)service-account.yaml

apiVersion: v1
kind: ServiceAccount
metadata:
 name: scdf-sa

執(zhí)行以下命令,創(chuàng)建對應賬號:

$ kubectl create -f src/kubernetes/server/server-roles.yaml 
$ kubectl create -f src/kubernetes/server/server-rolebinding.yaml 
$ kubectl create -f src/kubernetes/server/service-account.yaml 

執(zhí)行完成后,可以檢查一下:

$ kubectl get role
NAME AGE
scdf-role 119m

$ kubectl get rolebinding
NAME AGE
scdf-rb 117m

$ kubectl get serviceAccount
NAME SECRETS AGE
default 1  27d
scdf-sa 1  117m

2.3 部署MySQL

可以選擇其它數(shù)據(jù)庫,如果本來就有數(shù)據(jù)庫,可以不用部署,在部署Server的時候改一下配置就好了。這里跟著官方的Guide來。為了保證部署不會因為鏡像下載問題而失敗,我提前下載了鏡像:

$ docker pull mysql:5.7.25

MySQLyaml文件也不需要修改,直接執(zhí)行以下命令即可:

$ kubectl create -f src/kubernetes/mysql/

執(zhí)行完后檢查一下:

$ kubectl get Secret
NAME   TYPE     DATA AGE
default-token-jhgfp kubernetes.io/service-account-token 3 27d
mysql   Opaque    2 98m
scdf-sa-token-wmgk6 kubernetes.io/service-account-token 3 123m

$ kubectl get PersistentVolumeClaim
NAME STATUS VOLUME     CAPACITY ACCESS MODES STORAGECLASS AGE
mysql Bound pvc-e95b495a-bea5-40ee-9606-dab8d9b0d65c 8Gi RWO  hostpath 98m

$ kubectl get Deployment
NAME  READY UP-TO-DATE AVAILABLE AGE
mysql  1/1 1  1  98m

$ kubectl get Service
NAME  TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
mysql  ClusterIP 10.98.243.130 <none> 3306/TCP 98m

2.4 部署Data Flow Server

2.4.1 修改配置文件server-config.yaml

刪除掉不用的配置,主要是PrometheusGrafana的配置,結果如下:

apiVersion: v1
kind: ConfigMap
metadata:
 name: scdf-server
 labels:
 app: scdf-server
data:
 application.yaml: |-
 spring:
 cloud:
 dataflow:
  task:
  platform:
  kubernetes:
  accounts:
   default:
   limits:
   memory: 1024Mi
 datasource:
 url: jdbc:mysql://${MYSQL_SERVICE_HOST}:${MYSQL_SERVICE_PORT}/mysql
 username: root
 password: ${mysql-root-password}
 driverClassName: org.mariadb.jdbc.Driver
 testOnBorrow: true
 validationQuery: "SELECT 1"

2.4.2 修改server-svc.yaml

因為我是本地運行的Kubernetes,所以把Service類型從LoadBalancer改為NodePort,并配置端口為30093

kind: Service
apiVersion: v1
metadata:
 name: scdf-server
 labels:
 app: scdf-server
 spring-deployment-id: scdf
spec:
 # If you are running k8s on a local dev box or using minikube, you can use type NodePort instead
 type: NodePort
 ports:
 - port: 80
 name: scdf-server
 nodePort: 30093
 selector:
 app: scdf-server

2.4.3 修改server-deployment.yaml

主要把Stream相關的去掉,如SPRING_CLOUD_SKIPPER_CLIENT_SERVER_URI配置項:

apiVersion: apps/v1
kind: Deployment
metadata:
 name: scdf-server
 labels:
 app: scdf-server
spec:
 selector:
 matchLabels:
 app: scdf-server
 replicas: 1
 template:
 metadata:
 labels:
 app: scdf-server
 spec:
 containers:
 - name: scdf-server
 image: springcloud/spring-cloud-dataflow-server:2.5.3.RELEASE
 imagePullPolicy: IfNotPresent
 volumeMounts:
  - name: database
  mountPath: /etc/secrets/database
  readOnly: true
 ports:
 - containerPort: 80
 livenessProbe:
  httpGet:
  path: /management/health
  port: 80
  initialDelaySeconds: 45
 readinessProbe:
  httpGet:
  path: /management/info
  port: 80
  initialDelaySeconds: 45
 resources:
  limits:
  cpu: 1.0
  memory: 2048Mi
  requests:
  cpu: 0.5
  memory: 1024Mi
 env:
 - name: KUBERNETES_NAMESPACE
  valueFrom:
  fieldRef:
  fieldPath: "metadata.namespace"
 - name: SERVER_PORT
  value: '80'
 - name: SPRING_CLOUD_CONFIG_ENABLED
  value: 'false'
 - name: SPRING_CLOUD_DATAFLOW_FEATURES_ANALYTICS_ENABLED
  value: 'true'
 - name: SPRING_CLOUD_DATAFLOW_FEATURES_SCHEDULES_ENABLED
  value: 'true'
 - name: SPRING_CLOUD_KUBERNETES_SECRETS_ENABLE_API
  value: 'true'
 - name: SPRING_CLOUD_KUBERNETES_SECRETS_PATHS
  value: /etc/secrets
 - name: SPRING_CLOUD_KUBERNETES_CONFIG_NAME
  value: scdf-server
 - name: SPRING_CLOUD_DATAFLOW_SERVER_URI
  value: 'http://${SCDF_SERVER_SERVICE_HOST}:${SCDF_SERVER_SERVICE_PORT}'
  # Add Maven repo for metadata artifact resolution for all stream apps
 - name: SPRING_APPLICATION_JSON
  value: "{ \"maven\": { \"local-repository\": null, \"remote-repositories\": { \"repo1\": { \"url\": \"https://repo.spring.io/libs-snapshot\"} } } }"
 initContainers:
 - name: init-mysql-wait
 image: busybox
 command: ['sh', '-c', 'until nc -w3 -z mysql 3306; do echo waiting for mysql; sleep 3; done;']
 serviceAccountName: scdf-sa
 volumes:
 - name: database
  secret:
  secretName: mysql

2.4.4 部署Server

完成文件修改后,就可以執(zhí)行以下命令部署了:

# 提前下載鏡像
$ docker pull springcloud/spring-cloud-dataflow-server:2.5.3.RELEASE

# 部署Data Flow Server
$ kubectl create -f src/kubernetes/server/server-config.yaml 
$ kubectl create -f src/kubernetes/server/server-svc.yaml 
$ kubectl create -f src/kubernetes/server/server-deployment.yaml 

執(zhí)行完成,沒有錯誤就可以訪問:http://localhost:30093/dashboard/

3 運行一個Task

檢驗是否部署成功最簡單的方式就是跑一個任務試試。還是按以前的步驟,先注冊應用,再定義Task,然后執(zhí)行。

我們依舊使用官方已經準備好的應用,但要注意這次我們選擇是的Docker格式,而不是jar包了。

成功執(zhí)行后,查看KubernetesDashboard,能看到一個剛創(chuàng)建的Pod

4 總結

本文通過一步步講解,把Spring Cloud Data Flow成功部署在了Kubernetes上,并成功在Kubenetes上跑了一個任務,再也不再是Local本地單機模式了。

到此這篇關于把Spring Cloud Data Flow部署在Kubernetes上,再跑個任務試試的文章就介紹到這了,更多相關把Spring Cloud Data Flow部署在Kubernetes上,再跑個任務試試內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Maven打包時如何指定啟動類

    Maven打包時如何指定啟動類

    這篇文章主要介紹了Maven打包時如何指定啟動類問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Java反射機制如何解決數(shù)據(jù)傳值為空的問題

    Java反射機制如何解決數(shù)據(jù)傳值為空的問題

    這篇文章主要介紹了Java反射機制如何解決數(shù)據(jù)傳值為空的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • idea激活ActivateJrebel熱部署的方法詳解

    idea激活ActivateJrebel熱部署的方法詳解

    這篇文章主要介紹了idea激活ActivateJrebel熱部署的方法,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • SpringCloud Alibaba框架介紹

    SpringCloud Alibaba框架介紹

    spring cloud是一個基于springboot實現(xiàn)的微服務架構開發(fā)工具,目前主流的SpringCloud分為SpringCloud Netflix和阿里云開源的SpringCloud Alibaba兩個系列,本文主要介紹SpringCloud Alibaba框架,感興趣的朋友可以參考一下
    2023-04-04
  • Spring的事件監(jiān)聽機制示例詳解

    Spring的事件監(jiān)聽機制示例詳解

    這篇文章主要給大家介紹了關于Spring的事件監(jiān)聽機制的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-11-11
  • Java中的動態(tài)綁定機制

    Java中的動態(tài)綁定機制

    這篇文章主要介紹了Java中的動態(tài)綁定機制,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • spring?bean標簽中的init-method和destroy-method詳解

    spring?bean標簽中的init-method和destroy-method詳解

    這篇文章主要介紹了spring?bean標簽中的init-method和destroy-method,在很多項目中,經常在xml配置文件中看到init-method 或者 destroy-method ,因此整理收集下,方便以后參考和學習,需要的朋友可以參考下
    2023-04-04
  • java實現(xiàn)圖片上加文字水印(SpringMVC + Jsp)

    java實現(xiàn)圖片上加文字水印(SpringMVC + Jsp)

    這篇文章主要為大家詳細介紹了java實現(xiàn)在圖片上加文字水印的方法,水印可以是圖片或者文字,操作方便,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-05-05
  • Spring Boot 項目設置網站圖標的方法

    Spring Boot 項目設置網站圖標的方法

    這篇文章主要介紹了Spring Boot 項目設置網站圖標的方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • Java使用HttpClient詳細示例

    Java使用HttpClient詳細示例

    這篇文章介紹了Java使用HttpClient的詳細示例,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12

最新評論