7.7 KiB
via quay github
Running Quay For Development
The Quay team has developed and supports a Docker based local development environment. This environment can quickly setup Quay and Clair for developing and testing changes. When utilizing the local development environment changes to your source code are automatically hot-reloaded, taking effect in real time.
Beyond Docker and docker-compose, to develop Quay you will also need Python and the full set of requirements in order to successfully run the test suite. Python 3.9 and earlier are currently supported.
Requirements
- Docker
- docker-compose
- Python 3.9
- Node 16.12.0
- libmagic
❗ Be mindful that overriding your operating system's default Python version is not a good idea. Check out this guide for instructions on installing Python 3 on RHEL 8, or alternatively use pyenv.
Run either of the following in the quay directory where the repository is forked. It installs the pre-commit checks like trailing-whitespace, new line at EOF, secret leaks and black required before pushing to git.
pip install pre-commit==2.20.0
pre-commit install
or you can run:
make install-pre-commit-hook
Building and Running with Docker Compose
The below commands rely on Docker and Docker Compose to be installed. You can also run Quay with podman - refer to the project's docker-compose.yml
file to understand and reproduce the setup.
Starting Quay
To run Quay's basic components and database, use the local-dev-up
make target.
❗ If using Docker Desktop it's possible the virtual machine used is too resource constrained to host Quay. Refer to the Docker Desktop manual for instructions on increasing resources. Make sure to provide Docker Desktop with more memory and CPU to ensure smooth performance.
make local-dev-up
Components started:
Infra | Local Adress | Docker Network Address |
---|---|---|
Quay | localhost:8080 |
quay-quay:8080 |
Quay Database | localhost:5432 |
quay-db:5432 |
Quay Redis | localhost:6379 |
quay-redis:6379 |
Starting Quay With Clair
To also run Clair, use the local-dev-up-with-clair
make target instead.
make local-dev-up-with-clair
Components started:
Infra | Local Adress | Docker Network Address |
---|---|---|
Quay | localhost:8080 |
quay-quay:8080 |
Quay Database | localhost:5432 |
quay-db:5432 |
Quay Redis | localhost:6379 |
quay-redis:6379 |
Clair | (not exposed) | localhost:6000 from Quay container |
Clair Database | localhost:5433 |
clair-db:5432 |
Note: Clair is deployed in the network namespace of the Quay container. This allows Quay to provide Clair layer location information over localhost
.
Hot-Reload
The local development environment supports hot-reload of Quay, Quay workers, and the front end UI code.
Quay registry runs in production as a gunicorn worker so no changes except enabling hot-reload is necessary.
Quay workers run as generic python modules in production. To support hot-reloading each worker was modified to run as a gunicorn worker sub-process (only for local-dev). When the source code is updated and saved to disk the gunicorn worker is restarted.
The front end code supports hot-reload by running npm watch
in the background during container startup.
Container Reload
The make target local-docker-rebuild
focuses on reloading all running docker containers. By default only quay-quay
, quay-db
and quay-redis
are rebuilt. quay-clair
and clair-db
can be included in rebuild by passing an optional CLAIR
variable.
CLAIR=true make local-docker-rebuild
Troubleshooting
Here you'll find some common troubles people run into while setting up their local development environments.
Not Enough Resources
If using Docker Desktop it's possible the virtual machine used is too resource constrained to host Quay. Refer to the Docker Desktop manual for instructions on increasing resources. Make sure to provide Docker Desktop with more memory and CPU to ensure smooth performance.
Blocked Traffic (Firewalld)
In certain cases firewalld may block network traffic between the host and containers. If you are experiencing connectivity issues try disabling Firewalld or any other firewall on your host machine.
Port conflicts
If you are running any containers or services on the same ports the local development environment tries to bind to you will experience connectivity issues or errors. Make sure no other software is bound to the required ports (see Starting Quay and Starting Quay With Clair for the full list) while utilizing the local development environment.
Running Tests
Quay is covered by tests using various approaches. Read our testing guide for details.
Contributing
How great that you want to contribute to Quay! Before starting make sure to check our contributing guidelines.
Using Quay
Container images can be tagged and pushed to your local quay instance.
The following steps outline how to accomplish this:
NOTE: if you're using docker instead of podman, make sure to configure the docker daemon to accept insecure registries by following this guide.
-
Visit
http://localhost:8080
and create an account. (Using the username 'admin' will create a superuser account). -
Create an organization and repository, we will refer to these as {org} and {repo}.
-
Use podman or docker to login (we will use podman as pushing to http is far easier).
$ podman login --tls-verify=false localhost:8080
-
Tag any image with the local development repository hostname, org, repo, and tag.
$ podman tag ubuntu:latest localhost:8080/{org}/{repo}:{tag}
-
Push the tagged image to Quay
$ podman push --tls-verify=false localhost:8080/{org}/{repo}:{tag}