Table des matières
2. Idées de dépannage " >2. Idées de dépannage
2.1 Localiser le pid du processus à charge élevée" >2.1 Localiser le pid du processus à charge élevée
2.2 Localiser une activité anormale spécifique" >2.2 Localiser une activité anormale spécifique
2.3 Localisez le fil anormal et les lignes de code spécifiques" >2.3 Localisez le fil anormal et les lignes de code spécifiques
3. Analyse des causes profondes" >3. Analyse des causes profondes
2.2 Localiser une activité anormale spécifique
Maison Tutoriel système Linux Lâchez-moi, le processeur du système Linux est plein à 100 % !

Lâchez-moi, le processeur du système Linux est plein à 100 % !

Feb 13, 2024 pm 11:27 PM
linux linux教程 linux系统 linux命令 shell脚本 Linux embarqué Débuter avec Linux apprentissage Linux

Hier après-midi, j'ai soudainement reçu une alerte e-mail du service d'exploitation et de maintenance, qui montrait que le taux d'utilisation du processeur du serveur de la plateforme de données atteignait 98,94 %. Ces derniers temps, ce taux d'utilisation est resté supérieur à 70 %. À première vue, il semble que les ressources matérielles aient atteint un goulot d'étranglement et doivent être étendues. Mais après y avoir réfléchi attentivement, j'ai découvert que notre système d'entreprise n'est pas une application hautement concurrente ou gourmande en CPU. Ce taux d'utilisation est trop exagéré et le goulot d'étranglement matériel ne peut pas être atteint aussi rapidement. Il doit y avoir un problème avec la logique du code métier quelque part.

2. Idées de dépannage

2.1 Localiser le pid du processus à charge élevée

Connectez-vous d'abord au serveur et utilisez la commande top pour confirmer la situation spécifique du serveur, puis analysez et jugez en fonction de la situation spécifique.

我去,Linux 系统 CPU 100% 打满了!

En observant la charge moyenne et la norme d'évaluation de charge (8 cœurs), on peut confirmer que le serveur a une charge élevée

 ; 我去,Linux 系统 CPU 100% 打满了!

En observant l'utilisation des ressources de chaque processus, nous pouvons voir que le processus portant l'ID de processus 682 a un ratio CPU plus élevé

2.2 Localiser une activité anormale spécifique

Ici, nous pouvons utiliser la commande pwdx pour trouver le chemin du processus métier en fonction du pid, puis localiser le responsable et le projet :

我去,Linux 系统 CPU 100% 打满了!

On peut conclure que ce processus correspond au service web de la plateforme de données.

2.3 Localisez le fil anormal et les lignes de code spécifiques

La solution traditionnelle se déroule généralement en 4 étapes :

1. premier ordre par avec P : 1040 // Triez d'abord par charge de processus pour trouver maxLoad(pid)

2. top -Hp process PID : 1073 // Trouvez le PID du thread de chargement approprié

3. printf « 0x%x » PID du fil : 0x431 // Convertissez le PID du fil en hexadécimal pour préparer la recherche ultérieure dans le journal jstack

4. Processus jstack PID | vim +/fil hexadécimal PID – // Par exemple : jstack 1040|vim +/0x431 –

Mais pour la localisation des problèmes en ligne, chaque seconde compte, et les 4 étapes ci-dessus sont encore trop lourdes et prennent beaucoup de temps. Oldratlee, qui a déjà présenté Taobao, a encapsulé le processus ci-dessus dans un outil : show-busy-java-threads.sh. Vous pouvez facilement localiser ce type de problème en ligne :

我去,Linux 系统 CPU 100% 打满了!

On peut conclure que le processeur d'exécution d'une méthode d'outil temporel dans le système est relativement élevé. Après avoir localisé la méthode spécifique, vérifiez s'il existe des problèmes de performances dans la logique du code.

※ Si le problème en ligne est plus urgent, vous pouvez omettre 2.1 et 2.2 et exécuter directement 2.3. L'analyse ici est sous plusieurs angles juste pour vous présenter une idée d'analyse complète.

3. Analyse des causes profondes

