• [AIRFLOW] 如何增加Ubuntu的虚拟内存


    今日编译某软件系统时,出现如下错误:

    virtual memory exhausted: Cannot allocate memory 

    为解决此问题,找到如下解决方案。

    1、打开终端,切换到root用户,输入:free -m查看内存状态
    [root@lxt lxt]# free -m
    total used free shared buffers cached
    Mem: 498 357 141 0 27 162
    -/+ buffers/cache: 167 331
    Swap: 1023 0 1023
    2、输入df -B M(或df -m)查看各分区当前使用情况
    [root@lxt lxt]# df -B M
    文件系统 1M-块 已用 可用 已用% 挂载点
    /dev/mapper/vg_lxt-lv_root
    12875M 4059M 8162M 34% /
    /dev/sda7 194M 14M 170M 8% /boot
    tmpfs 250M 1M 249M 1% /dev/shm
    (fdisk -l可查看磁盘分区情况)
    3、选择一个较大的分区,建立分区文件:
    [root@lxt lxt]# dd if=/dev/zero of=/swapadd bs=1024 count=524288
    524288+0 records in
    524288+0 records out
    536870912 bytes (537 MB) copied,13.0709 秒,41.1 MB/秒
    以上命令在根目录新建一个名为swapadd,大小为512M的虚拟内存文件
    4、移动该文件到空间较大的其他分区:
    [root@lxt lxt]# mkdir /mnt/swap
    [root@lxt /]# mv swapadd /mnt/swap
    5、执行以下命令启用虚拟内存并重启电脑
    [root@lxt /]# mkswap /mnt/swap/swapadd
    Setting up swapspace version 1, size = 524284 KiB
    no label, UUID=a5c8b651-6f64-4414-bb5f-580b742acfce
    [root@lxt /]# swapon /mnt/swap/swapadd
    查看内存:
    [root@lxt /]# free -m
    total used free shared buffers cached
    Mem: 498 492 6 0 15 302
    -/+ buffers/cache: 174 323
    Swap: 1535 0 1535
    6、如果不需要使用新增的虚拟内存,则输入:
    swapoff -v /mnt/swap/swapadd

    扩展:

    如果需要一直保持这个 swap ,可以sudo -s换到root
    然后把它写入 /etc/fstab 文件。

    swapadd path swap swap defaults 0 0

    清除Linux缓存

     
     
    今天用spot on light 查了一下开发服务器的内存占用,只剩下60MB
    用下面的方法就可以实现清空缓存
    频繁的文件访问会导致系统的Cache使用量大增
    首先使用free -m查看剩余内存
    [root@Oracle ~]# free -m
    total used free shared buffers cached
    Mem: 3383 3319 63 0 97 2395
    -/+ buffers/cache: 826 2556
    Swap: 1983 195 1788

    total 内存总数 used 已经使用的内存数 free 空闲的内存数 shared 多个进程共享的内存总额

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

    使用方式 : sync 
    使用说明 : Linux 系统中欲写入硬盘的资料有的时候会了效率起见,

         会写到 filesystem buffer 中,这个 buffer 是一块记忆体空间,

         如果欲写入硬盘的资料存于此 buffer 中,而系统又突然断电的话,

         那么资料就会流失了,sync 指令会将存于 buffer 中的资料强制写入硬盘中。

     

    [root@Oracle ~]# echo 1 > /proc/sys/vm/drop_caches
    [root@oracle ~]# sysctl -p


    [root@oracle ~]# free -m
    total used free shared buffers cached
    Mem: 3383 1952 1431 0 1 1136
    -/+ buffers/cache: 814 2568
    Swap: 1983 195 1788
    说明:
    1>. /proc是一个虚拟文件系统,我们可以通过对它的读写操作作为与kernel实体间进行通信的一种手段。也就是说可以通过修改/proc中的文件,来对当前kernel的行为做出调整。也就是说我们可以通过调整/proc/sys/vm/drop_caches来释放内存。
    0 – 不释放
    1 – 释放页缓存
    2 – 释放dentries和inodes
    3 – 释放所有缓存
    数字1是用来清空最近放问过的文件页面缓存
    数字2是用来清空文件节点缓存和目录项缓存
    数字3是用来清空1和2所有内容的缓存。
    2>. 关于drop_caches的官方说明如下:
    Writing to this file causes the kernel to drop clean caches,dentries and inodes from memory, causing that memory to becomefree.
    To free pagecache, use echo 1 > /proc/sys/vm/drop_caches;
    to free dentries and inodes, use echo 2 > /proc/sys/vm/drop_caches;
    to free pagecache, dentries and inodes, use echo 3 >/proc/sys/vm/drop_caches.
    Because this is a non-destructive operation and dirty objects are not freeable, the user should run sync first.
     
    3>. Linux内核会将它最近访问过的文件页面缓存在内存中一段时间,这个文件缓存被称为pagecache。
    Inode是linux/unix操作系统中的一种数据结构,包含了各文件相关的一些重要信息。在创建文件系统时,就会同时创建大量的inode。一般inode表会占用文件系统磁盘空间的1%。
     

    目录项缓存(dcache)dentries

    各参数含义:
    total:总物理内存
    used:已使用内存
    free:完全未被使用的内存
    shared:应用程序共享内存
    buffers:缓存,主要用于目录方面,inode值等
    cached:缓存,用于已打开的文件
    -buffers/cache:应用程序使用的内存大小,used减去缓存值
    +buffers/cache:所有可供应用程序使用的内存大小,free加上缓存值
     
    其中:
    total = used + free
    -buffers/cache=used-buffers-cached,这个是应用程序真实使用的内存大小
    +buffers/cache=free+buffers+cached,这个是服务器真实还可利用的内存大小

    [oracle@cddserver1 ~]$ free -m
    total used free shared buffers cached
    Mem: 32096 10379 21717 0 38 7942
    -/+ buffers/cache: 2398 29698
    Swap: 34287 0 34287
    这里面的第二行才是真正服务器的空闲内存
     
     
    2. Linux的内存分配方式
    大家都知道,Linux服务器为了提高效率,会提前申请内存,即使这些内存没有被具体应用使用,Linux也会提前申请这些内存,然后利用这些内存做缓存用,即将刚打开的文件系统存入cache中,这样对应的服务器free值会越来越少,buffers和cached会越来越大,因此给大家表象就是内存越来越少了,大家就紧张了;其实,大家完全不用紧张,Linux服务器在发现内存不足时,会自动清理cached区域,释放内存,然后继续增大cache,free继续减少。因此,那样手动降低内存使用率的方法,其实就是图一时之快,呵呵。
     
     
     

    echo 1 > /proc/sys/vm/drop_caches 可以暂时清空cache和buffer

    在rhel5和Ubuntu上(rhel4不可以),可以直接修改内核文件
    # /etc/sysctl.conf
    vm.drop_caches = 1

    #sysctl -p

     

    $ sync
    $ free -m
    total used free shared buffers cached
    Mem: 32096 30084 2011 0 590 26162
    -/+ buffers/cache: 3332 28764
    Swap: 34287 0 34287
    echo 3 > /proc/sys/vm/drop_caches
    free -m

     
    原本以为是oracle缓存占满了,
    在SQLPLUS中输入
    ALTER SYSTEM FLUSH BUFFER_CACHE;
    alter system flush shared_pool;
    但是看了一下效果不明显
    后面试试Linux清除ARP缓存
    一、 arp -n|awk '/^[1-9]/ {print "arp -d "$1}' | sh
    清除所有ARP缓存,推荐!
    二、for((ip=2;ip<255;ip++));do arp -d 192.168.0.$ip &>/dev/null;done
    清除192.168.0.0网段的所有缓存
    三、arp -d IP
    这样可以清除单一IP 的ARP缓存
    注意:以上均需要root权限,尤其是最后一个,如果不再root下执行,则改为:
    arp -n|awk '/^[1-9]/ {print "arp -d "$1}' | sudo sh
  • 相关阅读:
    jquery如何获取url中问号后面的数值
    CSS3 @font-face
    如何在代码中应用设计模式
    面试中可能被问到的常用排序算法
    《深入java虚拟机》读书笔记之垃圾收集器与内存分配策略
    《深入java虚拟机》读书笔记之Java内存区域
    Spring系列之手写一个SpringMVC
    Java多线程之Executor框架和手写简易的线程池
    Spring系列之手写注解与配置文件的解析
    Spring系列之AOP的原理及手动实现
  • 原文地址:https://www.cnblogs.com/turingbrain/p/6531516.html
Copyright © 2020-2023  润新知