golang专题下共有 11714 篇文章
-
- Golang实现gRPCWeb服务及性能对比详解
- 要使用Golang开发gRPCWeb服务,需定义gRPC服务并生成Go和JavaScript代码;接着配置gRPC-Web代理(如grpc-web或Envoy)将HTTP/1.1请求转换为gRPC请求;最后通过HTTP服务器代理gRPC-Web请求。具体步骤如下:1.使用protoc编译protobuf文件生成服务端和客户端代码;2.安装protoc-gen-grpc-web插件并配置protobuf文件;3.创建HTTP反向代理服务器处理请求;4.处理流式传输时,gRPC-Web支持服务端和客户端流式模
- Golang· Go教程 | 1天 | golang 性能 grpc 代理 gRPCWeb 278浏览 收藏
-
- Golangio库核心接口与读写技巧
- 要高效使用Golang的io.Reader和io.Writer接口,需遵循以下最佳实践:1.对于io.Reader,应循环读取直到EOF,并正确处理短读取;2.使用io.LimitReader限制读取的数据量;3.对于io.Writer,始终检查写入的字节数,优先使用bufio.Writer进行缓冲写入以提升性能;4.可实现Writer接口以支持自定义输出目标;5.利用io.Copy高效地在Reader和Writer之间复制数据;6.组合使用Reader和Writer实现复杂功能,如io.TeeReade
- Golang· Go教程 | 2天 | golang 最佳实践 Writer Reader io库 440浏览 收藏
-
- GolangAPI错误处理与可重试客户端实现
- 调用第三方API时构建具备重试机制的HTTP客户端可提升稳定性。1.控制重试次数,一般设为2~3次;2.设置合理间隔时间,建议使用指数退避策略;3.区分可重试与不可重试错误,如网络超时、连接失败和5xx错误可重试,4xx和TLS握手失败通常不重试;4.使用自定义RoundTripper实现重试逻辑,在每次请求失败后判断错误类型并决定是否重试;5.结合context.Context控制超时,记录日志以便排查问题;6.封装成通用组件便于复用,提供默认配置同时支持自定义参数。通过这些策略,能有效增强程序的健壮性
- Golang· Go教程 | 2天 | golang 错误处理 HTTP客户端 重试机制 API调用 194浏览 收藏
-
- GolangRPC框架为何受欢迎?gRPC与JSON-RPC对比解析
- Golang的RPC框架在微服务中流行的核心原因在于其简洁高效、与高并发优势结合,能快速构建高性能系统。gRPC相比JSON-RPC性能更高,1.使用ProtocolBuffers作为二进制协议,序列化更快体积更小;2.基于HTTP/2支持多路复用和头部压缩;3.自动生成客户端和服务端代码减少人工错误。选择RPC框架需考虑:1.对性能要求高且接口稳定时选gRPC;2.项目简单或需集成非gRPC服务时选JSON-RPC;3.团队技术栈影响学习成本。其他值得关注的GolangRPC框架包括:Thrift跨语言
- Golang· Go教程 | 2天 | golang grpc 微服务 RPC框架 JSON-RPC 198浏览 收藏
查看更多
课程推荐
-
- Golang深入理解GPM模型
- Golang深入理解GPM调度器模型及全场景分析,希望您看完这套视频有所收获;包括调度器的由来和分析、GMP模型简介、以及11个场景总结。
- 474次学习
-
- Go语言课程Gin框架实战
- Gin是一个用Go(Golang)编写的HTTPweb框架。它是一个类似于 martini 但拥有更好性能的API框架,由于 httprouter,速度提高了近40倍。如果你需要极好的性能,使用Gin吧。
- 338次学习
-
- Golang云原生架构师课程
- Go是一门并发支持、垃圾回收的编译型系统编程语言;本课程转载自哔哩哔哩:https://www.bilibili.com/video/BV1Mh411M7A
- 204次学习
-
- Go编程基础视频教程
- Go是一门并发支持、垃圾回收的编译型系统编程语言,旨在创造一门具有在静态编译语言的高性能和动态语言的高效开发之间拥有良好平衡点的一门编程语言。我们收集了这套《Go编程基础视频教程》,希望能够帮助大家更好的学习go语言。
- 167次学习
-
- Golang进阶实战编程
- 本课程是在《Go语言基础视频》基础之上录制的,是Go语言基础的后半部分。包括包的管理,IO操作,Go语言最大的亮点:高并发,goroutine,channel,反射等。本视频主要为了帮助Go语言的初学者,从零到一的快速入门。学完本套课程,可以学会如果通过包管理Go项目,并发模型,以及并发实现,channel通道如何传递数据,反射等等。
- 128次学习