解决由于DNS解析导致Emacs启动巨慢的问题_VMware, Unix及操作系统讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  VMware, Unix及操作系统讨论区 »
总帖数
6
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 5697 | 回复: 5   主题: 解决由于DNS解析导致Emacs启动巨慢的问题        上一篇   下一篇 
斗破苍穹
注册用户
等级:中尉
经验:442
发帖:3
精华:0
注册:2016-1-8
状态:离线
发送短消息息给斗破苍穹 加好友    发送短消息息给斗破苍穹 发消息
发表于: IP:您无权察看 2016-3-30 16:45:47 | [全部帖] [楼主帖] 楼主


小白是Emacs的忠实用户,在CentOS服务器上也要自己编译安装一个Emacs供自己使用。由于使用了很多Emacs的插件,每次启动那是很缓慢的,几乎是5s左右才打开一

个文件(让大家误以为服务器配置很烂呢)。在打开文件的速度上与Vim有些差距,Vim打开文件几乎是零等待(我这里的vim是简单的配置,并没有使用额外的插件;

使用Emacs的同行可不要骂我哦)。


最近发现Emacs的打开速度是巨慢无比的,之前就没有这种问题。细想了一下,主要是之前有网络连接,而这几次是没有网络连接的。所以小白就想到底是Emacs的什么

插件需要用到网络呢?于是使用了系统下的strace工具进行追踪一下Emacs是如何启动的,终于找到是什么原因了,原来是主机名解析的问题,


在没有联网的情况下,启动到底是多慢呢?


[root@mydevops ~]# time emacs --kill
 
real    0m5.402s
user    0m0.367s
sys 0m0.019s


看一下strace emacs的部分输出,


# strace emacs
.......
open("/etc/hosts", O_RDONLY|O_CLOEXEC)  = 3 # 首先会查看/etc/hosts文件,在hosts文件里没有找到关于系统主机名的解析
fcntl(3, F_GETFD)                       = 0x1 (flags FD_CLOEXEC)
fstat(3, {st_mode=S_IFREG|0644, st_size=338, ...}) = 0
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7fa6ae5a3000
read(3, "127.0.0.1   localhost.localdomai"..., 4096) = 338
read(3, "", 4096)                       = 0
close(3)                                = 0
munmap(0x7fa6ae5a3000, 4096)            = 0
open("/etc/ld.so.cache", O_RDONLY)      = 3
fstat(3, {st_mode=S_IFREG|0644, st_size=49825, ...}) = 0
mmap(NULL, 49825, PROT_READ, MAP_PRIVATE, 3, 0) = 0x7fa6ae597000
close(3)                                = 0
open("/lib64/libnss_dns.so.2", O_RDONLY) = 3
read(3, "\177ELF\2\1\1\0\0\0\0\0\0\0\0\0\3\0>\0\1\0\0\0\0\20\0\0\0\0\0\0"..., 832) = 832
fstat(3, {st_mode=S_IFREG|0755, st_size=27424, ...}) = 0
mmap(NULL, 2117880, PROT_READ|PROT_EXEC, MAP_PRIVATE|MAP_DENYWRITE, 3, 0) = 0x7fa6a7483000
mprotect(0x7fa6a7488000, 2093056, PROT_NONE) = 0
mmap(0x7fa6a7687000, 8192, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_DENYWRITE, 3, 0x4000) = 0x7fa6a7687000
close(3)                                = 0
open("/lib64/libresolv.so.2", O_RDONLY) = 3
read(3, "\177ELF\2\1\1\0\0\0\0\0\0\0\0\0\3\0>\0\1\0\0\00009\0\0\0\0\0\0"..., 832) = 832
fstat(3, {st_mode=S_IFREG|0755, st_size=110960, ...}) = 0
mmap(NULL, 2202248, PROT_READ|PROT_EXEC, MAP_PRIVATE|MAP_DENYWRITE, 3, 0) = 0x7fa6a7269000
mprotect(0x7fa6a727f000, 2097152, PROT_NONE) = 0
mmap(0x7fa6a747f000, 8192, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_DENYWRITE, 3, 0x16000) = 0x7fa6a747f000
mmap(0x7fa6a7481000, 6792, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_ANONYMOUS, -1, 0) = 0x7fa6a7481000
close(3)                                = 0
mprotect(0x7fa6a747f000, 4096, PROT_READ) = 0
mprotect(0x7fa6a7687000, 4096, PROT_READ) = 0
munmap(0x7fa6ae597000, 49825)           = 0
socket(PF_INET, SOCK_DGRAM|SOCK_NONBLOCK, IPPROTO_IP) = 3
connect(3, {sa_family=AF_INET, sin_port=htons(53), sin_addr=inet_addr("127.0.0.1")}, 16) = 0 # 接着连接本地的53端口进行域名解析,随后sendto系统调用出现"Connection refused"的错误
poll([{fd=3, events=POLLOUT}], 1, 0)    = 1 ([{fd=3, revents=POLLOUT}])
sendto(3, "w\265\1\0\0\1\0\0\0\0\0\0\10mydevops\0\0\1\0\1", 26, MSG_NOSIGNAL, NULL, 0) = 26
poll([{fd=3, events=POLLIN|POLLOUT}], 1, 5000) = 1 ([{fd=3, revents=POLLOUT|POLLERR}])
sendto(3, "\32\205\1\0\0\1\0\0\0\0\0\0\10mydevops\0\0\34\0\1", 26, MSG_NOSIGNAL, NULL, 0) = -1 ECONNREFUSED (Connection refused)
close(3)                                = 0
socket(PF_INET, SOCK_DGRAM|SOCK_NONBLOCK, IPPROTO_IP) = 3
connect(3, {sa_family=AF_INET, sin_port=htons(53), sin_addr=inet_addr("127.0.0.1")}, 16) = 0
poll([{fd=3, events=POLLOUT}], 1, 0)    = 1 ([{fd=3, revents=POLLOUT}])
sendto(3, "w\265\1\0\0\1\0\0\0\0\0\0\10mydevops\0\0\1\0\1", 26, MSG_NOSIGNAL, NULL, 0) = 26
poll([{fd=3, events=POLLIN|POLLOUT}], 1, 5000) = 1 ([{fd=3, revents=POLLOUT|POLLERR}])
sendto(3, "\32\205\1\0\0\1\0\0\0\0\0\0\10mydevops\0\0\34\0\1", 26, MSG_NOSIGNAL, NULL, 0) = -1 ECONNREFUSED (Connection refused)
close(3)


