Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sanjayheaven/ggb
Go Gin Boilerplate. A development boilerplate based on the Gin framework, aimed at helping developers quickly build and develop web applications.
https://github.com/sanjayheaven/ggb
gin gin-boilerplate gin-template go go-gin go-gin-boilerplate go-gin-template project-layout
Last synced: 4 days ago
JSON representation
Go Gin Boilerplate. A development boilerplate based on the Gin framework, aimed at helping developers quickly build and develop web applications.
- Host: GitHub
- URL: https://github.com/sanjayheaven/ggb
- Owner: sanjayheaven
- License: mit
- Created: 2024-01-09T06:47:48.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-02-07T03:16:41.000Z (about 1 year ago)
- Last Synced: 2025-02-14T04:36:45.649Z (6 days ago)
- Topics: gin, gin-boilerplate, gin-template, go, go-gin, go-gin-boilerplate, go-gin-template, project-layout
- Language: Go
- Homepage: https://sanjayheaven.github.io/ggb/
- Size: 13 MB
- Stars: 279
- Watchers: 1
- Forks: 11
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Go Gin Boilerplate
data:image/s3,"s3://crabby-images/6095f/6095fab0723fcf960e07560528994d4c7537efb8" alt="GitHub go.mod Go version"
data:image/s3,"s3://crabby-images/0e5b0/0e5b05b949e0f73b0c851dac0717c02a1fd9cb62" alt="CI"
data:image/s3,"s3://crabby-images/b49c1/b49c118ff718df4d805cb8fae0e568cedea150a3" alt="License"## π Documents
- [Project Document](https://sanjayheaven.github.io/ggb/)
- [Swagger Api Document](https://ggb.gganbu.services/swagger/index.html)## π¬ Introduction
A development boilerplate based on the Gin framework, aimed at helping developers quickly build and develop web applications.
- [English](./README.md)
- [δΈζδ»η»](./README_zh.md)## π Keywords
[Go](https://github.com/golang/go)
[Gin](https://github.com/gin-gonic/gin)
[Cobra](https://github.com/spf13/cobra)
[Viper](https://github.com/spf13/viper)
[Gorm](https://github.com/go-gorm/gorm)
[Gin-Swagger](https://github.com/swaggo/gin-swagger)
[Air](https://github.com/cosmtrek/air)
[Logrus](https://github.com/sirupsen/logrus)
[Lumberjack](https://github.com/natefinch/lumberjack)
[Zap](https://github.com/uber-go/zap)
[Jwt](https://github.com/golang-jwt/jwt)## β¨ Features
- **Fast Development**: Using the **Gin** framework and related tools to speed up the development and iteration process of the project..
- **Easy to use**: Follow the [project-layout](https://github.com/golang-standards/project-layout/tree/master) specification and provide a clear and simple code structure so that even beginners can easily get started.
- **Advanced CLI**: Using **Cobra** to build modern command line tools to simplify project management and operations.
- **Hot Reload**: Using **Air** tool, support hot reload, improve development efficiency.
- **Logging system**: Integrated **Logrus**, **Zap** and **Lumberjack** to achieve all-round log recording and management.
- **Database Support**: Integrated **Gorm**, support mainstream databases such as MySQL, PostgreSQL, etc.
- **Flexible Middleware**: Integrate common middleware to easily implement functions such as logging, authentication, cross-domain, and flow control.
- **API Document**: Use **Gin-Swagger** to generate API documents for easy viewing and debugging of interfaces.## π Quick Start
```sh
git clone https://github.com/sanjayheaven/ggb.git
cd ggb
go mod download
```### Configuration Setup
- Navigate to the `configs` directory, copy the `config.example.yaml` file, and rename it to `config.yaml`.
```sh
cp configs/config.example.yaml configs/config.yaml
```- Modify the configuration items in the `config.yaml` file.
```sh
vi configs/config.yaml
```### Run the Application
- Run the project using [air](https://github.com/cosmtrek/air) **γRecommendedγ**
```sh
air
```- Run the project using [go run](https://golang.org/cmd/go/#hdr-Compile_and_run_Go_program)
```sh
go run main.go server
```## π¨ Build
```sh
make build
```## πͺ€ Deployment
### docker-compose
Deploy the application using **_docker-compose_**.
Ensure that Docker is installed on the server, and you are familiar with the usage of docker compose.- Copy the `deployments/docker-compose.yml` configuration file to the project root directory.
- Execute the following command to start the application```sh
docker compose up -d
```## π€ Support
- Star π the project
- Welcome to submit [issue](https://github.com/sanjayheaven/ggb/issues). Thank you for your support
- Help promote it on social media and recommend it to friends[data:image/s3,"s3://crabby-images/19018/1901876aa05bf504f71e5e6dc6f8ddc8e0a5a3e8" alt="Twitter"](https://twitter.com/intent/tweet?text=Wow:&url=https%3A%2F%2Fgithub.com%2Fsanjayheaven%2Fggb)
[data:image/s3,"s3://crabby-images/77d00/77d00efdd23be2f85ea022258a0fdc108f13817e" alt="Facebook"](https://www.facebook.com/sharer/sharer.php?u=https%3A%2F%2Fgithub.com%2Fsanjayheaven%2Fggb)
[data:image/s3,"s3://crabby-images/9fc04/9fc04bf60e7ea9638760c61cb2d657e6f422fbb8" alt="WhatsApp"](https://api.whatsapp.com/send?text=Wow:%20https%3A%2F%2Fgithub.com%2Fsanjayheaven%2Fggb)
[data:image/s3,"s3://crabby-images/aa7e0/aa7e0f3fa0cd6c6383d2194af016873e5dfadc5b" alt="Telegram"](https://t.me/share/url?url=https%3A%2F%2Fgithub.com%2Fsanjayheaven%2Fggb)- You can also sponsor a cup of coffee on [Ko-Fi](https://ko-fi.com/dorvan) or [Buy Me A Coffee](https://www.buymeacoffee.com/dorvan)