Die Verwendung des Thread-Pools unter Linux C
Stehen Sie häufig auf das Problem, dass die Serverauslastung zu hoch ist und nicht normal darauf zugegriffen werden kann? Dann müssen Sie ein sehr wichtiges Konzept in Linux-Systemen verstehen – den Thread-Pool. Durch die richtige Konfiguration des Thread-Pools können Sie eine Serverüberlastung effektiv vermeiden und die Systemstabilität und -zuverlässigkeit verbessern.
Thread-Pool ist auch eine Multithread-Verarbeitungsmethode. Der „Produzenten“-Thread schlägt Aufgaben vor und fügt sie der „Aufgabenwarteschlange“ hinzu. Anschließend erledigen einige Threads die Aufgaben in der „Aufgabenwarteschlange“ automatisch.

Multithread-Programmierung: Erstellen Sie einen Thread, geben Sie ihn an, um eine bestimmte Aufgabe auszuführen, und warten Sie, bis der Thread beendet wird. Obwohl es Programmieranforderungen erfüllen kann, kann beim Erstellen und Zerstören von Threads eine große Menge CPU verbraucht werden, wenn wir eine große Anzahl von Threads erstellen müssen, was zu einem hohen Overhead führt. Zum Beispiel: Kopie des Ordners, Antwort vom WEB-Server.
Thread-Pool wird verwendet, um ein Problem wie dieses zu lösen, wodurch der Overhead reduziert werden kann, der durch die häufige Erstellung und Zerstörung von Threads entsteht.
Thread-Pool-Technologie-Idee: Im Allgemeinen wird die vorab erstellte Thread-Technologie verwendet, dh eine bestimmte Anzahl erforderlicher Threads wird im Voraus erstellt. Nachdem diese Threads im Voraus erstellt wurden, vorausgesetzt, dass sich keine Aufgaben in der „Aufgabenwarteschlange“ befinden, lassen Sie diese Threads ruhen. Sobald eine Aufgabe vorhanden ist, aktivieren Sie den Thread, um die Aufgabe auszuführen Sie müssen den Thread zerstören, bis Sie möchten. Beim Beenden oder Herunterfahren rufen Sie zu diesem Zeitpunkt die Funktion auf, die den Thread-Pool zerstört, um den Thread zu zerstören.
Der Thread wird nach Abschluss der Aufgabe nicht zerstört, sondern führt automatisch die nächste Aufgabe aus. Wenn es viele Aufgaben gibt, können Sie außerdem über eine funktionale Schnittstelle verfügen, um die Anzahl der Threads zu erhöhen. Wenn es nur wenige Aufgaben gibt, können Sie über eine funktionale Schnittstelle verfügen, um einige Threads zu zerstören.
Wenn die Zeit zum Erstellen und Zerstören von Threads im Vergleich zur Zeit zum Ausführen von Aufgaben vernachlässigbar ist, müssen wir in diesem Fall keinen Thread-Pool verwenden.
„Aufgabenwarteschlange“ ist eine gemeinsam genutzte Ressource mit „gegenseitig exklusivem Zugriff“