Après l'analyse et le dépannage précédents, nous avons finalement localisé un problème avec les outils de temps, qui entraînait une charge excessive du serveur et une utilisation excessive du processeur.

  • Logique de la méthode d'exception : consiste à convertir l'horodatage dans le format de date et d'heure spécifique correspondant ;
  • Appel de la couche supérieure :
  • Calculez toutes les secondes depuis le petit matin jusqu'à l'heure actuelle, convertissez-les dans le format correspondant et mettez-les dans l'ensemble pour renvoyer le résultat ; Couche logique : Correspond à la logique de requête du rapport en temps réel de la plateforme de données. Le rapport en temps réel arrivera à un intervalle de temps fixe et il y aura plusieurs (n) appels de méthode dans une requête.
  • Ensuite, on peut conclure que si l'heure actuelle est 10 heures du matin, le nombre de calculs pour une requête est de 1060
  • 60
n fois = 36 000

n calculs, et à mesure que le temps augmente, le nombre Le nombre de requêtes uniques se rapproche de minuit et augmentera de manière linéaire. Étant donné qu'un grand nombre de requêtes de requêtes provenant de modules tels que les requêtes en temps réel et les alarmes en temps réel nécessitent d'appeler cette méthode plusieurs fois, une grande quantité de ressources CPU est occupée et gaspillée. 4.Solution

Après avoir localisé le problème, la première considération est de réduire le nombre de calculs et d'optimiser la méthode des exceptions. Après enquête, il a été constaté que lorsqu'il était utilisé au niveau de la couche logique, le contenu de la collection d'ensembles renvoyé par cette méthode n'était pas utilisé, mais la valeur de taille de l'ensemble était simplement utilisée. Après avoir confirmé la logique, simplifiez le calcul grâce à une nouvelle méthode (secondes actuelles - secondes tôt le matin), remplacez la méthode appelée et résolvez le problème des calculs excessifs. Après la mise en ligne, nous avons observé la charge du serveur et l'utilisation du processeur. Par rapport à la période anormale, la charge du serveur et l'utilisation du processeur ont diminué de 30 fois et sont revenues à la normale.  ![Hier après-midi, j'ai soudainement reçu une alerte e-mail du service d'exploitation et de maintenance, montrant que le taux d'utilisation du processeur du serveur de la plateforme de données atteignait 98,94 %. Ces derniers temps, ce taux d'utilisation est resté supérieur à 70 %. À première vue, il semble que les ressources matérielles aient atteint un goulot d'étranglement et doivent être étendues. Mais après y avoir réfléchi attentivement, j'ai découvert que notre système d'entreprise n'est pas une application hautement concurrente ou gourmande en CPU. Ce taux d'utilisation est trop exagéré et le goulot d'étranglement matériel ne peut pas être atteint aussi rapidement. Il doit y avoir un problème avec la logique du code métier quelque part.

2. Idées de dépannage

2.1 Localiser le pid du processus à charge élevée

Connectez-vous d'abord au serveur et utilisez la commande top pour confirmer la situation spécifique du serveur, puis analysez et jugez en fonction de la situation spécifique.

En observant la charge moyenne et la norme d'évaluation de charge (8 cœurs), on peut confirmer que le serveur a une charge élevée

 ;

我去,Linux 系统 CPU 100% 打满了!En observant l'utilisation des ressources de chaque processus, nous pouvons voir que le processus portant l'ID de processus 682 a un ratio CPU plus élevé

我去,Linux 系统 CPU 100% 打满了!

2.2 Localiser une activité anormale spécifique

Ici, nous pouvons utiliser la commande pwdx pour trouver le chemin du processus métier en fonction du pid, puis localiser le responsable et le projet :

On peut conclure que ce processus correspond au service web de la plateforme de données.

我去,Linux 系统 CPU 100% 打满了!

2.3 Localisez le fil anormal et les lignes de code spécifiques

La solution traditionnelle se déroule généralement en 4 étapes :

1. premier trieur par avec P : 1040 // Triez d'abord par charge de processus pour trouver maxLoad(pid)

2. top -Hp process PID : 1073 // Trouvez le PID du thread de chargement approprié

3. printf « 0x%x » PID du fil : 0x431 // Convertissez le PID du fil en hexadécimal pour préparer la recherche ultérieure dans le journal jstack

4. Processus jstack PID | vim +/fil hexadécimal PID – // Par exemple : jstack 1040|vim +/0x431 –

