golang
已收录文章:14251篇
-
使用Go标准库net/http实现文件上传,通过ParseMultipartForm解析表单,FormFile获取文件句柄,保存到服务器指定目录,同时支持前端HTML表单提交,完整示例包含错误处理与文件路径安全校验。153 收藏
-
Golang的archive/zip库通过zip.Writer和zip.Reader实现ZIP文件的压缩与解压,压缩时需为每个文件创建zip.FileHeader并写入相对路径以保留目录结构,解压时需校验路径防止ZipSlip漏洞;处理大文件时依赖流式I/O避免内存溢出,但需注意磁盘I/O、CPU消耗及小文件数量带来的性能瓶颈,可通过调整压缩级别、并发处理和缓冲区优化提升效率;常见错误包括文件I/O失败、ZIP格式无效、路径安全风险等,应全面检查错误、包装错误信息、验证路径合法性并确保资源及时释放。241 收藏
-
拆分Go包的核心是按职责边界将代码重构为高内聚、低耦合的子包,通过创建子目录、调整package声明和导入路径实现。拆分能提升可维护性与编译效率,合理使用接口和公共包可避免循环依赖,但需警惕过度拆分导致的认知负担与依赖复杂化,应以清晰职责划分而非文件大小为拆分依据。103 收藏
-
采用模块化结构提升可维护性,结合功能或DDD分层;2.用viper管理配置,环境变量注入敏感信息;3.使用zap等结构化日志并集成Prometheus与追踪系统;4.实现健康检查探针与优雅关闭;5.多阶段Docker构建轻量镜像,CI/CD集成静态检查与安全扫描;6.规范错误处理与重试熔断机制;7.通过context与并发控制优化资源使用。364 收藏
-
GolanggRPC服务的反射与动态调用通过protoreflect解析.proto文件获取服务信息,利用reflect包动态创建请求参数(支持嵌套message),结合context实现超时控制和错误处理,并通过Interceptor机制实现Token或TLS认证授权,从而在无需预生成代码的情况下实现灵活、安全的通用gRPC客户端调用。333 收藏
-
NATSStreaming通过消息持久化和可靠传递保障Golang应用消息不丢失,核心步骤包括:1.用Docker部署NATSStreaming服务器;2.安装stan.go客户端库;3.使用stan.Connect()建立连接并指定唯一客户端ID;4.通过Publish()发布消息,支持同步与异步模式;5.使用Subscribe()实现广播、QueueSubscribe()实现负载均衡消费;6.通过持久化ID实现断线重连后消息续传。尽管NATSStreaming仍用于部分存量系统,新项目建议优先评估Je157 收藏