An open source trusted cloud native registry project that stores, signs, and scans content.
Go to file
Daniel Jiang 5374f213c0 Merge pull request #261 from reasonerjt/job-service
store log in fs, provide api for getting log of a job
2016-05-24 11:10:48 +08:00
.github provide issue template 2016-04-22 15:04:29 +08:00
api store log in fs, provide api for getting log of a job 2016-05-23 19:39:13 +08:00
auth adapt to other ldap servers 2016-04-25 19:00:36 +08:00
contrib Rename 2016-04-22 18:03:40 +08:00
controllers Added support of Russian language 2016-05-13 13:31:09 +03:00
dao provide api to stop running jobs of a policy 2016-05-19 16:10:25 +08:00
Deploy remove job_log table 2016-05-24 11:08:49 +08:00
docs Resolve the merge conflict 2016-05-17 12:01:47 +08:00
job store log in fs, provide api for getting log of a job 2016-05-23 19:39:13 +08:00
jobservice store log in fs, provide api for getting log of a job 2016-05-23 19:39:13 +08:00
migration Update README.md 2016-05-13 18:08:52 +08:00
models api for getting jobs and policies 2016-05-17 18:49:02 +08:00
service add logs 2016-04-29 17:22:17 +08:00
static Added support of Russian language 2016-05-13 13:37:11 +03:00
ui update changepassword to /api/users/:id/password 2016-04-20 22:27:47 -07:00
utils update the depth in New func 2016-05-24 11:02:03 +08:00
vendor switch to /vendor, remove docker/distribution docker/libtrust go-sql-driver/mysql, and update Dockerfile to use go get to download these packages. 2016-02-19 13:01:58 +08:00
views Add support of Russian language 2016-05-13 13:27:35 +03:00
.gitignore add data migration module 2016-05-09 14:41:28 +08:00
.travis.yml bump up go version in travis.yml 2016-05-04 14:25:54 +08:00
AUTHORS update docs 2016-04-14 17:40:03 +08:00
Dockerfile.ui bump to golang 1.6.2 image to fix compilation error 2016-05-04 14:18:52 +08:00
favicon.ico added favicon.ico for Harbor 2016-03-11 14:34:56 +08:00
LICENSE update README, LICENSE, and bump to registry/2.3.0 2016-03-01 18:21:56 +08:00
NOTICE add NOTICE, update README.md 2016-03-03 10:15:12 +08:00
README.md Cleanup some of the documentation 2016-05-11 09:45:46 -07:00

Harbor

Build Status

alg tag

Project Harbor is initiated by VMware China R&D as a Cloud Application Accelerator (CAA) project. CAA provides a set of tools to improve the productivity of cloud developers in China and other countries. CAA includes tools like registry server, mirror server, decentralized image distributor, etc.

Project Harbor is an enterprise-class registry server, which extends the open source Docker Registry server by adding the functionality usually required by an enterprise, such as security, control, and management. Harbor is primarily designed to be a private registry - providing the needed security and control that enterprises require. It also helps minimize bandwidth usage, which is helpful to both improve productivity (local network access) as well as performance (for those with poor internet connectivity).

Features

  • Role Based Access Control: Users and docker repositories are organized via "projects", a user can have different permission for images under a namespace.
  • Graphical user portal: User can easily browse, search docker repositories, manage projects/namespaces.
  • AD/LDAP support: Harbor integrates with existing enterprise AD/LDAP for user authentication and management.
  • Auditing: All the operations to the repositories are tracked.
  • Internationalization: Already Localized for English, Chinese and German. More languages can be added.
  • RESTful API: RESTful APIs for most administrative operations, easing intergration with external management platforms.

Getting Started

Harbor is self-contained and can be easily deployed via docker-compose (Quick-Start steps below). Refer to the Installation and Configuration Guide for detailed information.

System requirements:
Harbor only works with docker 1.10+ and docker-compose 1.6.0+, and an internet-connected host

  1. Get the source code:

    $ git clone https://github.com/vmware/harbor
    
  2. Edit the file Deploy/harbor.cfg, make necessary configuration changes such as hostname, admin password and mail server. Refer to Installation and Configuration Guide for more info.

  3. Install Harbor with the following commands. Note that the docker-compose process can take a while!

    $ cd Deploy
    
    $ ./prepare
    Generated configuration file: ./config/ui/env
    Generated configuration file: ./config/ui/app.conf
    Generated configuration file: ./config/registry/config.yml
    Generated configuration file: ./config/db/env
    
    $ docker-compose up
    

If everything worked properly, you should be able to open a browser to visit the admin portal at http://reg.yourdomain.com . Note that the default administrator username/password are admin/Harbor12345 .

Log in to the admin portal and create a new project, e.g. myproject. You can then use docker commands to login and push images (By default, the registry server listens on port 80):

$ docker login reg.yourdomain.com
$ docker push reg.yourdomain.com/myproject/myrepo

NOTE:
For those who don't want to clone the source, or need to install Harbor on a server not connected to the Internet - there is a pre-built installation package available. For details on how to download and use this installation package, please refer to Installation and Configuration Guide .

For information on how to use Harbor, please see User Guide .

Deploy Harbor on Kubernetes

Detailed instruction about deploying Harbor on Kubernetes is available here.

Contribution

We welcome contributions from the community. If you wish to contribute code and you have not signed our contributor license agreement (CLA), our bot will update the issue when you open a pull request. For any questions about the CLA process, please refer to our FAQ.

License

Harbor is available under the Apache 2 license.

Partners

DataMan     SlamTec

Users

MaDaiLiCai

Supporting Technologies

beego Harbor is powered by Beego, an open source framework to build and develop applications in the Go way.