卓越飞翔博客卓越飞翔博客

卓越飞翔 - 您值得收藏的技术分享站
技术文章34448本站已运行393

Go SQLCMD 比 Windows 原生版本慢吗?

go sqlcmd 比 windows 原生版本慢吗?

php小编小新,你是否经常使用SQLCMD工具来管理和操作数据库?你是否曾经对比过Windows原生版本和Go SQLCMD的性能差异?如果你有这些疑问,那么今天我们就来探讨一下这个话题。在本文中,我们将对比这两个版本的性能,并给出答案,Go SQLCMD是否比Windows原生版本慢。让我们一起来看看吧!

问题内容

我一直在使用 Windows 本地 sqlcmd 在本地 SQL Server 数据库上运行脚本。我有一组脚本文件,用于创建数据库、添加表和索引、填充域数据、添加存储过程等。运行脚本是通过每个文件执行一个 sqlcmd -i .sql 来完成的。这运作良好并且足够快。 切换到 sqlcmd 的新 Go 实现后,数据库构建时间慢了几倍。

我一直无法找到任何方法从sqlcmd获取计时类型的统计信息来确定是否是连接问题、连接池或其他问题。如果我将多个文件作为附加的 -i 选项传递,我可以看到看起来有什么改进,这向我表明这是 Go 命令启动或初始数据库连接建立的问题。 p>

我做了一个测试,我拿了十个 SQL 文件,并将它们作为十个单独的 sqlcmd 执行来运行,也作为一个 sqlcmd 执行来运行,这十个文件作为单独的 -i 输入文件。单独的命令需要 20 秒,综合命令需要 4 秒。因此,这似乎是启动开销或连接开销的问题。

根据 @siggemannen 的建议,我使用 AD 凭据和直接数据库用户测试了连接。 AD 凭据比直接数据库连接慢得多,这意味着这是我在场景中看到的缓慢的根源。

我正在寻找任何建议或想法来解决问题或进一步排除故障。有什么办法可以加快 AD 身份验证的速度吗?

解决方法

Go sqlcmd 并不比原生版本慢。使用 Windows/AD 凭据建立连接会增加建立连接所需的启动时间,并且在用例中为每个 sqlcmd 实例运行一个 SQL 文件,这会增加额外的开销。

我们可以重新编写构建脚本,以便为每个单独的 sqlcmd 运行许多 SQL 文件,这将恢复我们所需的性能。但是,我们无需任何返工即可使用的替代方案是使用 SQL Server 级别主体 sa 在创建数据库时创建。这恢复了与使用 AD 登录的本机 sqlcmd 相当的性能。

卓越飞翔博客
上一篇: 如何在 Mac 上设置 Go 的 Wails 路径?
下一篇: 返回列表
留言与评论(共有 0 条评论)
   
验证码:
隐藏边栏