Использование пространства подкачки Linux не освобождено

Использование пространства подкачки Linux не освобождено

Я получил оповещения на одной из моих систем (RHEL6) о том, что в ней используется большое пространство подкачки.

Посмотрев на виртуальную машину, я действительно вижу, что раздел подкачки полностью использован, в то время как физической памяти у нас более чем достаточно, например:

[root@xxxxxxxxxx ~]# free -h
             total       used       free     shared    buffers     cached
Mem:           11G       5.3G       6.3G       2.6M       196M       560M
-/+ buffers/cache:       4.6G       7.0G
Swap:         4.0G       4.0G        21M

поэтому мой вопрос:

означает ли это, что в какой-то момент система исчерпала физическую память и ей «пришлось» использовать эти 4 Гбайт дополнительного SWAP? После этого память была освобождена, но swap остался высоким.

и если это так, есть ли способ «опустошить» этот своп?

при запускевершинана машине, фильтруя по использованию подкачки, я вижу, что некоторые процессы используют этот подкачка (в частности, Java вверху с2,7 г)

top - 14:57:06 up 72 days, 19:54,  4 users,  load average: 0.06, 0.02, 0.00
Tasks: 201 total,   1 running, 200 sleeping,   0 stopped,   0 zombie
Cpu(s):  1.2%us,  0.9%sy,  0.0%ni, 97.8%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Mem:  12197860k total,  5598708k used,  6599152k free,   201704k buffers
Swap:  4193276k total,  4170820k used,    22456k free,   573636k cached

    PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  SWAP COMMAND
   9180 pcmc03    20   0 7428m 980m 9208 S  0.3  8.2 797:35.54 2.7g java
   9474 pcmc03    20   0 3409m 999m 9.8m S  0.0  8.4 492:09.57 513m pmrepagent
   9455 pcmc03    20   0 2702m 1.5g 3712 S  0.0 13.0  29:42.06 297m pmrepagent
   9383 pcmc03    20   0 4362m 229m 1568 S  0.3  1.9 159:45.77 213m java
   9494 pcmc03    20   0 2705m 108m  10m S  0.3  0.9 183:49.58  61m pmserver
   7371 root      20   0  231m  69m 2104 S  0.0  0.6 360:27.50  60m prismd.pl
   1730 root      20   0  117m  44m  920 S  0.0  0.4  33:45.09  46m rootmon

Означает ли это, что этот процесс Java должен был использовать 2,7 Гб подкачки в какой-то момент и сохранил резервирование? И если так, я полагаю, что этой системе может потребоваться дополнительная память, чтобы избежать подобных ситуаций в будущем?

аvmstatне показывает никаких си/так.

большое спасибо

решение1

Да, похоже, у вас мало памяти. Нет, не пытайтесь освободить ее из подкачки. Если вы это сделаете, она попадет в оперативную память. Однако, возможно, стоит посмотреть, какие процессы тратят память впустую, и спросить, нужно ли им существовать?

Связанный контент