golang中连接达梦数据库使用域名来代替IP时会出现解析问题

中间件使用gorm

复制代码
driverName := "dm"
dataSourceName := fmt.Sprintf("dm://%s:%s@%s:%s/SYSDBA?charset=utf8&parseTime=true", config.Database.Username, config.Database.Password, config.Database.Address, config.Database.Port)

config.Database.Address 这里使用了比如"dm8"这样的字符串,而不是ip

执行程序会遇到Error 6001: Communication error dial address: localhost:5236的报错

这个是因为dm的驱动包中有问题,我这里使用的是V1.0.0版本的驱动
在n.go文件中,func (c *DmConnector) mergeConfigs(dsn string) error函数中有这样的逻辑

复制代码
host, port, err := net.SplitHostPort(host)
if err != nil || net.ParseIP(host) == nil {
 c.host = hostDef
} else {
 c.host = host
}

这里可以看到,会对域名进行格式校验,如果不是合法IP,则将其替换成了hostDef,也就是localhost。
吐槽一下,两个host明明不是同一个东西,为啥不能使用2个名称呢

所以将其修改

复制代码
if err != nil {
   c.host = hostDef
} else if net.ParseIP(host) == nil {
   if ip, err := net.LookupHost(host); err != nil {
      c.host = hostDef
   } else {
      if len(ip) == 1 {
         c.host = ip[0]
      } else {
         c.host = hostDef
      }
   }
} else {
   c.host = host
}
相关推荐
云和数据.ChenGuang7 分钟前
Django 应用安装脚本 – 如何将应用添加到 INSTALLED_APPS 设置中 原创
数据库·django·sqlite
woshilys35 分钟前
sql server 查询对象的修改时间
运维·数据库·sqlserver
Hacker_LaoYi36 分钟前
SQL注入的那些面试题总结
数据库·sql
2401_857439692 小时前
SSM 架构下 Vue 电脑测评系统:为电脑性能评估赋能
开发语言·php
建投数据2 小时前
建投数据与腾讯云数据库TDSQL完成产品兼容性互认证
数据库·腾讯云
SoraLuna2 小时前
「Mac畅玩鸿蒙与硬件47」UI互动应用篇24 - 虚拟音乐控制台
开发语言·macos·ui·华为·harmonyos
xlsw_2 小时前
java全栈day20--Web后端实战(Mybatis基础2)
java·开发语言·mybatis
Hacker_LaoYi3 小时前
【渗透技术总结】SQL手工注入总结
数据库·sql
岁月变迁呀3 小时前
Redis梳理
数据库·redis·缓存
独行soc3 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍06-基于子查询的SQL注入(Subquery-Based SQL Injection)
数据库·sql·安全·web安全·漏洞挖掘·hw