Utilisez vscode pour déboguer à distance le noyau Linux
Avant-propos
L'article précédent a présenté l'utilisation de QEMU+GDB pour déboguer le noyau Linux. Cependant, il n'est parfois pas très pratique d'utiliser directement GDB pour déboguer et afficher le code. Par conséquent, dans une occasion aussi importante, comment l'artefact de vscode peut-il manquer ? Cet article explique comment utiliser vscode pour déboguer à distance le noyau.
Environnement de cet article :
- Windows10
- vscode
- Ubuntu 20.04
J'utilise personnellement Tencent Cloud Server, j'enregistre donc le processus d'installation d'une machine virtuelle. Démarrez directement à partir de la configuration vscode.
Installation du plug-in vscode
télécommande-ssh
Trouvez le plug-in Remote-SSH dans la bibliothèque de plug-ins et installez-le.

Une fois l'installation terminée, il y aura une fonction supplémentaire sur la barre d'outils de droite

Appuyez sur F1 pour appeler la boîte de dialogue, entrez remote-ssh et sélectionnez ouvrir le fichier de configuration ssh.

Sélectionnez le premier profil

# Read more about SSH config files: https://linux.die.net/man/5/ssh_config Host ubuntu HostName 服务器IP地址 User 用户名 IdentityFile 私钥路径
J'utilise la clé privée pour me connecter au serveur, et IdentityFile remplit le chemin absolu de la clé privée.
Après la configuration, cliquez sur le bouton plus pour vous connecter au serveur

