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
}
相关推荐
汤米粥2 分钟前
小皮PHP连接数据库提示could not find driver
开发语言·php
冰淇淋烤布蕾4 分钟前
EasyExcel使用
java·开发语言·excel
Leo.yuan6 分钟前
数据量大Excel卡顿严重?选对报表工具提高10倍效率
数据库·数据分析·数据可视化·powerbi
拾荒的小海螺11 分钟前
JAVA:探索 EasyExcel 的技术指南
java·开发语言
Runing_WoNiu14 分钟前
MySQL与Oracle对比及区别
数据库·mysql·oracle
马剑威(威哥爱编程)35 分钟前
哇喔!20种单例模式的实现与变异总结
java·开发语言·单例模式
天道有情战天下35 分钟前
mysql锁机制详解
数据库·mysql
看山还是山,看水还是。38 分钟前
Redis 配置
运维·数据库·redis·安全·缓存·测试覆盖率
谷新龙00141 分钟前
Redis运行时的10大重要指标
数据库·redis·缓存
CodingBrother42 分钟前
MySQL 中单列索引与联合索引分析
数据库·mysql