共计 1243 个字符,预计需要花费 4 分钟才能阅读完成。
_ __ _
___ ___| |__ ___ / _|_ __ __ _ _ __ ___ _____ _____ _ __| | __
/ _ \/ __| '_ \ / _ \ _____| |_|'__/ _` | '_ ` _ \ / _ \ \ /\ / / _ \|'__| |/ /
| __/ (__| | | | (_) |_____| _| | | (_| | | | | | | __/\ V V / (_) | | | <
\___|\___|_| |_|\___/ |_| |_| \__,_|_| |_| |_|\___| \_/\_/ \___/|_| |_|\_\
echo-framework 是基于 echo 搭建用于疾速开发的我的项目框架
装置
go get -u github.com/nelsonkti/echo-framework
性能叙述
- 反对 gorm、logger 日志、jwt、cron 定时工作、redis 等
- mysql 数据库读写拆散、负载平衡
- socket.io 通信协议
- nsq 音讯队列
- 分布式部署
文件夹构造
- config 文件配置和初始化配置数据
- cron 定时工作
- lib 日常应用的库
- logic logic 业务逻辑
- main 程序启动入口, 次要能够启动 http
- routes 蕴含利用的所有路由定义
- socket 通信相干的代码,以 socket.io 通信协议为主
-
logic 目录
-
http 蕴含了控制器、中间件以及表单申请、验证器等
- controllers 控制器层
- middleware 中间件
- models 模型层
- repository 业务层调用数据拜访层
- responses 返回层
- services 服务层次要解决业务逻辑
- validators 表单验证器
-
mq nsq 生产者和消费者
- producer 生产者
-
我的项目介绍
我的项目默认反对 nsq
、memcache
、redis
,如果不须要,能够在 main
文件夹下 正文以下代码
memcache
// 连贯 memcache
db.ConnectMemcache(config.Memcache)
redis
// 连贯 redis
db.ConnectRedis(config.RedisIP, config.RedisPassword, 0, "default")
nsq
// 连贯 redis
go func() {defer helper.RecoverPanic()
//producer.StartNsqProducer(config.NSQIP)
mq.StartNsqServer(config.NSQIP, config.NSQConsumers)
}()
cron
本地默认不启动,须要启动,去掉 if
就能够了
// 启动定时工作
if config.Env != "local" {cron.RegisterCrons(config.RedisIP, config.RedisPassword)
}
grom
读写拆散 DBResolver
// 应用 Write 模式
User.Model().Clauses(dbresolver.Write).First(&User)
运行 logic
cd main
go run logic.go
运行 socket
cd main
go run socket.go
环境要求
- go >= 1.13
正文完