使用本地应用程序访问集群中的内部数据库 [英] Access internal database in cluster with local application
本文介绍了使用本地应用程序访问集群中的内部数据库的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我尝试将本地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屋!
查看全文