golang
已收录文章:14247篇
-
sync.Pool通过复用临时对象减少内存分配和GC开销,提升高并发性能;2.每个P维护本地池减少锁竞争,提供Get、Put和New方法;3.对象可能被GC随时清理,不可依赖长期存在;4.适用于JSON处理、缓冲区等频繁创建销毁对象的场景;5.使用前需重置对象状态,避免放入未清理或敏感数据对象;6.必须验证性能提升,防止误用适得其反。114 收藏
-
答案:通过net/http接收multipart文件,校验大小与类型后保存。示例解析10MB内图片并返回路径。114 收藏
-
答案:基于Golang的微服务权限控制方案包括JWT身份认证、RBAC访问控制、mTLS通信加密及注册中心元数据策略。1.使用JWT携带服务身份信息并验证签名;2.在中间件中解析JWT并检查service_id是否在允许列表内;3.启用mTLS确保双向证书认证与数据加密传输;4.在Consul或Etcd注册时附加权限元数据,结合配置中心动态更新策略。统一中间件与证书管理,提升安全性和可维护性。114 收藏
-
使用Benchmark和pprof可精准定位Go函数性能瓶颈:先通过Benchmark测量函数执行时间,再结合pprof分析CPU与内存使用情况,辅以TestMain启动HTTP服务采集profile数据,最后用benchstat统计优化前后差异,避免编译器优化干扰并确保输入典型、结果可信。114 收藏
-
gomodgraph命令可查看Go项目依赖关系,输出格式为“依赖源->依赖目标”,结合dot工具可生成可视化依赖图,配合grep和awk能筛选特定依赖或反向查找引用,常用于排查版本冲突、识别冗余依赖、理解项目结构及安全审计。114 收藏
-
正文 Redis作是一个高性能的内存数据库,常被应用于分布式系统中,除了作为分布式缓存或简单的内存数据库还有一些特殊的应用场景,本文结合Golang来编写对应的中间件。 本文所有代码见githu113 收藏