golang
已收录文章:997篇
-
TLS握手优化通过减少客户端与服务器之间建立安全连接的时间,提升性能。1.SessionTicket允许客户端重用之前的会话信息,通过配置tls.Config启用SessionTicketKey实现;2.0-RTT允许客户端在握手完成前发送数据,需在TLS1.3及以上版本中启用EarlyDataHandler处理早期数据;3.安全方面,需定期轮换SessionTicket密钥以防止泄露,并防范0-RTT的重放攻击风险;4.可通过openssls_client命令测试SessionTicket是否生效,检查262 收藏
-
在Golang中配置嵌入式SQLite数据库的步骤如下:1.导入modernc.org/sqlite库,使用goget命令安装并导入到Go文件;2.使用sql.Open函数打开数据库连接并创建db对象;3.执行SQL语句进行表创建、数据插入等操作;4.使用Query或QueryRow方法查询数据并通过rows.Scan获取结果。为提升并发性能,可启用WAL模式或合并批量写操作。迁移可通过golang-migrate/migrate工具实现,包括创建迁移文件并执行up/down命令。单元测试时可使用:mem232 收藏
-
sqlc通过预编译生成类型安全的Go代码,减少手动编写SQL的工作量并避免运行时错误。安装sqlc后,创建数据库和schema,编写带注释的SQL查询文件,配置sqlc.yaml指定数据库类型、SQL文件路径、输出目录等参数,运行sqlcgenerate生成代码,包括查询函数、结构体和辅助函数。在Go代码中导入生成的包,使用db.New()创建查询对象执行操作。对于复杂查询,正确编写SQL并注释指示结果处理方式;事务处理则通过db.BeginTx开始事务,将事务传递给新创建的Queries对象,最后提交或404 收藏
-
sync.Once是Go中实现单例最推荐的方式,它通过Do方法确保初始化函数仅执行一次。使用时定义一个Once实例和单例变量,在GetInstance函数中调用once.Do来初始化对象,保证并发安全、代码简洁且性能良好。常见误区包括传参错误和复用Once对象,此外还有全局变量、init函数和加锁等其他单例实现方式,但均不如sync.Once安全高效。282 收藏
-
Golang批处理框架与ArgoWorkflows集成的优势在于利用Go的高效并发、Kubernetes的云原生能力及Argo的声明式工作流管理。1.Go的goroutine和channel机制实现任务调度与执行的高并发;2.通过Kubernetes实现容器化部署与自动伸缩;3.ArgoWorkflows提供可视化工作流定义与插件扩展机制;4.结合元数据存储、API接口与监控日志系统,构建完整高效的批处理平台。422 收藏
-
防腐层模式在Go中通过适配器实现,核心是定义适配器接口并为每个外部系统实现具体适配器。1.定义核心领域模型,如User结构体;2.定义适配器接口,声明所需操作;3.实现具体适配器,处理外部系统调用与数据转换;4.在业务逻辑中依赖适配器接口;5.使用依赖注入切换适配器。策略选择取决于外部系统复杂度和数据需求,性能优化可通过缓存、批量处理、并行及优化转换逻辑实现。接口变更时只需修改适配器,不影响核心逻辑。该模式并非适用于所有场景,适合频繁集成且外部系统多变的情况。457 收藏