स्वैप उपयोग बहुत अधिक है?


9

मेरे पास एक डेबियन सिड बॉक्स है, जो लगभग एक महीने पहले स्थापित किया गया था, इस समय कोई डेस्कटॉप ऐप नहीं चल रहा है।

कोई भी कमांड जिसे मैं चलाने की कोशिश करता हूं (ssh के माध्यम से) हार्ड डिस्क को बहुत कठिन काम करता है। उबंटू 8.04 को चलाने के दौरान कुछ हफ्तों पहले सिस्टम ने त्रुटिपूर्ण रूप से काम किया। हार्डवेयर ठीक होना चाहिए, स्मार्ट उपकरण कोई समस्या नहीं रिपोर्ट करते हैं, न ही मेमोरी चेक आदि।

मुझे संदेह है कि समस्या स्वैपिंग से संबंधित है:

$ free -h
             total       used       free     shared    buffers     cached
Mem:          998M       986M        12M         0B       464K       904M
-/+ buffers/cache:        81M       917M
Swap:         511M       511M         0B

सामान का परीक्षण, मैं देखता हूं कि मैं रिबूट किए बिना स्वैप को अक्षम करने में असमर्थ हूं, भले ही अधिकांश भौतिक राम का उपयोग कैश के लिए किया जाता है:

# swapoff  -a
swapoff: /swapfile: swapoff failed: Cannot allocate memory

इस स्टैकओवरफ़्लो उत्तर में उल्लिखित स्क्रिप्ट को चलाने के दौरान , उच्चतम स्वैप-उपयोग प्रक्रिया मुश्किल से 1.5megs का उपयोग कर रही थी, और कुल गणना:

"Overall swap used: 18376 kB"

... जो कि आधे टमटम से बहुत दूर है जो htop या मुफ्त रिपोर्ट है।

मैं बदल रहा है की कोशिश की swappinessकरने के लिए 1आधे से एक महीने पहले, लेकिन वहाँ कोई अंतर नहीं (एक ही स्मृति उपयोग पैटर्न) है।

किसी भी विचार अपराधी क्या हो सकता है?

संपादित करें : यहां /proc/meminfoसामग्री (समान स्थिति, लेकिन 904 के बजाय 702 कैश कैश और क्रोमियम अभी भी खुले हैं):

MemTotal:        1022464 kB
MemFree:           14344 kB
Buffers:             192 kB
Cached:           719816 kB
SwapCached:         2212 kB
Active:           304304 kB
Inactive:         657344 kB
Active(anon):     294128 kB
Inactive(anon):   651264 kB
Active(file):      10176 kB
Inactive(file):     6080 kB
Unevictable:           0 kB
Mlocked:               0 kB
HighTotal:        127336 kB
HighFree:            316 kB
LowTotal:         895128 kB
LowFree:           14028 kB
SwapTotal:        524284 kB
SwapFree:              0 kB
Dirty:                 4 kB
Writeback:             0 kB
AnonPages:        239528 kB
Mapped:            11968 kB
Shmem:            703760 kB
Slab:              28924 kB
SReclaimable:      12116 kB
SUnreclaim:        16808 kB
KernelStack:        2200 kB
PageTables:         5812 kB
NFS_Unstable:          0 kB
Bounce:                0 kB
WritebackTmp:          0 kB
CommitLimit:     1035516 kB
Committed_AS:    2193368 kB
VmallocTotal:     122880 kB
VmallocUsed:       14092 kB
VmallocChunk:     105548 kB
HardwareCorrupted:     0 kB
AnonHugePages:         0 kB
HugePages_Total:       0
HugePages_Free:        0
HugePages_Rsvd:        0
HugePages_Surp:        0
Hugepagesize:       2048 kB
DirectMap4k:      911352 kB
DirectMap2M:           0 kB

और यहाँ top -b -n 1उत्पादन है:

