如何在 Linux/Unix/Mac 下清除 DNS 查询缓存

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在 Linux/Unix/Mac 下清除 DNS 查询缓存相关的知识,希望对你有一定的参考价值。

Linux和Unix提供了不同的方法来清除缓存。Linux可以运行 nscd 或者 BIND 或者 dnsmasq 作为名称服务缓存守护进程。
Nscd 会缓存libc发起的名称服务的请求。如果把检索NSS数据看做很慢,那么nscd能够显著加快连续访问同一数据的速度,并能提高整个系统的性能。只需重启nscd即可刷新缓存:
$ sudo /etc/init.d/nscd restart

# service nscd restart

# service nscd reload

Mac下用root用户输入下面的命令:
# dscacheutil -flushcache

或者
$ sudo dscacheutil -flushcache

如果你正在使用OSX 10.5 或者更早的版本,尝试使用下面的命令:
lookupd -flushcache
参考技术A Nscd 会缓存libc发起的名称服务的请求。如果把检索NSS数据看做很慢,那么nscd能够显著加快连续访问同一数据的速度,并能提高整个系统的性能。只需重启nscd即可刷新缓存:

$ sudo /etc/init.d/nscd restart


# service nscd restart


# service nscd reload
这个守护进程给最常用的名称服务请求提供了高速缓存。默认的配置文件/etc/nscd.conf,其决定了高速缓存守护进程的行为。

清除 dnsmasq dns 缓存
dnsmasq的是一个轻量级的DNS、TFTP和DHCP服务器。它的目的是给局域网提供配对的DNS和DHCP服务。 dnsmasq接受DNS查询,并从一个小的本地高速缓存应答它们或将其转发到一个真正的递归DNS服务器。该软件也被安装在很多便宜的路由器上来缓存DNS查询。只需重新启动dnsmasq的服务来清除DNS缓存:

$ sudo /etc/init.d/dnsmasq restart
或者

# service dnsmasq restart
清除BIND缓存服务器的dns缓存
一台BIND缓存服务器从另一台服务器(区域主)响应主机的查询而获得信息,然后保存(缓存)数据到本地。您所要做的就是重启BIND以清除其缓存:

# /etc/init.d/named restart
你也可以使用下面rndc命令来清除所有的缓存:

# rndc restart
或者

# rndc exec
BIND v9.3.0 及其以上版本支持一个清除一个特定域名的所有记录缓存的命令:rndc flushname。本例中刷新cyberciti.biz相关域的所有记录:

# rndc flushname cyberciti.biz
同样也可以清除BIND View。比如,LAN和WAN的View可以用下面的命令清除:

# rndc flush lan
# rndc flush wan
给 Mac OS X Unix 用户的提示
Mac下用root用户输入下面的命令:

# dscacheutil -flushcache
或者

$ sudo dscacheutil -flushcache
如果你正在使用OSX 10.5 或者更早的版本,尝试使用下面的命令:

lookupd -flushcache
关于 /etc/hosts 文件的一个提示
/etc/hosts用作静态查询主机的表格。你需要在类Unix操作系统下依据你的要求移除并且/或者更新它:

# vi /etc/hosts
示例输出:
127.0.0.1 localhost
127.0.1.1 wks01.WAG160N wks01
# The following lines are desirable for IPv6 capable hosts
::1 ip6-localhost ip6-loopback
fe00::0 ip6-localnet
ff00::0 ip6-mcastprefix
ff02::1 ip6-allnodes
ff02::2 ip6-allrouters
10.37.34.2 build
192.168.1.10 nas01
192.168.1.11 nas02
192.168.1.12 nas03
#192.168.2.50 nfs2.nixcraft.net.in nfs2
#192.168.2.51 nfs1.nixcraft.net.in nfs1
172.168.232.50 nfs1.nixcraft.net.in nfs1
172.168.232.51 nfs2.nixcraft.net.in nfs2
192.168.1.101 vm01
参考

如何在 UNIX/Linux 中对生产应用程序进行核心转储分析?

【中文标题】如何在 UNIX/Linux 中对生产应用程序进行核心转储分析?【英文标题】:How can I do core dump analysis for a production application in UNIX/Linux? 【发布时间】:2011-03-16 21:49:02 【问题描述】:

我遇到了一个使用 GDB 进行核心转储分析的选项 - 它提到我需要使用特殊的命令行参数构建可执行文件以包含符号信息的合并。 但它会增加可执行文件的大小,我猜它会减慢应用程序的速度。 如果有另一种方法可以在不影响应用程序性能的情况下进行核心转储分析,有人可以建议吗?

【问题讨论】:

【参考方案1】:

调试符号不会减慢应用程序的速度。您可以按如下方式使用拆分调试符号。

gcc -ggdb -o target obj1.o obj2.o ...
strip target --only-keep-debug -o target.dbg
strip target

然后在gdb中,使用symbol-file target.dbg

【讨论】:

以上是关于如何在 Linux/Unix/Mac 下清除 DNS 查询缓存的主要内容,如果未能解决你的问题,请参考以下文章

腾达w311MA在Linux里怎么安装驱动?

如何设置UNIX/Linux中新创建目录或文件的默认权限

为啥要在linux/unix下进行c/c++编程?

如何查看静态库内容 Unix/Linux

Unix/Linux 启动/查询 tomcat 状态

黑客基础命令,DOS命令,以及UNIX / Linux是啥?(具体点)