https://github.com/zeropsio/recipe-python
https://github.com/zeropsio/recipe-python
Last synced: about 1 month ago
JSON representation
- Host: GitHub
- URL: https://github.com/zeropsio/recipe-python
- Owner: zeropsio
- License: mit
- Created: 2024-06-11T12:24:11.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-06-23T13:16:17.000Z (almost 2 years ago)
- Last Synced: 2025-03-16T06:24:32.362Z (over 1 year ago)
- Language: Python
- Size: 15.6 KB
- Stars: 1
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Zerops x Python
This is the most bare-bones example of Python app running on [Zerops](https://zerops.io) — as few libraries as possible, just a simple endpoint with connnect, read and write to a Zerops PostgreSQL database.

## Deploy on Zerops
You can either click the deploy button to deploy directly on Zerops, or manually copy the [import yaml](https://github.com/zeropsio/recipe-python/blob/main/zerops-project-import.yml) to the import dialog in the Zerops app.
[](https://app.zerops.io/recipe/python)
## Recipe features
- **Python 3.12** app running on a load balanced **Zerops Python** service
- Zerops **PostgreSQL 16** service as database
- Healthcheck setup example
- Utilization of Zerops' built-in **environment variables** system
- Utilization of Zerops' built-in **log management**
## Production vs. development
Base of the recipe is ready for production, the difference comes down to:
- Use highly available version of the PostgreSQL database (change `mode` from `NON_HA` to `HA` in recipe YAML, `db` service section)
- Use at least two containers for the Python service to achieve high reliability and resilience (add `minContainers: 2` in recipe YAML, `api` service section)
Further things to think about when running more complex, highly available Python production apps on Zerops:
- Containers are volatile - use Zerops object storage to store your files
- Use Zerops Redis (KeyDB) for caching, storing sessions and pub/sub messaging
- Use more advanced logging lib, such as [loguru](https://github.com/Delgan/loguru), or [structlog](https://github.com/hynek/structlog)
Need help setting your project up? Join [Zerops Discord community](https://discord.com/invite/WDvCZ54).