Kratos

188 阅读2分钟

Kratos是bilibili开源的一套Go微服务框架,包含大量微服务相关框架及工具。

名字来源于:《战神》游戏以希腊神话为背景,讲述由凡人成为战神的奎托斯(Kratos)成为战神并展开弑神屠杀的冒 险历程。

Features HTTP Blademaster:核心基于gin进行模块化设计,简单易用、核心足够轻量; GRPC Warden:基于官方gRPC开发,集成discovery服务发现,并融合P2C负载均衡; Cache:优雅的接口化设计,非常方便的缓存序列化,推荐结合代理模式overlord; Database:集成MySQL/HBase/TiDB,添加熔断保护和统计支持,可快速发现数据层压力; Config:方便易用的paladin sdk,可配合远程配置中心,实现配置版本管理和更新; Log:类似zap的field实现高性能日志库,并结合log-agent实现远程日志管理; Trace:基于opentracing,集成了全链路trace支持(gRPC/HTTP/MySQL/Redis/Memcached); Kratos Tool:工具链,可快速生成标准项目,或者通过Protobuf生成代码,非常便捷使用gRPC、HTTP、swagger文档; 快速开始 快速开始前,首先需要安装Go环境:Go version>=1.13

CentOS Go环境搭建, Windows自行百度哈 设置代理环境变量,提高下载速度。注意GO1.13及之后支持direct的写法

go env -w GOPROXY=goproxy.cn,direct 1 由于安装过程中需要用到Protobuf,所以建议先安装Protobuf

CentOS安装Protobuf Windows安装 快速安装 GO111MODULE=on && go get -u github.com/go-kratos/kratos/tool/kratos 1 Windows注意,GO111MODULE设置无效,需要单独执行以下命令设置

go env -w GO111MODULE=on 1 注意:设置GO111MODULE=on后,可能IDE无法识别包内容: 原因:由于设置为on后,go get命令下载的第三方包都会下载到GOPATH的pkg里 需要对IDE进行相关设置