Contributed by Xiaoyu Yao.
Ozone Distribution
This folder contains the project to create the binary ozone distribution and provide all the helper script and docker files to start it locally or in the cluster.
Testing with local docker based cluster
After a full dist build you can find multiple docker-compose based cluster definition in the target/ozone-*/compose
folder.
Please check the README files there.
Usually you can start the cluster with:
cd compose/ozone
docker-compose up -d
Testing on Kubernetes
You can also test the ozone cluster in kubernetes. If you have no active kubernetes cluster you can start a local one with minikube:
minikube start
For testing in kubernetes you need to:
- Create a docker image with the new build
- Upload it to a docker registery
- Deploy the cluster with apply kubernetes resources
The easiest way to do all these steps is using the skaffold tool. After the installation of skaffold, you can execute
skaffold run
in this (hadoop-ozone/dist
) folder.
The default kubernetes resources set (src/main/k8s/
) contains NodePort based service definitions for the Ozone Manager, Storage Container Manager and the S3 gateway.
With minikube you can access the services with:
minikube service s3g-public
minikube service om-public
minikube service scm-public
Monitoring
Apache Hadoop Ozone supports Prometheus out-of the box. It contains a prometheus compatible exporter servlet. To start the monitoring you need a prometheus deploy in your kubernetes cluster:
cd src/main/k8s/prometheus
kubectl apply -f .
The prometheus ui also could be access via a NodePort service:
minikube service prometheus-public
Notes on the Kubernetes setup
Please not that the provided kubernetes resources are not suitable production:
- There are no security setup
- The datanode is started in StatefulSet instead of DaemonSet (To make it possible to scale it up on one node minikube cluster)
- All the UI pages are published with NodePort services