基于elton
的脚手架,实现了数据校验、行为统计等功能。
- 应用配置通过加载default.yml + 当前GO_ENV所对应的yml组合生成,简化配置
- 支持配置参数的校验,保证应用启动时的参数准确性
- 支持优先从ENV中获取配置参数,若获取失败再使用yml配置
缓存模块支持三类缓存:LRU+TTL的高速缓存,redis+ttl的共有缓存以及redis+lru+ttl的多级缓存
// redis缓存中简化的struct读取与保存
err := cache.GetRedisCache().SetStruct(context.Background(), "key", &map[string]string{
"name": "my name",
}, time.Minute)
data := make(map[string]string)
err = cache.GetRedisCache().GetStruct(context.Background(), "key", &data)
- 黑名单IP配置,允许设置黑名单IP禁止访问
- 路由Mock配置,允许自定义路由的响应
- 路由并发配置,允许限制路由的最大并发数及访问频率
- Session拦截配置,允许将session的读取拦截,返回出错信息,用于系统禁止客户使用
性能指标中包括以下的相关指标:
goMaxProcs
程序使用的最大CPU数量threadCount
程序当前线程数memSys
系统申请内存memHeapSys
系统申请heapmemHeapInuse
使用中的heapmemFrees
heap对象释放的数量routineCount
goroutine的数量cpuUsage
CPU使用率lastGC
上一次GC的时间numGC
GC的次数recentPause
最近一次GC暂停的时长pauseTotal
GC暂停的总时长connProcessing
当前处理中的连接数(http.Server)connProcessedCount
处理过的连接总数connAlive
当前活跃的连接数connCreatedCount
被创建的连接总数concurrency
请求并发数requestProcessedTotal
处理过的请求总数
redis模块记录了当前并发请求以及pipeline请求量,可以设置最大并发请求量,提供简单的熔断处理。
编译schema对应代码
make install && make generate
feat:新功能(feature)
fix:修补bug
docs:文档(documentation)
style: 格式(不影响代码运行的变动)
refactor:重构(即不是新增功能,也不是修改bug的代码变动)
test:增加测试
chore:构建过程或辅助工具的变动
docker pull postgres:alpine
docker run -d --restart=always \
-v $PWD/forest:/var/lib/postgresql/data \
-e DATABASE_URI=postgres://vicanso:[email protected]:5432/forest?maxIdleConns=5&maxIdleTime=30m&maxOpenConns=100 \
-e REDIS_URI=redis://127.0.0.1:6379/?slow=200ms&maxProcessing=1000 \
-p 5432:5432 \
--name=forest \
postgres:alpine
docker exec -it forest sh
psql -c "CREATE DATABASE forest;" -U postgres
psql -c "CREATE USER vicanso WITH PASSWORD 'A123456';" -U postgres
psql -c "GRANT ALL PRIVILEGES ON DATABASE forest to vicanso;" -U postgres
docker pull redis:alpine
docker run -d --restart=always \
-p 6379:6379 \
--name=redis \
redis:alpine
- 所有自定义的error都必须为hes.Error
- 数值类的展示需要使用专用组件
- 用户点击类的操作需要使用专用组件
- esbuild提示未成功安装,执行
node node_modules/esbuild/install.js