Skip to content

Kubernetes operator for Harbor service components

License

Notifications You must be signed in to change notification settings

chlins/harbor-operator

 
 

Repository files navigation

Harbor Operator

ATTENTIONS: THIS PROJECT IS STILL UNDER DEVELOPMENT AND NOT STABLE YET.

Why an Harbor Operator

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.

A modular and agnostic design

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.

Project status

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.

Features

Harbor components is controlled by a custom Harbor resource. With ConfigMaps and Secrets, it handles almost all configuration combination.

Supported storage configuration

  • 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.

Deploy a new stack

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

Delete the stack

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.

Adding/Removing a component

It is possible to add and delete ChartMuseum, Notary, Clair and Trivy by editing the Harbor resource.

Future features

  1. Auto-scaling for each component.
  2. Backup/restore data (registry layer, chartmuseum data, databases content).

Installation

See install documentation.

Compatibility

Supported platforms

Harbor version

This Operator currently only supports Harbor version 2.0

Howto's

Configuration

Generate resources using make generate

Development

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.

Community

Additional documentation

  1. Learn how reconciliation works
  2. Custom Resource Definition

Related links

License

See https://github.com/goharbor/harbor-operator/blob/master/LICENSE

About

Kubernetes operator for Harbor service components

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 96.6%
  • Makefile 3.1%
  • Other 0.3%