0

0

如何在Golang中连接CockroachDB分布式SQL数据库 Go语言Pgx驱动兼容

P粉602998670

P粉602998670

发布时间:2026-03-12 04:47:28

|

568人浏览过

|

来源于php中文网

原创

pgx连接cockroachdb需显式配置ssl模式或证书:本地--insecure时加?sslmode=disable;启用tls时须指定sslrootcert并设sslmode=verify-full;务必使用pgxpool连接池而非每次handler中connect();insert...returning和on conflict必须用queryrow()/query();事务中需defer tx.rollback(ctx)并在commit成功后取消;set transaction priority仅影响冲突裁决。

如何在golang中连接cockroachdb分布式sql数据库 go语言pgx驱动兼容

pgx 连接 CockroachDB 时 URL 格式要加 ?sslmode=disable 或配证书

默认情况下,CockroachDB 启动后强制要求 TLS(即使本地开发用 cockroach start --insecure),而 pgx 默认走 sslmode=require,结果一连就报错:dial tcp [::1]:26257: connect: connection refused 或更隐蔽的 failed to connect to `host=localhost user=root database=bank`: server error (FATAL: SSL is required)

解决方法很简单,但容易卡住:在连接字符串末尾显式关闭 SSL 检查——前提是确认你用的是 --insecure 模式;如果启用了 TLS(比如生产环境),就得提供 CA 证书路径。

  • 本地开发(cockroach start --insecure):连接串写成 postgresql://root@localhost:26257/defaultdb?sslmode=disable
  • 启用 TLS 的集群:必须加 sslrootcert=/path/to/ca.crt,且 sslmode 改为 verify-fullrequire
  • pgx.ParseConfig() 里手动设 Config.TLSConfig = nil 也能绕过,但不推荐——不如直接改 URL 清晰

pgx.Connect() 还是 pgxpool.Connect()?别在 HTTP handler 里单次 Connect()

CockroachDB 是分布式系统,连接建立本身有开销,而且 pgx.Connect() 返回的是单次连接,用完不关会泄漏;HTTP handler 里每次请求都 Connect() + Close(),轻则慢,重则触发连接数上限(CockroachDB 默认 max_connections=100)。

正确做法是复用连接池。CockroachDB 对连接池友好,pgxpool 能自动处理健康检查、连接重建和超时驱逐。

立即学习go语言免费学习笔记(深入)”;

免费语音克隆
免费语音克隆

这是一个提供免费语音克隆服务的平台,用户只需上传或录制一段 5 秒以上的清晰语音样本,平台即可生成与用户声音高度一致的 AI 语音克隆。

下载
  • 初始化一次全局 *pgxpool.Pool,例如在 main() 里调用 pgxpool.Connect(context.Background(), connString)
  • handler 中直接用 pool.Query()pool.Exec(),不用管打开/关闭
  • 注意设置合理 max_conns:CockroachDB 推荐每节点 100–200 连接,Go 服务端按并发量配,比如 pgxpool.ConnectConfig 里设 MaxConns: 50

CockroachDB 的 INSERT ... RETURNINGON CONFLICT 在 pgx 里要用 QueryRow()Query()

CockroachDB 兼容 PostgreSQL 语法,但有些惯用法在 pgx 里容易写错。比如想插入并返回主键,或做 upsert,不能只用 Exec()——它不返回结果集。

典型错误是写了 pool.Exec(ctx, "INSERT INTO users(name) VALUES($1) RETURNING id", "alice"),结果拿不到 id,因为 Exec() 忽略 RETURNING 子句。

  • RETURNING 的语句必须用 QueryRow()(单行)或 Query()(多行),例如:err := pool.QueryRow(ctx, "INSERT INTO users(name) VALUES($1) RETURNING id", "alice").Scan(&id)
  • ON CONFLICT DO UPDATE 也一样:只要含 RETURNING,就不能用 Exec()
  • CockroachDB 不支持 ON CONFLICT DO NOTHING 的变体(如 ON CONFLICT (col) WHERE ...),这点比 PG 严格,写之前先确认 schema 约束是否匹配

事务中执行 COMMIT 失败时,pgx 不会自动回滚,得靠 defer tx.Rollback(ctx)

CockroachDB 的事务模型是“乐观并发控制”,COMMIT 可能失败(比如遇到写冲突、事务超时),此时 tx.Commit() 返回非 nil error,但事务状态已不可用——你不能再对它做任何操作,包括再次 Commit()Rollback()

常见错误是只写 if err := tx.Commit(); err != nil { log.Fatal(err) },结果出错后程序挂死或数据不一致。

  • 标准写法是:在 Begin() 后立刻 defer tx.Rollback(ctx),然后在成功时手动 tx.Commit() 并清掉 defer(用 defer func() { if !committed { _ = tx.Rollback(ctx) } }() 或更简单地用 sql.Tx 风格的 defer 控制
  • CockroachDB 的 SET TRANSACTION PRIORITY 会影响冲突概率,高优先级事务更可能赢,但别滥用——优先级不是调度权,只是冲突时的裁决依据
  • 如果事务里执行了 DDL(如 CREATE TABLE),CockroachDB 要求该事务只能包含一条语句,否则报错 cannot execute multiple statements in a transaction that contains DDL
事情说清了就结束。最常漏的是 sslmode=disable 和事务里没设 defer Rollback,这两处一错,要么连不上,要么事务卡死又不报错。

相关文章

驱动精灵
驱动精灵

驱动精灵基于驱动之家十余年的专业数据积累,驱动支持度高,已经为数亿用户解决了各种电脑驱动问题、系统故障,是目前有效的驱动软件,有需要的小伙伴快来保存下载体验吧!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

210

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

247

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

356

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

214

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

409

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

490

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

201

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

1438

2025.06.17

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 6.1万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号