Linux修改/etc/hosts不起作用(ping: xxx: Name or service not known)的解决方法——开启NSCD

问题描述

起因是我在实验室云资源池的一台虚拟机(CentOS 8.5)上的/etc/hosts文件中为Fabric网络节点的域名指定了IP:

IP可以ping通,但是ping域名时提示ping: xxx: Name or service not known

问题本身应该是Linux通用的,不局限于CentOS8。特记录以供参考。

已尝试但不起作用的方法

花了两个上午在网上搜索关键词,尝试了各种方法,但是都不起作用。比如:

  • 检查hosts文件格式是否正确。

    结论:一般人都不会错...

  • 重启networking服务,例如
    /etc/init.d/networking restart
    /etc/init.d/networking force-reload

    结论:路径/etc/init.d/下根本不存在该服务。

  • 修改/etc/nsswitch.conf中的hosts键,将其改为:hosts: files dns,然后再重启networking服务。

    结论:也是不存在该服务。

  • 清除系统DNS缓存,例如
    systemd-resolve --flush-caches

    结论:没用。

  • /etc/resolv.conf中添加DNS服务器。

    结论:没用,这个是针对无法ping通外网的,我这个服务器的DNS本身没有问题,可以ping通外网的域名。

  • 修改/etc/sysconfig/network-scripts/下的网卡配置文件ifcfg-ens...,例如将其中的ONBOOT=no 改成 ONBOOT=yes,然后再重启networking服务。

    结论:也是不存在该服务。

最终生效的解决方案

参考1提到了重启NSCD,如果不存在就安装它。虽然略微有点语焉不详,不过本着试一试的态度,参照参考3参考4安装了NSCD,最终解决问题。

具体流程如下:

  • 使用yum安装NSCD。
bash 复制代码
yum -y install nscd
  • 启动NSCD服务。
bash 复制代码
systemctl start nscd
  • 检查其运行状态。
bash 复制代码
systemctl status nscd

无需修改NSCD服务的配置文件。NSCD的具体介绍详见上述参考。

附录

参考1:https://www.idc.net/help/150889/

参考2:https://blog.csdn.net/Unknownfuture/article/details/104642043

参考3:https://www.cnblogs.com/zhangmingcheng/p/13427995.html

参考4:https://cloud.tencent.com/developer/article/2242697

相关推荐
藥瓿锻13 分钟前
2024 CKA题库+详尽解析| 15、备份还原Etcd
linux·运维·数据库·docker·容器·kubernetes·cka
bbsh209923 分钟前
WebFuture:Ubuntu 系统上在线安装.NET Core 8 的步骤
linux·ubuntu·.netcore·webfuture
ZZZKKKRTSAE32 分钟前
快速上手Linux全局搜索正则表达式(grep)
linux·服务器·正则表达式
waving-black2 小时前
利用frp和腾讯云服务器将内网暴露至外网(内网穿透)
linux·服务器·腾讯云·frp·内网穿透
stormsha2 小时前
Linux中su与sudo命令的区别:权限管理的关键差异解析
linux·运维·服务器·鸿蒙系统·ux·batch命令
筏.k3 小时前
grep、wc 与管道符快速上手指南
linux
Johny_Zhao3 小时前
华为MAAS、阿里云PAI、亚马逊AWS SageMaker、微软Azure ML各大模型深度分析对比
linux·人工智能·ai·信息安全·云计算·系统运维
CodeOfCC3 小时前
c语言 封装跨平台线程头文件
linux·c语言·windows
科文小白狼3 小时前
Linux下VSCode开发环境配置(LSP)
linux·vscode·里氏替换原则·lsp
jugt5 小时前
CentOS 7.9安装Nginx1.24.0时报 checking for LuaJIT 2.x ... not found
linux·运维·centos