linux服务器配置物理内存_linux make menuconfig 物理内存配置 - CSDN
  • Linux服务器,tomcat启动参数根据服务器物理内存动态分配堆内存

    原理很简单,tomcat启动前会先执行bin目录下的setenv.sh脚本(默认不存在,需手动创建),在脚本中获取服务器内存进行动态分配即可

    #!/usr/bin/env bash
    MEM_SIZE="1" #默认1G
    function get_mem_k_size_func(){
        local _memSize="$(vmstat -s -S K | awk 'NR==1{print $1}')"
        echo "${_memSize}"
    }
    
    
    function get_mem_m_size_func(){
        local _memSize="$(vmstat -s -S M | awk 'NR==1{print $1}')"
        echo "${_memSize}"
    }
    
    function get_mem_g_size_func(){
        local _memSize=$(($(get_mem_m_size_func)/1024))
        echo "${_memSize}"
    }
    
    echo "[TOMCAT] TBM_HOME=$TBM_HOME"
    echo "[TOMCAT] runmode=$runmode"
    AVI_MEM_SIZE=$(get_mem_g_size_func)
    if [ ${AVI_MEM_SIZE} -gt 7 ]; then #大于7G内存设置为4G
    	MEM_SIZE="4"
    elif [ ${AVI_MEM_SIZE} -gt 4 ]; then #大于4G内存设置为2G
            MEM_SIZE="2"
    fi
    export JAVA_OPTS="-server -Xms512m -Xmx${MEM_SIZE}g -Xss256k -XX:PermSize=256m -XX:MaxPermSize=512m -XX:+UseG1GC -Dcom.sun.management.jmxremote.port=9089 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -DCmdbType=tbm"
    


    展开全文
  • [appdeploy@CNSZ22PL0217:/home/appdeploy]$free -m total used free shared buffers cachedMem: 258302 110198 148103 0 ...
    [appdeploy@CNSZ22PL0217:/home/appdeploy]$free -m
                      total             used         free        shared     buffers      cached
    Mem:    258302          110198      148103          0        1001          79948
    -/+ buffers/cache:        29248      229053

    Swap:            0                  0               0

    [appdeploy@CNSZ22PL0217:/home/appdeploy]$free -g
                      total       used       free     shared    buffers     cached
    Mem:           252        107        144         0              0              78
    -/+ buffers/cache:      28        223
    Swap:               0          0          0

    分析:以上数据说明该服务器的总物理内存为252G,已使用的内存107G,剩余144G为使用,其中物理内存使用=used-buffers-cached=107-0-78=29G,还剩252-29=223G可以使用,剩余较多


    展开全文
  • 查看linux系统中空闲内存/物理内存使用/剩余内存 查看系统内存有很多方法,但主要的是用top命令和free 命令 当执行top命令看到结果,要怎么看呢?这里说明一下: Mem: 666666k total, 55555k used,并不是代表你的...

    查看linux系统中空闲内存/物理内存使用/剩余内存

    查看系统内存有很多方法,但主要的是用top命令和free 命令
    当执行top命令看到结果,要怎么看呢?这里说明一下:
    Mem: 666666k total, 55555k used,并不是代表你的应用程序已经使用了55555k的内存,这55555k是包含了:应用程序内存 + 缓冲 + 缓存的内存的。
    用free命令查看更直接:
    下面是一个例子(单位是MB): 

    [root@linuxzgf ~]# free -m
                        total       used       free     shared    buffers     cached
    Mem:          7982       6811       1171          0        350       5114
    -/+ buffers/cache:       1346       6636
    Swap:        16935         11      16924

    在这里例子中,应用程序只使用了1346MB内存,还有6636MB空闲内存可以使用. 
    一些简单的计算方法: 
    物理已用内存 = 实际已用内存 - 缓冲 - 缓存 = 6811M - 350M - 5114M

    物理空闲内存 = 总物理内存 - 实际已用内存 + 缓冲 + 缓存 

    应用程序可用空闲内存 = 总物理内存 - 实际已用内存 

    应用程序已用内存 = 实际已用内存 - 缓冲 - 缓存

    top命令的结果详解
    top命令 是Linux下常用的性能 分析工具 ,能够实时显示系统 中各个进程的资源占用状况,类似于Windows的任务管理 器。下面详细介绍它的使用方法。

    top - 02:53:32 up 16 days,  6:34, 17 users,  load average: 0.24, 0.21, 0.24
    Tasks: 481 total,   3 running, 474 sleeping,   0 stopped,   4 zombie
    Cpu(s): 10.3%us,  1.8%sy,  0.0%ni, 86.6%id,  0.5%wa,  0.2%hi,  0.6%si,  0.0%st
    Mem:   4042764k total,  4001096k used,    41668k free,   383536k buffers
    Swap:  2104472k total,     7900k used,  2096572k free,  1557040k cached
    
      PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
    32497 jacky     20   0  669m 222m  31m R   10  5.6       29:27.62 firefox
     4788 yiuwing   20   0  257m  18m  13m S    5  0.5          5:42.44 konsole
     5657 Liuxiaof  20   0  585m 159m  30m S    4  4.0          5:25.06 firefox
     4455 xiefc      20   0  542m  124m  30m R    4  3.1         7:23.03 firefox
     6188 Liuxiaof  20   0  191m   17m  13m S    4  0.5          0:01.16 konsole

    统计信息区前五行是系统整体的统计信息。第一行是任务队列信息,同 uptime  命令的执行结果。其内容如下:

    01:06:48  当前时间  
    up 1:22  系统运行 时间,格式为时:分  
    1 user  当前登录用户 数  
    load average: 0.06, 0.60, 0.48  系统负载 ,即任务队列的平均长度。
                三个数值分别为  1分钟、5分钟、15分钟前到现在的平均值。 

    第二、三行为进程和CPU的信息。当有多个CPU时,这些内容可能会超过两行。内容如下:

    Tasks: 29 total  进程总数  
    1 running  正在运行的进程数  
    28 sleeping  睡眠的进程数  
    0 stopped  停止的进程数  
    0 zombie  僵尸进程数  
    Cpu(s): 0.3% us  用户空间占用CPU百分比  
    1.0% sy  内核 空间占用CPU百分比  
    0.0% ni  用户进程空间内改变过优先级的进程占用CPU百分比  
    98.7% id  空闲CPU百分比  
    0.0% wa  等待输入输出的CPU时间百分比  
    0.0% hi     
    0.0% si    

    最后两行为内存 信息。内容如下:

    Mem: 191272k total  物理内存总量  
    173656k used  使用的物理内存总量  
    17616k free  空闲内存总量  
    22052k buffers  用作内核缓存 的内存量  
    Swap: 192772k total  交换区总量  
    0k used  使用的交换区总量  
    192772k free  空闲交换区总量  
    123988k cached  缓冲的交换区总量。
                内存中的内容被换出到交换区,而后又被换入到内存,但使用过的交换区尚未被覆盖,
                该数值即为这些内容已存在于内存中 的交换区的大小。
                相应的内存再次被换出时可不必再对交换区写入。 

    进程信息区统计信息区域的下方显示了各个进程的详细信息。首先来认识一下各列的含义。

    序号  列名  含义  
    a  PID  进程id  
    b  PPID  父进程id  
    c  RUSER  Real user name  
    d  UID  进程所有者的用户id  
    e  USER  进程所有者的用户名  
    f  GROUP  进程所有者的组名  
    g  TTY  启动进程的终端名。不是从终端启动的进程则显示为 ?  
    h  PR  优先级  
    i  NI  nice值。负值表示高优先级,正值表示低优先级  
    j  P  最后使用的CPU,仅在多CPU环境 下有意义  
    k  %CPU  上次更新到现在的CPU时间占用百分比  
    l  TIME  进程使用的CPU时间总计,单位秒  
    m  TIME+  进程使用的CPU时间总计,单位1/100秒  
    n  %MEM  进程使用的物理内存 百分比  
    o  VIRT  进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES  
    p  SWAP  进程使用的虚拟内存中,被换出的大小,单位kb。  
    q  RES  进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA  
    r  CODE  可执行代码占用的物理 内存大小,单位kb  
    s  DATA  可执行代码以外的部分(数据 段+栈)占用的物理 内存大小,单位kb  
    t  SHR  共享内存大小,单位kb  
    u  nFLT  页面错误次数  
    v  nDRT  最后一次写入到现在,被修改过的页面数。  
    w  S  进程状态。
                D =不可中断的睡眠状态
                R =运行
                S =睡眠
                T =跟踪/停止
                Z =僵尸进程  
    x  COMMAND  命令名/命令行  
    y  WCHAN  若该进程在睡眠,则显示睡眠中的系统函数名  
    z  Flags  任务标志,参考 sched.h 

    默认情况下仅显示比较重要的  PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND  列。可以通过下面的快捷键来更改显示内容。
    更改显示内容通过 f 键可以选择显示的内容。按 f 键之后会显示列的列表,按 a-z  即可显示或隐藏对应的列,最后按回车键确定。
    按 o 键可以改变列的显示顺序。按小写的 a-z 可以将相应的列向右移动,而大写的 A-Z  可以将相应的列向左移动。最后按回车键确定。
    按大写的 F 或 O 键,然后按 a-z 可以将进程按照相应的列进行排序。而大写的  R 键可以将当前的排序倒转。
    top命令使用过程中,还可以使用一些交互的命令来完成其它参数的功能。这些命令是通过快捷键启动的。
    <空格>:立刻刷新。
    P:根据CPU使用大小进行排序。
    T:根据时间、累计时间排序。
    q:退出top命令。
    m:切换显示内存信息。
    t:切换显示进程和CPU状态信息。
    c:切换显示命令名称和完整命令行。
    M:根据使用内存大小进行排序。
    W:将当前设置写入~/.toprc文件中。这是写top配置文件的推荐方法。
    可以看到,top命令是一个功能十分强大的监控系统的工具,对于系统管理员而言尤其重要。但是,它的缺点是会消耗很多系统资源。

    居然查看了内存,以下指令也会用到:
    查看CPU个数
    # cat /proc/cpuinfo | grep "physical id" | uniq | wc -l
    查看CPU核数
    # cat /proc/cpuinfo | grep "cpu cores" | uniq
    查看CPU型号
    # cat /proc/cpuinfo | grep 'model name' |uniq
    那么,该服务器有2个4核CPU,型号Intel(R) Xeon(R) CPU E5630 @ 2.53GHz

    占用内存的测量
    测量一个进程占用了多少内存,linux为我们提供了一个很方便的方法,/proc目录为我们提供了所有的信息,实际上top等工具也通过这里来获取相应的信息。
    /proc/meminfo 机器的内存使用信息
    /proc/pid/maps pid为进程号,显示当前进程所占用的虚拟地址。
    /proc/pid/statm 进程所占用的内存

    业余草微信公众号

    感谢您的关注!可加QQ1群:135430763,QQ2群:454796847,QQ3群:187424846。QQ群进群密码:xttblog,想加微信群的朋友,可以微信搜索:xmtxtt,备注:“xttblog”,添加助理微信拉你进群。备注错误不会同意好友申请。再次感谢您的关注!后续有精彩内容会第一时间发给您!原创文章投稿请发送至532009913@qq.com邮箱。商务合作可添加助理微信进行沟通!

    展开全文
  • 操作系统为了屏蔽I/O底层的差异,创建了VFS(虚拟文件系统),为了屏蔽I/O层与内存之间的差异,产生了虚拟内存。为了屏蔽cpu与内存之间的差异,创建了进程。每个程序运行起来都会拥有一个自己的虚拟地址空间,32位cpu...

             操作系统为了屏蔽I/O底层的差异,创建了VFS(虚拟文件系统),为了屏蔽I/O层与内存之间的差异,产生了虚拟内存。为了屏蔽cpu与内存之间的差异,创建了进程。每个程序运行起来都会拥有一个自己的虚拟地址空间,32位cpu的操作系统,它是一个4GB的内存地址块,其地址线也为32位,所以虚拟地址空间为2^32 -1= 4G。

            在Linux系统中, 内核进程和用户进程所占的虚拟内存比例是1:3,而Windows系统为2:2(通过设置Large-Address-Aware Executables标志也可为1:3)。这并不意味着内核使用那么多物理内存,仅表示它可支配这部分地址空间,根据需要将其映射到物理内存。内核代码和数据总是可寻址,随时准备处理中断和系统调用。与此相反,用户模式地址空间的映射随进程切换的发生而不断变化。

           Linux虚拟内存空间布局如下:

    在将应用程序加载到内存空间执行时,操作系统负责代码段、数据段和BSS段的加载,并在内存中为这些段分配空间。栈也由操作系统分配和管理;堆由程序员自己管理,即显式地申请和释放空间。  BSS段、数据段和代码段是可执行程序编译时的分段,运行时还需要栈和堆。

    总结:

    1、 每个进程都有自己独立的4G内存空间,各个进程的内存空间具有类似的结构;

    2、每个进程的4G内存空间只是虚拟内存空间,每次访问内存空间的某个地址,都需要把地址翻译为实际物理内存地址;

    3、所有进程共享同一物理内存,每个进程只把自己目前需要的虚拟内存空间映射并存储到物理内存上;

    4、可以认为虚拟空间都被映射到了磁盘空间中,(事实上也是按需要映射到磁盘空间上,通过mmap),并且由页表记录映射位置。

    展开全文
  • 最近买了一个centos 的云主机,因为贫穷限制了我购买的内存大小,只有500M,所以导致物理内存经常处于饱和状态,无奈虚拟内存设置的只有132M,理论上讲虚拟内存应该要有物理内存的2倍也就是1G大小才够用!...

        最近买了一个centos 的云主机,因为贫穷限制了我购买的内存大小,只有500M,所以导致物理内存经常处于饱和状态,无奈虚拟内存设置的只有132M,理论上讲虚拟内存应该要有物理内存的2倍也就是1G大小才够用!

     

        又由于我安装微C微信防爆系统的时候,提示我内存不足,所以想用提高虚拟内存的方法去安装这个软件,本来都已经安装完了,今天我手贱把Linux重启了一下,没看仔细,不过也不是坏事情,正好记录下设置过程,以便下次再重启的时候方便设置!

     

    1.打开终端,切换到root用户,输入:free -m查看内存状态
    [maker@LLM ~]$ free -m
                  total        used        free      shared  buff/cache   available
    Mem:            992         189          79          13         722         614
    Swap:             0           0           0
    Swap也就是虚拟内存为0
    
    2.选择一个较大的分区,建立分区文件
    [root@LLM ~]# dd if=/dev/zero of=/opt/swap bs=1024 count=1024000
    1024000+0 records in
    1024000+0 records out
    1048576000 bytes (1.0 GB) copied, 16.6877 s, 62.8 MB/s
    [root@LLM ~]#
    该命令表示在opt分区建立名为swap,大小为1G的虚拟内存文件
    
    3.将swap文件设置为swap分区文件
    chmod 600 /opt/swap    //注意更改swap文件的权限
    [root@LLM ~]# mkswap /opt/swap
    Setting up swapspace version 1, size = 1023996 KiB
    no label, UUID=fc47f29e-31af-401e-856d-0fec5262179e
    
    4.激活swap,启用分区交换文件
    swapon /opt/swap
    5.现在看下结果
    [root@LLM ~]# free -m
                  total        used        free      shared  buff/cache   available
    Mem:            992         191          63          13         737         625
    Swap:           999           0         999

    虚拟内存的设置部分就完成了,接下来讲一下卸载虚拟内存,这个需求也是存在的,比如你走上人生巅峰了,不屑于使用虚拟内存,就需要卸载掉了,就是任性!

    1.首先停止swap分区
    [root@LLM ~]# swapoff /opt/swap
    [root@LLM ~]# free -m
                  total        used        free      shared  buff/cache   available
    Mem:            992         191          63          13         738         626
    Swap:             0           0           0
    
    2.其次删除掉swap文件即可
    首先看一下磁盘大小
    [root@LLM ~]# df -h
    Filesystem      Size  Used Avail Use% Mounted on
    /dev/vda1        40G  3.9G   34G  11% /
    devtmpfs        487M     0  487M   0% /dev
    tmpfs           497M  4.0K  497M   1% /dev/shm
    tmpfs           497M  420K  496M   1% /run
    tmpfs           497M     0  497M   0% /sys/fs/cgroup
    tmpfs           100M     0  100M   0% /run/user/0
    tmpfs           100M     0  100M   0% /run/user/1001
    [root@LLM ~]# rm -rf /opt/swap
    [root@LLM ~]# df -h
    Filesystem      Size  Used Avail Use% Mounted on
    /dev/vda1        40G  3.0G   35G   8% /
    devtmpfs        487M     0  487M   0% /dev
    tmpfs           497M  4.0K  497M   1% /dev/shm
    tmpfs           497M  420K  496M   1% /run
    tmpfs           497M     0  497M   0% /sys/fs/cgroup
    tmpfs           100M     0  100M   0% /run/user/0
    tmpfs           100M     0  100M   0% /run/user/1001
    
    可以看出删除后多了1G的空间

     

     

     

    展开全文
  • 最近在低配置上网本上装了路
  • documentlinux内存机制CPU内存虚拟内存硬盘物理内存内存和虚拟内存跟 Windows 完全不同的 Linux 内存机制Swap配置对性能的影响 linux内存机制 Linux支持虚拟内存(Virtual Mmemory),虚拟内存是指使用磁盘当作RAM的...
  • 最近买了一个CentOS的云主机,因为贫穷限制了我购买的内存大小,只有500M,所以导致物理内存经常处于饱和状态,无奈虚拟内存设置的只有132M,理论上讲虚拟内存应该要有物理内存的2倍也就是1G大小才够用! 又由于我...
  • Linux的Swap相当于Windows的虚拟内存,当物理内存不够的时候,就需要将物理内存中的一部分空间释放出来,以供当前运行的程序使用。那些被释放出来的空间可能来自一些很长时间没有什么操作的程序,这些被释放的空间...
  • 总核数 = 物理CPU个数 X 每颗物理CPU的核数 总逻辑CPU数 = 物理CPU个数 X 每颗物理CPU的核数 X 超线程数 1、查看物理CPU个数 cat /proc/cpuinfo| grep "physical id"| sort| uniq| wc -l 或 grep 'physical id' /...
  • 年前一客户来电,说他们信息中心机房一台Linux服务器运行缓慢,系统服务出现间歇性停止响应,让过去帮忙处理一下这一问题。 到达现场之后,发现此服务器的物理内存是16G,而最初装机的时候,系统管理人员却只分配...
  • 一、常见的Java内存溢出有以下三种: 1. java.lang.OutOfMemoryError: Java heap space 即JVM Heap溢出 解释说明:JVM在启动的...其初始空间默认是物理内存的1/64,最大空间不可超过物理内存。JVM提供-Xmn -Xms -Xm
  • Linux物理内存按固定大小的页面(一般为4K)划分内存,在内核初始化时,会建立一个全局struct page结构数组mem_map[ ]。如系统中有76G物理内存,则物理内存页面数为76*1024*1024k/4K= 19922944个页面,mem_map[ ]...
  • JVM堆的设置是指java程序运行过程中JVM可以调配使用的内存空间的设置.JVM在启动的时候会自动设置Heap size的值,其初始空间(即-Xms)是物理内存的1/64,最大空间(-Xmx)是物理内存的1/4。可以利用JVM提供的-Xmn -Xm...
  • 一台CentOS7 服务器,主要运行一个tomcat的服务,通常占用6G的常驻内存,整个VIRT也就是20G。 系统配置:32G内存,16G swap 系统在运行1段时间后,tomcat服务发现失联了。登陆上机器看tomcat进程已经不见了。 接...
  • 最近工作一直需要写服务器配置信息,好几台服务器,查来查去,写个笔记记录一下命令,(就不啰里八嗦什么原理了,这个找专门文档看去吧,咱也不是搞运维的) 查看服务器内存内存显示成kb(就不截图了毕竟...
  • 查看linux 服务器配置

    2019-02-24 17:33:42
    查询Linux服务器配置 在进行性能调优之前,需要清楚知道服务器的配置信息,比如说 CPU,内存,服务器版本等信息。 查询系统版本信息 root@ubuntu160:~# lsb_release -a No LSB modules are available. ...
1 2 3 4 5 ... 20
收藏数 93,750
精华内容 37,500
关键字:

linux服务器配置物理内存