使用本地应用程序访问集群中的内部数据库 [英] Access internal database in cluster with local application

查看:39
本文介绍了使用本地应用程序访问集群中的内部数据库的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我尝试将本地Spring引导应用程序与k8-cluster中的内部mysql-db连接。 我在坞站桌面本地使用了K8群集。

我的部署.yml:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: kazi-db
spec:
  selector:
    matchLabels:
      app: mysql
  strategy:
    type: Recreate
  template:
    metadata:
      labels:
        app: mysql
    spec:
      containers:
        - image: mysql/mysql-server:8.0
          name: mysql
          imagePullPolicy: IfNotPresent
          env:
            - name: MYSQL_ROOT_PASSWORD
              valueFrom:
                secretKeyRef:
                  name: kazi-db-secret
                  key: password
          ports:
            - containerPort: 3306
              name: mysql
          volumeMounts:
            - name: mysql-persistent-storage
              mountPath: /var/lib/mysql
      volumes:
        - name: mysql-persistent-storage
          persistentVolumeClaim:
            claimName: mysql-pv-claim
        - name: mysql-initdb
          configMap:
            name: kazi-initdb

我的service.yml:

apiVersion: v1
kind: Service
metadata:
  name: kazi-db
spec:
  ports:
    - port: 3306
  selector:
    app: kazi-db
  type: LoadBalancer

服务描述:

kubectl get services kazi-db     
NAME      TYPE           CLUSTER-IP      EXTERNAL-IP   PORT(S)          AGE
kazi-db   LoadBalancer   10.107.75.107   localhost     3306:31627/TCP   3d

我的Spring-boot应用程序.yml

## JDBC part
spring:
  config:
    activate:
      on-profile: local
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/kazi?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC
    username: emo
    password: 123qwe
  jpa:
    show-sql: true
    database-platform: org.hibernate.dialect.MySQL8Dialect
    hibernate:
      ddl-auto: update
  liquibase:
    change-log: classpath:liquibase/changelog.xml

我使用localhost是因为K8定义了一个localhost作为外部Ip。

kubectl describe services kazi-db
Name:                     kazi-db
Namespace:                default
Labels:                   <none>
Annotations:              <none>
Selector:                 app=kazi-db
Type:                     LoadBalancer
IP Families:              <none>
IP:                       10.107.75.107
IPs:                      <none>
LoadBalancer Ingress:     localhost
Port:                     <unset>  3306/TCP
TargetPort:               3306/TCP
NodePort:                 <unset>  31627/TCP
Endpoints:                <none>
Session Affinity:         None
External Traffic Policy:  Cluster
Events:
  Type    Reason  Age   From                Message
  ----    ------  ----  ----                -------
  Normal  Type    10m   service-controller  ClusterIP -> LoadBalancer    

我也有一个本地mysql-db,我可以毫无问题地连接应用程序。 我可以使用kubectl exec -it kazi-db-554bd6d787-2gb88 -- /bin/bash 和CREATE SOME TABLE连接到db-cluster,但应用程序不能。

当我启动Spring-boot应用程序时:

java.sql.SQLSyntaxErrorException: Unknown database 'kazi'
    at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:120) ~[mysql-connector-java-8.0.18.jar:8.0.18]
    at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97) ~[mysql-connector-java-8.0.18.jar:8.0.18]
    at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:122) ~[mysql-connector-java-8.0.18.jar:8.0.18]

虽然db-cluster中存在数据库Kazi。

但是怎样才能连接到内部K8集群数据库呢?

我正在使用停靠桌面v20.10.11和K8v1.22.4。我也用minikube version: v1.24.0试过。在这两个问题中,我遇到了相同的问题。

推荐答案

我用端口转发来解决:kubectl port-forward <pod-name> 3306:3306 -n default

这篇关于使用本地应用程序访问集群中的内部数据库的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