RAM của tôi đã đi đâu?


15

Lưu ý: trước khi bạn nhảy vào quá nhanh, vâng tôi đã đọc linuxHRyram.com !

Tôi có một máy chủ với 64GB RAM.

free -m nói rằng RAM của tôi đã đầy, và không phải vì bộ nhớ đệm trên đĩa:

             total       used       free     shared    buffers     cached
Mem:         64458      64117        340        201         67        331
-/+ buffers/cache:      63719        739
Swap:         1532        383       1149

Tuy nhiên, được topsắp xếp theo mức sử dụng bộ nhớ không thêm tối đa 64GB:

KiB Mem:  66005116 total, 65652464 used,   352652 free,    67512 buffers
KiB Swap:  1569780 total,   392656 used,  1177124 free.   337464 cached Mem

  PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND
 6258 mysql     20   0 38.665g 0.033t   4924 S   1.3 54.3 482:26.21 mysqld
 2293 root      20   0  165896 102116 101964 S   0.0  0.2   0:43.53 systemd-journal
 4909 root      20   0  377548  57840  57548 S   0.0  0.1   0:18.47 rsyslogd
26639 www       20   0  650076  53348  32968 S   0.0  0.1  11:32.27 php-fpm
26640 www       20   0  648344  51912  32984 S   0.0  0.1  11:37.43 php-fpm
26642 www       20   0  648600  51472  32580 S   0.0  0.1  11:37.16 php-fpm
26669 www       20   0  648148  50696  31988 S   0.0  0.1  11:35.24 php-fpm
26643 www       20   0  648452  50616  31628 S   0.0  0.1  11:36.19 php-fpm
26641 www       20   0  648620  50496  31340 S   0.0  0.1  11:36.51 php-fpm
28121 www       20   0  648620  48820  29660 S   0.0  0.1  11:35.75 php-fpm
27231 www       20   0  647508  48804  30760 S   0.0  0.1  11:35.61 php-fpm
28029 www       20   0  648044  48752  30172 S   0.0  0.1  11:37.20 php-fpm
28117 www       20   0  647868  48700  30296 S   0.0  0.1  11:36.45 php-fpm
28122 www       20   0  648340  48568  29676 S   0.0  0.1  11:35.73 php-fpm
 8569 www       20   0  649028  40268  20704 S   0.0  0.1  11:31.50 php-fpm
10126 www       20   0  648432  39420  20700 S   0.0  0.1   9:58.52 php-fpm
22386 www       20   0  647996  39400  20868 S   0.0  0.1  11:25.00 php-fpm
 9643 www       20   0  647976  39220  20704 S   0.0  0.1  11:29.23 php-fpm
23077 www       20   0  647852  39084  20692 S   0.0  0.1  11:11.80 php-fpm
10139 www       20   0  647580  38808  20692 S   0.0  0.1   9:59.94 php-fpm
 6326 www       20   0  647368  38396  20696 S   0.7  0.1   8:32.34 php-fpm
 4727 www       20   0  646128  37304  20692 S   0.0  0.1   8:30.20 php-fpm
 5459 www       20   0  645988  37156  20688 S   0.0  0.1   7:15.13 php-fpm
 2173 www       20   0  645240  36408  20684 S   0.0  0.1   4:39.13 php-fpm
20752 www       20   0  644536  35428  20680 S   0.0  0.1   4:29.78 php-fpm
 5396 www       20   0  644468  35324  20692 S   0.0  0.1   4:14.65 php-fpm
17558 www       20   0  642668  33816  20740 S   0.0  0.1   1:28.34 php-fpm
28133 www       20   0  642780  33636  20704 S   0.0  0.1   0:49.88 php-fpm
10925 www       20   0  479584  29264  11212 S   3.0  0.0   0:00.09 php
26632 root      20   0  552136  26072  19468 S   0.0  0.0   0:37.74 php-fpm
 4946 named     20   0  697996  18748   2104 S   0.0  0.0   3:46.96 named
15609 apache    20   0 2137056   8120   1592 S   0.0  0.0   0:56.18 httpd
 8584 root      20   0  133432   4864   3700 S   0.0  0.0   0:00.08 sshd

MySQL sử dụng 54,3% một mình, điều này là hoàn toàn bình thường vì nó có một innodb_buffer_pool_sizesố 32G. Việc sử dụng bộ nhớ của các quá trình khác tăng thêm khoảng 2,8%, tổng cộng là 57,1%.

32% còn lại ở đâu?


Chỉnh sửa: nội dung của /proc/meminfo:

