Как весенняя загрузка соединяет localhost mysql в k8s? - PullRequest
0 голосов
/ 01 апреля 2020

Я новичок в k8s, использую docker -ma c -desktop k8s приложение для тестирования пружинной загрузки.

Я могу подключиться успешно, когда загрузка пружины в локальном соединении mysql.

преобразовать в docker k8s не может подключиться.

ошибка:

com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure
at com.mysql.cj.jdbc.exceptions.SQLError.createCommunicationsException(SQLError.java:174) ~[mysql-connector-java-8.0.19.jar!/:8.0.19]
at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:64) ~[mysql-connector-java-8.0.19.jar!/:8.0.19]
at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:836) ~[mysql-connector-java-8.0.19.jar!/:8.0.19]
at com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:456) ~[mysql-connector-java-8.0.19.jar!/:8.0.19]
at com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:246) ~[mysql-connector-java-8.0.19.jar!/:8.0.19]
at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:197) ~[mysql-connector-java-8.0.19.jar!/:8.0.19]

- это локальный порт прослушивания:

redis-ser  2008    f    6u  IPv4 0x135c39363e412e7f      0t0  TCP 127.0.0.1:6379 (LISTEN)
kubectl    2909    f    7u  IPv4 0x135c39365cf8a6ff      0t0  TCP 127.0.0.1:8500 (LISTEN)
kubectl    2909    f    8u  IPv6 0x135c39365e7fb2cf      0t0  TCP [::1]:8500 (LISTEN)
mysqld     4091    f   28u  IPv4 0x135c39364db92abf      0t0  TCP 127.0.0.1:3306 (LISTEN)
mysqld     4091    f   32u  IPv4 0x135c39364dc7e6ff      0t0  TCP 127.0.0.1:33060 (LISTEN)
com.docke 41823    f   20u  IPv4 0x135c39365b9a4d1f      0t0  TCP 127.0.0.1:6443 (LISTEN)
com.docke 41823    f   25u  IPv6 0x135c39365e7f9a4f      0t0  TCP *:32003 (LISTEN)
com.docke 41926    f    8u  IPv4 0x135c393660b3785f      0t0  TCP 127.0.0.1:60701 (LISTEN)

пружинная загрузка конфигурация базы данных:

spring:
datasource:
url: jdbc:mysql://mysqldb:3306/foo
# mysqldb.default.svc.cluster.local tried
#
driver-class-name: com.mysql.cj.jdbc.Driver
username: f

пружинный загрузочный pod.yml:

apiVersion: v1
kind: Pod
metadata:
  name: user-service
  labels:
    app: user-service
spec:
  containers:
    - name: user-service
      image: user_service:v1

ссылка на базу данных карты: https://cloud.google.com/blog/products/gcp/kubernetes-best-practices-mapping-external-services

mysql_sv c .yml:

apiVersion: v1
kind: Service
metadata:
name: mysqldb
spec:
ports:
    - port: 3306
    targetPort: 3306

---
kind: Endpoints
apiVersion: v1
metadata:
name: mysqldb
subsets:
- addresses:
    - ip: 192.168.0.101
    ports:
    - port: 3306

в то время как ip пришел от ifconfig

en0: flags=8863<UP,BROADCAST,SMART,RUNNING,SIMPLEX,MULTICAST> mtu 1500
    options=400<CHANNEL_IO>
    inet6 fe80::c2c:cc27:8121:fbac%en0 prefixlen 64 secured scopeid 0x5 
    inet 192.168.0.101 netmask 0xffffff00 broadcast 192.168.0.255
    nd6 options=201<PERFORMNUD,DAD>
    media: autoselect
    status: active

как подключиться из базы данных k8s pod connect localhost? :)

1 Ответ

1 голос
/ 01 апреля 2020

Я решил эту проблему.

изменено mysql_sv c .yml

apiVersion: v1
kind: Service
metadata:
name: mysqldb
spec:
type: ExternalName
externalName: host.docker.internal
ports:
    - port: 3306
    targetPort: 3306

сопоставление локального порта

изменение конфигурации источника данных:

spring.datasource.url=jdbc:mysql://mysqldb/foo

затем подключиться успешно.

ref answer

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...