【Kubernetes】動態修改數據庫連接


環境

  1. kubernetes 1.20.2
  2. Spring Boot 2.5.0-M1

目標

在之前集群訪問本地服務中,打成鏡像之前,我們還查看了 Service 的 IP 地址,然后修改配置。
如果 Service 的 IP 地址還不清楚,或者每個環境的 IP 都不一致,那就可以使用環境變量動態修改。

修改 Service IP

因為 Service 的 IP 分配了就不能再修改,所以我們直接刪除,重新建立 Service。

svc.yaml

apiVersion: v1
kind: Service
metadata:
  name: svc-pg
spec:
  ports:
    - port: 5432

ep.yaml

apiVersion: v1
kind: Endpoints
metadata:
  name: svc-pg
subsets:
  - addresses:
      - ip: 192.168.56.103
    ports:
      - port: 5432

刪除重建

刪除 Service 的時候,默認把 Endpoints 也一起刪除了,所以需要重新創建。

[root@master kubernetes]# kubectl delete -f svc.yaml
service "svc-pg" deleted
[root@master kubernetes]# kubectl apply -f svc.yaml
service/svc-pg created
[root@master kubernetes]# kubectl apply -f ep.yaml
endpoints/svc-pg created

Service 前后對比

[root@master kubernetes]# kubectl get service svc-pg
NAME         TYPE           CLUSTER-IP       EXTERNAL-IP     PORT(S)          AGE
svc-pg       NodePort       10.109.50.111    <none>          5432:32206/TCP   15h

[root@master kubernetes]# kubectl get service svc-pg
NAME     TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)    AGE
svc-pg   ClusterIP   10.108.222.50   <none>        5432/TCP   20s

可以看到 IP 地址已經變化了。

修改前訪問測試

訪問 hostname

[root@master kubernetes]# curl 10.244.1.105/hostname
rc-demo-r6nv8 external[root@master kubernetes]#

訪問數據庫

[root@master kubernetes]# curl 10.244.1.105/users | jq
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100   119    0   119    0     0      3      0 --:--:--  0:00:30 --:--:--    29
{
  "timestamp": "2021-01-31T06:51:59.519+00:00",
  "status": 500,
  "error": "Internal Server Error",
  "message": "",
  "path": "/users"
}

已經訪問不到數據庫了,因為 Service 的 IP 已經變化。

修改數據庫連接

rc.yaml

apiVersion: v1
kind: ReplicationController
metadata:
  name: rc-demo
spec:
  replicas: 3
  template:
    metadata:
      labels:
        app: myapp
    spec:
      containers:
        - name: pod-demo
          image: jiangbo920827/spring-demo:external
          ports:
            - containerPort: 80
          env:
            - name: SERVER_PORT
              value: "80"
            - name: SPRING_DATASOURCE_URL
              value: jdbc:postgresql://10.108.222.50:5432/postgres

修改 rc

[root@master kubernetes]# kubectl apply -f rc.yaml
replicationcontroller/rc-demo configured

重啟 Pod

[root@master kubernetes]# kubectl delete pod -l app=myapp
pod "rc-demo-b7r9f" deleted
pod "rc-demo-b9mqr" deleted
pod "rc-demo-r6nv8" deleted

查看重啟后狀態

[root@master kubernetes]# kubectl get pod -o wide
NAME            READY   STATUS    RESTARTS   AGE     IP             NODE    NOMINATED NODE   READINESS GATES
rc-demo-8ld7l   1/1     Running   0          6m43s   10.244.1.107   node1   <none>           <none>
rc-demo-9fhdz   1/1     Running   0          6m43s   10.244.2.54    node2   <none>           <none>
rc-demo-f7dcd   1/1     Running   0          6m43s   10.244.2.55    node2   <none>           <none>

驗證

訪問 hostname

[root@master kubernetes]# curl 10.244.2.55/hostname
rc-demo-f7dcd external[root@master kubernetes]#

訪問數據庫值

[root@master kubernetes]# curl 10.244.2.55/users | jq
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100    29    0    29    0     0    190      0 --:--:-- --:--:-- --:--:--   192
[
  {
    "name": "jiangbo",
    "age": 44
  }
]

查看環境變量

通過環境變量列表,我們看到了我們注入的數據庫的連接信息。但同時,我們也看了額外的 Service 信息。
原來 k8s 早就想到了這點,已經把建立的 Service 的信息放到環境變量了。

[root@master kubernetes]# kubectl exec rc-demo-f7dcd -- printenv | grep SPRING
SPRING_DATASOURCE_URL=jdbc:postgresql://10.108.222.50:5432/postgres
[root@master kubernetes]# kubectl exec rc-demo-f7dcd -- printenv
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/lib/jvm/java-1.8-openjdk/jre/bin:/usr/lib/jvm/java-1.8-openjdk/bin
HOSTNAME=rc-demo-f7dcd
SPRING_DATASOURCE_URL=jdbc:postgresql://10.108.222.50:5432/postgres
SERVER_PORT=80
KUBERNETES_PORT_443_TCP=tcp://10.96.0.1:443
KUBERNETES_PORT_443_TCP_PORT=443
SVC_DEMO_PORT_8080_TCP_PORT=8080
SVC_PG_PORT_5432_TCP=tcp://10.108.222.50:5432
KUBERNETES_PORT=tcp://10.96.0.1:443
SVC_PG_PORT_5432_TCP_PORT=5432
KUBERNETES_SERVICE_HOST=10.96.0.1
KUBERNETES_SERVICE_PORT_HTTPS=443
KUBERNETES_PORT_443_TCP_PROTO=tcp
SVC_PG_PORT=tcp://10.108.222.50:5432
SVC_PG_PORT_5432_TCP_PROTO=tcp
KUBERNETES_SERVICE_PORT=443
SVC_DEMO_SERVICE_HOST=10.106.217.209
SVC_DEMO_SERVICE_PORT=8080
SVC_DEMO_PORT=tcp://10.106.217.209:8080
SVC_DEMO_PORT_8080_TCP_ADDR=10.106.217.209
SVC_PG_SERVICE_HOST=10.108.222.50
SVC_PG_SERVICE_PORT=5432
SVC_DEMO_PORT_8080_TCP=tcp://10.106.217.209:8080
SVC_DEMO_PORT_8080_TCP_PROTO=tcp
SVC_PG_PORT_5432_TCP_ADDR=10.108.222.50
KUBERNETES_PORT_443_TCP_ADDR=10.96.0.1
LANG=C.UTF-8
JAVA_HOME=/usr/lib/jvm/java-1.8-openjdk/jre
JAVA_VERSION=8u212
JAVA_ALPINE_VERSION=8.212.04-r0
HOME=/root

總結

通過給 Pod 注入數據庫連接的環境變量,來達到動態修改數據庫訪問連接的目的。
同時也發現了 k8s 自動幫我們注入了 Service 中相關的信息。

附錄


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM