Mem Cgroup目录无法清理问题分析
? ? ? ? Cgroup(Control Group)是内核提供的资源隔离的技术,用于对Linux 系统中用户态进程使用的资源进行隔离,核心思想是:把进程分组,然后为进程组分配资源(包括内存、CPU、IO等)。其中Mem Cgroup用来隔离进程组使用的内存资源。 ? ? ? ? 在Hadoop集群
? ? ? ? Cgroup(Control Group)是内核提供的资源隔离的技术,用于对Linux 系统中用户态进程使用的资源进行隔离,核心思想是:把进程分组,然后为进程组分配资源(包括内存、CPU、IO等)。其中Mem Cgroup用来隔离进程组使用的内存资源。
? ? ? ? 在Hadoop集群中,我们使用了Mem Cgroup对MapReduce任务使用的内存资源进行隔离控制,以保证单个任务不能占用太大的内存,进而保证整个系统的稳定性。同时我们配置了release_agent,用于在mem cgroup中的所有进程退出后清理相关的资源。
? ? ? ? 但Mem Cgroup在Hadoop集群上线后,经常会出现某个Mem Cgroup中的进程已经全部退出,但对应的Cgroup目录清理不掉的现象。查看Cgroup的状态,有如下现象:
? ? ? ? [root@]# cat /cgroup/memory/test/tasks
? ? ? ? [root@]# cat /cgroup/memory/test/memory.usage_in_bytes
? ? ? ? 90112
? ? ? ??该cgroup的所有进程确实都已经退出了,但还是存在部分内存处于被使用状态,这是神马情况,下意识地想到,难道是Page Cache,果断验证下:
? ? ? ? echo 3 > /proc/sys/vm/drop_caches
? ? ? ? 刷掉Page Cache之后,残留的cgroup目录竟然成功被清理了,?那基本断定是Page Cache的影响了,后面就得分析下代码,研究下其中的原理了。
? ? ? ? 经过几天的分析,终于把Mem Cgroup的基本原理搞明白了。
? ? ? ? 在Linux内核中,每个Mem Cgroup都对应一个mem_cgroup结构,该结构的的核心是res_counter,记录了资源使用情况和资源限制,每个mem cgroup对象都包含一个与之关联的res_counter。
? ? ? ? ?Linux内核管理内核的基本单位是页面,采用page结构管理,一个物理页框对应着一个page结构,与此同时,新增了一个page_cgroup结构,用来关联page和mem_cgroup,这样给定任何一个页面,都可以找到对应的mem_cgroup。另外,每个进程都有一个mm_struct结构来管理进程的内存信息。每个mm_struct知道自己属于的进程,进而可以知道进程所属的mem_cgroup。
??
? ? ? ? 用户进程物理内存的分配基本都是通过page_fault来实现,现在来看下这个过程中是如何实现mem cgroup相关功能的,page_fault的大体流程如下:
? ? ? ?1、? 根据current进程找到对应的mm_struct结构
? ? ? ?2、? 分配需要的page页面
? ? ? ?3、? 调用mem_cgroup_newpage_charge:该函数根据mm struct查找到对应的mem_cgroup,然后? ? ? ??? ? ? ??? ? ? ? ? ? ? ??判断下当前mem_cgroup是否已经超过限制,如果没有,则把新分配page对应page_cgroup指向该mem_cgroup,并更新资源使用计数。如果已经超过了限制,则进行oom相关的处理。
? ? ? ? 现在来考虑下Page cache,这些内存是系统级的,可以被所有进程使用,那这些内存的使用算在哪个进程的头上呢?mem cgroup采用的是first touch的原则,就是说哪个进程把page cache页面“带进”内存,这个页面就算在谁的头上。
? ? ? ? 大致了解了Mem cgroup的原理,回到一开始的问题,虽然mem cgroup中的进程都已经退出了,但是这些进程使用的page cache仍然计算在这个mem cgroup中,导致mem cgroup一直被引用,因此mem cgroup清理不掉,刷掉page cache后,mem cgroup就没有被引用了,也就可以清理了。
? ? ? ? 针对该问题,我们在内核新增加了一个page cache的使用计算选择:把page cache全部算入默认的根mem cgroup。这样做的另外一个好处是,mem cgroup只记录进程本身利用的物理内存,更直观可控。同时page cache是可回收的,如果某个mem cgroup中的进程产生大量的page cache时,其他mem cgroup进程的内存基本不受影响,可能的坏处是影响其他mem cgroup内存分配的效率。
? ? ? ? 参考:http://lwn.net/Articles/432224/
你也许会喜欢:
- hadoop集群System Cpu消耗过高问题分析 by 杂货店店长
- 性能测试中sql索引引起的性能问题
- 从Blue Pill、硬件虚拟化谈安全防护完备性上的一个小原则
- 利用 Flash 漏洞的木马程序分析报告 by 师兄
- 端午节蓝屏之谜:金山系列软件同微软KB2839229冲突技术分析

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Viele Win10-Benutzer können die Datei hiberfil.sys auf dem Laufwerk C sehen, und diese Datei belegt oft einen großen Teil des Laufwerks C des Systems. Daher möchten viele Benutzer, die nicht über genügend Laufwerk C verfügen, diese Datei löschen Einzelheiten finden Sie weiter unten. 1. Sehen Sie sich die Ruhezustandsdatei an und entfernen Sie das Häkchen vor der folgenden Markierung im Popup-Fenster. 2. Überprüfen Sie das Laufwerk C erneut und finden Sie mehrere große Dateien, darunter hiberfil.sys, die Ruhezustandsdatei. Öffnen Sie hier das cmd-Befehlsfenster. Einige Computer verfügen möglicherweise nicht über Administratorrechte. Sie können den cmd-Befehl direkt im Systemverzeichnis finden und ihn mit der rechten Maustaste ausführen. 3. Durch die Eingabe von powercfg-hoff in das Befehlsfenster wird die Ruhezustandsfunktion automatisch deaktiviert, und die Ruhezustandsdatei wird ebenfalls automatisch deaktiviert

Die mobile Version der WeChat-Lese-App ist eine sehr gute Lesesoftware. Sie können sie jederzeit und überall mit nur einem Klick lesen und online lesen Sortieren Sie Ihre Bücher ordentlich und genießen Sie eine angenehme und entspannte Leseatmosphäre. Wechseln Sie den Lesemodus verschiedener Szenarien, aktualisieren Sie jeden Tag kontinuierlich die neuesten Buchkapitel, unterstützen Sie die Online-Anmeldung von mehreren Geräten und laden Sie sie stapelweise in das Bücherregal herunter. Sie können es mit oder ohne Internet lesen, sodass jeder mehr Wissen daraus entdecken kann Jetzt erläutert der Herausgeber online die Methode zum Anzeigen des Katalogs für WeChat-Lesepartner. 1. Öffnen Sie das Buch, dessen Katalog Sie ansehen möchten, und klicken Sie in die Mitte des Buchs. 2. Klicken Sie auf das Symbol mit den drei Linien in der unteren linken Ecke. 3. Sehen Sie sich im Popup-Fenster den Buchkatalog an

Titel: Analyse der Gründe und Lösungen, warum das sekundäre Verzeichnis von DreamWeaver CMS nicht geöffnet werden kann. Dreamweaver CMS (DedeCMS) ist ein leistungsstarkes Open-Source-Content-Management-System, das häufig bei der Erstellung verschiedener Websites verwendet wird. Allerdings kann es beim Erstellen einer Website manchmal vorkommen, dass das sekundäre Verzeichnis nicht geöffnet werden kann, was zu Problemen beim normalen Betrieb der Website führt. In diesem Artikel analysieren wir die möglichen Gründe, warum das sekundäre Verzeichnis nicht geöffnet werden kann, und stellen spezifische Codebeispiele zur Lösung dieses Problems bereit. 1. Mögliche Ursachenanalyse: Pseudostatisches Regelkonfigurationsproblem: während der Verwendung

Tree ist ein Befehlszeilentool, das den Inhalt eines Verzeichnisses rekursiv in einem Baumformat auflistet, sodass alle Verzeichnisse, Unterverzeichnisse und Dateien hierarchisch aufgelistet werden und so die Organisationsstruktur von Dateien und Ordnern visuell angezeigt wird. Das Folgende ist die Installation und Verwendung von Tree unter Windows- und Linux-Systemen. Die Installation und Verwendung von Tree unter Linux: aptupdate&&aptinstalltree Im Folgenden werden die üblichen Methoden zur Verwendung des Tree-Befehls beschrieben. #Zeigen Sie den Verzeichnisbaum unter dem angegebenen Pfad an.tree/d/temp#Begrenzen Sie die maximale Anzeigetiefe.tree-L3#Zeigen Sie nur Verzeichnisse, aber keine Dateien an.tree-d#Anzeige einschließlich versteckter Dateien und Verzeichnisse tr