Mais pour la localisation des problèmes en ligne, chaque seconde compte, et les 4 étapes ci-dessus sont encore trop lourdes et prennent beaucoup de temps. Oldratlee, qui a déjà présenté Taobao, a encapsulé le processus ci-dessus dans un outil : show-busy-java-threads.sh. Vous pouvez facilement localiser ce type de problème en ligne :

我去,Linux 系统 CPU 100% 打满了!

On peut conclure que le processeur d'exécution d'une méthode d'outil temporel dans le système est relativement élevé. Après avoir localisé la méthode spécifique, vérifiez s'il existe des problèmes de performances dans la logique du code.

※ Si le problème en ligne est plus urgent, vous pouvez omettre 2.1 et 2.2 et exécuter directement 2.3. L'analyse ici est sous plusieurs angles juste pour vous présenter une idée d'analyse complète.

3. Analyse des causes profondes

Après l'analyse et le dépannage précédents, nous avons finalement localisé un problème d'outil de temps, qui entraînait une charge excessive du serveur et une utilisation excessive du processeur.

  • Logique de la méthode d'exception : consiste à convertir l'horodatage dans le format de date et d'heure spécifique correspondant ;
  • Appel de la couche supérieure :
  • Calculez toutes les secondes depuis le petit matin jusqu'à l'heure actuelle, convertissez-les dans le format correspondant et mettez-les dans l'ensemble pour renvoyer le résultat ; Couche logique : Correspond à la logique de requête du rapport en temps réel de la plateforme de données. Le rapport en temps réel arrivera à un intervalle de temps fixe et il y aura plusieurs (n) appels de méthode dans une requête.
  • Ensuite, on peut conclure que si l'heure actuelle est 10 heures du matin, le nombre de calculs pour une requête est de 1060
  • 60
n fois = 36 000

n calculs, et à mesure que le temps augmente, le nombre Le nombre de requêtes uniques se rapproche de minuit et augmentera de manière linéaire. Étant donné qu'un grand nombre de requêtes de requêtes provenant de modules tels que les requêtes en temps réel et les alarmes en temps réel nécessitent d'appeler cette méthode plusieurs fois, une grande quantité de ressources CPU est occupée et gaspillée. 4.Solution

Après avoir localisé le problème, la première considération est de réduire le nombre de calculs et d'optimiser la méthode des exceptions. Après enquête, il a été constaté que lorsqu'il était utilisé au niveau de la couche logique, le contenu de la collection d'ensembles renvoyé par cette méthode n'était pas utilisé, mais la valeur de taille de l'ensemble était simplement utilisée. Après avoir confirmé la logique, simplifiez le calcul grâce à une nouvelle méthode (secondes actuelles - secondes tôt le matin), remplacez la méthode appelée et résolvez le problème des calculs excessifs. Après la mise en ligne, nous avons observé la charge du serveur et l'utilisation du processeur. Par rapport à la période anormale, la charge du serveur et l'utilisation du processeur ont diminué de 30 fois et sont revenues à la normale.

5.Résumé我去,Linux 系统 CPU 100% 打满了!

Pendant le processus de codage, en plus de mettre en œuvre la logique métier, nous devons également nous concentrer sur l’optimisation des performances du code. La capacité à répondre à une exigence commerciale et la capacité à y parvenir de manière plus efficace et plus élégante sont en fait deux manifestations complètement différentes des capacités et des domaines des ingénieurs, et cette dernière constitue également le cœur de la compétitivité des ingénieurs.

    Une fois le code écrit, effectuez davantage de révisions et réfléchissez davantage à la question de savoir s'il peut être mieux implémenté.
  • Ne manquez aucun petit détail dans les questions en ligne ! Les détails sont le diable. Les étudiants techniques doivent avoir la soif de connaissances et l'esprit de recherche de l'excellence. Ce n'est qu'ainsi qu'ils pourront continuer à grandir et à s'améliorer.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quelle configuration de l'ordinateur est requise pour VScode Quelle configuration de l'ordinateur est requise pour VScode Apr 15, 2025 pm 09:48 PM

Vs Code Système Exigences: Système d'exploitation: Windows 10 et supérieur, MacOS 10.12 et supérieur, processeur de distribution Linux: minimum 1,6 GHz, recommandé 2,0 GHz et au-dessus de la mémoire: minimum 512 Mo, recommandée 4 Go et plus d'espace de stockage: Minimum 250 Mo, recommandée 1 Go et plus d'autres exigences: connexion du réseau stable, xorg / wayland (Linux) recommandé et recommandée et plus

