<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="fr">
	<id>https://wikibr.binets.fr/index.php?action=history&amp;feed=atom&amp;title=Sites_Python</id>
	<title>Sites Python - Historique des versions</title>
	<link rel="self" type="application/atom+xml" href="https://wikibr.binets.fr/index.php?action=history&amp;feed=atom&amp;title=Sites_Python"/>
	<link rel="alternate" type="text/html" href="https://wikibr.binets.fr/index.php?title=Sites_Python&amp;action=history"/>
	<updated>2026-05-11T19:46:40Z</updated>
	<subtitle>Historique des versions pour cette page sur le wiki</subtitle>
	<generator>MediaWiki 1.38.2</generator>
	<entry>
		<id>https://wikibr.binets.fr/index.php?title=Sites_Python&amp;diff=8891&amp;oldid=prev</id>
		<title>Chi.huynh : Création de la page Sites Python</title>
		<link rel="alternate" type="text/html" href="https://wikibr.binets.fr/index.php?title=Sites_Python&amp;diff=8891&amp;oldid=prev"/>
		<updated>2022-08-14T19:14:03Z</updated>

		<summary type="html">&lt;p&gt;Création de la page Sites Python&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Nouvelle page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Il existe plusieurs façons de faire des sites internet. Le serveur du BR qui héberge les sites binets peuvent héberger des sites créés avec Python.&lt;br /&gt;
