Skip to content

spiritman1990/juno

 
 

Repository files navigation

Juno


juno 是一套轻量级 Go 微服务框架,包含大量微服务相关框架及工具。

特点

  1. 灵活:仅仅搭建了项目框架,每个部分都可以用类似组件替代,组件升级不依赖于框架升级;
  2. 简单:不过度设计,代码平实简单;
  3. 通用:通用业务开发所需要的功能;
  4. 高效:提高业务迭代的效率;
  5. 健壮:通过良好的基础库设计,减少错用;
  6. 高性能:性能高,但不特定为了性能做 hack 优化,引入 unsafe ;
  7. 扩展性:良好的接口设计,来扩展实现,或者通过新增目录来扩展功能;
  8. 容错性:为失败设计,大量引入对 SRE 的理解,鲁棒性高;
  9. 工具链:包含大量工具链,比如代码生成,lint 工具等等;

创建项目

版本需求

需要使用 go v1.16 以上版本;

环境准备

需要安装好对应的依赖环境,以及工具:

开启 GO111MODULE go env -w GO111MODULE=on

安装


go install github.com/go-juno/juno@latest

创建项目

# 创建项目模板
juno new helloworld
cd helloworld
# 拉取项目依赖
go mod download

# 生成service模板
juno service hello

# 生成endpoint模板
juno endpoint hello

# 生成http模板
juno http hello

# 生成grpc模板
juno grpc hello

项目结构

项目

目录结构如下

├── Dockerfile
├── LICENSE
├── README.md
├── api  --- 为外部提供的服务(http,grpc)
│   ├── grpc ---grpc服务
│   │   ├── grpc.go  ---提供grpc实例
│   │   ├── protos ---proto 文件以及生成的代码
│   │   │   ├── greeting.pb.go
│   │   │   ├── greeting.proto
│   │   │   └── greeting_grpc.pb.go
│   │   └── service ---根据proto文件实现的具体方法
│   │       ├── greeting.go
│   │       ├── greeting_test.go
│   │       └── service.go
│   └── http ---http服务
│       ├── handle  ---提供具体的http handle
│       │   └── greeting.go
│       ├── http.go  ---提供http实例
│       ├── middleware  ---http中间件
│       │   └── middleware.go
│       ├── schema  ---http请求校验以及转化为endpoint的入参
│       │   └── greeting.go
│       └── serialize ---endpoint的出参转化为http的response
│           ├── base.go
│           └── greeting.go
├── cmd  --- 整个项目启动的入口文件
│   ├── serve.go
│   ├── wire.go --- 使用wire来维护依赖注入
│   └── wire_gen.go
├── configs  --- 配置文件
│   └── config.yaml
├── generate.go
├── go.mod
├── go.sum
├── init
│   ├── config
│   │   └── config.go
│   └── flag
│       └── flag.go
├── internal   ---所有不对外暴露的代码,通常的业务逻辑都在这下面,使用internal避免错误引用
│   ├── constant ---常量
│   │   └── constant.go
│   ├── database ---数据库
│   │   └── database.go
│   ├── endpoint --- 业务逻辑的组装层,类似 DDD 的 domain 层
│   │   ├── endpoint.go
│   │   └── greeting.go
│   ├── model --- 数据模型
│   │   └── greeting.go
│   └── service --- 业务数据访问,包含 cache、db 等封装
│       ├── greeting.go
│       └── service.go
├── main.go ---项目启动
└── pkg  ---公用包
    ├── model ---基础数据模型
    │   └── model.go
    ├── res ---http返回类型
    │   └── response.go
    └── util ---工具包
        └── util.go

启动项目


# 先修改configs/config.yaml 中数据库连接的配置
go run main.go

awesome 工具

air 代码热更新

代码变更,自动热更新重启。推荐使用 github.com/cosmtrek/air .air.conf文件是一份默认配置,若已安装 air ,直接在路径下运行 air 即可

golangci-lint 代码静态检查

  // brew
  brew install golangci-lint

pre-commit git commit hook

  // brew
    brew install pre-commit
  // python
  pip3 install pre-commit

  // install
   pre-commit install

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 84.0%
  • Smarty 15.3%
  • Dockerfile 0.7%