top - 22:00:18 up 1 day,  2:34,  4 users,  load average: 1,97, 1,25, 0,88
Tasks: 137 total,   3 running, 134 sleeping,   0 stopped,   0 zombie
%Cpu(s):  4,9 us,  3,0 sy,  2,7 ni, 83,2 id,  6,1 wa,  0,0 hi,  0,0 si,  0,0 st
KiB Mem:   1022464 total,  1008788 used,    13676 free,      188 buffers
KiB Swap:   524284 total,   524284 used,        0 free,   719792 cached

  PID USER      PR  NI  VIRT  RES  SHR S  %CPU %MEM     TIME+ COMMAND
 7861 stenyak   20   0  6336 1252  976 R  18,0  0,1   0:00.03 top
 5194 isabel    30  10 44372 5344 1404 R  12,0  0,5   0:36.11 glmatrix
17940 root      20   0  103m 6844 2828 S   6,0  0,7  11:02.21 Xorg
    1 root      20   0  2280   28    0 S   0,0  0,0   0:02.49 init
    2 root      20   0     0    0    0 S   0,0  0,0   0:00.00 kthreadd
    3 root      20   0     0    0    0 S   0,0  0,0   0:15.25 ksoftirqd/0
    5 root      20   0     0    0    0 S   0,0  0,0   0:00.00 kworker/u:0
    6 root      rt   0     0    0    0 S   0,0  0,0   0:00.93 migration/0
    7 root      rt   0     0    0    0 S   0,0  0,0   0:00.46 watchdog/0
    8 root      rt   0     0    0    0 S   0,0  0,0   0:00.73 migration/1
   10 root      20   0     0    0    0 S   0,0  0,0   0:17.30 ksoftirqd/1
   12 root      rt   0     0    0    0 S   0,0  0,0   0:00.43 watchdog/1
   13 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 cpuset
   14 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 khelper
   15 root      20   0     0    0    0 S   0,0  0,0   0:00.00 kdevtmpfs
   16 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 netns
   17 root      20   0     0    0    0 S   0,0  0,0   0:00.44 sync_supers
   18 root      20   0     0    0    0 S   0,0  0,0   0:00.00 bdi-default
   19 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 kintegrityd
   20 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 kblockd
   22 root      20   0     0    0    0 S   0,0  0,0   0:00.07 khungtaskd
   23 root      20   0     0    0    0 D   0,0  0,0   2:50.47 kswapd0
   24 root      25   5     0    0    0 S   0,0  0,0   0:00.00 ksmd
   25 root      20   0     0    0    0 S   0,0  0,0   0:00.00 fsnotify_mark
   26 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 crypto
   99 root      20   0     0    0    0 S   0,0  0,0   0:00.00 khubd
  115 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 ata_sff
  116 root      20   0     0    0    0 S   0,0  0,0   0:00.00 scsi_eh_0
  117 root      20   0     0    0    0 S   0,0  0,0   0:00.00 scsi_eh_1
  118 root      20   0     0    0    0 S   0,0  0,0   0:01.66 kworker/u:1
  152 root      20   0     0    0    0 S   0,0  0,0   0:02.12 jbd2/sda1-8
  153 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 ext4-dio-unwrit
  280 root      20   0  2944  352  128 S   0,0  0,0   0:00.30 udevd
  423 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 hd-audio0
 1286 root      20   0     0    0    0 S   0,0  0,0   0:07.06 jbd2/sda2-8
 1287 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 ext4-dio-unwrit
 1561 root      20   0     0    0    0 S   0,0  0,0   0:03.09 flush-8:0
 1603 root      20   0  2376   48    0 S   0,0  0,0   0:00.33 rpcbind
 1634 statd     20   0  2648   68   64 S   0,0  0,0   0:00.00 rpc.statd
 1639 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 rpciod
 1641 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 nfsiod
 1648 root      20   0  2576    0    0 S   0,0  0,0   0:00.00 rpc.idmapd
 2019 root      20   0 29088  976    0 S   0,0  0,1   0:22.26 rsyslogd
 2123 root      20   0  1876   84   24 S   0,0  0,0   0:00.23 acpid
 2161 message+  20   0  3756  728    0 S   0,0  0,1   0:02.06 dbus-daemon
 2213 daemon    20   0  2152   20    0 S   0,0  0,0   0:00.00 atd
 2231 root      20   0  4488  220  128 S   0,0  0,0   0:00.00 bluetoothd
 2242 root      10 -10     0    0    0 S   0,0  0,0   0:00.00 krfcommd
 2259 avahi     20   0  3272  292  168 S   0,0  0,0   0:00.66 avahi-daemon
 2262 avahi     20   0  3156   24    0 S   0,0  0,0   0:00.00 avahi-daemon
 2265 root      20   0  5968  180  152 S   0,0  0,0   0:00.00 bitlbee
 2271 root      20   0     0    0    0 S   0,0  0,0   0:11.69 kworker/0:2
 2304 root      20   0 19056  700  220 S   0,0  0,1   0:00.75 NetworkManager
 2334 root      20   0  5536  176  108 S   0,0  0,0   0:02.86 cron
 2350 root      20   0  6700  492  152 S   0,0  0,0   0:00.01 sudo
 2351 root      20   0 15304 5880 1428 R   0,0  0,6  61:42.79 iotop
 2359 root      20   0 24256  600   56 S   0,0  0,1   0:01.12 polkitd
 2390 root      20   0  6892  368  180 S   0,0  0,0   0:00.15 modem-manager
 2392 root      20   0  7536   80    0 S   0,0  0,0   0:00.13 cupsd
 2396 root      20   0 20964  516  296 S   0,0  0,1   0:00.15 gdm3
 2712 root      20   0 10068  196   84 S   0,0  0,0   0:11.72 kerneloops
 2714 root      20   0  6896 2108  372 S   0,0  0,2   0:05.69 ddclient - slee
 2802 Debian-+  20   0  7424  100   40 S   0,0  0,0   0:00.05 exim4
 2877 daemon    20   0  1868  236  172 S   0,0  0,0   0:01.22 uptimed
 2881 root      20   0  6464  208  104 S   0,0  0,0   0:00.27 sshd
 2913 root      20   0  1848   72    8 S   0,0  0,0   0:00.00 minissdpd
 2936 root      20   0  4328   40   36 S   0,0  0,0   0:00.00 getty
 2937 root      20   0  4328   40   36 S   0,0  0,0   0:00.00 getty
 2938 root      20   0  4328   40   36 S   0,0  0,0   0:00.00 getty
 2939 root      20   0  4328   40   36 S   0,0  0,0   0:00.00 getty
 2940 root      20   0  4328   40   36 S   0,0  0,0   0:00.00 getty
 2941 root      20   0  4328   40   36 S   0,0  0,0   0:00.00 getty
 2961 root      20   0 23384  540  156 S   0,0  0,1   0:00.88 accounts-daemon
 2965 root      20   0 29216  292   64 S   0,0  0,0   0:01.35 console-kit-dae
 3050 root      20   0 27408  320    0 S   0,0  0,0   0:00.48 upowerd
 3115 stenyak   20   0  6260  320   84 S   0,0  0,0   0:00.51 screen
 3119 stenyak   20   0  6260  248   40 S   0,0  0,0   0:00.61 screen
 3121 stenyak   20   0  6260  132   16 S   0,0  0,0   0:00.48 screen
 3124 stenyak   20   0  6388 1004  572 S   0,0  0,1   1:33.81 p2p.sh
 3125 stenyak   20   0 34176 5604 1764 S   0,0  0,5   1:57.10 quasselcore
 3129 stenyak   20   0 55268 2972  652 S   0,0  0,3   3:00.32 bot.py
 3280 rtkit     21   1 18980  180   64 S   0,0  0,0   0:01.23 rtkit-daemon
 3367 root      20   0     0    0    0 S   0,0  0,0   0:00.00 kauditd
 3684 root      20   0  2940  340  112 S   0,0  0,0   0:00.00 udevd
 3685 root      20   0  2940  208    0 S   0,0  0,0   0:00.00 udevd
 5845 root      20   0  6444  904  592 S   0,0  0,1   0:00.00 cron
 5876 stenyak   20   0  1932  428  368 S   0,0  0,0   0:00.00 sh
 5878 stenyak   20   0  6048 1232 1080 S   0,0  0,1   0:00.00 memmon.sh
 7857 stenyak   20   0  5060  508  448 S   0,0  0,0   0:00.00 sleep
 9071 root      20   0  9816  860  200 S   0,0  0,1   0:00.10 sshd
 9080 stenyak   20   0 10180 1112  136 S   0,0  0,1   0:06.93 sshd
 9081 stenyak   20   0  9280 3232  148 S   0,0  0,3   0:00.62 bash
 9436 root      20   0  7396 1188  684 S   0,0  0,1   0:07.05 bitlbee
