【SOLVED】Linux使用sudo到出现输入密码提示延迟时间长

【SOLVED】Linux使用sudo到出现输入密码提示延迟时间长

问题

使用任意发行版,如Fedora、Debian等,/etc/sudoers 包含的用户执行 sudo 命令,到输入密码提示中间延迟时间过长。

解决办法

查看当前 hostname,如PS提示符有提示也可。顺便看了下 /etc/hosts

sudo 或 root 权限编辑 /etc/hosts,将你本机的 hostname 名称追加到 localhost 后,保存退出即可。

sudo vim /etc/hosts

至此,仅 sudo 卡而 su 不卡的问题解决。

分析原因

sudo 命令执行时需要找到执行入口,默认是以hostname作为执行入口的地址。当 /etc/hosts 或 /etc/resolv.conf 中不含主机名映射时,就会等待直到超时,时间可能有15~20秒之间。

出现这种情况有两种可能:

安装系统时变更了主机名

自行修改 /etc/hosts 去除了主机名映射

对于第一种情况,是安装系统工具的bug,未将新 hostname 映射变更到 /etc/hosts 中;

对于第二种情况,多出现于重度洁癖Linux用户,比如我。 😄 我是之前看着后边好长一串,好像没啥用,只保留了 localhost,所以才出现这个问题的。

推荐的方式

如果需要修改 hostname,推荐使用 hostnamectl 命令进行设置,命令设置完主机名时,会同步变更 /etc/hosts 的旧主机名为新主机名。

最后

吐个槽,原来不只是中文圈不求甚解,我出现这个问题时,查了好多论坛、博客,都只给出各种可能、猜测,以及直接给出类似 我也不知道为什么好使,但是我查了谷歌大家都说他好使,我也的确解决了 这种答案……

最后根据其他关键字找到了真正的答案,即 为什么 sudo 需要使用网络?

简言之,sudo 只是一个命令,支持访问别的主机执行 sudo 命令,即 IP 不能写死为 127.0.0.1 。对于本地多网卡的情况,不容易找出当前的主机IP是多少(多网卡多IP),所以使用主机访问 lookback 网卡(网卡名为lo,IP为127.0.0.1)与当前主机沟通。如果没设置这个映射,只能等待DNS超时,访问 127.0.0.1 保底。

我也是查了n多答案才到这里……这该死的求知欲,洗洗睡……

引用:

https://stackoverflow.com/questions/22249688/linux-sudo-is-working-slow-after-changing-the-hostname

https://unix.stackexchange.com/questions/218145/why-does-sudo-need-the-loopback-interface

https://www.sudo.ws/repos/sudo/file/d8150a3fd577/interfaces.c

相关推荐

CAD绘制齿轮的步骤详解-BIM免费教程
36566666

CAD绘制齿轮的步骤详解-BIM免费教程

📅 07-29 👁️ 9629
C语言ASM汇编内嵌语法
365体育APP官网

C语言ASM汇编内嵌语法

📅 09-20 👁️ 4774
锁车门的按键哪个位置
365体育APP官网

锁车门的按键哪个位置

📅 10-24 👁️ 7980
小米内测申请全攻略:流程、时长与注意事项解析
bat365app官网入口登录

小米内测申请全攻略:流程、时长与注意事项解析

📅 07-19 👁️ 7555