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
}
相关推荐
RestCloud13 小时前
SQL Server到Hive:批处理ETL性能提升30%的实战经验
数据库·api
RestCloud13 小时前
为什么说零代码 ETL 是未来趋势?
数据库·api
ClouGence15 小时前
CloudCanal + Paimon + SelectDB 从 0 到 1 构建实时湖仓
数据库
DemonAvenger1 天前
NoSQL与MySQL混合架构设计:从入门到实战的最佳实践
数据库·mysql·性能优化
AAA修煤气灶刘哥1 天前
后端人速藏!数据库PD建模避坑指南
数据库·后端·mysql
RestCloud2 天前
揭秘 CDC 技术:让数据库同步快人一步
数据库·api
得物技术2 天前
MySQL单表为何别超2000万行?揭秘B+树与16KB页的生死博弈|得物技术
数据库·后端·mysql
侃侃_天下2 天前
最终的信号类
开发语言·c++·算法
可涵不会debug2 天前
【IoTDB】时序数据库选型指南:工业大数据场景下的技术突围
数据库·时序数据库
ByteBlossom2 天前
MySQL 面试场景题之如何处理 BLOB 和CLOB 数据类型?
数据库·mysql·面试