关于框架:分享-echoframework-项目基础框架

4次阅读

共计 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 生产者

我的项目介绍

我的项目默认反对 nsqmemcacheredis,如果不须要,能够在 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
正文完
 0