1》内存子系统

     1>组件:

        slab    allocator

        buddy    system

        kswapd

        pdflush

     2>虚拟化环境:

         PA:进程地址;

         HA:虚拟机地址;

         MA:机器地址;

         虚拟机转换:PA---->HA

         GuestOS(来宾主机),OS(宿主主机);

         Shadow   PT:影子列表

     3>Memory:

         TLB:提升性能;

          Hugetable  page:

              使用的文件系统:Hugetlbfs;

                      

linux stress 模拟内存占用高 CPU低 linux内存性能调优_进程间通信

       

        启用hugepages:

              1)修改/etc/sysctl.conf:

                  vm.nr_hugepages = n

                    

linux stress 模拟内存占用高 CPU低 linux内存性能调优_消息队列_02

               2) Kernel  parameter:

                  hugepages = n

2》创建hugepages从而被应用所使用(不必明确指定文件系统类型,应用要使用时会自动调用,一般MYSQL的缓存块需要使用大页面):

          

linux stress 模拟内存占用高 CPU低 linux内存性能调优_消息队列_03

          

linux stress 模拟内存占用高 CPU低 linux内存性能调优_消息队列_04

3》Strace看进程如何运行,执行了哪些系统调用:

     1>strace  -p     PID ***查看启动进程的系统调用;

           

linux stress 模拟内存占用高 CPU低 linux内存性能调优_进程间通信_05

     2>strace   命令:查看命令的系统调用;

           

linux stress 模拟内存占用高 CPU低 linux内存性能调优_缓存_06

       strace  -c   命令:加入-c可以只输出命令过程中的摘要信息;

              

linux stress 模拟内存占用高 CPU低 linux内存性能调优_缓存_07

      

       -o:将追踪结果保存至文件中,以供后续分析使用;

4》优化内存子系统的使用:

      1>尽可能降低微小内存对象的开销;

          Slab   cache: 

               

linux stress 模拟内存占用高 CPU低 linux内存性能调优_缓存_08

               

      2>降低或延迟慢速子系统的服务时间;

          Filesystem   metadata:buffer  cache(slab  cache)====>使用buffer  cache缓存文件元数据;

          Disk  IO:page  cache====>使用page  cache来缓存DISK  IO,加速读操作;

          Interprocess  communications:shared  memory====>使用共享内存来完成进程间通信;

          Network  IO:buffer  cache,arp  cache,connection  ruacking====>使用buffer  cache,arp  cache和connection  tracking提升网络IO性能;

      3>设置内存的最小空余KB;

      4>注意避免内存过量使用:

            物理内存的过量使用是以swap为前提的,可以超出物理内存一部分;

              

linux stress 模拟内存占用高 CPU低 linux内存性能调优_进程间通信_09

              0:不回收dentries和inodes;

              1-99:倾向于不回收;

              100:倾向性与page  cache和swap  cache相同;

              100+:倾向于回收;

              

linux stress 模拟内存占用高 CPU低 linux内存性能调优_进程间通信_10

       

          内存溢出(OOM):当内核发现由于发生内存溢出而无法再使用时会强制杀死占用大量内存的进程;

      5>调整网络IO的ARP缓存(/proc/net/arp);

5》进程间通信相关内存的调优:

      1>进程间通信类型:messages,semaphores,shared  memory;

            

linux stress 模拟内存占用高 CPU低 linux内存性能调优_缓存_11

      2>查看三者当前的限值:

            

linux stress 模拟内存占用高 CPU低 linux内存性能调优_进程间通信_12

      3>进程间通信管理类命令:

          ipcs:查看一些消息队列;

          ipcrm:删除某些已经失去作用的消息队列,释放内存;

      4>share  memory  和messages的相关参数:

          shm:

            shmmni:系统级别,所允许使用的共享内存段上限;

            shmall:系统级别,能够为共享内存分配使用的最大页面数;

            shmmax:单个共享内存段的上限;

          messages:

            msgmnb:单个消息队列的上限,单位为字节,默认是16384;

            msgmni:系统级别,消息队列个数上限;

            msgmax:单个消息大小的上限,单位为字节;

      5>手动清写脏缓存和缓存,然后回收:

            sync:

            echo  s  >  /proc/sysrq-trigger

         回收:

            echo  1 >  /proc/sys/vm/drop_caches

              

linux stress 模拟内存占用高 CPU低 linux内存性能调优_进程间通信_13

            1  to   free   pagecache

            2  to   free   dentries   and   inodes

            3  to   free   pagecache,dentries  and  inodes

      6>Out-of-memory  killer:

          决定各个进程是否会被杀死的数值oom_score:

                -16-15:帮助计算oom_score

                -17:disables  the oom_killer  for  that  process

6》Swap相关:

      1>哪些页面会被swap:

             非活动页;

             匿名页;

        Swap  cache:可以有效的避免资源竞争;  

      2>如何提高swap的性能:

          降低swap的think time,意味着我们使用小的swap分区;

          降低访问次数,尽量不要使用swap,增大物理内存,不行的话就增加多个swap分区;

          降低服务时间;                

7》监控内存使用相关命令:

        sar   -r:查看内存活动情况;

        sar  -R:内存变换速率;

        sar  -W:缓存空间活动情况;

        sar  -B:I/O使用情况,报告页面换进换出;  

            

linux stress 模拟内存占用高 CPU低 linux内存性能调优_进程间通信_14