Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/neoxelox/service
Highly opinionated Go service.
https://github.com/neoxelox/service
api cli go golang http microservice neoxelox service worker
Last synced: 2 months ago
JSON representation
Highly opinionated Go service.
- Host: GitHub
- URL: https://github.com/neoxelox/service
- Owner: Neoxelox
- License: mit
- Created: 2020-02-28T22:37:37.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2024-09-09T14:10:29.000Z (4 months ago)
- Last Synced: 2024-09-09T17:12:26.152Z (4 months ago)
- Topics: api, cli, go, golang, http, microservice, neoxelox, service, worker
- Language: Go
- Homepage:
- Size: 253 KB
- Stars: 16
- Watchers: 6
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# service
**`Highly opinionated Go service.`** 🐻
## What
This is a complete over-engineered Golang service template, which strongly relies on the building blocks of my (also) [**`highly opinionated Go backend kit`**](https://github.com/neoxelox/kit).
> This template is already being used by some companies on production, handling non-trivial volumes of traffic. However, use it at your own "risk", this is a personal project and support is not the main intention.
## Features
This repository packs so many features that I am unable to sit down and list them all : ). Feel free to take a look at the code.
## Before Getting Started
### Development
Make a copy of `envs/dev/.env.example` to `envs/dev/.env` and fill the variables. `envs/dev/.env` is an ignored file so you won't have the chance to commit it with potential production values 😉.
Also, to setup the environment, follow these steps:
1. Install dependencies: `pip install -r scripts/requirements.txt`
2. Install tools `inv tool.install --include "dev*"`Run `inv help` for further commands and `inv --help` for their usage.
### Production
To make this environment work you will have to make the following changes:
1. Make a copy of `envs/prod/.env.example` to `envs/prod/.env` (which is ignored) and fill the variables.
2. Create 2 [Cloudflare Tunnels](https://developers.cloudflare.com/cloudflare-one/connections/connect-networks/), one for exterior user accessible services `ext`, and the other for interior company-only accessible services and tools `int`.
3. Download both Tunnels certificates to `envs/prod/certs/` (which is ignored).
4. Fill both Tunnels configuration files `envs/prod/cloudflared-ext.yaml & cloudflared-int.yaml` with the Tunnel ID, credentials path and hostnames.
5. Change the `scripts/tasks.py` `build & deploy` tasks to tag and push your service images to your registry of preference (it should be a private registry...).
6) Finally, fill the `envs/prod/docker-compose.yaml` so the service containers point to your own registry images.
## Contribute
Feel free to contribute to this project : ) .
## License
This project is licensed under the [MIT License](https://opensource.org/licenses/MIT) - read the [LICENSE](LICENSE) file for details.