位置: 编程技术 - 正文

mysql could not be resolved: Name or service not known

编辑:rootadmin

推荐整理分享mysql could not be resolved: Name or service not known,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

问题: mysql DNS反解:skip-name-resolve错误日志有类似警告:

1. :: [Warning] IP address '..1.' could not be resolved: Name or service not known2. :: [Warning] IP address '..1.' could not be resolved: Name or service not known3. :: [Warning] IP address '..1.' could not be resolved: Name or service not known

通过show processlist发现大量类似如下的连接:

1.||unauthenticated user|..1.:|NULL|Connect| |login|NULL|2.||unauthenticated user|..1.:|NULL|Connect| |login|NULL|3.||unauthenticated user|..1.:|NULL|Connect| |login|NULL|

skip-name-resolve 参数的作用:不再进行反解析(ip不反解成域名),这样可以加快数据库的反应时间。

修改配置文件添加并需要重启:

其实就是在[mysqld]下面一行加入skip-name-resolve重启mysql服务就可以了。

下面是更加详细的解释:

现象:

程序连接mysql时,mysql的error.log里面提示:

[Warning] IP address '.0.0.' could not be resolved: Name or service not known

原因:

Mysql数据库服务器没有配置 /etc/hosts,也没有DNS服务,导致mysqld线程解析IP对应的主机名时,解析失败。

参考资料:

Mysql域名解析:

当一个新的客户端尝试跟mysqld创建连接时,mysqld产生一个新线程来处理这个请求。新线程会先检查请求建立连接的主机名是否在Mysql的主机名缓冲中,如果不在,线程会尝试去解析请求连接的主机名。

解析的逻辑如下:

a. Mysql线程通过gethostbyaddr()把获取的IP地址解析成主机名,然后通过gethostbyname()把获取的主机名解析成IP地址,保障主机名和IP地址对应关系的准确;

b. 如果操作系统支持使用安全进程的gethostbyaddr_r()和gethostbyname_r() 调用,Mysqld线程可以用它俩来优化主机名解析;

c. 如果操作系统不支持安全线程调用,Mysqld进程先做一个互斥锁,然后调用gethostbyaddr()和gethostbyname()解析主机名。此时,在第一个进程释放掉主机名缓冲池的主机名之前,其它进程无法再次解析这个主机名; <-------MySQL手册里面在此处说的host name ,意思应该是指同一个IP地址和对应的第一个主机名关系。

在启动mysqld进程是,可以使用 --skip-name-resolve 参数禁用DNS的主机名解析功能,禁用该功能后,在MySQL授权表里面,你只能使用IP地址。

如果你所处环境的DNS非常慢 或者 有很多主机, 你可以通过禁用DNS解析功能--skip-name-resolve 或者 提高 HOST_CACHE_SIZE大小 来提升数据库的响应效率。

禁用主机名缓冲的发方法: 使用--skip-host-cache 参数; 刷新主机名缓冲区: 执行 flush hosts 或者执行mysqladmin flush-hosts;

禁用TCP/IP连接: 使用--skip-networking参数。

实验:# grep ..1.1 /etc/hosts ..1.1 hostname_online

sql> grant usage on *.* to root@'h_tt_%' identified by 'root';

mysql could not be resolved: Name or service not known

sql> flush hosts;

# mysql -h ..1.1 -uroot -proot

ERROR (): Access denied for user 'root'@'hostname_online' (using password: YES) ### IP解析为hostname_online,不是h_tt_%,访问被拒。

# grep ..1.1 /etc/hosts

..1.1 hostname_online

..1.1 h_tt_1

# mysql -h ..1.1 -uroot -proot

ERROR (): Access denied for user 'root'@'hostname_online' (using password: YES)#### mysqld没有刷新主机池缓冲池中的IP和主机名信息,此时IP对应hostname_online

sql> flush hosts;

# mysql -h ..1.1 -uroot -proot

ERROR (): Access denied for user 'root'@'hostname_online' (using password: YES) #### mysqld解析了/etc/hosts里面同一个IP对应的第一个主机名关系时,就不再解析后面这个IP对应的主机名关系

# grep ..1.1 /etc/hosts

..1.1 h_tt_1

..1.1 hostname_online

sql> flush hosts;

# mysql -h ..1.1 -uroot -proot

sql> exit

【实验:】验证解析相同IP对应的第一个主机名关系后,就不再解析相同IP:

Sql>grant usage on *.* to root@'h_tt_%' identified by ‘root';

Sql>flush hosts;

# grep h_tt /etc/hosts # grep h_tt /etc/hosts

..1.1hostname_online ..1.1h_tt_1

..1.1h_tt_1 ,.1.2h_tt_1

访问mysql被拒绝; 从两个IP都可以访问mysql.

【结论】

此实验验证了,上述mysql手册中对"How MySQL Uses DNS"的解释。

