Я пытаюсь подключиться к Hive-metastore из приложения Spark, но каждый раз, когда он застревает при попытке подключиться, и происходит сбой с таймаутом:
INFO metastore:376 - Trying to connect to metastore with URI thrift://hive-metastore:9083
WARN metastore:444 - set_ugi() not successful, Likely cause: new client talking to old server. Continuing without it.
org.apache.thrift.transport.TTransportException: java.net.SocketTimeoutException: Read timed out
Приложение падает на линии, где я создаювнешняя таблица Hive
Я запускаю Hive-metastore, а также приложение Spark (с помощью оператора Spark K8s) в кластере Kubernetes.Я проверил доступность службы Hive-metastore за пределами кластера, используя telnet (узел ip: порт узла службы) и свернул службу внутри кластера. Эта служба, кажется, оцениваема.В чем может быть причина этой ошибки?
Это конфигурация Uri-metastore uri в приложении Spark
val sparkSession = SparkSession
.builder()
.config(sparkConf)
.config("hive.metastore.uris", "thrift://hive-metastore:9083")
.config("hive.exec.dynamic.partition", "true")
.config("hive.exec.dynamic.partition.mode", "nonstrict")
.enableHiveSupport()
.getOrCreate()
Конфигурация yaml Hive-metastore выглядит следующим образом:
apiVersion: v1
kind: Service
metadata:
name: hive-metastore-np
spec:
selector:
app: hive-metastore
ports:
- protocol: TCP
targetPort: 9083
port: 9083
nodePort: 32083
type: NodePort
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: hive-metastore
spec:
replicas: 1
selector:
matchLabels:
app: hive-metastore
template:
metadata:
labels:
app: hive-metastore
spec:
containers:
- name: hive-metastore
image: mozdata/docker-hive-metastore:1.2.1
imagePullPolicy: Always
env:
- name: DB_URI
value: postgresql
- name: DB_USER
value: hive
- name: DB_PASSWORD
value: hive-password
- name: CORE_CONF_fs_defaultFS
value: hdfs://hdfs-namenode:8020
ports:
- containerPort: 9083
ОБНОВЛЕНИЕ: Когда я пытаюсь свернуть hive-metastore: 9083, служба доступна, но возвращает пустой ответ, что означает, что может быть проблема с определением hive-metastore K8s
> GET / HTTP/1.1
> User-Agent: curl/7.35.0
> Host: hive-metastore:9083
> Accept: */*