10285 root      20   0     0    0    0 S   0,0  0,0   0:00.00 kworker/1:0
12728 stenyak   20   0  7960 2960  648 S   0,0  0,3  23:35.01 htop
12950 root      20   0  9832   80   76 S   0,0  0,0   0:00.08 sshd
12955 stenyak   20   0  9832    0    0 S   0,0  0,0   0:00.04 sshd
12956 stenyak   20   0  9304   36   32 S   0,0  0,0   0:00.64 bash
17939 root      20   0 23284 1080  320 S   0,0  0,1   0:00.11 gdm-simple-slav
18062 root      20   0 29808  964  364 S   0,0  0,1   0:00.38 gdm-session-wor
20066 root      20   0     0    0    0 S   0,0  0,0   0:09.72 kworker/0:0
28369 isabel    20   0  1932  112  108 S   0,0  0,0   0:00.03 sh
28404 isabel    20   0  3868  260   68 S   0,0  0,0   0:00.20 ssh-agent
28407 isabel    20   0  3516    0    0 S   0,0  0,0   0:00.00 dbus-launch
28408 isabel    20   0  3420  304  116 S   0,0  0,0   0:00.24 dbus-daemon
28416 isabel    20   0  6344  744  548 S   0,0  0,1   0:00.29 xfconfd
28422 isabel    20   0  8336  496  248 S   0,0  0,0   0:01.46 xscreensaver
28424 isabel    20   0 21932  580  340 S   0,0  0,1   0:00.17 xfce4-session
28430 isabel    20   0 24392 2032 1160 S   0,0  0,2   0:16.32 xfwm4
28432 isabel    20   0  117m 2072  908 S   0,0  0,2   0:01.26 xfce4-panel
28434 isabel    20   0 22520  256  256 S   0,0  0,0   0:00.06 Thunar
28436 isabel    20   0 21016  688  460 S   0,0  0,1   0:00.06 xfsettingsd
28437 isabel    20   0  119m 3344 1312 S   0,0  0,3   0:03.50 xfdesktop
28441 isabel    20   0 21072  272  268 S   0,0  0,0   0:00.07 kerneloops-appl
28443 isabel    20   0 29816  540  228 S   0,0  0,1   0:00.10 polkit-gnome-au
28450 isabel    20   0  263m  544  276 S   0,0  0,1   0:00.30 xfce4-volumed
28452 isabel    20   0 63936  488    0 S   0,0  0,0   0:00.31 tracker-store
28457 isabel    20   0 23240  768  472 S   0,0  0,1   0:00.18 xfce4-settings-
28460 isabel     9 -11 99532  500  248 S   0,0  0,0   0:00.38 pulseaudio
28470 isabel    20   0 21936  612  312 S   0,0  0,1   0:00.20 panel-6-systray
28472 isabel    20   0  339m 1348  552 S   0,0  0,1   0:00.42 xfce4-mixer-plu
28473 isabel    20   0 22028 2292 1740 S   0,0  0,2   0:59.33 xfce4-oragecloc
28514 isabel    20   0  371m  21m 2428 S   0,0  2,1   3:46.22 chromium
28517 isabel    20   0  111m 3020  288 S   0,0  0,3   0:00.58 chromium
28518 isabel    20   0  1948   64    0 S   0,0  0,0   0:00.00 chromium-sandbo
28519 isabel    20   0  120m 3324  288 S   0,0  0,3   0:00.20 chromium
28522 isabel    20   0  128m 3252  204 S   0,0  0,3   0:00.01 chromium
28558 isabel    20   0  208m  52m  476 S   0,0  5,3   1:25.92 chromium
28573 isabel    20   0  271m 103m 1244 S   0,0 10,3   3:01.64 chromium
28693 isabel    20   0  120m 3836  628 S   0,0  0,4   0:43.86 chromium
28696 isabel    20   0 83088 6412  108 S   0,0  0,6   0:16.55 GoogleTalkPlugi
28706 isabel    20   0  159m 6896  972 S   0,0  0,7   9:00.72 chromium
32332 root      20   0     0    0    0 S   0,0  0,0   0:06.24 kworker/1:2
32351 stenyak    9 -11 99108 1032  192 S   0,0  0,1   0:00.51 pulseaudio
32455 root      20   0  9816  108   76 S   0,0  0,0   0:00.11 sshd
32460 stenyak   20   0  9992  264  144 S   0,0  0,0   0:07.43 sshd
32462 stenyak   20   0  9300 1976  108 S   0,0  0,2   0:01.31 bash

