golang
已收录文章:11745篇
-
云原生环境中使用Go框架中间件至关重要,因为它提供了:模块化:解耦通用功能,提高可维护性。可扩展性:抽象底层细节,轻松采用新技术或集成服务。安全性:应用安全措施,保护应用程序免受漏洞侵害。性能:提供缓存、速率限制等功能,提升应用程序性能。可观察性:记录和收集指标,便于故障排除和性能分析。实战示例:使用GinGonic框架的中间件,通过gin.Logger()和gin.Recovery()实现了日志记录和错误处理功能。102 收藏
-
在GoLang框架中,性能优化至关重要。通过实施以下策略来实现:利用并发编程:通过Goroutine同时执行多个任务。选择合适的数据结构:使用高效的切片、映射和并发安全数据结构。优化内存管理:了解指针、逃逸分析和手动内存管理技术。实战案例中,使用Gin框架的博客应用程序通过并发获取帖子和预加载相关数据优化了性能,将数据库查询时间减少了约50%,请求时间进一步减少了约20%。102 收藏
-
Golang实现排序算法的核心在于理解sort包提供的接口,并根据需要选择或自定义排序算法。具体步骤包括:1.定义一个类型,如MySlice;2.为该类型实现Len()、Less(i,jint)和Swap(i,jint)方法;3.调用sort.Sort进行排序。此外,Golang还提供便捷的排序函数如sort.Ints、sort.Float64s、sort.Strings等用于常见数据类型的排序。对于不同场景的选择建议:小规模数据适合插入排序或选择排序;大规模数据适合快速排序、归并排序或堆排序;基本有序数102 收藏
-
优化高并发Golang程序内存占用,需从栈大小调整与资源复用两方面入手。1.初始栈默认为2KB,自动扩容可能导致大量goroutine下内存激增,但手动调小需谨慎以免影响性能,普通开发者不建议修改;2.使用sync.Pool缓存临时对象、复用协程池减少频繁创建销毁;3.避免设计不合理导致的goroutine泛滥,通过context控制生命周期、限流、缓冲channel等手段控制数量。合理控制与资源复用是关键,栈调整属底层操作应慎用。102 收藏
-
请求: HTTP 请求报文由请求行、请求头部、空行、请求包体4个部分组成,如下图所示: 请求行: 请求行由方法字段、URL 字段 和HTTP 协议版本字段 3个部分组成,他们之间使用空格隔开。常用101 收藏
-
最近在看一些 getway 相关的资料,发现有关 Nginx 负载均衡的算法有点多,但是有点乱,所以整理下。。。如有不对地方请指出。 一,Nginx 负载均衡的轮询 (round-robin) 在说加权轮询之前我们101 收藏