MemTotal:       66005116 kB
MemFree:          353272 kB
Buffers:           66328 kB
Cached:           736620 kB
SwapCached:        11348 kB
Active:         34396680 kB
Inactive:        2651132 kB
Active(anon):   34223240 kB
Inactive(anon):  2228020 kB
Active(file):     173440 kB
Inactive(file):   423112 kB
Unevictable:           0 kB
Mlocked:               0 kB
SwapTotal:       1569780 kB
SwapFree:        1177448 kB
Dirty:               328 kB
Writeback:             0 kB
AnonPages:      36234364 kB
Mapped:           125208 kB
Shmem:            206396 kB
Slab:           28058904 kB
SReclaimable:   28010224 kB
SUnreclaim:        48680 kB
KernelStack:        2760 kB
PageTables:        94780 kB
NFS_Unstable:          0 kB
Bounce:                0 kB
WritebackTmp:          0 kB
CommitLimit:    34572336 kB
Committed_AS:   38572348 kB
VmallocTotal:   34359738367 kB
VmallocUsed:      382304 kB
VmallocChunk:   34359353572 kB
HardwareCorrupted:     0 kB
DirectMap4k:        9000 kB
DirectMap2M:     2054144 kB
DirectMap1G:    67108864 kB

Đầu ra của slabtop:

 Active / Total Objects (% used)    : 147380425 / 147413026 (100.0%)
 Active / Total Slabs (% used)      : 7005839 / 7005839 (100.0%)
 Active / Total Caches (% used)     : 71 / 144 (49.3%)
 Active / Total Size (% used)       : 27615020.12K / 27627490.91K (100.0%)
 Minimum / Average / Maximum Object : 0.01K / 0.19K / 16.12K

  OBJS ACTIVE  USE OBJ SIZE  SLABS OBJ/SLAB CACHE SIZE NAME
146851887 146851887  12%    0.19K 6992947       21  27971788K dentry
124936 124936 100%    0.07K   2231       56      8924K Acpi-ParseExt
105144 105144 100%    0.10K   2696       39     10784K buffer_head
 49920  49172  98%    0.06K    780       64      3120K kmalloc-64
 29916  29916 100%    0.11K    831       36      3324K sysfs_dir_cache
 29856  29661  99%    0.12K    933       32      3732K kmalloc-128
 21450  21128  98%    0.18K    975       22      3900K vm_area_struct
 19328  19328 100%    0.03K    151      128       604K kmalloc-32
 18258  13383  73%    0.93K    537       34     17184K ext4_inode_cache
 17952  11651  64%    0.04K    176      102       704K ext4_extent_status
 16828   6513  38%    0.55K    601       28      9616K radix_tree_node
 14400  13996  97%    0.06K    225       64       900K anon_vma
 11645   7903  67%    0.05K    137       85       548K shared_policy_node
 10710   7006  65%    0.19K    510       21      2040K kmalloc-192
 10608  10608 100%    0.04K    104      102       416K Acpi-Namespace
  9728   9728 100%    0.01K     19      512        76K kmalloc-8
...

3
đọc lại linuxHRyram.com. Sau đó đọc kernel.org/doc/gorman/html/understand
symcbean

Tôi đọc nó một lần nữa, và kết thúc bằng gợi ý rằng đó free -mlà cách để thực sự có được việc sử dụng bộ nhớ. Ngoài ra, việc sử dụng trao đổi không phải là 0 khiến tôi hơi mơ hồ. Tôi đã kiểm tra liên kết của bạn, nhưng nó có quá nhiều dữ liệu để đọc mà tôi chỉ không thể xử lý tất cả những điều này vào lúc này tôi sợ.
Benjamin

Đây có phải là một máy chủ vật lý?
Optichip

@Optichip Đây là một máy chủ vật lý.
Benjamin

5
@AndrewSchulman Tôi không nghĩ đây là một câu hỏi trùng lặp với câu hỏi cụ thể đó. Câu hỏi này là về bộ nhớ được sử dụng cho các tấm. Các câu hỏi khác không đề cập đến tấm nào cả.
kasperd

Câu trả lời:


23
  OBJS ACTIVE  USE OBJ SIZE  SLABS OBJ/SLAB CACHE SIZE NAME
146851887 146851887  12%    0.19K 6992947       21  27971788K dentry

Bạn nói rằng nó không phải vì bộ nhớ đệm đĩa, nhưng rõ ràng nó là.

