golang
已收录文章:1545篇
-
中介者模式通过引入中介者对象解耦多个对象间的复杂交互,使对象无需直接引用彼此。在聊天室示例中,用户通过ChatRoom发送消息,由中介者转发给其他用户,避免了直接依赖。该模式降低耦合、提升可维护性,适用于GUI、游戏、通信系统等多对象协作场景,但需注意中介者自身复杂度控制。282 收藏
-
使用Golang模拟CPU负载过高可通过启动多个执行计算密集型任务的goroutine实现,每个goroutine占用一个CPU核心,从而提升整体CPU使用率;具体方法是在main函数中根据CPU核心数启动相应数量的goroutine,每个goroutine持续调用如computeSomething等耗时计算函数,运行指定时间后通过context或信号机制优雅停止;模拟网络延迟则借助os/exec包调用Linux的tc命令,在指定网络接口上添加延迟规则,需使用sudo权限执行“tcqdiscadd”命令设469 收藏
-
Go环境配置成功后,可通过goversion和goenv验证。若命令无法识别,需检查PATH环境变量是否包含Go的bin目录。GOPATH在GoModules时代已无需手动设置,主要用于缓存和安装可执行文件。编写第一个程序只需创建hello.go文件,使用gorun运行即可输出结果,gobuild可生成exe可执行文件。269 收藏
-
如何用Golang实现事件驱动架构并集成NATSStreaming?1.定义事件结构,包含ID、类型、数据和时间戳;2.使用stan.Connect连接NATSStreaming集群;3.通过sc.Publish发布序列化后的事件到指定主题;4.利用sc.Subscribe订阅事件并用回调函数处理接收的数据;5.处理错误及确保可靠传递,使用持久化、ACK机制和DurableNames;6.采用领域.事件类型命名规范如user.created;7.引入版本控制,如添加version字段或使用不同主题区分版本350 收藏
-
Golang通过net/http标准库可快速构建HTTP服务,使用http.HandleFunc注册路由并监听端口即可启动服务器。通过r.Method可区分GET、POST等请求方法,在Handler中实现不同逻辑。中间件通过函数包装实现,如日志和认证,形成洋葱圈式处理链。优雅关闭利用signal.Notify监听系统信号,结合context.WithTimeout和server.Shutdown确保服务在终止前完成正在进行的请求,保障服务稳定性。278 收藏
-
在Kubernetes中为Golang服务配置探针需设置Liveness、Readiness和Startup探针:1.Liveness探针通过/healthz接口检测服务健康,失败后重启容器;2.Readiness探针通过/ready接口判断服务是否就绪,失败后停止流量接入;3.Startup探针用于启动耗时较长的场景,防止早期误判。各探针需合理配置initialDelaySeconds、periodSeconds、timeoutSeconds和failureThreshold参数,避免影响服务稳定性。探409 收藏