golang
已收录文章:121篇
-
Go语言中通过channel和goroutine实现发布订阅模式,核心角色为发布者、订阅者和消息中心。使用chan传递消息,消息中心管理订阅关系并广播消息,支持多主题、动态增删订阅者,利用缓冲channel避免阻塞,确保高效并发。示例中定义Topic、Event、Subscriber及PubSub结构,通过Start启动事件循环,Subscribe注册订阅,Publish发送消息,Unsubscribe移除订阅者,Stop停止服务。每个订阅者独立接收消息,发布者将事件推送到对应主题的channel,所有订165 收藏
-
Golang长连接维护的核心是心跳机制,通过客户端定时发送“ping”消息、服务端检测超时连接来确保连接活跃;结合TCPKeepalive可提升可靠性。162 收藏
-
服务定位器模式通过全局注册表解耦服务获取与创建,适用于Go中数据库、日志等全局服务访问,简化依赖传递,但存在隐藏依赖和生命周期管理问题,建议结合接口键、安全获取及初始化限制优化使用。160 收藏
-
减少Golang锁竞争的核心是避免不必要的锁操作。1.使用atomic包进行原子操作,如atomic.AddInt64,适用于计数器等简单场景,避免Mutex的系统调用开销;2.利用sync.Pool复用对象,减少内存分配与GC压力,间接降低锁竞争;3.缩小锁粒度,仅保护必要临界区;4.读多写少场景使用sync.RWMutex,允许多个读并发执行;5.通过channel替代共享内存通信,避免锁的使用。不同场景应选择合适机制:atomic适合简单操作,RWMutex适合读多写少,channel适合gorou157 收藏
-
答案:Cosign支持本地密钥、KMS、PKCS#11和无密钥签名,通过GitHubActions可实现Golang代码自动签名与容器镜像验证,需处理版本、权限、环境变量等错误,并结合Rekor日志与监控确保安全。155 收藏
-
命令模式通过封装请求为对象实现调用者与接收者解耦,支持撤销、队列和扩展,适用于Go语言中的遥控操作、任务队列等场景。154 收藏