क्या आपने किसी भी अन्य मापदंडों को बदल दिया है, के अलावा अन्य swappiness?
डेविड श्वार्ट्ज

आपकी मशीन भर गई है। topकिसी भी भगोड़ा प्रक्रिया मेमोरी वार का पता लगाने के लिए उपयोग करें , और इसे पुनरारंभ करें।
थोरबजोरन राव एंडरसन 3

@DavidSchwartz नहीं, गैर-महत्वपूर्ण सामान (जैसे मुनिन, अपाचे ...) की स्थापना रद्द करने के अलावा और कुछ नहीं किया।
STENyaK

@ ThorbjørnRavnAndersen कोई भी प्रक्रिया स्मृति की उन राशियों (न तो VIRT, RES और न ही SHR) का उपयोग कर रही है, आधे गिग के करीब भी नहीं , इसलिए मुझे नहीं पता कि क्या मारना है। फिर से, कुल उपयोग की जाने वाली मेमोरी - / + बफ़र्स / कैश सिर्फ 81megs है, (और जाहिर है कि केवल 18megs स्वैप वास्तविक प्रक्रियाओं द्वारा उपयोग किया जाता है?)।
STENyaK

आपके पास 511 एमबी स्वैप विभाजन है जो हमें पूरी तरह से उपयोग करता है! सिर्फ 18 नहीं free। विश्वास ।
थोरबजोरन राव एंडरसन