Đặt cược của tôi là bạn có mã tạo ra nhiều lần tìm nạp cho các tệp không tồn tại và bạn nhận được rất nhiều bộ đệm âm. Linux sẽ loại bỏ các mục này nếu nó chịu áp lực bộ nhớ, vì vậy nó có thể không có gì đáng lo ngại. Ví dụ, như trong vấn đề NSS này .


5
Ah, điều đó có thể giải thích điều đó. Xin vui lòng tha thứ cho sự thiếu hiểu biết của tôi, tôi nghĩ rằng free -mmột mình sẽ chỉ ra nếu bộ nhớ bị ăn vì bộ nhớ đệm đĩa. Tôi cũng không biết về "bộ nhớ đệm tiêu cực", sẽ rất thú vị khi hiểu những gì đang cố gắng tìm các tệp không tồn tại. Bất cứ ý tưởng làm thế nào tôi có thể điều tra này, vì tò mò? Đây là một cài đặt gần đây chỉ với một cơ sở dữ liệu + ứng dụng web, vì vậy tôi thực sự ngạc nhiên khi thấy hành vi này.
Benjamin

@Benjamin Theo liên kết của tôi để biết một ví dụ về cách điều này có thể xảy ra. Ngoài ra, hãy nhìn vào những gì ứng dụng web đang thực sự làm.
David Schwartz

10
Trên thực tế, tôi sử dụng libcurl rất nhiều, chính xác hơn là các ràng buộc PHP của nó. Máy chủ web của tôi tải xuống và xử lý nhiều hình ảnh: chúng được tải xuống bộ nhớ, được xử lý, sau đó được tải lên S3, không bao giờ nhấn hệ thống tệp. Do đó tôi phải thừa nhận rằng tôi đã bỏ qua liên kết của bạn, vì thoạt nhìn nó quá cục bộ để tác động đến tôi, nhưng rất có thể đây là vấn đề chính xác: Tôi đã chạy giống strace curlnhư anh chàng đã làm, và thấy rằng nó đã tạo ra 7421 ENOENT (No such file or directory) cho một lần duy nhất truy vấn! Đó phải là nó. Cảm ơn rất nhiều!
Benjamin

2
Bạn có thể muốn xem linux-mm.org/Drop_Caches và làm gì echo 2 > /proc/sys/vm/drop_cachesđể không phá hủy bộ nhớ cache và bộ đệm inode, và xem liệu RAM của bạn có trở lại không. Rõ ràng là tốt nhất thực hiện tại một thời điểm yên tĩnh.
bỏ qua

1
Một xác nhận thêm rằng Linux sẽ bỏ các mục đó nếu chịu áp lực xuất phát từ thực tế là phần lớn các tấm hoạt động ( Slabtrong /proc/meminfo) nằm dưới SReclaimable(như tên giải thích, có thể được thu hồi khi cần thiết).
Marco Leogrande

4

Nó có thể là một số cấu trúc kernel bên trong và các công cụ liên quan đến hệ thống tập tin / thư mục. Điều này cũng hoàn toàn bình thường mặc dù khó hiểu; thử xem đầu ra từ đâu slabtopcat /proc/meminfo.


Tôi đã thêm đầu ra của các lệnh này vào câu hỏi của tôi, bạn có thể vui lòng xem được không?
Benjamin

1
Chà, khoảng 27 gigabyte RAM của bạn dường như được sử dụng bởi kernel, và hầu hết trong số đó là vào dentrycác mục trong thư mục. Tôi đoán bạn có rất nhiều tập tin xung quanh trong hệ thống tập tin của bạn. Đó thực tế chỉ là những thứ được lưu trong bộ nhớ cache, trong trường hợp một số tiến trình thực sự cần bộ nhớ, nó sẽ được phát hành theo cách tương tự như với bộ đệm / bộ đệm thông thường mà bạn có xu hướng nhìn thấy ở đầu ra hàng đầu.
Janne Pikkarainen

Đó là điều tốt để biết, cảm ơn bạn. Mặc dù vậy, tôi chỉ ngạc nhiên vì tôi không có nhiều tệp trên hệ thống tệp: find / | wc -ltrả về 134578, không phải hàng triệu như dentrycó thể đề xuất. Bạn có biết những gì có thể làm điều này?
Benjamin

Có khả năng tìm thấy những gì tạo ra các mục thư mục rác, nhờ câu trả lời của David Schwartz ở trên. Cảm ơn sự giúp đỡ của bạn nào!
Benjamin
Khi sử dụng trang web của chúng tôi, bạn xác nhận rằng bạn đã đọc và hiểu Chính sách cookieChính sách bảo mật của chúng tôi.
Licensed under cc by-sa 3.0 with attribution required.