Titel: Ist Tencents wichtigste Programmiersprache Go: Eine eingehende Analyse Als Chinas führendes Technologieunternehmen hat Tencent bei der Auswahl seiner Programmiersprachen schon immer große Aufmerksamkeit auf sich gezogen. In den letzten Jahren glauben einige Leute, dass Tencent hauptsächlich Go als Hauptprogrammiersprache übernommen hat. In diesem Artikel wird eine eingehende Analyse durchgeführt, ob die Hauptprogrammiersprache von Tencent Go ist, und es werden konkrete Codebeispiele angegeben, um diese Ansicht zu untermauern. 1. Anwendung der Go-Sprache in Tencent Go ist eine von Google entwickelte Open-Source-Programmiersprache. Viele Entwickler schätzen ihre Effizienz, Parallelität und Einfachheit.

Wuhua Mixin hat bestätigt, dass es am 28. Februar einen Breaking-Test durchführen wird. Dieses Mal werden wir hauptsächlich die allgemeinen Probleme des Breaking-Tests lösen, einschließlich der Frage, ob Sie an früheren Tests teilgenommen haben, ob Sie dieses Mal berechtigt sind, den Beginn und das Ende des Tests Schauen wir uns an, welche Geräteplattformen und welche anderen Inhalte unterstützt werden. Häufig gestellte Fragen zum neuen Durchbruchstest von Wuhuami: 28. Februar, wir freuen uns auf Ihre Ankunft! 1. Was ist der „Breaking Test“? Bei diesem Test handelt es sich um einen eingeschränkten Abrechnungs- und Dateilöschtest. Nach dem Test werden die Spieldaten dieses Tests gelöscht. 2. Haben Sie schon einmal am „Eröffnungstest“ oder „Eintrittstest“ teilgenommen? Haben Sie die Voraussetzungen, dieses Mal am „Eröffnungstest“ oder „Eintrittstest“ teilzunehmen? Bitte scannen Sie den QR-Code unten, um zu „An Spieler, die an der Closed Beta teilgenommen haben“ zu gelangen

Wenn Sie bei der Verwendung Ihres vivo-Telefons häufig auf das Problem eines unzureichenden Speichers stoßen, ist es jetzt an der Zeit, zu erfahren, wie Sie den Speicher Ihres Telefons bereinigen und Speicherplatz freigeben. Dieser Leitfaden stellt Ihnen einige einfache und effektive Methoden vor, mit denen Sie die Speichernutzung Ihres vivo-Telefons optimieren und für einen reibungsloseren Betrieb sorgen können. 1. Cache-Dateien belegen einen großen Teil des Telefonspeichers. Das Löschen des Caches kann die Leistung des Telefons erheblich verbessern. Öffnen Sie zunächst das Einstellungsmenü Ihres Telefons, suchen Sie in der Option „Speicher“ nach der Option „Cache-Daten“ oder „Cache löschen“ und klicken Sie zum Aufrufen. Wählen Sie dann „Cache löschen“ und warten Sie, bis die Bereinigung abgeschlossen ist. 2. Unnötige Apps deinstallieren Laden Sie oft verschiedene Apps herunter, nutzen aber nur wenige davon tatsächlich? Diese verlassenen Apps nehmen viel in Anspruch

Der Soundkartentreiber ist ein Systemprogramm im Computer, das die Soundkarte steuert und steuert. Es kann uns bei der Tonwiedergabe helfen. Wenn also ein Problem mit dem Soundkartentreiber vorliegt, ist dies die intuitivste Situation. Es ist kein Ton zu hören oder der Ton schwankt und friert ungewöhnlich ein. Was passiert, wenn es ein Problem mit dem Soundkartentreiber gibt: 1. Soundfehler 1. Der Soundkartentreiber liefert den Sound, daher ist das Soundproblem das intuitivste Problem. 2. Wenn vom Computer kein Ton zu hören ist, der Ton stecken bleibt, verzögert oder laut ist oder die Lautstärke nicht normal ist, kann dies am Soundkartentreiber liegen. 3. Wenn wir also auf ähnliche Probleme stoßen, können wir versuchen, den Soundkartentreiber neu zu installieren oder zu aktualisieren. 2. Ausrufezeichen im Geräte-Manager 1. Wenn kein Problem mit dem Ton vorliegt, bedeutet dies, dass der Soundkartentreiber in den meisten Fällen normal ist. 2. Aber ich
