进程退出后内存仍在使用

问题描述

我有一个关于奇怪事件的问题,我在一台 1GB 内存的服务器上,我只运行一个轻量级的应用程序,一段时间后它的内存使用量增加(可能是我还没有发现内存泄漏),但那是另一回事了,问题是,当它使用太多内存时我退出进程,令我惊讶的是内存使用率仍然很高,这怎么可能?内存没有缓存,它是正在使用的“原始”内存,但 htop 似乎也不知道哪个进程正在使用它......
在这里,我附上了图像,以便您可以看到它,它按内存使用情况降序排列。 如果使用最多内存的进程使用 1.8%,我不明白内存使用量为 751MB。
我已经阅读了一些解决方案,例如禁用交换,但交换被禁用,如图所示。

enter image description here

更新 1

这里附上 meminfo:

MemTotal:        1004852 kB
MemFree:          108456 kB
MemAvailable:      97392 kB
Buffers:            2768 kB
Cached:            31868 kB
SwapCached:            0 kB
Active:           503268 kB
Inactive:          15100 kB
Active(anon):     491920 kB
Inactive(anon):     2852 kB
Active(file):      11348 kB
Inactive(file):    12248 kB
Unevictable:       18516 kB
mlocked:           18516 kB
SwapTotal:             0 kB
SwapFree:              0 kB
Dirty:                20 kB
Writeback:             0 kB
AnonPages:        502288 kB
Mapped:            28200 kB
Shmem:              2856 kB
KReclaimable:      96860 kB
Slab:             308536 kB
SReclaimable:      96860 kB
SUnreclaim:       211676 kB
KernelStack:        5676 kB
PageTables:        11836 kB
NFS_Unstable:          0 kB
Bounce:                0 kB
WritebackTmp:          0 kB
CommitLimit:      502424 kB
Committed_AS:     808208 kB
VmallocTotal:   34359738367 kB
VmallocUsed:       12656 kB
VmallocChunk:          0 kB
Percpu:             1772 kB
HardwareCorrupted:     0 kB
AnonHugePages:         0 kB
ShmemHugePages:        0 kB
ShmemPmdMapped:        0 kB
FileHugePages:         0 kB
FilePmdMapped:         0 kB
CmaTotal:              0 kB
CmaFree:               0 kB
HugePages_Total:       0
HugePages_Free:        0
HugePages_Rsvd:        0
HugePages_Surp:        0
Hugepagesize:       2048 kB
Hugetlb:               0 kB
DirectMap4k:      501740 kB
DirectMap2M:      546816 kB

一个关于在 https://unix.stackexchange.com/questions/524846/why-does-my-system-use-more-ram-after-an-hour-of-usage 上释放缓存内存的有趣解决方案,但在这里它不起作用,问题不在于缓存内存......

更新 2

我认识的人告诉我有这么多 sshd 进程很奇怪,我尝试杀死所有那些 root@notty sshd 进程并且它起作用了。问题解决了,我把这个问题留在这里希望对其他人有用。

解决方法

我认识的人告诉我有这么多 sshd 进程很奇怪,我尝试杀死所有那些 root@notty sshd 进程并且它起作用了。问题解决了,我把这个问题留在这里希望对其他人有用。 为了简化流程,我使用了以下 Golang 代码:


import (
    "github.com/shirou/gopsutil/v3/process"
    "fmt"
    "strings"
)

func main() {
    processes,err := process.Processes()
    if err != nil {
        panic(err)
    }
    sshCount := 0
    for i := 0; i < len(processes); i++ {
        currentProcess := processes[i]
        name,err := currentProcess.Name()
        if err != nil {
            fmt.Printf("Failed to retrieve the name of process %d\n",currentProcess.Pid)
            continue
        }

        // username,err := currentProcess.Username()
        cmdLine,err := currentProcess.Cmdline()
        // cwd,_ := currentProcess.Cwd()
        // terminalStr,_ := currentProcess.Terminal()

        if strings.Contains(name,"sshd") && cmdLine == "sshd: root@notty" {
            sshCount++
            err = currentProcess.Terminate()
            if err != nil {
                fmt.Printf("Error on terminating %d %s\n",currentProcess.Pid,name)
                err = currentProcess.Kill()
                if err != nil {
                    fmt.Printf("Error on Killing %d %s\n",name)
                } else {
                    fmt.Printf("Killed %d %s\n",name)
                }
            } else {
                fmt.Printf("Terminated successfully %d %s\n",name)
            }
        }
    }

    fmt.Printf("We got %d sshd processes\n",sshCount)
}