Maison > développement back-end > Tutoriel Python > Déploiement python+tornado+superviseur+nginx sous Ubuntu

Déploiement python+tornado+superviseur+nginx sous Ubuntu

PHP中文网
Libérer: 2017-07-14 18:13:09
original
1296 Les gens l'ont consulté

É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 #设置日志路径
Copier après la connexion

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
Copier après la connexion

 

(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
Copier après la connexion

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>
Copier après la connexion

 

(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
Copier après la connexion

 

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!

Étiquettes associées:
source:php.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal