1》内存子系统

     1>组件:

        slab    allocator

        buddy    system

        kswapd

        pdflush

     2>虚拟化环境:

         PA:进程地址;

         HA:虚拟机地址;

         MA:机器地址;

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

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

         Shadow   PT:影子列表

     3>Memory:

         TLB:提升性能;

          Hugetable  page:

              使用的文件系统:Hugetlbfs;

                             

        启用hugepages:

              1)修改/etc/sysctl.conf:

                  vm.nr_hugepages = n

                    

               2) Kernel  parameter:

                  hugepages = n

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

          

          

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

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

           

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

           

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

                    

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

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

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

          Slab   cache: 

                              

      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为前提的,可以超出物理内存一部分;

              

              0:不回收dentries和inodes;

              1-99:倾向于不回收;

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

              100+:倾向于回收;

                     

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

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

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

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

            

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

            

      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

              

            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内存子系统及常用调优参数的更多相关文章

  1. JVM的常用的调优策略和垃圾回收算法及Tomcat的常用调优参数

    jvm调优主要针对堆内存,堆内存分为:新生区.养老区和永久区 永久区存放的是系统jdk自身的interface和class的元数据,所以唯有新生区和养老区具有优化空间. 新生区:伊甸区和幸存者区.所有 ...

  2. JVM常用调优工具介绍

    前言 王子在之前的JVM文章中已经大体上把一些原理性问题说清楚了,今天主要是介绍一些实际进行JVM调优工作的工具和命令,不会深入讲解,因为网上资料很多,篇幅可能不长,但都是实用的内容,小伙伴们有不清楚 ...

  3. Dubbo性能调优参数及原理

    本文是针对 Dubbo 协议调用的调优指导,详细说明常用调优参数的作用域及源码. Dubbo调用模型 常用性能调优参数 参数名 作用范围 默认值 说明 备注 threads provider 200 ...

  4. Linux TCP/IP调优参数 /proc/sys/net/目录

    所有的TCP/IP调优参数都位于/proc/sys/net/目录. 例如, 下面是最重要的一些调优参数,后面是它们的含义: /proc/sys/net/core/rmem_default " ...

  5. JVM性能调优的6大步骤,及关键调优参数详解

    JVM性能调优方法和步骤1.监控GC的状态2.生成堆的dump文件3.分析dump文件4.分析结果,判断是否需要优化5.调整GC类型和内存分配6.不断分析和调整JVM调优参数参考 对JVM内存的系统级 ...

  6. 直通BAT必考题系列:JVM性能调优的6大步骤,及关键调优参数详解

    JVM内存调优 对JVM内存的系统级的调优主要的目的是减少GC的频率和Full GC的次数. 1.Full GC 会对整个堆进行整理,包括Young.Tenured和Perm.Full GC因为需要对 ...

  7. 大数据集群Linux CentOS 7.6 系统调优篇

    大数据集群Linux CentOS 7.6 系统调优篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.设置主机hosts文件 1>.修改主机名 [root@node100 ...

  8. JVM调优参数、方法、工具以及案例总结

    这种文章挺难写的,一是JVM参数巨多,二是内容枯燥乏味,但是想理解JVM调优又是没法避开的环节,本文主要用来总结梳理便于以后翻阅,主要围绕四个大的方面展开,分别是JVM调优参数.JVM调优方法(流程) ...

  9. linux分析、诊断及调优的必备“杀器”之一

    下面分别列出linux分析.诊断及调优时用到的工具,并分别进行说明,以方便自己和其他同学参考学习,禁止转载. 1.top top - 02:06:59 up 4 days, 17:14, 2 user ...

随机推荐

  1. Zookeeper 注册中心

    一.Zookeeper的介绍 Zookeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件.它是一个为分布式应用 ...

  2. SharePoint 2010 图表控件

    需求: 统计每周的事件创建数量及关闭数量 以折线的形式显示 一张图表显示两条折线 知识点: 图表控件的使用 外部内容类型 数据库(sql)view(数据源) 结果:

  3. 【校招面试 之 C/C++】第10题 C++不在构造函数和析构函数中调用虚函数

    1.不要在构造函数中调用虚函数的原因 在概念上,构造函数的工作是为对象进行初始化.在构造函数完成之前,被构造的对象被认为“未完全生成”.当创建某个派生类的对象时,如果在它的基类的构造函数中调用虚函数, ...

  4. 二级联动的作业&左右移动作业

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. 240. Search a 2D Matrix II&&74. Search a 2D Matrix 都用不严格递增的方法

    一句话思路:从左下角开始找.复杂度是o(m+n). 一刷报错: 应该是一个while循环中有几个条件判断语句,而不是每个条件判断语句里去加while,很麻烦 数组越界了.从0开始,y的最大条件应该是& ...

  6. CSS中margin边界叠加问题及解决方案(转)

    边界叠加简介 边界叠加是一个相当简单的概念.但是,在实践中对网页进行布局时,它会造成许多混淆.简单地说,当两个垂直边界相遇时,它们将形成一个边界.这个边界的高度等于两个发生叠加的边界的高度中的较大者. ...

  7. 局域网代理通过wget下载

    下载方法: wget -r -p -np -k http://ftp.loongnix.org/os/Fedora13-o32/RPMS/mipsel/ -r,  --recursive(递归)    ...

  8. [SoapUI] 各种日期计算

    import java.util.*; import java.text.SimpleDateFormat; // current date String dateNew = today() // t ...

  9. OSGi 系列(七)之服务的监听、跟踪、声明等

    OSGi 系列(七)之服务的监听.跟踪.声明等 1. OSGi 服务的事件监听 和 bundle 的事件监听类似,服务的事件监听是在服务注册.注销,属性被修改的时候,OSGi 框架会发出各种不同的事件 ...

  10. LINUX网络编程 IO 复用

    参考<linux高性能服务器编程> LINUX下处理多个连接时候,仅仅使用多线程和原始socket函数,效率十分低下 于是就出现了selelct poll  epoll等IO复用函数. 这 ...