即mysqld线程解析/etc/hosts是,是以IP作为唯一标识的,及时一个IP对应了多个主机名,但是mysqld线程只解析第一条对应关系,不论后面有几条这个IP对应的不同主机名的记录,Mysqld进程都不会去解析,都是无效的。

【适用环境:】

没有DNS服务器,主机非常非常多,或者 不想维护/etc/hosts里面手动配置的IP和主机名对应列表时,可以在mysql授权时执行主机名为"%" 或者禁用IP和主机名解析功能(--skip-name-resolve)。

mysql导入导出命令解析 mysqldump是mysql用于转存储数据库的实用程序。它主要产生一个SQL脚本,其中包含从头重新创建数据库所必需的命令CREATETABLEINSERT等。下面就让我们一起学

分享一下Mysql常见的几个错误问题及解决方法 1.问题:mysqlDNS反解:skip-name-resolve错误日志有类似警告:1.::[Warning]IPaddress'..1.'couldnotberesolved:Nameorservicenotknown2.::[Warning]IPaddress'

一次MySQL慢查询导致的故障 我们知道分析MySQL语句查询性能的方法除了使用EXPLAIN输出执行计划,还可以让MySQL记录下查询超过指定时间的语句,我们将超过指定时间的SQL语句查询称

标签: mysql could not be resolved: Name or service not known

本文链接地址:https://www.jiuchutong.com/biancheng/347950.html 转载请保留说明!

上一篇:19个MySQL性能优化要点解析(mysql数据库性能)

下一篇:mysql导入导出命令解析(mysql导入导出sql文件)

  • 公司税务年报没报罚款多少
  • 印花税的征税范围具体有哪些
  • 烟叶增值税税率10%
  • 应交税金怎么算出来的
  • 以公允价值计量计入其他综合收益
  • 小规模交社保有人数限制吗
  • 企业购房产的进项税税额
  • 清卡重用
  • 应收账款余额百分比法会计分录
  • 员工团体意外保险怎么报销
  • 装修费用税法规定
  • 零星物流运费无法支付
  • 库存现金贷方为负数说明什么
  • 企业想成为退税商店需具备哪些条件
  • 计算并分摊本月利润
  • 有形资产包括什么资产
  • 物业企业门禁卡如何记账?
  • 以物易物差价印花税
  • 溢价发行股票的账务处理
  • 公司账户资金
  • 现金流量表借款还了流入和流出可以抵消吗
  • 国外公司怎么付款给国内
  • 税收征管法关于全款未收房的规定
  • 个体工商户是否需要报税
  • 返回的工会经费如何做账最新
  • 公司为职工购买社保只购买三险可以吗
  • 盘盈对应的入账科目
  • 销项负数发票会计分录怎么写
  • 税金及附加期末结转分录
  • 专项附加扣除如何自行申报
  • php html5
  • Win11 Build 22449.1000更新里哪些内容?Win11 Build 22449更新介绍与安装方法
  • 公司收到发票怎么做账
  • 如何设置路由器步骤要详细
  • PHP:pg_set_error_verbosity()的用法_PostgreSQL函数
  • 存货盘盈怎么做账
  • 公司给其他单位分红需要对方开票吗
  • 增值税发票红冲后税款怎么办
  • vue数据实时更新
  • vue侧边栏导航,右侧显示对应内容
  • php base64 编码与解码实例代码
  • vue项目引入ts
  • 业务招待费属于现金流量表中的哪个项目
  • php解析base64数据生成图片的方法
  • ab1562a固件
  • 建行对账单回签平啥意思
  • 汇兑损益会计处理方法
  • 企业净利润率是多少好
  • 数论电子书下载
  • access中宏是按什么调用的
  • mysql修改表结构会锁表吗
  • 别人公司过账用自己的银行卡会查吗
  • 建筑公司租赁设备怎么入账
  • 什么是品种法?适用于什么范围?
  • 无偿赠送货物如何申报增值税
  • 出口退税账务处理难吗
  • 清理固定资产的税费
  • 出口退税的范围是多少
  • 固定资产报废如何记账
  • 物流运输业务
  • 库存商品盘点流程
  • 残保金是交上一年的吗
  • sql数据库连不上可能的原因
  • mysql2002解决办法
  • linux命令视频讲解
  • linux dd 系统
  • windows7中ie浏览器怎么打开
  • 苹果电脑使用u盾怎么用
  • linux程序死机
  • win7系统关机没反应
  • win7系统c盘占用空间大
  • 使用速度最快的手机
  • opengl es api
  • python利用for循环求1到100的奇数之和
  • 从零开始学什么好
  • 全面解析日本失去的十年
  • android实时获取微信聊天信息
  • 残疾人交房产契税有优惠吗
  • 国家税务北京税务局
  • 五证合一后工商变更完还要税务变更吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设