golang
已收录文章:14180篇
-
sync.Pool通过对象复用减少内存分配,降低GC压力,适用于短生命周期且频繁创建的对象如*bytes.Buffer;使用时需重置状态,不保证对象留存,合理应用可显著提升高并发场景下的性能。166 收藏
-
在Go中实现RPC客户端超时控制需结合context、channel和DialTimeout,首先为连接与调用阶段分别设置超时。使用net.DialTimeout防止连接阻塞,通过context.WithTimeout或time.After配合select控制调用等待时间,避免无限等待。对于JSONRPC等基于HTTP的场景,可自定义http.Transport和http.Client设置更细粒度超时。推荐封装通用CallWithTimeout函数复用逻辑,提升系统健壮性。关键在于分离连接与调用超时管理。166 收藏
-
Golang中通过sync.Mutex、RWMutex、channel、WaitGroup和atomic实现并发安全。Mutex确保临界区互斥,RWMutex提升读多写少性能,channel支持通信共享内存,WaitGroup协调goroutine等待,atomic提供无锁原子操作,按场景选用可保障数据安全与程序高效。166 收藏
-
首先实现用户注册与登录功能,通过bcrypt哈希密码确保安全;接着使用JWT生成令牌实现无状态认证,并通过中间件验证token有效性,控制受保护路由访问。166 收藏
-
集成工作流引擎可解耦业务逻辑与流程控制,提升系统可维护性和可观测性;在Golang中,Temporal因原生支持、强大功能和活跃社区成为首选方案,适用于复杂业务编排,而简单场景可选自研状态机或Conductor。166 收藏
-
原先的jwt-go仓库已经不再维护,迁移到了github.com/golang-jwt/jwt/v4 但是网上大多数还是v3版本的使用教程,建议使用更加安全的v4 1.什么是JWT JSON Web Token (JWT)是一个开放标准(RFC 7519),它定义了一种165 收藏