_                  __                                             _      ___  ___| |__   ___        / _|_ __ __ _ _ __ ___   _____      _____  _ __| | __ / _ \/ __| '_ \ / _ \ _____| |_| '__/ _` | '_ ` _ \ / _ \ \ /\ / / _ \| '__| |/ /|  __/ (__| | | | (_) |_____|  _| | | (_| | | | | | |  __/\ 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

//连贯 memcachedb.ConnectMemcache(config.Memcache)

redis

//连贯redisdb.ConnectRedis(config.RedisIP, config.RedisPassword, 0, "default")

nsq

//连贯redisgo 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 maingo run logic.go

运行socket

cd maingo run socket.go

环境要求

  • go >= 1.13