Erreur : configuration de l'hôte SSH XX : copie de VS Code Server sur l'hôte avec scp
Je suis resté bloqué lors de la connexion et j'attendais la configuration de l'hôte SSH XX : copie de VS Code Server pour héberger avec scp.
Raison
C'est parce que le répertoire personnel ~/.vscode-server/bin/commit_id/vscode-servlet.tar.gz
sur le serveur distant n'est pas téléchargé.
commit_id peut être consulté dans vscode [Aide] -> [Terminal].
Solution
Ensuite, nous téléchargerons vscode-servlet.tar.gz manuellement. Téléchargez via le lien ci-dessous.
#注意把:${commit_id}替换成对应的Commit ID https://update.code.visualstudio.com/commit:${commit_id}/server-linux-x64/stable
Exécutez la ligne de commande suivante. Supprimez tout ce qui se trouve dans le répertoire ~/.vscode-server/bin
.
rm ~/.vscode-server/bin/* -rf
S'il n'y a pas de ~/.vscode-server/bin
répertoire, créez-le. S'il y en a, veuillez ignorer cette étape*.
mkdir -p ~/.vscode-server/bin
Placez le package compressé téléchargé vscode-server-linux-x64.tar.gz dans le répertoire ~/.vscode-server/bin
.
Exécutez les trois lignes de commandes suivantes, où ${commit_id}
doit être remplacé par le commit_id enregistré à l'étape 2.
cd ~/.vscode-server/bin tar -zxf vscode-server-linux-x64.tar.gz mv vscode-server-linux-x64 ${commit_id}
报错:Permissions for ‘vscode_rsa’ are too open.
然后就可以在原来的文件浏览界面,打开远程的文件夹。但是在配置好进行连接的时候,VScode的终端报错了:
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ @ WARNING: UNPROTECTED PRIVATE KEY FILE! @ @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ Permissions for 'vscode_rsa' are too open. It is required that your private key files are NOT accessible by others. This private key will be ignored. Load key "vscode_rsa": bad permissions
根本原因是私钥的权限问题。这要是在Linux里,直接使用chmod,就可以修改,修改为644即可,但是windows,就稍微麻烦点。
在私钥上右击选择属性,然后选择【安全】选项卡,然后点击下面的【高级】按钮,然后在新弹出的窗口下方点击【禁用继承】,然后点击继承那个按钮上面的【添加】按钮重新将当前window登录用户设置为私钥的所有者,并勾选所有权限。最后跟下面一样即可:

这时再次打开VScode远程连接,就没有问题了。
C/C++
安装C/C++插件

依次点击【运行】->【打开配置】,将以下配置复制到launch.json中。
{ "version": "0.2.0", "configurations": [ { "name": "kernel-debug", "type": "cppdbg", "request": "launch", "miDebuggerServerAddress": "127.0.0.1:1234", "program": "${workspaceFolder}/vmlinux", "args": [], "stopAtEntry": false, "cwd": "${workspaceFolder}", "environment": [], "externalConsole": false, "logging": { "engineLogging": false }, "MIMode": "gdb", } ] }
然后在main函数中,打上两个断点,在服务器上开启QEMU,F5即可开启调试。

在vscode中调试内核,和正常的在windows调试代码是一样的,侧边栏可以看到变量,监视变量,调用堆栈等,非常方便。

大功告成,以后就可以在可视化界面调试内核了!

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!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

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

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

Clothoff.io
Dissolvant de vêtements AI

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 !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

L'idée principale d'intégrer les capacités de compréhension visuelle AI dans les applications PHP est d'utiliser l'API de service visuel AI tiers, qui est responsable du téléchargement d'images, de l'envoi de demandes, de la réception et de l'analyse des résultats JSON et du stockage de balises dans la base de données; 2. Le marquage automatique de l'image peut considérablement améliorer l'efficacité, améliorer la recherche de contenu, optimiser la gestion et la recommandation et changer le contenu visuel des "données mortes" aux "données en direct"; 3. La sélection des services d'IA nécessite des jugements complets basés sur la correspondance fonctionnelle, la précision, le coût, la facilité d'utilisation, le retard régional et la conformité des données, et il est recommandé de commencer à partir de services généraux tels que Google CloudVision; 4. Les défis courants comprennent le délai d'expiration du réseau, la sécurité clé, le traitement des erreurs, la limitation du format d'image, le contrôle des coûts, les exigences de traitement asynchrones et les problèmes de précision de reconnaissance de l'IA.

LinuxCanrunonModesthardwarewithSpecificminimumRequirements.A1GHZProcessor (x86orx86_64) est ensemble, avec-corecpureComend.r.R AmshouldBeatleast512MBForCommand-lineUseor2gbfordesktopenvironments.

En tant que pionnier dans le monde numérique, le nom de code unique de Bitcoin et la technologie sous-jacente ont toujours été au centre de l’attention des gens. Son code standard est BTC, également connu sous le nom de XBT sur certaines plateformes qui répondent aux normes internationales. D'un point de vue technique, Bitcoin n'est pas un style de code unique, mais un projet logiciel open source énorme et sophistiqué. Son code principal est principalement écrit en C et intègre la cryptographie, les systèmes distribués et les principes économiques, afin que n'importe qui puisse voir, examiner et contribuer son code.

Sélectionnez le service de reconnaissance vocale AI approprié et intégrez PHPSDK; 2. Utilisez PHP pour appeler FFMPEG pour convertir les enregistrements en formats requis API (tels que WAV); 3. Téléchargez des fichiers sur le stockage cloud et appelez API Asynchronous Recognition; 4. Analyser les résultats JSON et organiser du texte à l'aide de la technologie NLP; 5. Générez des documents Word ou Markdown pour terminer l'automatisation des enregistrements de la réunion. L'ensemble du processus doit assurer le chiffrement des données, le contrôle d'accès et la conformité pour garantir la confidentialité et la sécurité.

Pour permettre aux conteneurs PHP de prendre en charge la construction automatique, le noyau réside dans la configuration du processus d'intégration continue (CI). 1. Utilisez Dockerfile pour définir l'environnement PHP, y compris l'image de base, l'installation d'extension, la gestion de la dépendance et les paramètres d'autorisation; 2. Configurez des outils CI / CD tels que GitLabci et définissez les étapes de construction, de test et de déploiement via le fichier .gitlab-ci.yml pour réaliser une construction, un test et un déploiement automatique; 3. Intégrer des cadres de test tels que PHPUnit pour s'assurer que les tests sont automatiquement exécutés après les modifications du code; 4. Utiliser des stratégies de déploiement automatisées telles que Kubernetes pour définir la configuration de déploiement via le fichier de déploiement.yaml; 5. Optimiser Dockerfile et adopter une construction en plusieurs étapes

La commande d'arrêt de Linux / MacOS peut être arrêtée, redémarrée et chronométré les opérations à travers les paramètres. 1. Éteignez immédiatement la machine et utilisez les paramètres de Sudoshutdown ou -h / -p; 2. Utilisez le temps ou le point de temps spécifique pour l'arrêt, annulez l'utilisation de -c; 3. Utilisez les paramètres -r pour redémarrer, prendre en charge le redémarrage chronométré; 4. Faites attention à la nécessité des autorisations sudo, soyez prudent dans le fonctionnement à distance et évitez la perte de données.

La construction d'un environnement de conteneur de tâches PHP indépendant peut être implémentée via Docker. Les étapes spécifiques sont les suivantes: 1. Installez Docker et DockerCose comme base; 2. Créez un répertoire indépendant pour stocker les fichiers Dockerfile et Crontab; 3. Écrivez Dockerfile pour définir l'environnement PHPCLI et installer Cron et les extensions nécessaires; 4. Écrivez un fichier crontab pour définir les tâches de synchronisation; 5. Écrivez un répertoire de script Docker-Compose.yml et configurer les variables d'environnement; 6. Démarrez le conteneur et vérifiez le journal. Par rapport à l'exécution de tâches de synchronisation dans des conteneurs Web, les conteneurs indépendants présentent les avantages de l'isolement des ressources, de l'environnement pur, de la forte stabilité et de l'expansion facile. Pour assurer la journalisation et la capture d'erreur

Confirmez le nom du périphérique du disque dur cible (tel que / dev / sda) pour éviter de supprimer accidentellement le disque système; 2. Utilisez sudoddif = / dev / zeroof = / dev / sdxbs = 1mstatus = progresser pour écraser la valeur zéro dans le disque complet, qui convient à la plupart des scénarios; 3. Utilisez Sudoshred-V-N3 / Dev / SDX pour trois augmentations de données aléatoires pour vous assurer qu'elle ne peut pas être restaurée; 4. Exécuter éventuellement SudObAdBlocks-Wsv / Dev / SDX pour les tests d'écriture destructeurs; Enfin, utilisez SudoHExDump-C / Dev / SDX | Head pour vérifier si tout est zéro et une efface complète en toute sécurité.
