- Gin as web framework
- JWT for authentication and authorization
- Redis for caching
- Elasticsearch for logging database
- Beat for log shipping
- Kibana as log viewer
- Postgresql as main database engine
- PgAdmin as database management tool
- Prometheus for metric database
- Grafana for metric dashboards
- Validator for endpoint input Validation
- Viper for configurations
- Zap for logging
- Zerolog for logging
- Gorm as ORM
- Swagger for documentation
- Docker compose to run project with all dependencies in docker
docker compose -f "docker/docker-compose.yml" up -d setup elasticsearch kibana filebeat postgres pgadmin redis prometheus node-exporter alertmanager grafana
cd src
go install github.com/swaggo/swag/cmd/swag@latest
cd src/cmd
go run main.go
Address: http://localhost:5005
docker compose -f "docker/docker-compose.yml" down
curl -X 'POST' \
'http://localhost:5005/api/v1/users/login-by-username' \
-H 'accept: application/json' \
-H 'Content-Type: application/json' \
-d '{
"password": "12345678",
"username": "admin"
}'
{
"filter": {
"Name": {
"filterType": "text",
"from": "t",
"type": "contains"
}
},
"pageNumber": 1,
"pageSize": 10,
"sort": [
{
"colId": "name",
"sort": "desc"
}
]
}
{
"filter": {
"Id": { // Column name
"filterType": "number", // number, text,...
"from": "1",
"to": "7",
"type": "inRange" // contains, equals,...
}
},
"pageNumber": 1,
"pageSize": 10,
"sort": [
{
"colId": "name",
"sort": "desc"
}
]
}
docker compose -f "docker/docker-compose.yml" up -d --build
Web API Run in docker http://localhost:9001
Token Url: http://localhost:9001/api/v1/users/login-by-username
Username: admin
Password: 12345678
Kibana http://localhost:5601
Username: elastic
Password: @aA123456
Prometheus http://localhost:9090
Grafana http://localhost:3000
Username: admin
Password: foobar
PgAdmin http://localhost:8090
Username: [email protected]
Password: 123456
Postgres Server info:
Host: postgres_container
Port: 5432
Username: postgres
Password: admin
docker compose -f 'docker/docker-compose.yml' --project-name 'docker' down
- build Project and copy configuration
/src > go build -o ../prod/server ./cmd/main.go
/src > mkdir ../prod/config/ && cp config/config-production.yml ../prod/config/config-production.yml
- Create systemd unit
sudo vi /lib/systemd/system/go-api.service
- Service config
[Unit]
Description=go-api
[Service]
Type=simple
Restart=always
RestartSec=20s
ExecStart=/home/hamed/github/golang-clean-web-api/prod/server
Environment="APP_ENV=production"
WorkingDirectory=/home/hamed/github/golang-clean-web-api/prod
[Install]
WantedBy=multi-user.target
- Start service
sudo systemctl start go-api
- Stop service
sudo systemctl stop go-api
- Show service logs
sudo journalctl -u go-api -e