Thread-Pool ist im Wesentlichen eine Datenstruktur und erfordert eine Struktur, um sie zu beschreiben:
struct pthread_pool //线程池的实现 { //一般会有如下成员 //互斥锁,用来保护这个“任务队列” pthread_mutex_t lock; //互斥锁 //线程条件变量 表示“任务队列”是否有任务 pthread_cond_t cond; //条件变量 bool shutdown; //表示是否退出程序 bool:类型 false / true //任务队列(链表),指向第一个需要指向的任务 //所有的线程都从任务链表中获取任务 "共享资源" struct task * task_list; //线程池中有多个线程,每一个线程都有tid, 需要一个数组去保存tid pthread_t * tids; //malloc() //线程池中正在服役的线程数,当前线程个数 unsigned int active_threads; //线程池任务队列最大的任务数量 unsigned int max_waiting_tasks; //线程池任务队列上当前有多少个任务 unsigned int cur_waiting_tasks; //...... }; //任务队列(链表)上面的任务结点,只要能够描述好一个任务就可以了, //线程会不断地任务队列取任务 struct task //任务结点 { // 1. 任务结点表示的任务,“函数指针”指向任务要执行的函数(cp_file) void*(* do_task)(void * arg); //2. 指针,指向任务指向函数的参数(文件描述符) void * arg; //3. 任务结点类型的指针,指向下一个任务 struct task * next; };
Der Thread-Pool-Framework-Code lautet wie folgt und die Funktionen werden von Ihnen selbst ausgefüllt:
Funktionsschnittstellen, die zum Betreiben des Thread-Pools erforderlich sind: pthread_pool.c, pthread_pool.h
Stellen Sie sich den „Thread-Pool“ als Outsourcing-Unternehmen vor. Sie müssen die vom Thread-Pool bereitgestellte Funktionsschnittstelle bedienen.
pthread_pool.c
#include "pthread_pool.h" /* init_pool: 线程池初始化函数,初始化指定的线程池中有thread_num个初始线程 @pool:指针,指向您要初始化的那个线程池 @threa_num: 您要初始化的线程池中开始的线程数量 返回值: 成功 0 失败 -1 */ int init_pool(pthread_pool * pool , unsigned int threa_num) { //初始化线程池的结构体 //初始化线程互斥锁 pthread_mutex_init(&pool->lock, NULL); //初始化线程条件变量 pthread_cond_init(&pool->cond, NULL); pool->shutdown = false ;// 不退出 pool->task_list = (struct task*)malloc(sizeof(struct task)); pool->tids = (pthread_t *)malloc(sizeof(pthread_t) * MAX_ACTIVE_THREADS); if(pool->task_list == NULL || pool->tids == NULL) { perror("malloc memery error"); return -1; } pool->task_list->next = NULL; //线程池中一开始初始化多少个线程来服役 pool->active_threads = threa_num; //表示线程池中最多有多少个任务 pool->max_waiting_tasks = MAX_WAITING_TASKS; //线程池中任务队列当前的任务数量 pool->cur_waiting_tasks = 0; //创建thread_num个线程,并且让线程去执行任务调配函数, //记录所有线程的tid int i = 0; for(i = 0; i tids)[i], NULL, routine, (void*)pool); if(ret != 0) { perror("create thread error"); return -1; } printf("[%lu]:[%s] ===> tids[%d]:[%lu]",pthread_self(), __FUNCTION__, i , pool->tids[i]); } return 0; } /* routine: 任务调配函数。 所有线程开始都执行此函数,此函数会不断的从线程池的任务队列 中取下任务结点,去执行。 任务结点中包含“函数指针” h "函数参数" */ void * routine(void * arg) { //arg表示你的线程池的指针 while() { //获取线程互斥锁,lock //当线程池没有结束的时候,不断地从线程池的任务队列取下结点 //去执行。 //释放线程互斥锁,unlock //释放任务结点 } } /* destroy_pool: 销毁线程池,销毁前要保证所有的任务已经完成 */ int destroy_pool(pthread_pool * pool) { //释放所有空间 等待任务执行完毕(join)。 //唤醒所有线程 //利用join函数回收每一个线程资源。 } /* add_task:给任务队列增加任务, 把do_task指向的任务(函数指针)和 arg指向的参数保存到一个任务结点,添加到pool任务队列中。 @pool : 您要添加任务的线程池 @do_task : 您需要添加的任务(cp_file) @arg: 您要执行的任务的参数(文件描述符) */ int add_task(pthread_pool *pool,void*(* do_task)(void * arg), void*arg) { //把第二个参数和第三个参数封装成struct task //再把它添加到 pool->task 任务队列中去 //注意任务队列是一个共享资源 //假如任务后要唤醒等待的线程。 } //如果任务多的时候,往线程池中添加线程 pthread_create int add_threads(pthread_pool * pool, unsigned int num); { //新创建num个线程,让每一个线程去执行线程调配函数 //将每一个新创建的线程tid,添加到pool-> tids } //如果任务少的时候,减少线程池中线程的数量 pthread_cancel join int remove_threads(pthread_pool * pool, unsigned int num) { //用pthread_cancel取消num个线程 //利用pthread_join函数去回收资源。 }
pthread_pool.h
#ifndef __PTHREAD_POOL_H__ #define __PTHREAD_POOL_H__ //表示线程池中最多有多少个线程 #define MAX_ACTIVE_THREADS 20 //表示线程池中最多有多少个任务 #define MAX_WAITING_TASKS 1024 //任务队列(链表)上面的任务结点,只要能够描述好一个任务就可以了, //线程会不断地任务队列取任务 struct task //任务结点 { // 1. 任务结点表示的任务,“函数指针”指向任务要执行的函数(cp_file) void*(* do_task)(void * arg); //2. 指针,指向任务指向函数的参数(文件描述符) void * arg; //3. 任务结点类型的指针,指向下一个任务 struct task * next; }; struct pthread_pool //线程池的实现 { //一般会有如下成员 //互斥锁,用来保护这个“任务队列” pthread_mutex_t lock; //互斥锁 //线程条件变量 表示“任务队列”是否有任务 pthread_cond_t cond; //条件变量 bool shutdown; //表示是否退出程序 bool:类型 false / true //任务队列(链表),指向第一个需要指向的任务 //所有的线程都从任务链表中获取任务 "共享资源" struct task * task_list; //线程池中有多个线程,每一个线程都有tid, 需要一个数组去保存tid pthread_t * tids; //malloc() //线程池中正在服役的线程数,当前线程个数 unsigned int active_threads; //线程池任务队列最大的任务数量 unsigned int max_waiting_tasks; //线程池任务队列上当前有多少个任务 unsigned int cur_waiting_tasks; //...... }; /* init_pool: 线程池初始化函数,初始化指定的线程池中有thread_num 个初始线程 @pool:指针,指向您要初始化的那个线程池 @threa_num: 您要初始化的线程池中开始的线程数量 返回值: 成功 0 失败 -1 */ int init_pool(pthread_pool * pool , unsigned int threa_num); /* routine: 任务调配函数。 所有线程开始都执行此函数,此函数会不断的从线程池的任务队列 中取下任务结点,去执行。 任务结点中包含“函数指针” h "函数参数" */ void * routine(void * arg); /* destroy_pool: 销毁线程池,销毁前要保证所有的任务已经完成 */ int destroy_pool(pthread_pool * pool); /* add_task:给任务队列增加任务, 把do_task指向的任务(函数指针)和 arg指向的参数保存到一个任务结点,添加到pool任务队列中。 @pool : 您要添加任务的线程池 @do_task : 您需要添加的任务(cp_file) @arg: 您要执行的任务的参数(文件描述符) */ int add_task(pthread_pool *pool,void*(* do_task)(void * arg), void*arg); //如果任务多的时候,往线程池中添加线程 pthread_create int add_threads(pthread_pool * pool, unsigned int num); //如果任务少的时候,减少线程池中线程的数量 pthread_cancel join int remove_threads(pthread_pool * pool, unsigned int num); #endif
Das obige ist der detaillierte Inhalt vonDie Verwendung des Thread-Pools unter Linux C. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

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





