高效率低代码Go语言开发框架
Sponge是一个基于Go语言的开发框架,集成自动代码生成、Gin和gRPC。该框架提供多种代码生成命令,支持将不同功能代码组合成完整服务。Sponge覆盖项目全周期,包括代码生成、开发、测试、API文档和部署。它适用于Web和gRPC服务开发,支持MySQL、MongoDB等多种数据库,并提供微服务框架和服务治理功能,有助于提高开发效率,降低开发难度。
Sponge 是一个强大的开发框架,集成了自动代码生成
、Gin和GRPC
。Sponge拥有丰富的代码生成命令集,生成的不同功能代码可以组合成一个完整的服务(类似于人为破碎的海绵细胞可以自动重组成新的完整海绵)。Sponge提供一站式项目开发(代码生成、开发、测试、API文档、部署),它极大地提高了开发效率并降低了开发难度,以"低代码方式"开发高质量项目。
如果您正在开发带有CRUD API的Web或gRPC服务,无需编写任何Go代码即可编译并部署到Linux服务器、Docker、K8s,只需连接到数据库(mysql、mongodb、postgresql、tidb、sqlite)即可生成完整的后端服务Go代码。
如果您开发通用的Web或gRPC服务,只需专注于在数据库中定义表
、在proto文件中定义API描述信息
、在生成的模板文件中填写业务逻辑代码
这三个核心部分,其余的Go代码都由sponge自动生成。
Sponge主要基于SQL
和Protobuf
两种方式生成代码,每种方式都可以生成不同功能的代码。SQL
支持mysql、mongodb、postgresql、tidb、sqlite数据库。
Sponge也是一个微服务框架,框架图如下所示,这是一个典型的微服务分层结构,具有高性能、高可扩展性,包含常用的服务治理功能,您可以轻松替换或添加自己的服务治理功能。
<p align="center"> <img width="1000px" src="https://yellow-cdn.veclightyear.com/2b54e442/b6def84c-2766-42f4-a7b1-146175c982e6.png"> </p> <br>微服务框架创建的http和grpc服务代码的性能测试:50并发,总请求100万。
点击查看测试代码。
<br>sponge创建的项目代码目录结构遵循project-layout,结构如下。支持的仓库类型有单体应用单仓库(monolith)
、微服务多仓库(multi-repo)
、微服务单仓库(mono-repo)
。
<br>. ├── api # 对外暴露API接口的目录,通常包含proto文件和生成的*.pb.go文件。目录结构通常为api/xxx/v1的形式,其中v1表示版本。 ├── assets # 存放各种静态资源,如图片、markdown文件等。 ├── cmd # 程序入口目录 │ └── serviceName │ ├── initial # 程序初始化,由三个文件组成:initApp初始化配置,registerServers注册服务(HTTP或grpc),registerClose注册资源清理。 │ └── main.go # 程序入口文件 ├── configs # 配置文件目录 ├── deployments # 部署脚本目录,支持裸机、Docker和Kubernetes部署。 ├─ docs # API接口Swagger文档目录。 ├── i(I)nternal # 业务逻辑代码目录,如果首字母小写(internal),表示私有代码,如果首字母大写(Internal),表示可以被其他代码复用。 │ ├── cache # 封装业务逻辑的缓存目录。 │ ├── config # Go结构配置文件目录。 │ ├── dao # 数据访问目录。 │ ├── ecode # 系统错误码和自定义业务错误码目录。 │ ├── handler # 实现HTTP业务功能的目录(特定于web服务)。 │ ├── model # 数据库模型目录。 │ ├── routers # HTTP路由目录。 │ ├── rpcclient # 连接grpc服务的客户端代码目录。 │ ├── server # 创建服务的目录,包括HTTP和grpc。 │ ├── service # 实现grpc业务功能的目录(特定于grpc服务)。 │ └── types # 定义HTTP请求和响应参数结构 的目录。 ├── pkg # 共享库目录。 ├── scripts # 脚本目录,包括编译、执行、代码生成和部署脚本。 ├── test # 测试服务所需的脚本目录和测试SQL。 └── third_party # 外部辅助程序、分叉代码和其他第三方工具的目录。
Sponge可以安装在Windows、macOS、Linux和Docker环境中。点击此处查看安装sponge的说明。
安装sponge后,启动UI服务:
sponge run
在本地浏览器访问http://localhost:24631
,在UI页面上操作生成代码。
<br>如果要在跨主机浏览器上访问,需要在启动UI时指定主机ip或域名,例如
sponge run -a http://your_host_ip:24631
。也可以在docker上启动UI服务以支持跨主机访问,点击查看在docker中启动sponge UI服务的说明。
使用sponge开发的项目操作、配置和部署的详细说明,点击此处查看sponge开发文档
<br>如果对你有帮助,请给个star ⭐。
<br>