hydra后端统一框架----支持api,rpc,websocket,定时任务,消息消费服务

enjoylv · 2019-08-01 12:23:49 · 2798 次点击    
这是一个分享于 2019-08-01 12:23:49 的资源,其中的信息可能已经有所发展或是发生改变。

hydra

hydra 是基于 go 语言和众多开源项目实现的分布式微服务框架

hydra['haɪdrə]致力于提供统一的,丰富功能的后端开发框架,降低后端开发的复杂性,提高开发效率。目前已支持的服务类型有:http api服务,rpc服务,websocket服务,mqc消息消费服务,cron定时任务服务,web服务,静态文件服务。

特性

  • 后端一体化框架, 支持 6+服务器类型
  • 微服务的基础设施, 服务注册发现,熔断降级,集成监控与统一配置管理
  • 多集群模式支持,对等,主备,分片等
  • 丰富的后端库支持 redis,memcache,activieMQ,mqtt,influxdb,mysql,oracle,elasticsearch,jwt 等等
  • 跨平台支持(linux,macOS 10.9+,windows 7+)
  • 20+线上项目实践经验
  • 全 golang 原生实现

示例

  1. 编写代码

新建文件夹hello,并添加main.go文件,输入以下代码:

package main

import (
    "github.com/micro-plat/hydra/context"
    "github.com/micro-plat/hydra/component"
    "github.com/micro-plat/hydra/hydra"
)

func main() {
    app := hydra.NewApp(
        hydra.WithPlatName("myplat"), //平台名称
        hydra.WithSystemName("demo"), //系统名称
        hydra.WithClusterName("test"), //集群名称
        hydra.WithServerTypes("api"), //服务器类型为http api
        hydra.WithRegistry("fs://../"), //使用本地文件系统作为注册中心
        hydra.WithDebug())

    app.API("/hello",hello)
    app.Start()
}

func hello(ctx *context.Context) (r interface{}) {
    return "hello world"
}
  1. 编译生成服务
go install hello
  1. 安装本地服务和生成注册中心配置
hello install
  1. 运行服务
./hello run
  1. 测试服务
curl http://localhost:8090/hello

{"data":"hello world"}

hydra 微服务开发入门

hydra 微服务开发规范

构建 API 服务一

构建 API 服务二

构建消息消费服务(MQC)

构建任务调度服务(CRON)

构建远程调用服务(RPC)

构建静态文件服务

构建 websocket 服务(WS)

性能指标收集(metric)

日志配置与管理


入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

2798 次点击  ∙  1 赞  
加入收藏 微博
3 回复  |  直到
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传