大家可以看到有很多“Connection refused”的错误信息,在这些步骤中消耗了很多时间,最后超时导致的。不知道为什么Emacs启动时要解析这些信息?


既然问题出现了,这里的解决办法是在/etc/hosts文件里加上了关于主机名的解析。果然问题解决了。另外以emacs的守护进程方式启动,然后以emacsclient打开文件

也是飞快的。


在/etc/hosts里添加了主机名解析后,打开Emacs的用时为:


[root@mydevops ~]# time emacs --kill
 
real    0m0.400s
user    0m0.378s
sys 0m0.019s


是不是相差很多。


最后,关于Emacs的启动速度问题,小白这里总结了3种方法:


1.Emacs以daemon的方式先启动(从emacs23版本开始支持),然后使用emacslient来编辑文件,这样的打开速度几乎是秒开。


# 具体如何操作
# emacs --daemon # 首先以daemon的方式启动
# emacsclient /etc/hosts # 然后就可以编辑文件了


2. 在/etc/hosts里设置系统主机名解析


# hostname
mydevops
echo "192.168.56.101 mydevops" >> /etc/hosts

3. 不加载任何配置文件进行启动(定制的内容越多启动越慢)






-------本文出自“固态U盘)博客










赞(0)    操作        顶端 
beefly
注册用户
等级:上尉
经验:758
发帖:1
精华:0
注册:2015-7-27
状态:离线
发送短消息息给beefly 加好友    发送短消息息给beefly 发消息
发表于: IP:您无权察看 2016-3-30 20:37:50 | [全部帖] [楼主帖] 2  楼

学习一下



赞(0)    操作        顶端 
twany
注册用户
等级:少校
经验:1408
发帖:17
精华:0
注册:2015-6-2
状态:离线
发送短消息息给twany 加好友    发送短消息息给twany 发消息
发表于: IP:您无权察看 2016-3-31 9:02:47 | [全部帖] [楼主帖] 3  楼

太慢



赞(0)    操作        顶端 
ettu
注册用户
等级:上尉
经验:787
发帖:0
精华:0
注册:2016-2-22
状态:离线
发送短消息息给ettu 加好友    发送短消息息给ettu 发消息
发表于: IP:您无权察看 2016-3-31 9:04:12 | [全部帖] [楼主帖] 4  楼



赞(0)    操作        顶端 
k3neeb
注册用户
等级:上尉
经验:799
发帖:15
精华:0
注册:2015-5-28
状态:离线
发送短消息息给k3neeb 加好友    发送短消息息给k3neeb 发消息
发表于: IP:您无权察看 2016-3-31 17:15:34 | [全部帖] [楼主帖] 5  楼

一直以来困扰很久的一个问题。。一部分网站的DNS解析为何如此的慢?而别人好像却没有这样的问题。。。于是我开始一步一步排查找原因了。

多次测试,用本机测试,服务器测试,解析域名的速度都很慢。

最后发现,由于我都手工指定了202.96.209.5这个DNS作为主DNS服务器,而别人大部分用户都是通过路由器自动获取,而我突然想到了ISP分配给我们的DNS地址好像都是些不太看到的202.109之类的。

于是我就尝试把DNS更改为ISP分配的202.109.15.135以及202.96.209.134,结果发现解析速度正常了。。。

总结:可能是由于历史原因。。一直以来人们都把202.96.209.5和202.96.209.133这2个DNS作为自己的DNS地址,所以服务器的负荷相当的大,上海有多少用户啊。。。还有那么多的机房~因此,解析速度慢可能是由于服务器负荷较高而造成转发速度变慢甚至超时。

如果是家庭用户,大家可以尝试让路由器自动获取ISP的DNS服务器,因为ISP会做分流,所以给的DNS不会负荷较重。

我的Speed Touch Home 511里获取到的DNS是:202.109.15.135/202.96.209.134



赞(0)    操作        顶端 
duff
注册用户
等级:少校
经验:968
发帖:0
精华:0
注册:2015-7-22
状态:离线
发送短消息息给duff 加好友    发送短消息息给duff 发消息
发表于: IP:您无权察看 2016-3-31 18:15:52 | [全部帖] [楼主帖] 6  楼



赞(0)    操作        顶端 
总帖数
6
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论