-
Notifications
You must be signed in to change notification settings - Fork 147
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Addon Hive-operator #655
base: master
Are you sure you want to change the base?
Addon Hive-operator #655
Changes from all commits
aa34a06
36169a8
0ed9f6e
a9c0a66
f6abee7
a25efc5
3c29f74
a34505e
7bcf3e4
03d9e9b
6d85bc5
7d6b85e
adb4b66
91e4d4c
86e0ecd
0b3aa6c
1a2ab34
fbd4ae5
b85ac8e
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
apiVersion: core.oam.dev/v1beta1 | ||
kind: Application | ||
metadata: | ||
name: hive-postgres-cluster | ||
spec: | ||
components: | ||
- type: hive-cluster | ||
name: hive-postgres-cluster | ||
properties: | ||
image: | ||
productVersion: 3.1.3 | ||
stackableVersion: 23.1.0 | ||
clusterConfig: | ||
database: | ||
connString: jdbc:postgresql://postgresql:5432/hive | ||
user: hive | ||
password: hive | ||
dbType: postgres | ||
s3: | ||
reference: minio | ||
metastore: | ||
roleGroups: | ||
default: | ||
replicas: 1 |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
apiVersion: core.oam.dev/v1beta1 | ||
kind: Application | ||
metadata: | ||
name: s3-connection-sample | ||
spec: | ||
components: | ||
- type: s3-connection | ||
name: minio | ||
properties: | ||
host: minio | ||
port: 9000 | ||
accessStyle: Path | ||
credentials: | ||
secretClass: hive-s3-secret-class |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
apiVersion: core.oam.dev/v1beta1 | ||
kind: Application | ||
metadata: | ||
name: secret-class-sample | ||
spec: | ||
components: | ||
- type: secret-class | ||
name: hive-s3-secret-class | ||
properties: | ||
backend: | ||
k8sSearch: | ||
searchNamespace: | ||
pod: {} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,142 @@ | ||
# hive-operator | ||
|
||
Apache Hive is a distributed, fault-tolerant data warehouse system that enables analytics at a massive scale. Hive Metastore(HMS) provides a central repository of metadata that can easily be analyzed to make informed, data driven decisions, and therefore it is a critical component of many data lake architectures. Hive is built on top of Apache Hadoop and supports storage on S3, adls, gs etc though hdfs. Hive allows users to read, write, and manage petabytes of data using SQL. | ||
|
||
This is an operator for Kubernetes that can manage Apache Hive. Currently, it only supports the Hive Metastore! | ||
|
||
## Install Operator | ||
|
||
Add experimental registry | ||
``` | ||
vela addon registry add experimental --type=helm --endpoint=https://addons.kubevela.net/experimental/ | ||
``` | ||
|
||
Enable this addon | ||
``` | ||
vela addon enable hive-operator | ||
``` | ||
|
||
```shell | ||
$ vela ls -A | grep hive | ||
vela-system addon-hive-operator ns-hive-operator k8s-objects running healthy | ||
vela-system └─ hive-operator helm running healthy Fetch repository successfully, Create helm release | ||
``` | ||
|
||
Disable this addon | ||
``` | ||
vela addon disable hive-operator | ||
``` | ||
|
||
## Use | ||
|
||
After going through the Installation section and having installed all the dependencies, you will now deploy a Hive metastore cluster and it’s dependencies. Afterwards you can verify that it works. | ||
|
||
In order to connect Hive to MinIO we need to create several dependent components like S3Connection, Secret and a SecretClass | ||
|
||
**s3-connection** | ||
|
||
An S3Connection to connect to MinIO, Apply below YAML: | ||
|
||
```yaml | ||
apiVersion: core.oam.dev/v1beta1 | ||
kind: Application | ||
metadata: | ||
name: s3-connection-sample | ||
spec: | ||
components: | ||
- type: s3-connection | ||
name: minio | ||
properties: | ||
host: minio | ||
port: 9000 | ||
accessStyle: Path | ||
credentials: | ||
secretClass: hive-s3-secret-class | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why not put all these (including the single-component Applications below) into one single Application that the user can run and test? If used in this way, it is essentially the same as applying a bunch of yamls. The benfit of vela applications are gone. |
||
``` | ||
|
||
**secret** | ||
|
||
Credentials for the S3Connection to log into MinIO, Apply below YAML: | ||
|
||
```yaml | ||
apiVersion: core.oam.dev/v1beta1 | ||
kind: Application | ||
metadata: | ||
name: hive-secret-sample | ||
spec: | ||
components: | ||
- type: k8s-objects | ||
name: k8s-demo-secret | ||
properties: | ||
objects: | ||
- apiVersion: v1 | ||
kind: Secret | ||
metadata: | ||
name: hive-s3-secret | ||
labels: | ||
secrets.stackable.tech/class: hive-s3-secret-class | ||
stringData: | ||
accessKey: hive | ||
secretKey: hivehive | ||
``` | ||
|
||
**secret-class** | ||
|
||
A SecretClass for the credentials to the Minio. The credentials were defined in the installation of Minio via helm, Apply below YAML: | ||
|
||
```yaml | ||
apiVersion: core.oam.dev/v1beta1 | ||
kind: Application | ||
metadata: | ||
name: secret-class-sample | ||
spec: | ||
components: | ||
- type: secret-class | ||
name: hive-s3-secret-class | ||
properties: | ||
backend: | ||
k8sSearch: | ||
searchNamespace: | ||
pod: {} | ||
``` | ||
|
||
**hive-cluster** | ||
|
||
And lastly the actual Apache Hive cluster definition, Apply below YAML: | ||
|
||
```yaml | ||
apiVersion: core.oam.dev/v1beta1 | ||
kind: Application | ||
metadata: | ||
name: hive-postgres-cluster | ||
spec: | ||
components: | ||
- type: hive-cluster | ||
name: hive-postgres-cluster | ||
properties: | ||
image: | ||
productVersion: 3.1.3 | ||
stackableVersion: 23.1.0 | ||
clusterConfig: | ||
database: | ||
connString: jdbc:postgresql://postgresql:5432/hive | ||
user: hive | ||
password: hive | ||
dbType: postgres | ||
s3: | ||
reference: minio | ||
metastore: | ||
roleGroups: | ||
default: | ||
replicas: 1 | ||
``` | ||
|
||
Verify that it works | ||
|
||
```shell | ||
$ kubectl get statefulset -n prod | ||
MdSahil-oss marked this conversation as resolved.
Show resolved
Hide resolved
|
||
NAME READY AGE | ||
hive-postgres-cluster-metastore-default 1/1 76s | ||
``` | ||
|
||
For more visit on the website https://docs.stackable.tech/home/stable/hive/index.html. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. please provide some information here about how to use the hive cluster. |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,77 @@ | ||
"hive-cluster": { | ||
alias: "" | ||
annotations: {} | ||
attributes: workload: type: "autodetects.core.oam.dev" | ||
description: "s3 bucket component" | ||
labels: {} | ||
type: "component" | ||
} | ||
|
||
template: { | ||
output: { | ||
kind: "HiveCluster" | ||
apiVersion: "hive.stackable.tech/v1alpha1" | ||
metadata: { | ||
name: context.name | ||
} | ||
spec: { | ||
image: parameter.image | ||
clusterConfig: parameter.clusterConfig | ||
metastore: parameter.metastore | ||
} | ||
} | ||
parameter: { | ||
//+usage=The Hive metastore image to use. | ||
image: { | ||
//+usage=Overwrite the docker image. Specify the full docker image name, e.g. `docker.stackable.tech/stackable/superset:1.4.1-stackable2.1.0 | ||
custom: *null | string | ||
//+usage=Version of the product, e.g. `1.4.1`. | ||
productVersion: *null | string | ||
//+usage=Pull policy used when pulling the Images. | ||
pullPolicy: *"IfNotPresent" | string | ||
//+usage=Image pull secrets to pull images from a private registry. | ||
pullSecrets: *null | [...] | ||
//+usage=Name of the docker repo, e.g. `docker.stackable.tech/stackable. | ||
repo: *null | string | ||
//+usage=Stackable version of the product, e.g. 2.1.0. | ||
stackableVersion: *null | string | ||
} | ||
//+usage=General Hive metastore cluster settings. | ||
clusterConfig: { | ||
//+usage=Database connection specification. | ||
database: { | ||
connString: *null | string | ||
dbType: *null | string | ||
password: *null | string | ||
user: *null | string | ||
} | ||
//+usage=HDFS connection specification. | ||
hdfs: *null | {...} | ||
//+usage=S3 connection specification. | ||
s3: { | ||
//+usage=S3 connection definition as CRD. | ||
inline: *null | {...} | ||
reference: *null | string | ||
} | ||
//+usage=Specify the type of the created kubernetes service. This attribute will be removed in a future release when listener-operator is finished. Use with caution. | ||
serviceType: *"ClusterIP" | string | ||
//+usage=Name of the Vector aggregator discovery ConfigMap. It must contain the key `ADDRESS` with the address of the Vector aggregator. | ||
vectorAggregatorConfigMapName: *null | string | ||
} | ||
//+usage=Configure metastore. | ||
metastore: { | ||
//+usage=Name of the discovery-configmap providing information about the HDFS cluster. | ||
cliOverrides: *{} | {...} | ||
//+usage=Name of the discovery-configmap providing information about the HDFS cluster. | ||
config: *{} | {...} | ||
//+usage=Name of the discovery-configmap providing information about the HDFS cluster. | ||
configOverrides: *{} | {...} | ||
//+usage=Name of the discovery-configmap providing information about the HDFS cluster. | ||
envOverrides: *{} | {...} | ||
//+usage=Name of the discovery-configmap providing information about the HDFS cluster. | ||
roleGroups: *{} | {...} | ||
} | ||
//+usage=Emergency stop button, if `true` then all pods are stopped without affecting configuration (as setting `replicas` to `0` would. | ||
stopped: *null | bool | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
"s3-bucket": { | ||
alias: "" | ||
annotations: {} | ||
attributes: workload: type: "autodetects.core.oam.dev" | ||
description: "s3 bucket component" | ||
labels: {} | ||
type: "component" | ||
} | ||
|
||
template: { | ||
output: { | ||
kind: "S3Bucket" | ||
apiVersion: "s3.stackable.tech/v1alpha1" | ||
metadata: { | ||
name: context.name | ||
} | ||
spec: { | ||
bucketName: parameter.bucketName | ||
connection: parameter.connection | ||
} | ||
} | ||
parameter: { | ||
//+usage=the name of the Bucket. | ||
bucketName: *null | string | ||
//+usage=can either be inline or reference. | ||
connection: { | ||
//+usage=the name of the Bucket. | ||
inline: *null | {...} | ||
//+usage=the name of the referenced S3Connection resource, which must be in the same namespace as the S3Bucket resource. | ||
reference: *null | string | ||
} | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
"s3-connection": { | ||
alias: "" | ||
annotations: {} | ||
attributes: workload: type: "autodetects.core.oam.dev" | ||
description: "s3 connection component" | ||
labels: {} | ||
type: "component" | ||
} | ||
|
||
template: { | ||
output: { | ||
kind: "S3Connection" | ||
apiVersion: "s3.stackable.tech/v1alpha1" | ||
metadata: { | ||
name: context.name | ||
} | ||
spec: { | ||
host: parameter.host | ||
port: parameter.port | ||
accessStyle: parameter.accessStyle | ||
credentials: parameter.credentials | ||
} | ||
} | ||
parameter: { | ||
//+usage=the domain name of the host of the object store, such as s3.west.provider.com. | ||
host: *null | string | ||
//+usage=a port such as 80 or 4242. | ||
port: *null | int | ||
//+usage=Optional. Can be either "VirtualHosted" (default) or "Path". | ||
accessStyle: *"VirtualHosted" | string | ||
//+usage=contains a secretClass. | ||
credentials: { | ||
//+usage=a reference to a SecretClass resource | ||
secretClass: *null | string | ||
} | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
"secret-class": { | ||
alias: "" | ||
annotations: {} | ||
attributes: workload: type: "autodetects.core.oam.dev" | ||
description: "secret class component" | ||
labels: {} | ||
type: "component" | ||
} | ||
|
||
template: { | ||
output: { | ||
kind: "SecretClass" | ||
apiVersion: "secrets.stackable.tech/v1alpha1" | ||
metadata: { | ||
name: context.name | ||
} | ||
spec: { | ||
backend: parameter.backend | ||
} | ||
} | ||
parameter: { | ||
//+usage=Configure backend. | ||
backend: { | ||
//+usage=Configure k8sSearch. | ||
k8sSearch: *null | {...} | ||
//+usage=Configure autoTls. | ||
autoTls: *null | {...} | ||
} | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
name: hive-operator | ||
version: 1.0.0 | ||
description: This addon adds hive-operator to the kubevela to be used across the application installed in kubevela. | ||
icon: "https://github.com/apache/hive/blob/master/docs/images/hive-logo.jpg" | ||
url: "https://hive.apache.org/" | ||
|
||
tags: | ||
- hive-operator | ||
|
||
invisible: false | ||
|
||
dependencies: | ||
- name: fluxcd |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can you try vela status?