जवाबों:


4

आप स्वैप नहीं कर सकते क्योंकि स्वैप की गई मेमोरी की मात्रा आपके RAM से आगे नहीं बढ़ सकती है। आपको वैध त्रुटि संदेश मिल रहा है।

छोटा स्निपेट।

if (!quiet || errno == ENOMEM)
    warn(_("%s: swapoff failed"), orig_special);

return -1;

मेरी राय में, आपके कार्यभार में आपकी रैम की मांग बढ़ जाती है। आप एक वर्कलोड चला रहे हैं जिसमें अधिक मेमोरी की आवश्यकता होती है। पूरे स्वैप का उपयोग इंगित करता है कि। इसके अलावा, 1 के लिए स्वप्नदोष बदलना एक बुद्धिमान निर्णय नहीं हो सकता है। 1 को स्वैग सेट करने से यह संकेत नहीं मिलता है कि स्वैपिंग नहीं होगी। यह सिर्फ इंगित करता है कि स्वैपिंग के संबंध में कितना आक्रामक कर्नेल होगा, यह स्वैपिंग को समाप्त नहीं करता है। जरूरत पड़ने पर स्वैपिंग होगी।

इसके अलावा, मुझे नहीं पता कि आप स्वैप को अक्षम करने का प्रयास क्यों कर रहे हैं। जब तक आपके पास टन और टन रैम नहीं है, आपको स्वैप को अक्षम नहीं करना चाहिए।

