ATTENTIONS: THIS PROJECT IS STILL UNDER DEVELOPMENT AND NOT STABLE YET.
Harbor is a very active project, composed on numerous stateful and stateless sub-projects and dependencies. These components may be deployed, updated, healed, backuped or scaled respecting some constraints.
The Harbor Operator extends the usual K8s resources with Harbor-related custom ones. The Kubernetes API can then be used in a declarative way to manage Harbor and ensure its high-availability operation, thanks to the Kubernetes control loop.
The Harbor operator aims to cover both Day1 and Day2 operations of an enterprise-grade Harbor deployment.
The operator was initially developed by OVHcloud and donated to the CNCF as part of the Harbor project in March 2020, becoming the basis of the official Kubernetes Operator.
OVHcloud uses the operator at scale to operate part of its private registry service, but the project was designed in an agnostic way, to bring value to any company in search of deploying and managing one or multiple Harbor.
Configuration allows tuning both Harbor itself (with or without some optional components) or its dependencies. It is designed to be used on any Kubernetes cluster, in a cloud or on premise context.
Harbor Operator is still very early stage and currently covers deployment, scale and destruction of Harbor in 1.10 version. Other parts of the life-cycle will be managed in future versions of the operator. As any project in this repository, do not hesitate to raise issues or suggest code improvements.
Harbor components is controlled by a custom Harbor resource. With ConfigMaps and Secrets, it handles almost all configuration combination.
- filesystem: A storage driver configured to use a directory tree in the a kubernetes volume.
- s3: A driver storing objects in an Amazon Simple Storage Service (S3) bucket.
- swift: A driver storing objects in Openstack Swift.
- azure: A driver storing objects in Microsoft Azure Blob Storage.
- oss: A driver storing objects in Aliyun OSS.
- gcs: A driver storing objects in a Google Cloud Storage bucket.
This operator is able to deploy an Harbor stack, fully or partially.
When Creating the Harbor
resource, following components are always deployed:
- Harbor Core
- Registry
- Registry Controller
- Portal
- Job Service
Following components are optional:
- ChartMuseum
- Notary
- Clair
- Trivy
When deleting the Harbor resource, all linked components are deleted. With two Harbor resources, the right components are deleted and components of the other Harbor are not changed.
It is possible to add and delete ChartMuseum, Notary, Clair and Trivy by editing the Harbor resource.
- Auto-scaling for each component.
- Backup/restore data (registry layer, chartmuseum data, databases content).
- Kubernetes >= 1.16
This Operator currently only supports Harbor version 2.0
Generate resources using make generate
Now, this project is maintained and developed by the Harbor operator workgroup. If you're willing to join the group and do contributions to operator project, welcome to contact us. Follow the Development guide to start on the project.
- Slack channel
#harbor-operator-dev
at CNCF Workspace - Send mail to Harbor dev mail group: [email protected]
- Contribute: https://github.com/goharbor/harbor-operator/blob/master/CONTRIBUTING.md
- Report bugs: https://github.com/goharbor/harbor-operator/issues
- Get latest version: https://hub.docker.com/r/goharbor/harbor-operator
See https://github.com/goharbor/harbor-operator/blob/master/LICENSE