NameNode节点忽然挂了,重启后提示OOM,但是这台测试机的内存是16G的,只运行了Namenode和Jenkins,不至于OOM。于是使用free命令查看,发现cached的缓存有10G。很不正常,于是需要进行缓存释放。

1
echo 1 > /proc/sys/vm/drop_caches

此时在使用free -g就发现cached的缓存以及没有了。

cache释放:
Sync

1
sync

To free pagecache:

1
echo 1 > /proc/sys/vm/drop_caches

To free dentries and inodes:

1
echo 2 > /proc/sys/vm/drop_caches

To free pagecache, dentries and inodes (释放页面缓存,dentries和inode):

1
echo 3 > /proc/sys/vm/drop_caches

说明,释放前最好sync一下,防止丢数据。

补充:free命令的补充

1
2
3
4
5
[hadoop@OP-APM-02 hadoop]$ free
total used free shared buffers cached
Mem: 16199748 2625692 13574056 12648 91292 382608
-/+ buffers/cache: 2151792 14047956
Swap: 4194300 0 4194300

其中第一行用全局角度描述系统使用的内存状况:

  • total——总物理内存
  • used——已使用内存,一般情况这个值会比较大,因为这个值包括了cache+应用程序使用的内存
  • free——完全未被使用的内存
  • shared——应用程序共享内存
  • buffers——缓存,主要用于目录方面,inode值等(ls大目录可看到这个值增加)
  • cached——缓存,用于已打开的文件
  • note:
    • total=used+free
    • used=buffers+cached (maybe add shared also)

第二行描述应用程序的内存使用:
前个值表示-buffers/cache——应用程序使用的内存大小,used减去缓存值
后个值表示+buffers/cache——所有可供应用程序使用的内存大小,free加上缓存值

  • note:
    • -buffers/cache=used-buffers-cached
    • +buffers/cache=free+buffers+cached

第三行表示swap的使用:

  • used——已使用
  • free——未使用

手动执行sync命令(描述:sync 命令运行 sync 子例程。如果必须停止系统,则运行 sync 命令以确保文件系统的完整性。sync 命令将所有未写的系统缓冲区写到磁盘中,包含已修改的 i-node、已延迟的块 I/O 和读写映射文件)