बेशक, आप रिबूट कर सकते हैं और स्वैप का उपयोग तब शून्य होगा। और फिर आप सुरक्षित रूप से स्वैप कर सकते हैं। लेकिन, यह समस्या को दीर्घकालिक रूप से हल नहीं करता है।

क्या आपका मन करेगा, /proc/meminfoआउटपुट पोस्ट करने का ।


मैं फिर से भरने के लिए स्वैप का इंतजार कर रहा हूं (कंप्यूटर के उपयोग पर निर्भर करता है, जो इन दिनों कम है)। मैंने केवल कोशिश करने / जांच करने के लिए स्वैप को अक्षम करने की कोशिश की कि क्या रैम कैश गिराया जाएगा (जो मैं नेट पर पढ़ता हूं, उन 904megs कैश को छोड़ दिया जाना चाहिए जब अधिक RAM की आवश्यकता होती है, और मुझे 511megs RAM की आवश्यकता होगी; निष्क्रिय करने के लिए स्वैप)।
STENyaK

कल फिर से स्वैप भर गया। उपयोगकर्ता द्वारा कंप्यूटर को रिबूट करने से पहले, एक क्रोन-एड स्क्रिप्ट कुछ जानकारी लॉग करने में कामयाब रही, जिसे मैंने मूल प्रश्न में संपादित किया है। उम्मीद है की वो मदद करदे।
STENyaK

3

एक संभावित कारण आपके द्वारा मेमोरी पर समर्थित फ़ाइल सिस्टम पर /tmpमाउंट किया जाना होगा tmpfs

इस मामले (है df -hT /tmp/ tmp), बस हटाने / वहाँ रहने, विस्थापित फ़ाइलों सुनिश्चित करें कि कोई आवेदन भरण फिर से बनाने के (या किसी भी फाइल सिस्टम पर रखा tmpfs: df -ht tmpfs) और इस समस्या का समाधान कर दिया जाएगा।


अच्छी बात। डेटा tmpfsआमतौर पर कैश्ड के रूप में दिखाई देगा ।
स्टीफन चेज़लस

नहीं पता था कि! मैंने df -ht tmpfs --totalअपने क्रोन-एड डिबग स्क्रिप्ट में जोड़ा है। अगली बार समस्या होने पर, मैं आउटपुट पोस्ट करूँगा। हालांकि एक सवाल: क्या मुझे Usedस्तंभ या स्तंभ के बारे में चिंता करनी चाहिए Size?
STENyaK

usedस्तंभ फ़ाइलों द्वारा प्रयोग किया स्मृति के आकार की रिपोर्ट। इन फ़ाइलों को हटाने से मेमोरी खाली हो जाएगी।
jlliagre

1

ध्यान दें कि यह वास्तव में बुरा नहीं है यदि सिस्टम स्वैप को मेमोरी को स्वैप करता है और इसके बजाय बफ़र्स के लिए मेमोरी का उपयोग करता है। यह संभवतः दो चीजों को इंगित करता है:

  • आपके पास कई एप्लिकेशन चल रहे हैं (~ 500 एमबी) जिनका उपयोग बहुत अधिक नहीं किया जाता है
  • आप अन्य एप्लिकेशन का उपयोग करते हैं जो 1 जीबी रैम से अधिक डेटा को पढ़ते / लिखते हैं, जो आपके पास है। सिस्टम तेज पहुंच के लिए मेमोरी में हार्ड डिस्क डेटा को बफर करके इन एप्लिकेशन के प्रदर्शन को बेहतर बनाने का प्रयास करता है

हां, ऐसा प्रतीत हो सकता है कि आपके पास उपयोग में केवल ~ 600 एमबी मेमोरी है। स्वैप करने के लिए सिस्टम के कारण क्या होता है, शायद यह अत्यधिक मेमोरी एग्ज़ॉस्टिव एप्लिकेशन नहीं है, लेकिन एक बहुत ही I / O भारी काम का बोझ बफ़र्स को मारता है। क्या आप पहचान सकते हैं कि कौन सी प्रक्रिया सभी I / O कर रही है? आप किस सर्वर के लिए उपयोग कर रहे हैं?