VS Code system requirements: Operating system: Windows 10 and above, macOS 10.12 and above, Linux distribution processor: minimum 1.6 GHz, recommended 2.0 GHz and above memory: minimum 512 MB, recommended 4 GB and above storage space: minimum 250 MB, recommended 1 GB and above other requirements: stable network connection, Xorg/Wayland (Linux)

Die Gründe für die Installation von VS -Code -Erweiterungen können sein: Netzwerkinstabilität, unzureichende Berechtigungen, Systemkompatibilitätsprobleme, VS -Code -Version ist zu alt, Antiviren -Software oder Firewall -Interferenz. Durch Überprüfen von Netzwerkverbindungen, Berechtigungen, Protokolldateien, Aktualisierungen von VS -Code, Deaktivieren von Sicherheitssoftware und Neustart von Code oder Computern können Sie Probleme schrittweise beheben und beheben.

Obwohl Notepad den Java -Code nicht direkt ausführen kann, kann er durch Verwendung anderer Tools erreicht werden: Verwenden des Befehlszeilencompilers (JAVAC), um eine Bytecode -Datei (Dateiname.class) zu generieren. Verwenden Sie den Java Interpreter (Java), um Bytecode zu interpretieren, den Code auszuführen und das Ergebnis auszugeben.

VS -Code ist auf Mac verfügbar. Es verfügt über leistungsstarke Erweiterungen, GIT -Integration, Terminal und Debugger und bietet auch eine Fülle von Setup -Optionen. Für besonders große Projekte oder hoch berufliche Entwicklung kann VS -Code jedoch Leistung oder funktionale Einschränkungen aufweisen.

VS Code ist der vollständige Name Visual Studio Code, der eine kostenlose und open-Source-plattformübergreifende Code-Editor und Entwicklungsumgebung von Microsoft ist. Es unterstützt eine breite Palette von Programmiersprachen und bietet Syntax -Hervorhebung, automatische Codebettel, Code -Snippets und intelligente Eingabeaufforderungen zur Verbesserung der Entwicklungseffizienz. Durch ein reiches Erweiterungs -Ökosystem können Benutzer bestimmte Bedürfnisse und Sprachen wie Debugger, Code -Formatierungs -Tools und Git -Integrationen erweitern. VS -Code enthält auch einen intuitiven Debugger, mit dem Fehler in Ihrem Code schnell gefunden und behoben werden können.

Visual Studio Code (VSCODE) ist ein plattformübergreifender, Open-Source-Editor und kostenloser Code-Editor, der von Microsoft entwickelt wurde. Es ist bekannt für seine leichte, Skalierbarkeit und Unterstützung für eine Vielzahl von Programmiersprachen. Um VSCODE zu installieren, besuchen Sie bitte die offizielle Website, um das Installateur herunterzuladen und auszuführen. Bei der Verwendung von VSCODE können Sie neue Projekte erstellen, Code bearbeiten, Code bearbeiten, Projekte navigieren, VSCODE erweitern und Einstellungen verwalten. VSCODE ist für Windows, MacOS und Linux verfügbar, unterstützt mehrere Programmiersprachen und bietet verschiedene Erweiterungen über den Marktplatz. Zu den Vorteilen zählen leicht, Skalierbarkeit, umfangreiche Sprachunterstützung, umfangreiche Funktionen und Versionen

Zu den Hauptanwendungen von Linux gehören: 1. Server -Betriebssystem, 2. Eingebettes System, 3. Desktop -Betriebssystem, 4. Entwicklungs- und Testumgebung. Linux zeichnet sich in diesen Bereichen aus und bietet Stabilität, Sicherheits- und effiziente Entwicklungstools.

Um die Git -Repository -Adresse anzuzeigen, führen Sie die folgenden Schritte aus: 1. Öffnen Sie die Befehlszeile und navigieren Sie zum Repository -Verzeichnis; 2. Führen Sie den Befehl "git remote -v" aus; 3.. Zeigen Sie den Repository -Namen in der Ausgabe und der entsprechenden Adresse an.
