


Déploiement python+tornado+superviseur+nginx sous Ubuntu
Étant donné que les données précédemment collectées à l'hôpital étaient des photos d'ordonnance obtenues en prenant des photos, ce qui doit être utilisé, c'est la forme textuelle de l'ordonnance. Par conséquent, j'ai écrit un petit programme au cours des deux dernières semaines pour afficher des images du serveur aux utilisateurs (en embauchant certaines personnes à ce moment-là), permettant aux utilisateurs de saisir des informations textuelles basées sur les images.
J'ai déjà utilisé Java pour écrire des pages Web. Je pensais récemment utiliser Python pour apprendre l'apprentissage automatique, alors j'ai utilisé Python pour l'écrire. De plus, parce que je voulais utiliser quelque chose de nouveau et que le programme était relativement petit, J'ai envisagé d'utiliser mongodb pour le stockage (même si ce n'est vraiment pas nécessaire).
L'architecture de base est la suivante : (langage backend) python + (framework web et serveur web) tornado + (base de données) mongodb + (gestion des processus) superviseur + (proxy inverse) nginx
(1) python : Je regarde le tutoriel python de Liao Xuefeng
J'ai appris quelques phrases de base, puis je les vérifiais si je ne les comprenais pas lorsque je les faisais.
(2) tornade : J'ai commencé à apprendre après avoir regardé ce tutoriel
tornado est très rapide à utiliser. Il peut mapper directement les requêtes comme un transitaire au printemps, et peut également surveiller directement les requêtes http sur un certain port comme Tomcat a fait toutes ces choses pour nous. Les méthodes get et post conviennent.
D'autres sont presque les mêmes que dans Java Web. Sans le framework springMVC et hibernate, vous pouvez vous-même superposer le contrôleur, le service et le dao dans le package python.
(3) mongodb : Une base de données non relationnelle, il n'est pas nécessaire que le même nom de champ soit unifié pour chaque ligne de données (appelée document en mongodb) dans une table (appelée collection en mongodb). Plus ou moins inégal. Un autre point est que les transactions ne sont pas prises en charge et qu'il n'y a aucun moyen d'annuler lors de l'exécution de plusieurs instructions de lecture et d'écriture en python, vous devez donc trouver un moyen d'éviter les problèmes causés par la concurrence dans le programme.
Par exemple, je dois trouver un document avec un statut de 0 dans la collection et le mettre à jour à 1, ce qui signifie que l'utilisateur le consulte. Une fois que l'utilisateur a apporté des modifications, définissez le statut sur 2, puis mettez-le. Ici, 0 signifie non parcouru, 1 signifie qu'il est en cours de navigation et 2 signifie qu'il a été modifié. À l’heure actuelle, de nombreux utilisateurs peuvent avoir obtenu les données de statut 0 en même temps. Cela va à l’encontre de notre souhait et permet à de nombreuses personnes de modifier les mêmes données. Vous pouvez envisager directement update_one pour changer le statut d'un document de 0 à 1, puis ajouter un champ unique pour identifier le document, et utiliser ce champ unique pour trouver le document. Pour le moment, les autres utilisateurs ne peuvent pas obtenir le document car update_one. Il sera verrouillé le moment venu et d’autres ne pourront pas obtenir ces données.
(4) superviseur : Supervisor est un programme de gestion de processus développé en python, qui peut transformer des commandes ordinaires en démons d'arrière-plan et surveiller l'état du processus.
Après l'installation, vous pouvez ajouter le fichier de configuration printprescription.conf dans le répertoire /etc/supervisor/conf.d L'exemple de configuration est le suivant
[program:printprescription] #设置守护进程名 command = python /home/liaohuqiang/Code/printprescription/main2.py #设置执行命令 autorstart=true #设置随supervisor的启动而启动 stdout_logfile = /home/liaohuqiang/Code/printprescription/printprescription.log #设置日志路径
Une fois la configuration terminée, vous pouvez ouvrir, fermer et redémarrer le service superviseur. Vous pouvez utiliser superviseurctl status pour vérifier l'état du processus, et vous pouvez également vérifier les informations d'erreur dans les fichiers journaux pertinents
sudo /etc/init.d/supervisor start sudo /etc/init.d/supervisor stop sudo /etc/init.d/supervisor restart<br><br>sudo supervisorctl status printprescripton<br>vim cat /var/log/supervisor/xxx.log
(5) nginx : nginx est utilisé comme proxy inverse. Il peut surveiller le port 80 et transmettre les requêtes correspondantes à d'autres hôtes et d'autres ports. Le chemin de l'image que nous affichons ici n'est pas en tornade. en statique (static est utilisé pour stocker des ressources statiques frontales telles que js et css), mais dans un autre emplacement sur le serveur, afin que l'image puisse être obtenue via le transfert nginx. D'un autre côté, les autres ports (tels que le port 8001 sur lequel tornado écoute) ne sont généralement pas exposés aux utilisateurs, donc nginx est utilisé pour le transfert. De plus, la directive location /static/ indique à nginx de fournir directement des fichiers de répertoire statiques au lieu de transmettre des requêtes proxy à tornado. Nginx peut fournir des fichiers statiques plus efficacement que tornado.
Après avoir installé nginx, vérifiez les fichiers de configuration pertinents et trouvez cette phrase : include /etc/nginx/sites-enabled/*. Vous pouvez créer un nouveau fichier de configuration dans ce répertoire pour la configuration
cat /etc/nginx/nginx.conf<br>sudo touch /etc/nginx/sites-enabled/default2
L'exemple de configuration est le suivant. Il convient de noter que le bas http://127.0.0.1:8001/ Si la dernière barre oblique ici n'est pas saisie, la prescription d'impression ci-dessus sera en fait ajoutée lorsque l'utilisateur accédera à "host". /printprescription" Cela équivaut à accéder à "Host:8001/printprescription". Étant donné que la requête sur Tornado est mappée sur Host:8001/, 404 apparaîtra à ce moment-là.
<span style="color: #000000"> upstream frontends { server </span><span style="color: #800080">222.222</span>.<span style="color: #800080">222.222</span>:<span style="color: #800080">8000</span><span style="color: #000000">; server </span><span style="color: #800080">222.222</span>.<span style="color: #800080">222.222</span>:<span style="color: #800080">8001</span><span style="color: #000000">; } server { listen </span><span style="color: #800080">80</span><span style="color: #000000">; location </span>/<span style="color: #000000"> { proxy_read_timeout </span><span style="color: #800080">1800</span><span style="color: #000000">; proxy_pass_header Server; proxy_set_header Host $http_host; proxy_redirect off; proxy_set_header X</span>-Real-<span style="color: #000000">IP $remote_addr; proxy_set_header X</span>-<span style="color: #000000">Scheme $scheme; proxy_pass http:</span><span style="color: #008000">//</span><span style="color: #008000">frontends;</span> <span style="color: #000000"> } location </span>/doctorAfter/<span style="color: #000000"> { #配置图片路径 root </span>/home/<span style="color: #000000">wenserver; } location </span>/static/<span style="color: #000000"> { #配置前端静态资源路径 root </span>/home/xxx/Code/printprescription/<span style="color: #000000">view; } location </span>/printprescription/<span style="color: #000000"> { proxy_read_timeout </span><span style="color: #800080">1800</span><span style="color: #000000">; proxy_pass_header Server; proxy_set_header Host $http_host; proxy_redirect off; proxy_set_header X</span>-Real-<span style="color: #000000">IP $remote_addr; proxy_set_header X</span>-<span style="color: #000000">Scheme $scheme; proxy_pass http:</span><span style="color: #008000">//</span><span style="color: #008000">127.0.0.1:8001/;</span> <span style="color: #000000"> } }</span>
(6)opencv:一个计算机视觉库,实现了图像处理和计算机视觉方面的很多通用算法。由于之前采集数据的时候在处方图片数据中混杂了人脸图片,所以采用oepncv里的算法检测人脸,如果是人脸则删除该记录。然而还是会残留一些人脸图片,需要人工清洗,这个数据好像之前有师兄清洗过,到时候拿过来重构一下数据库。
ps:安装opencv的时候imshow报错,虽然imshow用不到,但是强迫症使然,搞了我一天,来来回回装了十多次,最后还是没搞定,真是心力交瘁,特想吐嘈:垃圾opencv!毁我青春!颓我精神!耗我时间!磨我意志!浪费人生!!!
好吧我就随便说说,回头还要靠它干活。
cv2.error: /io/opencv/modules/highgui/src/window.<span style="color: #0000ff">cpp</span>:<span style="color: #800080">583</span>: error: (-<span style="color: #800080">2</span>) The <span style="color: #0000ff">function</span> is not implemented. Rebuild the library with Windows, GTK+ <span style="color: #800080">2</span>.x or Carbon support. If you are on Ubuntu or Debian, <span style="color: #0000ff">install</span> libgtk2.<span style="color: #800080">0</span>-dev and <span style="color: #0000ff">pkg-config</span>, <span style="color: #0000ff">then</span> re-run cmake or configure script <span style="color: #0000ff">in</span> <span style="color: #0000ff">function</span> cvShowImage
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

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.

Undress AI Tool
Images de déshabillage gratuites

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)

Sujets chauds





C'est un problème très courant de nos jours qu'Ubuntu ne permet pas à ses utilisateurs d'ouvrir le terminal. Si vous rencontrez un problème similaire et ne savez pas quoi faire ensuite, découvrez cinq correctifs permettant de résoudre ce problème « Ubuntu ne peut pas ouvrir le terminal » sur votre appareil Linux. Sans plus tarder, examinons ses causes et les solutions disponibles. Pourquoi Ubuntu ne peut-il pas ouvrir le terminal ? Cela se produit principalement lorsque vous installez un logiciel défectueux ou modifiez la configuration du terminal. En plus de cela, les nouvelles applications ou jeux qui interagissent avec les paramètres régionaux et les corrompent peuvent provoquer des problèmes similaires. Certains utilisateurs ont signalé un correctif pour ce problème lors de la recherche de Terminal dans le menu d'activité d'Ubuntu. Cela montre que

Dans les systèmes Ubuntu, l'utilisateur root est généralement désactivé. Pour activer l'utilisateur root, vous pouvez utiliser la commande passwd pour définir un mot de passe, puis utiliser la commande su- pour vous connecter en tant que root. L'utilisateur root est un utilisateur disposant de droits d'administration système illimités. Il dispose des autorisations nécessaires pour accéder et modifier les fichiers, la gestion des utilisateurs, l'installation et la suppression de logiciels et les modifications de la configuration du système. Il existe des différences évidentes entre l'utilisateur root et les utilisateurs ordinaires. L'utilisateur root possède la plus haute autorité et des droits de contrôle plus étendus sur le système. L'utilisateur root peut exécuter des commandes système importantes et modifier des fichiers système, ce que les utilisateurs ordinaires ne peuvent pas faire. Dans ce guide, j'explorerai l'utilisateur root Ubuntu, comment se connecter en tant que root et en quoi il diffère d'un utilisateur normal. Avis

Ubuntu24.04LTS, nom de code "NobleNumbat", sera bientôt disponible ! Si vous utilisez une version non LTS telle qu'Ubuntu 23.10, vous devrez tôt ou tard envisager une mise à niveau. Pour ceux qui utilisent Ubuntu20.04LTS ou Ubuntu22.04LTS, cela vaut la peine de réfléchir à l'opportunité de mettre à niveau. Canonical a annoncé qu'Ubuntu 24.04LTS fournira un support de mise à jour jusqu'à 12 ans, réparti comme suit : En tant que version LTS, elle bénéficiera de 5 ans de maintenance et de mises à jour de sécurité régulières. Si vous vous abonnez à Ubuntu Pro, vous pouvez bénéficier de 5 années supplémentaires de support. Actuellement, cette période d'assistance supplémentaire a été étendue à 7 ans, ce qui signifie que vous bénéficierez d'un maximum de 12 ans.

OBS est un logiciel open source développé par des contributeurs bénévoles du monde entier pendant leur temps libre. Un logiciel d'enregistrement vidéo en direct, principalement utilisé pour l'enregistrement vidéo et le streaming en direct. Veuillez noter que lors de l'installation d'Ubuntu/Mint, OBSStudio ne peut pas fonctionner entièrement sur ChromeOS et que les fonctions telles que la capture d'écran et de fenêtre ne peuvent pas être utilisées. Il est recommandé d'utiliser xserver-xorg1.18.4 ou une version plus récente pour éviter des problèmes de performances potentiels avec certaines fonctionnalités d'OBS, telles que les projecteurs plein écran. FFmpeg est requis Si FFmpeg n'est pas installé (si vous n'êtes pas sûr, ce n'est probablement pas le cas), vous pouvez l'obtenir avec : sudoaptinstallffmpeg Je l'ai déjà installé ici.

Pour de nombreux utilisateurs, pirater un boîtier Android TV semble intimidant. Cependant, le développeur Murray R. Van Luyn a dû relever le défi de rechercher des alternatives appropriées au Raspberry Pi pendant la pénurie de puces Broadcom. Ses efforts de collaboration avec l'Armbia

Pour supprimer FirefoxSnap dans UbuntuLinux, vous pouvez suivre ces étapes : Ouvrez un terminal et connectez-vous à votre système Ubuntu en tant qu'administrateur. Exécutez la commande suivante pour désinstaller FirefoxSnap : sudosnapremovefirefox Vous serez invité à saisir votre mot de passe administrateur. Entrez votre mot de passe et appuyez sur Entrée pour confirmer. Attendez la fin de l’exécution de la commande. Une fois terminé, FirefoxSnap sera complètement supprimé. Notez que cela supprimera les versions de Firefox installées via le gestionnaire de packages Snap. Si vous avez installé une autre version de Firefox par d'autres moyens (tels que le gestionnaire de packages APT), vous ne serez pas affecté. Suivez les étapes ci-dessus

Angular.js est une plateforme JavaScript librement accessible pour créer des applications dynamiques. Il vous permet d'exprimer rapidement et clairement divers aspects de votre application en étendant la syntaxe HTML en tant que langage de modèle. Angular.js fournit une gamme d'outils pour vous aider à écrire, mettre à jour et tester votre code. De plus, il offre de nombreuses fonctionnalités telles que le routage et la gestion des formulaires. Ce guide expliquera comment installer Angular sur Ubuntu24. Tout d’abord, vous devez installer Node.js. Node.js est un environnement d'exécution JavaScript basé sur le moteur ChromeV8 qui vous permet d'exécuter du code JavaScript côté serveur. Être à Ub

Si vous avez utilisé Docker, vous devez comprendre les démons, les conteneurs et leurs fonctions. Un démon est un service qui s'exécute en arrière-plan lorsqu'un conteneur est déjà utilisé dans n'importe quel système. Podman est un outil de gestion gratuit permettant de gérer et de créer des conteneurs sans recourir à un démon tel que Docker. Par conséquent, il présente des avantages dans la gestion des conteneurs sans nécessiter de services backend à long terme. De plus, Podman ne nécessite pas d'autorisations au niveau racine pour être utilisé. Ce guide explique en détail comment installer Podman sur Ubuntu24. Pour mettre à jour le système, nous devons d'abord mettre à jour le système et ouvrir le shell du terminal d'Ubuntu24. Pendant les processus d’installation et de mise à niveau, nous devons utiliser la ligne de commande. un simple