कम मेमोरी उपयोग के समय, केवल चित्रमय अनुप्रयोग चल रहा है gdm3। पहले (उपयोगकर्ता द्वारा लॉग आउट होने से पहले), एक xfce डेस्कटॉप चल रहा था, जिसमें बमुश्किल कोई विजेट और केवल क्रोमियम-ब्राउज़र अपने कार्य प्रबंधक पर दिखा रहा था। जब यह फिर से होता है, तो मैं I / O गहन प्रक्रियाओं को देखने के लिए iotop का उपयोग करूंगा। सलाह के लिये धन्यवाद।
STENyaK

I / O भारीपन की वजह से स्वयं की अदला-बदली नहीं होनी चाहिए। आप स्टॉक कर्नेल का उपयोग करते हैं? यदि हाँ, तो यह मेमोरी रिसाव वाला एक उपयोगकर्ता प्रोग्राम होना चाहिए।
Thorbjørn Ravn Andersen

मैंने क्रोम को सिर्फ 1 जीबी रैम के साथ बहुत अधिक अनुपयोगी पाया। यकीन है कि यह तेज़ है और इसमें सैंडबॉक्सिंग है, आपको स्मृति तीव्रता के साथ इसके लिए भुगतान करना होगा। लेकिन यह नहीं समझाएगा कि आपका सिस्टम कैशिंग के लिए 900 एमबी का उपयोग क्यों करता है।
हैसिट - Anony-Mousse

@ ThorbjørnRavnAndersen कर्नेल स्टॉक एक है: 3.2.0-4-686-pae #1 SMP Debian 3.2.32-1 i686 GNU/Linuxकिसी भी विचार को कैसे संभव है कि जब संभव हो तो मूल प्रवर्तक प्रक्रिया में मेमोरी रिसाव को ट्रैक किया जा सकता है?
STENyaK

1

मैं एक ऐसे उपकरण के बारे में नहीं जानता, जो आपको प्रति प्रक्रिया के आधार पर स्वैप का आकार देता हो, लेकिन इसे लिखना आसान होगा ... (शेल स्क्रिप्ट उदाहरण को और नीचे देखें)

लिनक्स नाम के टूल के साथ आता है smem। डेबियन / उबंटू के तहत स्थापित करने के लिए आपको उपयोग करने में सक्षम होना चाहिए (यह प्रक्रिया में कई अजगर पैकेज स्थापित करेगा):

apt-get install smem

फिर इसका उपयोग करने के लिए, बस smemअपनी कमांड लाइन पर टाइप करें।


अन्य समाधान यह पता लगाने के लिए कि एक प्रक्रिया वर्तमान स्वैप उपयोग कितना है, आप प्रक्रिया फ़ाइल में VmSwap पैरामीटर की जांच करना चाहते हैं status

का उपयोग करते हुए topया htopया psया pgrepया pidof... प्रक्रिया पहचानकर्ता निर्धारित ( PID) और फिर स्थिति फ़ाइल को देखो:

$ pidof myprocess
123
$ cat /proc/123/status

इसमें वर्तमान में प्रक्रिया द्वारा उपयोग की जाने वाली मेमोरी के बारे में जानकारी शामिल है। एक उदाहरण है:

Name:   snapinit
State:  S (sleeping)
Tgid:   2769
Ngid:   0
Pid:    2769
PPid:   1
TracerPid:  0
Uid:    0   0   0   0
Gid:    0   0   0   0
FDSize: 64
Groups: 
NStgid: 2769
NSpid:  2769
NSpgid: 2765
NSsid:  2765
VmPeak:   141952 kB
VmSize:   141952 kB
VmLck:         0 kB
VmPin:         0 kB
VmHWM:     11552 kB
VmRSS:      3444 kB
VmData:      772 kB
VmStk:       136 kB
VmExe:       244 kB
VmLib:     62356 kB
VmPTE:       208 kB
VmPMD:        12 kB
VmSwap:     1968 kB
HugetlbPages:          0 kB
Threads:    1
SigQ:   0/3912
SigPnd: 0000000000000000
ShdPnd: 0000000000000000
SigBlk: 0000000000014006
SigIgn: 0000000000001000
SigCgt: 00000001800004c8
CapInh: 0000000000000000
CapPrm: 0000003fffffffff
CapEff: 0000003fffffffff
CapBnd: 0000003fffffffff
CapAmb: 0000000000000000
Seccomp:    0
Cpus_allowed:   1
Cpus_allowed_list:  0
Mems_allowed:   00000000,00000001
Mems_allowed_list:  0
voluntary_ctxt_switches:    36
nonvoluntary_ctxt_switches: 23

