golang微服务框架特性分析及选型
目录
- 一、微服务框架特性(10个)
- 包括:Istio、go-zero、go-kit、go-kratos、go-micro、rpcx、kitex、goa、jupiter、dubbo-go、tarsgo
- 1、特性及使用场景
- 2、比较
- 二、web框架特性(7个)
- 包括:gin、fiber、beego、echo、iris、mux、goa
- 1、特性及使用场景
- 2、比较
(以下框架均为go框架)
一、微服务框架特性(10个)
包括:Istio、go-zero、go-kit、go-kratos、go-micro、rpcx、kitex、goa、jupiter、dubbo-go、tarsgo
1、特性及使用场景
start统计截止至2024.04.01
| 序号 | 名称 | 特性 | 适用场景 | stars |
|---|---|---|---|---|
| 1 | Istio | Istio 是一个开源的服务网格(Service Mesh)解决方案,提供了流量管理、安全策略、监控和故障注入等功能。它通过 Sidecar 模式,为微服务架构提供了可观察性、可控制性和安全性。 | 适用于构建大规模的微服务架构,特别是需要灵活的流量管理、安全策略和监控的项目。 | 34.8k |
| 2 | go-zero | 基于 Go 语言的微服务框架,提供了代码生成工具、RPC 框架、数据访问层、缓存、限流、熔断等功能,支持快速开发和部署微服务应用。 | 适用于构建中小型的微服务架构,特别是对于需要高效率和高性能的项目。 | 27.4k |
| 3 | go-kit | go-kit 是一个用于构建微服务的工具集,提供了服务发现、负载均衡、熔断器、追踪、日志等功能。它的设计理念是提供一组小型、可组合的库,使开发者可以根据需要选择和组合不同的组件,构建符合自己需求的微服务系统。 | 适用于构建可扩展、可维护的微服务系统,特别是对于需要模块化和可插拔式设计的项目。 | 26.1k |
| 4 | go-kratos | go-kratos 是一个基于 Protobuf 和 gRPC 的微服务框架,提供了快速开发和部署微服务应用的工具和库。它支持快速迭代、高性能和高可用性。 | 适用于构建高性能的微服务架构,特别是对于需要快速迭代和高可用性的项目。 | 22.3k |
| 5 | go-micro | go-micro 是一个基于 gRPC 的微服务框架,提供了服务发现、负载均衡、熔断器、追踪等功能,支持多种微服务架构。它支持多种传输协议和序列化格式,具有很好的可扩展性。 | 适用于构建大规模微服务架构,特别是对于需要灵活的服务发现和负载均衡功能的项目。 | 21.3k |
| 6 | rpcx | 基于 gRPC 和 HTTP/JSON 的 RPC 框架,提供了服务注册、发现、负载均衡、熔断器、追踪等功能,支持分布式系统开发。 | 适用于构建大规模分布式系统,特别是对于需要高性能和可靠性的项目。 | 7.9k |
| 7 | kitex | KiteX 是字节跳动框架组研发的下一代高性能、强可扩展性的 Go RPC 框架,提供了高性能、低延迟的 RPC 通信和服务注册、发现等功能。 | 适用于构建高性能的微服务架构,特别是对于需要低延迟和高并发的项目。 | 6.6k |
| 8 | jupiter | 斗鱼开源的一套基于配置驱动的微服务治理框架,提供了丰富的功能和插件系统和后台功能,管理应用的资源、配置,应用的性能、配置等可视化。 | 适用于构建中小型的微服务架构,特别是对于需要配置驱动和插件化设计的项目。 | 4.3k |
| 9 | dubbo-go | 基于 Dubbo 协议的分布式服务框架,提供了服务注册、发现、负载均衡、熔断器、追踪等功能,支持大规模分布式系统开发。架构是基于dubbo的extension模块和分层的代码设计,主要解决 Go 项目与 Java & Dubbo 项目的互通问题。 | 适用于构建大规模分布式系统,特别是对于需要 Dubbo 协议和高性能的项目。 | 4.6k |
| 10 | tarsgo | 腾讯开源项目,基于 Tars 协议的微服务框架,提供了服务注册、发现、负载均衡、熔断器、追踪等功能,支持大规模分布式系统开发。 | 适用于构建大规模分布式系统,特别是对于需要 Tars 协议和高性能的项目。 | 3.3k |
2、比较
- go-kit 适用于中大型的项目规模,适合模块化和可插拔式设计的项目;
- go-kratos 适用于中大型到大型的项目规模,适合快速迭代和高可用性的项目;
- go-micro 适用于大型的项目规模,适合需要灵活的服务发现和负载均衡功能的项目;
- Istio 适用于大型的项目规模,提供了完善的服务网格解决方案。
二、web框架特性(7个)
包括:gin、fiber、beego、echo、iris、mux、goa
1、特性及使用场景
start统计截止至2024.04.01
| 名称 | 特性 | 适用场景 | start | |
|---|---|---|---|---|
| 1 | Gin | 快速、轻量级、灵活的路由功能、中间件支持、性能较高、RESTful API 设计友好。 | 适用于构建轻量级的 Web 应用、RESTful API 和微服务,适合快速开发和部署应用。 | 75.1k |
| 2 | gorilla/mux | 用于构建 HTTP 路由的库,提供了灵活的路由和中间件功能,适用于构建 Web 应用和 RESTful API。 | 适用于构建中小型的 Web 应用和 RESTful API,特别是对于需要灵活的路由功能的项目。 | 20.1k |
| 3 | fiber | 高性能、低延迟、快速路由、中间件支持、与 Express.js 类似的 API 风格。 | 适用于构建高性能的 Web 应用和 RESTful API,特别是对于需要快速响应的场景,如实时通信、实时游戏等。 | 31.1k |
| 4 | beego | 有完整的 MVC 框架、自动生成文档、自带 ORM、路由、日志、配置、验证等功能。 | 适用于构建中小型的 Web 应用和企业级应用,尤其是需要快速开发和维护的项目。 | 30.8k |
| 5 | Echo | 快速、轻量级、灵活的路由功能、中间件支持、高性能。 | 适用于构建轻量级的 Web 应用、RESTful API 和微服务,与 Gin 类似,但更加轻量级。 | 28.3k |
| 6 | iris | 高性能、强大的功能集成、自动生成文档、路由、中间件、验证、Websocket、GRPC、GraphQL 等。 | 适用于构建中大型的 Web 应用和企业级应用,特别是需要丰富功能和强大性能的项目。 | 24.8k |
| 7 | goa | 基于设计优先的 API 开发框架,提供了 DSL 和代码生成工具,支持快速开发和部署 RESTful API。 | 适用于构建 RESTful API,特别是对于需要设计优先和代码生成的项目。 | 5.4k |
2、比较
-
Gin、Echo 和 Mux 都是==轻量级==的 Web 框架,适合构建快速、简单的 Web 应用和微服务;
-
Fiber 提供了高性能和低延迟的 Web 框架,适用于构建高性能的 Web 应用和 API 服务;
-
Beego 和 Iris 则是更为完整和功能丰富的 Web 框架,适合构建中大型的 Web 应用和企业级应用;
-
Goa 则是基于设计优先的 API 开发框架,适用于需要设计优先和代码生成的项目。
选择合适的框架取决于项目的需求、规模和预期性能,star不是绝对的标准
参考链接:
https://blog.miuyun.work/archives/1712124913576
如有不对,烦请指出,感谢!
相关文章:
golang微服务框架特性分析及选型
目录 一、微服务框架特性(10个)包括:Istio、go-zero、go-kit、go-kratos、go-micro、rpcx、kitex、goa、jupiter、dubbo-go、tarsgo 1、特性及使用场景2、比较 二、web框架特性(7个)包括:gin、fiber、beego…...
苹果cmsV10 MXProV4.5自适应PC手机影视站主题模板苹果cms模板mxone pro
演示站:http://a.88531.cn:8016 MXPro 模板主题(又名:mxonepro)是一款基于苹果 cms程序的一款全新的简洁好看 UI 的影视站模板类似于西瓜视频,不过同对比 MxoneV10 魔改模板来说功能没有那么多,也没有那么大气,但是比较且可视化功…...
GPU的了解
3D动画揭秘显卡的GPU是如何工作的_哔哩哔哩_bilibili 位于显卡中。 与CPU区别: 100名小学生和1位数学博士 做100道非常简单的算术题,小朋友一个人一道题,比博士快。 做1道非常复杂的数学问题,只有博士可以做出来。 CPU主要用于快…...
鸿蒙实战开发-如何使用Stage模型卡片
介绍 本示例展示了Stage模型卡片提供方的创建与使用。 用到了卡片扩展模块接口,ohos.app.form.FormExtensionAbility 。 卡片信息和状态等相关类型和枚举接口,ohos.app.form.formInfo 。 卡片提供方相关接口的能力接口,ohos.app.form.for…...
蓝桥杯刷题 前缀和与差分-[2128]重新排序(C++)
问题描述 给定一个数组 A 和一些查询 L**i, R**i,求数组中第 L**i 至第 R**i 个元素之和。 小蓝觉得这个问题很无聊,于是他想重新排列一下数组,使得最终每个查询结果的和尽可能地大。小蓝想知道相比原数组,所有查询结果的总和最多…...
STM32重要参考资料
stm32f103c8t6 一、引脚定义图 二、时钟树 三、系统结构图 四、启动配置 (有时候不小心短接VCC和GND,芯片会锁住,可以BOOT0拉高试试(用跳线帽接)) 五、最小系统原理图 可用于PCB设计 六、常见折腾人bug…...
[StartingPoint][Tier0]Preignition
Task 1 Directory Brute-forcing is a technique used to check a lot of paths on a web server to find hidden pages. Which is another name for this? (i) Local File Inclusion, (ii) dir busting, (iii) hash cracking. (目录暴力破解是一种用于检查 Web 服务器上的大…...
数据库系统概论(超详解!!!)第三节 关系数据库标准语言SQL(Ⅴ)
1.数据更新 1.插入数据 1.插入元组 语句格式 INSERT INTO <表名> [(<属性列1>[,<属性列2 >…)] VALUES (<常量1> [,<常量2>]… ); 功能:将新元组插入指定表中 INTO子句 : 指定要插入数据的表名及…...
SpringBoot | Spring Boot“整合Redis“
目录: 1. Redis 介绍2. Redis 下载安装3. Redis “服务开启”和“连接配置”4. Spring Boot整合Redis的“前期准备” :① 编写实体类② 编写Repository 接口③ 在“全局配置文件”中添加 “Redis数据库” 的 “相关配置信息” 5. Spring Boot整合“Redis” (案例展示) 作者简介…...
SV学习笔记(四)
OCP Open Closed Principle 开闭原则 文章目录 随机约束和分布为什么需要随机?为什么需要约束?我们需要随机什么?声明随机变量的类什么是约束权重分布集合成员和inside条件约束双向约束 约束块控制打开或关闭约束内嵌约束 随机函数pre_random…...
Midjourney艺术家分享|By Moebius
Moebius,本名让吉拉德(Jean Giraud),是一位极具影响力的法国漫画家和插画师,以其独特的科幻和幻想风格而闻名于世。他的艺术作品不仅在漫画领域内受到高度评价,也为电影、时尚和广告等多个领域提供了灵感。…...
Vue - 1( 13000 字 Vue 入门级教程)
一:Vue 导语 1.1 什么是 Vue Vue.js(通常称为Vue)是一款流行的开源JavaScript框架,用于构建用户界面。Vue由尤雨溪在2014年开发,是一个轻量级、灵活的框架,被广泛应用于构建单页面应用(SPA&am…...
Vue关键知识点
watch侦听器 Vue.js 中的侦听器(Watcher)是 Vue提供的一种响应式系统的核心机制之一。 监听数据的变化,并在数据发生变化时执行相应的回调函数。 目的:数据变化能够自动更新到视图中 原理: Vue 的侦听器通过观察对象的属性&#…...
Prometheus+grafana环境搭建redis(docker+二进制两种方式安装)(四)
由于所有组件写一篇幅过长,所以每个组件分一篇方便查看,前三篇 Prometheusgrafana环境搭建方法及流程两种方式(docker和源码包)(一)-CSDN博客 Prometheusgrafana环境搭建rabbitmq(docker二进制两种方式安装)(二)-CSDN博客 Prometheusgrafana环境搭建m…...
宝塔面板安装nginx流媒体服务器(http-flv)
前文介绍了使用nginx搭建流媒体服务器,实现了hls切片方式播放,不过延迟较长。本文采用nginx搭建支持http-flv方式的流媒体服务器,用以测试期性能。 目录 一、服务器操作系统安装 二、在控制台安装宝塔面板...
LNMP环境:揭秘负载均衡与高可用性设计
lb1: 192.168.8.5 lb2: 192.168.8.6 web1:192.168.8.7 web2:192.168.8.8 php-fpm: 192.168.8.9 mysql: 192.168.8.10 nfs:192.168.8.11 分别插入镜像 8.5-8.8 分别安装nginx,并设置启动 8.9 安装php 8.10 安装mysql 先配置一台web服务器然后同步 设置网站根目录 cp -…...
深入理解Java异常处理机制(day20)
异常处理 异常处理是程序运行过程产生的异常情况进行恰当的处理技术 在计算机编程里面,异常的情况比所我们所想的异常情况还要多。 Java里面有两种异常处理方式; 1.利用trycatchfinaly语句处理异常,优点是分开了处理异常代码和程序正常代码…...
Docker实战教程 第1章 Linux快速入门
2-1 Linux介绍 为什么要学Linux 三个不得不学习 课程需要:Docker开发最好在Linux环境下。 开发需要:作为一个后端程序员,是必须要掌握Linux的,这是找工作的基础门槛。 运维需要:在服务器端,主流的大型服…...
java数据结构与算法刷题-----LeetCode172. 阶乘后的零
java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/123063846 文章目录 数学:阶乘的10因子个数数学优化:思路转变为求5的倍数…...
掌握数据相关性新利器:基于R、Python的Copula变量相关性分析及AI大模型应用探索
在工程、水文和金融等各学科的研究中,总是会遇到很多变量,研究这些相互纠缠的变量间的相关关系是各学科的研究的重点。虽然皮尔逊相关、秩相关等相关系数提供了变量间相关关系的粗略结果,但这些系数都存在着无法克服的困难。例如,…...
猫抓浏览器插件:网页资源嗅探与下载的终极解决方案
猫抓浏览器插件:网页资源嗅探与下载的终极解决方案 【免费下载链接】cat-catch 猫抓 chrome资源嗅探扩展 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 你是否曾在浏览网页时,看到精彩的视频、音频或图片资源,却苦于无…...
别再只用Set5了!超分辨率模型训练,这5个开源数据集(DIV2K、Flickr2K等)的实战配置与对比
超分辨率模型训练:5个开源数据集的深度实战指南 在超分辨率研究领域,数据集的选择往往决定了模型性能的上限。许多开发者习惯性地使用Set5、Set14等小型数据集,却忽略了更丰富的数据资源可能带来的性能突破。本文将深入解析DIV2K、Flickr2K、…...
当多线雷达遇上RTK:一个能跑工业现场的SLAM方案
多传感器融合建图及定位的工程化落地方案,多线雷达rtk;室内室外导航都适用。 包含部署文档和代码注释;包含工程落地角度的优化。 不含运动控制。 室外场景用RTK信号稳如老狗,一进厂房立马抓瞎;多线雷达在室内横扫千军…...
大厂速报:小红书期权涨麻,字节年终暴击,AI赛道卷疯了
互联网圈没有岁月静好,只有暗潮涌动——大厂裁员传闻从未断档,AI内卷卷到凌晨三点,打工人一边焦虑KPI,一边蹲守大厂福利,有人靠期权实现财富跃迁,有人被组织调整撞个正着。一、核心福利|打工人狂…...
计算机毕设 java 基于 Android 的医疗预约系统的设计与实现 SpringBoot 安卓智能医疗预约挂号平台 JavaAndroid 医患预约诊疗管理系统
计算机毕设 java 基于 Android 的医疗预约系统的设计与实现 53m069,末尾的数字和英文也要加上 (配套有源码 程序 mysql 数据库 论文)本套源码可以先看具体功能演示视频领取,文末有联 xi 可分享随着信息技术的飞速发展和医疗需求的…...
通义千问3-Reranker-0.6B优化升级:调整批处理大小和自定义指令,性能再提升5%
通义千问3-Reranker-0.6B优化升级:调整批处理大小和自定义指令,性能再提升5% 1. 为什么需要优化重排序模型性能? 在信息检索和问答系统中,重排序模型扮演着至关重要的角色。它负责对初步检索得到的文档进行二次排序,…...
如何选择适合的单北斗变形监测一体机以提升基础设施安全?
本文将重点讨论如何选择适合的单北斗变形监测一体机,以增强基础设施的安全性。在当前基础设施建设快速发展的背景下,单北斗GNSS的应用显得尤为重要。通过深入理解单北斗变形监测的原理,用户能够更好地把握设备的核心优势,尤其是在…...
硬件工程师职业发展路径与核心技术解析
硬件工程师的职业发展路径与技术深度探讨1. 行业现状与职业定位1.1 硬件工程师的职责演变现代硬件工程师的职责范围已从传统的电路设计扩展到系统集成、信号完整性分析、EMC设计等多个领域。典型的职责矩阵包括:职责类别传统要求现代扩展要求电路设计原理图绘制、PC…...
ANPC逆变器下垂控制的“阻抗相消术
ANPC-下垂功率均分-两台ANPC三电平逆变器在不同阻感性线路阻抗下实现有功均分与无功均分,采用积分改进法(阻抗相消法),电压电流双闭环控制,中点电位平衡控制,SPWM调制。 1.下垂,电压电流双闭环控…...
智能文献管理全面指南:从学术研究痛点到高效解决方案
智能文献管理全面指南:从学术研究痛点到高效解决方案 【免费下载链接】zotero Zotero is a free, easy-to-use tool to help you collect, organize, annotate, cite, and share your research sources. 项目地址: https://gitcode.com/gh_mirrors/zo/zotero …...