&lt;br /&gt;
Pour faire un site avec Python, on peut utiliser un framework. Les deux plus connus sont&lt;br /&gt;
&lt;br /&gt;
* [https://www.djangoproject.com/ Django]&lt;br /&gt;
* [http://flask.pocoo.org/ Flask]&lt;br /&gt;
&lt;br /&gt;
Le but de cet article n'est pas de vous expliquer comment créer un tel site : des guides bien meilleurs que ce que l'on pourrait écrire ici existent déjà, et on propose des formations au cours de l'année pour vous apprendre comment.&lt;br /&gt;
&lt;br /&gt;
Ici, on vous explique comment déployer un site fait en Python sur notre serveur, une fois les fichiers en place (voir le [Sites Binet|guide sur les sites binets]).&lt;br /&gt;
&lt;br /&gt;
== Préambule ==&lt;br /&gt;
&lt;br /&gt;
On doit faire des manipulations de notre côté pour gérer votre site Python, donc il faut nous dire :&lt;br /&gt;
* que vous utilisez Python&lt;br /&gt;
* quelle version de Python vous utilisez (2.7 ou 3.x)&lt;br /&gt;
* quel est le nom du fichier principal WSGI (voir la documentation du framework que vous utilisez)&lt;br /&gt;
&lt;br /&gt;
== Environnement virtuel ==&lt;br /&gt;
&lt;br /&gt;
Le serveur fait tourner simultanément plusieurs sites Python, qui ont chacun leur version de Python (2.7 ou 3.x) et leurs dépendances.&lt;br /&gt;
&lt;br /&gt;
Pour bien compartimenter tout cela, il faut définir un environnement virtuel, c'est-à-dire un interpréteur Python séparé et indépendant des autres avec ses propres librairies.&lt;br /&gt;
&lt;br /&gt;
=== Création ===&lt;br /&gt;
&lt;br /&gt;
Il se crée en allant au dossier et en faisant&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;virtualenv -p /usr/bin/python3.6 venv&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
pour créer un virtualenv Python 3.6 nommé &amp;lt;code&amp;gt;venv&amp;lt;/code&amp;gt;, ou&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;virtualenv -p /usr/bin/python2.7 venv&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
pour Python 2.7.&lt;br /&gt;
&lt;br /&gt;
=== Activer le virtualenv ===&lt;br /&gt;
&lt;br /&gt;
Maintenant, si vous affichez les fichiers dans votre répertoire avec &amp;lt;code&amp;gt;ls&amp;lt;/code&amp;gt;, celui-ci ressemble à&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;&lt;br /&gt;
user@domaine:/hosting/www/nom_binet/htdocs$ ls&lt;br /&gt;
dossier&lt;br /&gt;
fichier.truc&lt;br /&gt;
venv&lt;br /&gt;
&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Il faut désormais activer le virtualenv pour utiliser l'environnement Python, en faisant&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;&lt;br /&gt;
source venv/bin/activate # Linux&lt;br /&gt;
venv\Scripts\activate # Windows&lt;br /&gt;
&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Normalement, votre shell ressemble à&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;(venv) user@domaine:/hosting/www/nom_binet/htdocs$&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Pour quitter l'environnement virtuel, il suffit d'exécuter la commande&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;deactivate&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Installer les dépendances avec pip ===&lt;br /&gt;
&lt;br /&gt;
Pour se faire facilement, nous conseillons d'inclure avec les fichiers source un &amp;lt;code&amp;gt;requirements.txt&amp;lt;/code&amp;gt;, un fichier qui contient la liste des librairies Python dont dépend votre site, au mieux avec les numéros de version. Par exemple, il ressemblerait à&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;&lt;br /&gt;
flask==0.12.2&lt;br /&gt;
markdown&lt;br /&gt;
glob&lt;br /&gt;
requests==2.8.1&lt;br /&gt;
&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Installer les dépendances, une fois les fichiers en place, devient un simple&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;pip install -r requirements.txt&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Vous pouvez créer un &amp;lt;code&amp;gt;requirements.txt&amp;lt;/code&amp;gt; contenant ce qui est installé sur votre machine avec&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;pip freeze &amp;gt; requirements.txt&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
et ensuite l'ouvrir avec un éditeur de texte pour enlever ce dont vous n'avez pas besoin (par exemple Numpy, Scipy...).&lt;br /&gt;
&lt;br /&gt;
== Lancer son site ==&lt;br /&gt;
&lt;br /&gt;
Il faut maintenant dire au serveur de redémarrer. Les utilisateurs Sigma n'ont pas les permissions pour faire ça de la manière usuelle. On fournit donc la méthode suivante : entrez la commande&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;touch /var/run/please/restart&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
et attendez le signal&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;EOF&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Vous pouvez tester que ça marche en naviguant à &amp;lt;code&amp;gt;http://nom_site.binets.fr&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
== Erreurs ==&lt;br /&gt;
&lt;br /&gt;
=== Erreurs Python ===&lt;br /&gt;
&lt;br /&gt;
Il est bien sûr possible de tester si le serveur tourne dans l'interpréteur Python en faisant&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;python manage.py runserver&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
sous Django ou&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;python app.py&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
sous Flask (où &amp;lt;code&amp;gt;app.py&amp;lt;/code&amp;gt; est le nom de l'application Flask).&lt;br /&gt;
&lt;br /&gt;
=== Erreurs web ===&lt;br /&gt;
&lt;br /&gt;
Pour checker les changements il suffit de taper l'url du site pour constater en direct les changements. Si jamais il y a un souci il y a deux emplacements pour les logs :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/code&amp;gt;/var/log/uwsgi/nom_binet ou /hosting/log/nom_binet&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Troubleshooting ===&lt;br /&gt;
&lt;br /&gt;
Si toutes les pages affichent &amp;lt;code&amp;gt;Internal Server Error&amp;lt;/code&amp;gt; (pas en gras) : c'est une erreur de uWSGI qui n'arrive pas à :&lt;br /&gt;
* trouver votre site&lt;br /&gt;
* trouver le virtualenv&lt;br /&gt;
&lt;br /&gt;
une exception est levée au démarrage du serveur (&amp;lt;code&amp;gt;ImportError&amp;lt;/code&amp;gt; notamment).&lt;br /&gt;
&lt;br /&gt;
Vous pouvez lire les logs dans &amp;lt;code&amp;gt;/var/log/uwsgi//&amp;lt;ton site&amp;gt;.log&amp;lt;/code&amp;gt; et vérifier où uwsgi va chercher ton site dans &amp;lt;code&amp;gt;/etc/uwsgi.d/.json&amp;lt;/code&amp;gt;. S'il faut modifier ce dernier fichier, demande-le au BR, tu ne peux pas le faire toi-même.&lt;br /&gt;
&lt;br /&gt;
Pour Django :&lt;br /&gt;
* si toutes les pages affichent &amp;lt;code&amp;gt;Internal Server Error(500)&amp;lt;/code&amp;gt; en gras, il faut activer les mails pour avoir des détails, mais c'est probablement un oubli de faire les migrations sur une base de données SQL vide.&lt;/div&gt;</summary>
		<author><name>Chi.huynh</name></author>
	</entry>
</feed>