mirror of
https://github.com/goharbor/harbor.git
synced 2025-01-21 23:21:26 +01:00
Add document for admin server refactor (#7479)
Signed-off-by: stonezdj <stonezdj@gmail.com>
This commit is contained in:
parent
e091916d54
commit
978c7027a1
112
docs/configure_user_settings.md
Normal file
112
docs/configure_user_settings.md
Normal file
@ -0,0 +1,112 @@
|
||||
# Config Harbor user settings by command line
|
||||
|
||||
After release 1.8.0, all user settings are separated from system settings, it can not be configured in config file anymore. Users need to configure it with admin privileges in web console or via HTTP request.
|
||||
|
||||
`curl -X PUT -u "<username>:<password>" -H "Content-Type: application/json" -ki <Harbor Server URL>/api/configurations -d'{"<item_name>":"<item_value>"}'`
|
||||
|
||||
Get current configurations
|
||||
|
||||
`curl -u "<username>:<password>" -H "Content-Type: application/json" -ki <Harbor Server URL>/api/configurations`
|
||||
|
||||
## Sample config commands:
|
||||
|
||||
1. Update Harbor to use LDAP auth
|
||||
|
||||
Command
|
||||
```shell
|
||||
curl -X PUT -u "<username>:<password>" -H "Content-Type: application/json" -ki https://harbor.sample.domain/api/configurations -d'{"auth_mode":"ldap_auth"}'
|
||||
```
|
||||
Output
|
||||
```
|
||||
HTTP/1.1 200 OK
|
||||
Server: nginx
|
||||
Date: Wed, 08 May 2019 08:22:02 GMT
|
||||
Content-Type: text/plain; charset=utf-8
|
||||
Content-Length: 0
|
||||
Connection: keep-alive
|
||||
Set-Cookie: sid=a5803a1265e2b095cf65ce1d8bbd79b1; Path=/; HttpOnly
|
||||
```
|
||||
|
||||
1. Restrict project creation to admin only
|
||||
|
||||
Command
|
||||
```shell
|
||||
curl -X PUT -u "<username>:<password>" -H "Content-Type: application/json" -ki https://harbor.sample.domain/api/configurations -d'{"project_creation_restriction":"adminonly"}'
|
||||
```
|
||||
|
||||
Output
|
||||
```
|
||||
HTTP/1.1 200 OK
|
||||
Server: nginx
|
||||
Date: Wed, 08 May 2019 08:24:32 GMT
|
||||
Content-Type: text/plain; charset=utf-8
|
||||
Content-Length: 0
|
||||
Connection: keep-alive
|
||||
Set-Cookie: sid=b7925eaf7af53bdefb13bdcae201a14a; Path=/; HttpOnly
|
||||
```
|
||||
|
||||
1. Update the token expiration time
|
||||
|
||||
Command
|
||||
```shell
|
||||
curl -X PUT -u "<username>:<password>" -H "Content-Type: application/json" -ki https://harbor.sample.domain/api/configurations -d'{"token_expiration":"300"}'
|
||||
```
|
||||
|
||||
Output
|
||||
```
|
||||
HTTP/1.1 200 OK
|
||||
Server: nginx
|
||||
Date: Wed, 08 May 2019 08:23:38 GMT
|
||||
Content-Type: text/plain; charset=utf-8
|
||||
Content-Length: 0
|
||||
Connection: keep-alive
|
||||
Set-Cookie: sid=cc1bc93ffa2675253fc62b4bf3d9de0e; Path=/; HttpOnly
|
||||
```
|
||||
|
||||
## Harbor user settings
|
||||
|
||||
| Configure item name | Description | Type | Required | Default Value |
|
||||
| ------------ |------------ | ---- | ----- | ----- |
|
||||
auth_mode | Authentication mode, it can be db_auth, ldap_auth, uaa_auth or oidc_auth | string
|
||||
email_from | Email from | string | required (email feature)
|
||||
email_host | Email server | string | required (email feature)
|
||||
email_identity | Email identity | string | optional (email feature)
|
||||
email_password | Email password | string | required (email feature)
|
||||
email_insecure | Email verify certificate, true or false |boolean | optional (email feature) | false
|
||||
email_port | Email server port | number | required (email feature)
|
||||
email_ssl | Email SSL | boolean | optional | false
|
||||
email_username | Email username | string | required (email feature)
|
||||
ldap_url | LDAP URL | string | required |
|
||||
ldap_base_dn | LDAP base DN | string | required(ldap_auth)
|
||||
ldap_filter | LDAP filter | string | optional
|
||||
ldap_scope | LDAP search scope, 0-Base Level, 1- One Level, 2-Sub Tree | number | optional | 2-Sub Tree
|
||||
ldap_search_dn | LDAP DN to search LDAP users| string | required(ldap_auth)
|
||||
ldap_search_password | LDAP DN's password |string | required(ldap_auth)
|
||||
ldap_timeout | LDAP connection timeout | number | optional | 5
|
||||
ldap_uid | LDAP attribute to indicate the username in Harbor | string | optional | cn
|
||||
ldap_verify_cert | Verify cert when create SSL connection with LDAP server, true or false | boolean | optional | true
|
||||
ldap_group_admin_dn | LDAP Group Admin DN | string | optional
|
||||
ldap_group_attribute_name | LDAP Group Attribute, the LDAP attribute indicate the groupname in Harbor, it can be gid or cn | string | optional | cn
|
||||
ldap_group_base_dn | The Base DN which to search the LDAP groups | string | required(ldap_auth and LDAP group)
|
||||
ldap_group_search_filter | The filter to search LDAP groups | string | optional
|
||||
ldap_group_search_scope | LDAP group search scope, 0-Base Level, 1- One Level, 2-Sub Tree | number | optional | 2-Sub Tree|
|
||||
ldap_group_membership_attribute | LDAP group membership attribute, to indicate the group membership, it can be memberof, or ismemberof | string | optional | memberof
|
||||
project_creation_restriction | The option to indicate user can be create object, it can be everyone, adminonly | string | optional | everyone
|
||||
read_only | The option to set repository read only, it can be true or false | boolean | optional | false
|
||||
self_registration | User can register account in Harbor, it can be true or false | boolean | optional| true
|
||||
token_expiration | Security token expirtation time in minutes | number |optional| 30
|
||||
uaa_client_id | UAA client ID | string | required(uaa_auth)
|
||||
uaa_client_secret | UAA certificate | string | required(uaa_auth)
|
||||
uaa_endpoint | UAA endpoint | string | required(uaa_auth)
|
||||
uaa_verify_cert | UAA verify cert, true or false | boolean | optional | true
|
||||
oidc_name | name for OIDC authentication | string | required(oidc_auth)
|
||||
oidc_endpoint | endpoint for OIDC auth | string | required(oidc_auth)
|
||||
oidc_client_id | client id for OIDC auth | string | required(oidc_auth)
|
||||
oidc_client_secret | client secret for OIDC auth |string | required(oidc_auth)
|
||||
oidc_scope | scope for OIDC auth | string| required(oidc_auth)
|
||||
oidc_verify_cert | verify cert for OIDC auth, true or false | boolean | optional| true
|
||||
robot_token_duration | Robot token expiration time in minutes | number | optional | 43200 (30days)
|
||||
|
||||
|
||||
|
||||
**Note:** Both boolean and number can be enclosed with double quote in the request json, for example: `123`, `"123"`, `"true"` or `true` is OK.
|
@ -87,40 +87,7 @@ The parameters are described below - note that at the very least, you will need
|
||||
* **http_proxy**: Config http proxy for Clair, e.g. `http://my.proxy.com:3128`.
|
||||
* **https_proxy**: Config https proxy for Clair, e.g. `http://my.proxy.com:3128`.
|
||||
* **no_proxy**: Config no proxy for Clair, e.g. `127.0.0.1,localhost,core,registry`.
|
||||
|
||||
##### Optional parameters
|
||||
* **Email settings**: These parameters are needed for Harbor to be able to send a user a "password reset" email, and are only necessary if that functionality is needed. Also, do note that by default SSL connectivity is _not_ enabled - if your SMTP server requires SSL, but does _not_ support STARTTLS, then you should enable SSL by setting **email_ssl = true**. Setting **email_insecure = true** if the email server uses a self-signed or untrusted certificate. For a detailed description about "email_identity" please refer to [rfc2595](https://tools.ietf.org/rfc/rfc2595.txt)
|
||||
* email_server = smtp.mydomain.com
|
||||
* email_server_port = 25
|
||||
* email_identity =
|
||||
* email_username = sample_admin@mydomain.com
|
||||
* email_password = abc
|
||||
* email_from = admin <sample_admin@mydomain.com>
|
||||
* email_ssl = false
|
||||
* email_insecure = false
|
||||
|
||||
* **harbor_admin_password**: The administrator's initial password. This password only takes effect for the first time Harbor launches. After that, this setting is ignored and the administrator's password should be set in the Portal. _Note that the default username/password are **admin/Harbor12345** ._
|
||||
* **auth_mode**: The type of authentication that is used. By default, it is **db_auth**, i.e. the credentials are stored in a database.
|
||||
For LDAP authentication, set this to **ldap_auth**.
|
||||
|
||||
**IMPORTANT:** When upgrading from an existing Harbor instance, you must make sure **auth_mode** is the same in ```harbor.cfg``` before launching the new version of Harbor. Otherwise, users
|
||||
may not be able to log in after the upgrade.
|
||||
* **ldap_url**: The LDAP endpoint URL (e.g. `ldaps://ldap.mydomain.com`). _Only used when **auth_mode** is set to *ldap_auth* ._
|
||||
* **ldap_searchdn**: The DN of a user who has the permission to search an LDAP/AD server (e.g. `uid=admin,ou=people,dc=mydomain,dc=com`).
|
||||
* **ldap_search_pwd**: The password of the user specified by *ldap_searchdn*.
|
||||
* **ldap_basedn**: The base DN to look up a user, e.g. `ou=people,dc=mydomain,dc=com`. _Only used when **auth_mode** is set to *ldap_auth* ._
|
||||
* **ldap_filter**: The search filter for looking up a user, e.g. `(objectClass=person)`.
|
||||
* **ldap_uid**: The attribute used to match a user during a LDAP search, it could be uid, cn, email or other attributes.
|
||||
* **ldap_scope**: The scope to search for a user, 0-LDAP_SCOPE_BASE, 1-LDAP_SCOPE_ONELEVEL, 2-LDAP_SCOPE_SUBTREE. Default is 2.
|
||||
* **ldap_timeout**: Timeout (in seconds) when connecting to an LDAP Server. Default is 5.
|
||||
* **ldap_verify_cert**: Verify certificate from LDAP server. Default is true.
|
||||
* **ldap_group_basedn**: The base dn from which to lookup a group in LDAP/AD, e.g. `ou=group,dc=mydomain,dc=com`.
|
||||
* **ldap_group_filter**: The filter to search LDAP/AD group, e.g. `objectclass=group`.
|
||||
* **ldap_group_gid**: The attribute used to name a LDAP/AD group, it could be cn, name.
|
||||
* **ldap_group_scope**: The scope to search for ldap groups. 0-LDAP_SCOPE_BASE, 1-LDAP_SCOPE_ONELEVEL, 2-LDAP_SCOPE_SUBTREE. Default is 2.
|
||||
* **self_registration**: (**on** or **off**. Default is **on**) Enable / Disable the ability for a user to register himself/herself. When disabled, new users can only be created by the Admin user, only an admin user can create new users in Harbor. _NOTE: When **auth_mode** is set to **ldap_auth**, self-registration feature is **always** disabled, and this flag is ignored._
|
||||
* **token_expiration**: The expiration time (in minutes) of a token created by token service, default is 30 minutes.
|
||||
* **project_creation_restriction**: The flag to control what users have permission to create projects. By default everyone can create a project, set to "adminonly" such that only admin can create project.
|
||||
|
||||
#### Configuring storage backend (optional)
|
||||
|
||||
@ -140,7 +107,6 @@ registry_storage_provider_config="username: admin, password: ADMIN_PASS, authurl
|
||||
|
||||
_NOTE: For detailed information on storage backend of a registry, refer to [Registry Configuration Reference](https://docs.docker.com/registry/configuration/) ._
|
||||
|
||||
|
||||
#### Finishing installation and starting Harbor
|
||||
Once **harbor.cfg** and storage backend (optional) are configured, install and start Harbor using the ```install.sh``` script. Note that it may take some time for the online installer to download Harbor images from Docker hub.
|
||||
|
||||
@ -378,6 +344,9 @@ hostname = 192.168.0.2:8888
|
||||
|
||||
4.Re-deploy Harbor referring to previous section "Managing Harbor's lifecycle".
|
||||
|
||||
## Manage user settings
|
||||
After release 1.8.0, User settings are separated with system settings, and all user settings should be configured in web console or by HTTP request.
|
||||
Please refer [Configure User Settings](configure_user_settings.md) to config user settings.
|
||||
|
||||
## Performance tuning
|
||||
By default, Harbor limits the CPU usage of Clair container to 150000 and avoids its using up all the CPU resources. This is defined in the docker-compose.clair.yml file. You can modify it based on your hardware configuration.
|
||||
|
Loading…
Reference in New Issue
Block a user