Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/packit/deployment
Ansible playbooks and scripts for deploying packit-service to OpenShift
https://github.com/packit/deployment
ansible hacktoberfest
Last synced: about 2 months ago
JSON representation
Ansible playbooks and scripts for deploying packit-service to OpenShift
- Host: GitHub
- URL: https://github.com/packit/deployment
- Owner: packit
- License: mit
- Created: 2019-08-12T11:44:08.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2024-11-20T18:02:58.000Z (about 2 months ago)
- Last Synced: 2024-11-20T19:19:10.723Z (about 2 months ago)
- Topics: ansible, hacktoberfest
- Language: Jinja
- Homepage:
- Size: 1.47 MB
- Stars: 8
- Watchers: 9
- Forks: 25
- Open Issues: 19
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# Deploying Packit service or Stream service to Openshift
This repository contains Ansible playbooks/roles
to deploy our services/bots to Openshift cluster.
This file documents basic usage, for more info see
[docs](docs/) (below).## What's in here
- [containers/](containers/) - files used to build container images
- [cron-jobs/](cron-jobs/) - OpenShift cron jobs
- [docs/](docs/) - more documentation
- [Images](docs/images.md) - what images we have and how we build them
- [Continuous deployment](docs/continuous-deployment.md) - how are the deployed services/bots updated
- [Testing changes](docs/testing-changes.md) - how to test our services/bots locally
- [Let's encrypt TLS certs](docs/tls-certs.md) - generating & renewing with `certbot`
- [Monitoring](docs/monitoring.md)
- [PostgreSQL data migration](docs/postgresql-db-upgrade.md)
- [Packit service deployment specifics](docs/packit-service.md)
- [Fedora source-git bot deployment specifics](docs/fedora-source-git.md)
- [CentOS Stream source-git bot deployment specifics](docs/centos-stream-source-git.md)
- [Logs](docs/logs.md) - how we aggregate worker logs and where to find them
- [playbooks/](playbooks/) - Ansible playbooks
- [roles/](roles/) - Ansible roles
- [vars/](vars/) - Variable file(s). See [vars/README.md](vars/README.md).
- [openshift/](openshift/) - Openshift resource configuration files (templates).
- [secrets/](secrets/) - secret stuff to be used from `openshift/secret-*.yml.j2`
- [scripts/](scripts/) - devops scripts used in multiple repositories## tl;dr How to deploy
1. Configure the deployment by creating a variable file in 'vars/' from a
template as described in [vars/README](vars/README.md).
2. Install some dependencies:
- `dnf install ansible python3-openshift python3-passlib jq make`
- `dnf install origin-clients` or (for a more recent version) download
`openshift-client-linux` from the [OKD
releases](https://github.com/openshift/okd/releases) page, unpack it, and
place `oc` in your `$PATH` (ex: `~/.local/bin`).
- Download the [Bitwarden
CLI](https://bitwarden.com/help/cli/#download-and-install),
unpack and place it in your `$PATH` (ex: `~/.local/bin`).
3. `[SERVICE={service}] DEPLOYMENT={deployment} make deploy` (see
[vars/README](vars/README.md)).By default, the playbook checks that the local copy of the deployment is
up-to-date, and the variable file used is
up-to-date with the corresponding template.To disable these checks, set `check_up_to_date` to `false` in the
variable file.To only disable comparing the variable file to the template, set
`check_vars_template_diff` to `false`.### Partial deployments
To run only the tasks related to some of the services, this way doing a
partial deployment, you can set the `TAGS` environment variable before calling
`make`. For example, to run only the tasks to deploy Redict and Redis
Commander, run:$ DEPLOYMENT=dev TAGS="redict,redis-commander" make deploy
Use `make tags` to list the currently available tags.
## See [docs/](docs/) for more documentation.