ब्याज की धारा एक दिखावा Vm<name>पैरामीटर है (यानी वर्चुअल मेमोरी जो कि एक प्रकार की मेमोरी है जो एक प्रक्रिया के लिए उपलब्ध है, केवल कर्नेल वास्तविक भौतिक मेमोरी से संबंधित है; वीएम आपके एमएमयू द्वारा बनाया गया है ):

VmPeak:   141952 kB
VmSize:   141952 kB
VmLck:         0 kB
VmPin:         0 kB
VmHWM:     11552 kB
VmRSS:      3444 kB
VmData:      772 kB
VmStk:       136 kB
VmExe:       244 kB
VmLib:     62356 kB
VmPTE:       208 kB
VmPMD:        12 kB
VmSwap:     1968 kB

मेरे मामले में, मैं देख रहा हूं कि इस प्रक्रिया द्वारा उपयोग की जाने वाली स्वैप मेमोरी (VmSwap) 1968Kb, लगभग 2Mb है।

VmLib पैरामीटर साझा पुस्तकालयों (.so फ़ाइलों) के लिए उपयोग की जाने वाली मेमोरी की मात्रा को दर्शाता है। हालांकि यह बहुत बड़ा लगता है, याद रखें कि साझा पुस्तकालयों द्वारा उपयोग की जाने वाली मेमोरी ... सभी प्रक्रियाओं के बीच साझा की जाती है।

एक शेल में, आप इस तरह एक कमांड लाइन के साथ मापदंडों को प्राप्त कर सकते हैं:

#!/bin/sh
echo "  NAME                        PID        SWAP"
for PID in /proc/[0-9]*
do
  if stat $PID/status >/dev/null
  then
    # get name of process
    procname=`grep 'Name:' $PID/status | awk -e '{ print $2 };'`
    # get amount of swap in use by that process
    procswap=`grep 'VmSwap:' $PID/status | awk -e '{ print $2 };'`

    printf "%-21s %11d %11d\n" $procname `basename $PID` $procswap
  fi
done

ध्यान दें कि $ PID / स्थिति फ़ाइल गायब हो जाएगी जब एक प्रक्रिया मर जाती है और यह लूप के लिए ठीक से जाँच नहीं करता है। साथ ही कुछ फ़ाइलों को एक सामान्य उपयोगकर्ता द्वारा पढ़ा नहीं जा सकता है (यानी यदि आप रूट हैं, तो आपको प्रत्येक प्रक्रिया के लिए एक परिणाम दिखाई देगा, अन्यथा कुछ प्रक्रियाएं केवल एक त्रुटि या 0Kb वापस करती हैं।)

एक नमूना आउटपुट है। SWAP डेटा किलो बाइट्स में है

  NAME                        PID        SWAP
systemd                         1         348
watchdog/0                     10           0
ipv6_addrconf                 106           0
ureadahead                  13234          28
gnome-calculato             13997           0
apache2                     14175        7240
freshclam                    1447        3072
systemd-logind               1449         244

-1

स्वैप पूर्ण है, इसलिए आपको कुछ प्रक्रिया को रोकना होगा, हत्या प्रक्रिया के उपयोग के लिए kill -9 PID और फिर उपयोग करना होगा sudo swapoff -a

अपनी हालत में मैं अपने साइडकी कार्यकर्ता को रोक देता हूं और फिर स्वैप मेमोरी को पुनः प्राप्त करता हूं।

digitalocean server स्वैप मेमोरी

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.