0
Fork 0
mirror of https://github.com/project-zot/zot.git synced 2024-12-16 21:56:37 -05:00
zot/pkg/api
Vishwas R 5ae7a028d9
feat(cluster): Add support for request proxying for scale out (#2385)
* feat(cluster): initial commit for scale-out cluster

Signed-off-by: Ramkumar Chinchani <rchincha@cisco.com>

* feat(cluster): support shared storage scale out

This change introduces support for shared storage backed
zot cluster scale out.

New feature
Multiple stateless zot instances can run using the same shared
storage backend where each instance looks at a specific set
of repositories based on a siphash of the repository name to improve
scale as the load is distributed across multiple instances.
For a given config, there will only be one instance that can perform
dist-spec read/write on a given repository.

What's changed?
- introduced a transparent request proxy for dist-spec endpoints based on
siphash of repository name.
- new config for scale out cluster that specifies list of
cluster members.

Signed-off-by: Vishwas Rajashekar <vrajashe@cisco.com>

---------

Signed-off-by: Ramkumar Chinchani <rchincha@cisco.com>
Signed-off-by: Vishwas Rajashekar <vrajashe@cisco.com>
Co-authored-by: Ramkumar Chinchani <rchincha@cisco.com>
2024-05-20 09:05:21 -07:00
..
config feat(cluster): Add support for request proxying for scale out (#2385) 2024-05-20 09:05:21 -07:00
constants feat(cluster): Add support for request proxying for scale out (#2385) 2024-05-20 09:05:21 -07:00
errors refactor: rename go module from zotregistry.io/zot to zotregistry.dev/zot (#2187) 2024-01-31 20:34:07 -08:00
authn.go fix(sync): added bearer client for sync (#2222) 2024-02-14 09:18:10 -08:00
authn_test.go test: fix flacky coverage in cookiestore cleanup tests (#2257) 2024-02-19 14:43:30 -08:00
authz.go refactor: rename go module from zotregistry.io/zot to zotregistry.dev/zot (#2187) 2024-01-31 20:34:07 -08:00
controller.go feat(cluster): Add support for request proxying for scale out (#2385) 2024-05-20 09:05:21 -07:00
controller_test.go feat(cluster): Add support for request proxying for scale out (#2385) 2024-05-20 09:05:21 -07:00
cookiestore.go test: fix flacky coverage in cookiestore cleanup tests (#2257) 2024-02-19 14:43:30 -08:00
ldap.go chore: fix dependabot alerts (#2377) 2024-04-09 10:40:16 +03:00
proxy.go feat(cluster): Add support for request proxying for scale out (#2385) 2024-05-20 09:05:21 -07:00
proxy_test.go feat(cluster): Add support for request proxying for scale out (#2385) 2024-05-20 09:05:21 -07:00
recovery.go refactor: rename go module from zotregistry.io/zot to zotregistry.dev/zot (#2187) 2024-01-31 20:34:07 -08:00
routes.go feat(cluster): Add support for request proxying for scale out (#2385) 2024-05-20 09:05:21 -07:00
routes_test.go refactor: rename go module from zotregistry.io/zot to zotregistry.dev/zot (#2187) 2024-01-31 20:34:07 -08:00
session.go refactor: rename go module from zotregistry.io/zot to zotregistry.dev/zot (#2187) 2024-01-31 20:34:07 -08:00