VScode ne peut pas installer l'extension VScode ne peut pas installer l'extension Apr 15, 2025 pm 07:18 PM

Les raisons de l'installation des extensions de code vs peuvent être: l'instabilité du réseau, les autorisations insuffisantes, les problèmes de compatibilité système, la version de code vs est trop ancienne, un logiciel antivirus ou des interférences de pare-feu. En vérifiant les connexions réseau, les autorisations, les fichiers journaux, la mise à jour vs du code, la désactivation des logiciels de sécurité et le redémarrage du code ou des ordinateurs, vous pouvez progressivement dépanner et résoudre les problèmes.

Peut-on utiliser pour mac Peut-on utiliser pour mac Apr 15, 2025 pm 07:36 PM

VS Code est disponible sur Mac. Il a des extensions puissantes, l'intégration GIT, le terminal et le débogueur, et offre également une multitude d'options de configuration. Cependant, pour des projets particulièrement importants ou un développement hautement professionnel, le code vs peut avoir des performances ou des limitations fonctionnelles.

Qu'est-ce que VScode pour quoi est VScode? Qu'est-ce que VScode pour quoi est VScode? Apr 15, 2025 pm 06:45 PM

VS Code est le code Visual Studio Nom complet, qui est un éditeur de code multiplateforme gratuit et open source et un environnement de développement développé par Microsoft. Il prend en charge un large éventail de langages de programmation et fournit une mise en surbrillance de syntaxe, une complétion automatique du code, des extraits de code et des invites intelligentes pour améliorer l'efficacité de développement. Grâce à un écosystème d'extension riche, les utilisateurs peuvent ajouter des extensions à des besoins et des langues spécifiques, tels que les débogueurs, les outils de mise en forme de code et les intégrations GIT. VS Code comprend également un débogueur intuitif qui aide à trouver et à résoudre rapidement les bogues dans votre code.

Comment utiliser vscode Comment utiliser vscode Apr 15, 2025 pm 11:21 PM

Visual Studio Code (VSCODE) est un éditeur de code Open Source, Open Source et gratuit développé par Microsoft. Il est connu pour son léger, l'évolutivité et le support pour une large gamme de langages de programmation. Pour installer VScode, veuillez visiter le site officiel pour télécharger et exécuter l'installateur. Lorsque vous utilisez VSCODE, vous pouvez créer de nouveaux projets, modifier le code, déboguer le code, naviguer dans les projets, développer VSCODE et gérer les paramètres. VScode est disponible pour Windows, MacOS et Linux, prend en charge plusieurs langages de programmation et fournit diverses extensions via Marketplace. Ses avantages incluent le léger, l'évolutivité, le support linguistique étendu, les fonctionnalités riches et la version

Comment exécuter le code Java dans le bloc-notes Comment exécuter le code Java dans le bloc-notes Apr 16, 2025 pm 07:39 PM

Bien que le bloc-notes ne puisse pas exécuter directement le code Java, il peut être réalisé en utilisant d'autres outils: à l'aide du compilateur de ligne de commande (Javac) pour générer un fichier bytecode (filename.class). Utilisez l'interpréteur Java (Java) pour interpréter ByteCode, exécuter le code et sortir le résultat.

Quel est le but principal de Linux? Quel est le but principal de Linux? Apr 16, 2025 am 12:19 AM

Les principales utilisations de Linux comprennent: 1. Système d'exploitation du serveur, 2. Système intégré, 3. Système d'exploitation de bureau, 4. Environnement de développement et de test. Linux excelle dans ces domaines, offrant des outils de stabilité, de sécurité et de développement efficaces.

Comment vérifier l'adresse de l'entrepôt de Git Comment vérifier l'adresse de l'entrepôt de Git Apr 17, 2025 pm 01:54 PM

Pour afficher l'adresse du référentiel GIT, effectuez les étapes suivantes: 1. Ouvrez la ligne de commande et accédez au répertoire du référentiel; 2. Exécutez la commande "git Remote -v"; 3. Affichez le nom du référentiel dans la sortie et son adresse correspondante.

See all articles