Wiki

Version 155 (Paul Carensac, 03/21/2016 03:30 pm)

1 1 Etienne Pallier
h1. Technical Documentation for the PYROS project (FGFT-CC)
2 1 Etienne Pallier
3 1 Etienne Pallier
4 1 Etienne Pallier
HOWTO Format Redmine Wiki : http://www.redmine.org/projects/redmine/wiki/FrRedmineWikiFormatting
5 1 Etienne Pallier
6 1 Etienne Pallier
{{>toc}}
7 1 Etienne Pallier
8 1 Etienne Pallier
9 121 Etienne Pallier
---
10 1 Etienne Pallier
11 121 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}I - TODO%
12 121 Etienne Pallier
13 126 Etienne Pallier
 * installation sur windows
14 125 Etienne Pallier
15 126 Etienne Pallier
 * gitlab
16 1 Etienne Pallier
17 126 Etienne Pallier
 * séparation des BD Django et Pyros
18 125 Etienne Pallier
19 126 Etienne Pallier
 * intégration dans Eclipse
20 126 Etienne Pallier
21 126 Etienne Pallier
 * récupération des modules existants
22 125 Etienne Pallier
23 121 Etienne Pallier
24 3 Etienne Pallier
---
25 1 Etienne Pallier
26 140 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}I - DATABASE SCHEMA (v0.2.1)%
27 116 Etienne Pallier
28 116 Etienne Pallier
29 117 Etienne Pallier
{{thumbnail(PYROS_PDM_v021.png, size=300, title=Pyros data model)}}
30 121 Etienne Pallier
31 121 Etienne Pallier
32 121 Etienne Pallier
---
33 116 Etienne Pallier
34 141 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}II - Get the project (from gitlab)%
35 141 Etienne Pallier
36 141 Etienne Pallier
https://gitlab.irap.omp.eu/epallier/pyros
37 141 Etienne Pallier
38 141 Etienne Pallier
39 141 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}III - INSTALLATION%
40 2 Etienne Pallier
41 120 Etienne Pallier
42 120 Etienne Pallier
---
43 120 Etienne Pallier
44 51 Etienne Pallier
h3. If necessary, install MySql
45 2 Etienne Pallier
46 49 Etienne Pallier
 * Linux Ubuntu
47 49 Etienne Pallier
<pre>
48 107 Paul Carensac
49 107 Paul Carensac
$ sudo apt-get install mysql-server
50 107 Paul Carensac
$ sudo apt-get install mysql-client
51 107 Paul Carensac
52 49 Etienne Pallier
</pre>
53 49 Etienne Pallier
54 49 Etienne Pallier
 * Linux CentOS
55 49 Etienne Pallier
<pre>
56 49 Etienne Pallier
TODO:
57 49 Etienne Pallier
$ sudo yum install mysql
58 49 Etienne Pallier
...
59 49 Etienne Pallier
</pre>
60 49 Etienne Pallier
61 49 Etienne Pallier
 * Mac OS X
62 49 Etienne Pallier
<pre>
63 49 Etienne Pallier
TODO:
64 49 Etienne Pallier
Install XAMPP
65 49 Etienne Pallier
(but you could also use the pre-installed Mac OS MySql)
66 49 Etienne Pallier
</pre>
67 49 Etienne Pallier
68 49 Etienne Pallier
 * Windows
69 49 Etienne Pallier
<pre>
70 49 Etienne Pallier
TODO:
71 49 Etienne Pallier
</pre>
72 49 Etienne Pallier
73 49 Etienne Pallier
74 49 Etienne Pallier
---
75 1 Etienne Pallier
76 6 Etienne Pallier
h3. Create database
77 1 Etienne Pallier
78 52 Etienne Pallier
79 52 Etienne Pallier
 * Linux and Mac OS X:
80 52 Etienne Pallier
<pre>
81 3 Etienne Pallier
One liner:
82 115 Etienne Pallier
$ mysql -u root < pyros_create.sql
83 1 Etienne Pallier
84 3 Etienne Pallier
Or :
85 3 Etienne Pallier
$ mysql -u root
86 3 Etienne Pallier
mysql> create database pyros;
87 3 Etienne Pallier
mysql> use pyros;
88 115 Etienne Pallier
mysql> source pyros_create.sql;
89 1 Etienne Pallier
90 3 Etienne Pallier
(
91 3 Etienne Pallier
TODO:
92 3 Etienne Pallier
mysql> grant all on pyros.* to pyros@localhost identified by ‘pyros’;)
93 3 Etienne Pallier
mysql> flush privileges;
94 3 Etienne Pallier
)
95 52 Etienne Pallier
</pre>
96 1 Etienne Pallier
97 53 Etienne Pallier
98 53 Etienne Pallier
 * Windows:
99 52 Etienne Pallier
<pre>
100 52 Etienne Pallier
TODO: Use phpmyadmin ?
101 52 Etienne Pallier
</pre>
102 1 Etienne Pallier
103 1 Etienne Pallier
104 4 Etienne Pallier
---
105 5 Etienne Pallier
106 6 Etienne Pallier
h3. Install python3.5
107 1 Etienne Pallier
108 11 Etienne Pallier
109 11 Etienne Pallier
 * Mac OS X :
110 23 Etienne Pallier
<pre>
111 24 Etienne Pallier
1) Installer MacPort
112 24 Etienne Pallier
(TODO: doc)
113 24 Etienne Pallier
114 24 Etienne Pallier
2) Installer le "port" python35
115 1 Etienne Pallier
$ sudo port install python35
116 1 Etienne Pallier
</pre>
117 1 Etienne Pallier
118 1 Etienne Pallier
 * Linux (Ubuntu) :
119 1 Etienne Pallier
<pre>
120 107 Paul Carensac
sudo add-apt-repository ppa:fkrull/deadsnakes
121 107 Paul Carensac
sudo apt-get update
122 107 Paul Carensac
sudo apt-get install python3.5
123 107 Paul Carensac
124 107 Paul Carensac
sudo pip install virtualenv
125 23 Etienne Pallier
</pre>
126 1 Etienne Pallier
127 5 Etienne Pallier
128 3 Etienne Pallier
129 4 Etienne Pallier
---
130 5 Etienne Pallier
131 59 Etienne Pallier
h3. Get the project (from git)
132 59 Etienne Pallier
133 78 Etienne Pallier
<pre>
134 59 Etienne Pallier
TODO:
135 79 Etienne Pallier
136 130 Etienne Pallier
$ git http://pyros... PYROS
137 78 Etienne Pallier
</pre>
138 1 Etienne Pallier
139 130 Etienne Pallier
This creates a PYROS folder containing the project
140 59 Etienne Pallier
141 59 Etienne Pallier
142 59 Etienne Pallier
---
143 59 Etienne Pallier
144 131 Etienne Pallier
h3. Create project structure
145 131 Etienne Pallier
146 131 Etienne Pallier
<pre>
147 131 Etienne Pallier
$ mkdir PYROS
148 132 Etienne Pallier
</pre>
149 131 Etienne Pallier
150 131 Etienne Pallier
Example of a good organization :
151 131 Etienne Pallier
152 131 Etienne Pallier
1 project = N applis
153 131 Etienne Pallier
(but 1 appli can be part of many projects)
154 144 Etienne Pallier
1 appli = 1 Python module, organized for Django, by default = appli web (but not mandatory)
155 131 Etienne Pallier
(then 1 appli = N models)
156 131 Etienne Pallier
157 131 Etienne Pallier
<pre>
158 131 Etienne Pallier
159 131 Etienne Pallier
MYPROJECT/
160 131 Etienne Pallier
161 131 Etienne Pallier
162 131 Etienne Pallier
	src/
163 131 Etienne Pallier
		myproject/
164 131 Etienne Pallier
		appli1/
165 131 Etienne Pallier
		appli2/
166 131 Etienne Pallier
167 131 Etienne Pallier
		appliN/
168 131 Etienne Pallier
169 131 Etienne Pallier
	public/
170 131 Etienne Pallier
		static/
171 131 Etienne Pallier
172 131 Etienne Pallier
	private/
173 131 Etienne Pallier
		REQUIREMENTS.txt
174 148 Etienne Pallier
		venv_py35_pyros/
175 131 Etienne Pallier
176 131 Etienne Pallier
</pre>
177 131 Etienne Pallier
178 131 Etienne Pallier
179 131 Etienne Pallier
Set needed folders:
180 131 Etienne Pallier
<pre>
181 131 Etienne Pallier
$ cd PYROS/
182 131 Etienne Pallier
$ mkdir private public
183 131 Etienne Pallier
$ mkdir public/static
184 131 Etienne Pallier
</pre>
185 131 Etienne Pallier
186 131 Etienne Pallier
187 131 Etienne Pallier
188 131 Etienne Pallier
---
189 131 Etienne Pallier
190 3 Etienne Pallier
h3. Create virtualenv with python3.5 dedicated to pyros project (inside the project folder)
191 127 Etienne Pallier
192 131 Etienne Pallier
<pre>
193 1 Etienne Pallier
194 133 Etienne Pallier
$ cd private/
195 3 Etienne Pallier
196 3 Etienne Pallier
$ which python3.5
197 3 Etienne Pallier
/opt/local/bin/python3.5
198 15 Etienne Pallier
199 127 Etienne Pallier
$ virtualenv-3.5 venv_py35_pyros -p /opt/local/bin/python3.5
200 3 Etienne Pallier
=> creates a venv_py35_pyros/ folder inside PYROS/private/
201 1 Etienne Pallier
202 131 Etienne Pallier
</pre>
203 1 Etienne Pallier
204 7 Etienne Pallier
---
205 3 Etienne Pallier
206 65 Etienne Pallier
h3. Activate the python virtual environment (from inside the project)
207 7 Etienne Pallier
208 55 Etienne Pallier
<pre>
209 1 Etienne Pallier
210 65 Etienne Pallier
$ pwd
211 134 Etienne Pallier
.../PYROS/private
212 1 Etienne Pallier
213 65 Etienne Pallier
$ source ./venv_py35_pyros/bin/activate
214 65 Etienne Pallier
215 3 Etienne Pallier
$ python -V
216 1 Etienne Pallier
Python 3.5.1
217 3 Etienne Pallier
218 3 Etienne Pallier
$ which pip
219 77 Etienne Pallier
.../PYROS/venv_py35_pyros/bin/pip
220 16 Etienne Pallier
221 18 Etienne Pallier
Upgrade pip to last version available :
222 3 Etienne Pallier
$ pip install --upgrade pip
223 3 Etienne Pallier
Collecting pip
224 3 Etienne Pallier
  Downloading pip-8.1.1-py2.py3-none-any.whl (1.2MB)
225 3 Etienne Pallier
Installing collected packages: pip
226 3 Etienne Pallier
  Found existing installation: pip 7.1.2
227 3 Etienne Pallier
    Uninstalling pip-7.1.2:
228 3 Etienne Pallier
      Successfully uninstalled pip-7.1.2
229 1 Etienne Pallier
Successfully installed pip-8.1.1
230 55 Etienne Pallier
231 55 Etienne Pallier
</pre>
232 18 Etienne Pallier
233 27 Etienne Pallier
h3. Install needed python packages (from within the virtual environment)
234 18 Etienne Pallier
235 66 Etienne Pallier
First, be sure that the virtual environment is activated:
236 66 Etienne Pallier
<pre>
237 66 Etienne Pallier
$ python -V
238 66 Etienne Pallier
Python 3.5.1
239 66 Etienne Pallier
</pre>
240 66 Etienne Pallier
241 62 Etienne Pallier
 * *Automatic Installation of all packages*
242 62 Etienne Pallier
<pre>
243 90 Etienne Pallier
$ pip install -r REQUIREMENTS.txt
244 62 Etienne Pallier
</pre>
245 62 Etienne Pallier
246 93 Etienne Pallier
 * *Or, manual installation of each package*
247 62 Etienne Pallier
248 62 Etienne Pallier
  * *Install Django* :
249 32 Etienne Pallier
<pre>
250 3 Etienne Pallier
$ pip install django
251 3 Etienne Pallier
Collecting django
252 3 Etienne Pallier
  Downloading Django-1.9.4-py2.py3-none-any.whl (6.6MB)
253 3 Etienne Pallier
Installing collected packages: django
254 3 Etienne Pallier
Successfully installed django-1.9.4
255 3 Etienne Pallier
256 3 Etienne Pallier
$ pip install django-admin-tools
257 3 Etienne Pallier
Collecting django-admin-tools
258 3 Etienne Pallier
  Downloading django_admin_tools-0.7.2-py2.py3-none-any.whl (289kB)
259 3 Etienne Pallier
Installing collected packages: django-admin-tools
260 3 Etienne Pallier
Successfully installed django-admin-tools-0.7.2
261 3 Etienne Pallier
262 21 Etienne Pallier
$ pip install django-debug-toolbar
263 21 Etienne Pallier
Collecting django-debug-toolbar
264 21 Etienne Pallier
  Downloading django_debug_toolbar-1.4-py2.py3-none-any.whl (212kB)
265 21 Etienne Pallier
Requirement already satisfied (use --upgrade to upgrade): Django>=1.7 in ./venv_py35_pyros/lib/python3.5/site-packages (from django-debug-toolbar)
266 21 Etienne Pallier
Collecting sqlparse (from django-debug-toolbar)
267 21 Etienne Pallier
  Downloading sqlparse-0.1.19.tar.gz (58kB)
268 21 Etienne Pallier
Building wheels for collected packages: sqlparse
269 21 Etienne Pallier
  Running setup.py bdist_wheel for sqlparse ... done
270 21 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/7b/d4/72/6011bb100dd5fc213164e4bbee13d4e03261dd54ce6a5de6b8
271 21 Etienne Pallier
Successfully built sqlparse
272 21 Etienne Pallier
Installing collected packages: sqlparse, django-debug-toolbar
273 21 Etienne Pallier
Successfully installed django-debug-toolbar-1.4 sqlparse-0.1.19
274 21 Etienne Pallier
275 21 Etienne Pallier
$ pip install django-extensions
276 21 Etienne Pallier
Collecting django-extensions
277 21 Etienne Pallier
  Downloading django_extensions-1.6.1-py2.py3-none-any.whl (202kB)
278 21 Etienne Pallier
Collecting six>=1.2 (from django-extensions)
279 21 Etienne Pallier
  Downloading six-1.10.0-py2.py3-none-any.whl
280 21 Etienne Pallier
Installing collected packages: six, django-extensions
281 21 Etienne Pallier
Successfully installed django-extensions-1.6.1 six-1.10.0
282 21 Etienne Pallier
283 21 Etienne Pallier
$ pip install django-suit
284 21 Etienne Pallier
Collecting django-suit
285 21 Etienne Pallier
  Downloading django-suit-0.2.18.tar.gz (587kB)
286 21 Etienne Pallier
Building wheels for collected packages: django-suit
287 1 Etienne Pallier
  Running setup.py bdist_wheel for django-suit ... done
288 1 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/12/8b/9a/e02ab0ad9229881638aa040d47d77c8f562999533811927d41
289 1 Etienne Pallier
Successfully built django-suit
290 1 Etienne Pallier
Installing collected packages: django-suit
291 1 Etienne Pallier
Successfully installed django-suit-0.2.18
292 21 Etienne Pallier
293 32 Etienne Pallier
</pre>
294 32 Etienne Pallier
295 63 Etienne Pallier
  * *Install the web application server gunicorn (will be used in production instead of the dev django web server)* :
296 32 Etienne Pallier
<pre>
297 25 Etienne Pallier
$ pip install gunicorn
298 25 Etienne Pallier
Collecting gunicorn
299 25 Etienne Pallier
  Downloading gunicorn-19.4.5-py2.py3-none-any.whl (112kB)
300 21 Etienne Pallier
Installing collected packages: gunicorn
301 26 Etienne Pallier
Successfully installed gunicorn-19.4.5
302 1 Etienne Pallier
</pre>
303 1 Etienne Pallier
304 63 Etienne Pallier
  * *Install the python mysql client*:
305 32 Etienne Pallier
<pre>
306 32 Etienne Pallier
$ pip install mysqlclient
307 72 Etienne Pallier
...
308 72 Etienne Pallier
</pre>
309 33 Etienne Pallier
310 73 Etienne Pallier
   * => Issue under Mac OS X:
311 72 Etienne Pallier
<pre>
312 3 Etienne Pallier
$ pip install mysqlclient
313 3 Etienne Pallier
Collecting mysqlclient
314 1 Etienne Pallier
  Downloading mysqlclient-1.3.7.tar.gz (79kB)
315 22 Etienne Pallier
Building wheels for collected packages: mysqlclient
316 3 Etienne Pallier
  Running setup.py bdist_wheel for mysqlclient ... error
317 3 Etienne Pallier
318 1 Etienne Pallier
  ----------------------------------------
319 1 Etienne Pallier
  Failed building wheel for mysqlclient
320 1 Etienne Pallier
  Running setup.py clean for mysqlclient
321 1 Etienne Pallier
Failed to build mysqlclient
322 1 Etienne Pallier
Installing collected packages: mysqlclient
323 1 Etienne Pallier
  Running setup.py install for mysqlclient ... done
324 1 Etienne Pallier
Successfully installed mysqlclient-1.3.7
325 1 Etienne Pallier
326 1 Etienne Pallier
BOUH !!!
327 1 Etienne Pallier
328 1 Etienne Pallier
$ pip install --upgrade wheel
329 1 Etienne Pallier
Collecting wheel
330 1 Etienne Pallier
  Downloading wheel-0.29.0-py2.py3-none-any.whl (66kB)
331 1 Etienne Pallier
Installing collected packages: wheel
332 1 Etienne Pallier
  Found existing installation: wheel 0.24.0
333 1 Etienne Pallier
    Uninstalling wheel-0.24.0:
334 1 Etienne Pallier
      Successfully uninstalled wheel-0.24.0
335 1 Etienne Pallier
Successfully installed wheel-0.29.0
336 1 Etienne Pallier
337 1 Etienne Pallier
$ pip uninstall mysqlclient
338 1 Etienne Pallier
339 1 Etienne Pallier
$ pip install mysqlclient
340 1 Etienne Pallier
Collecting mysqlclient
341 1 Etienne Pallier
  Using cached mysqlclient-1.3.7.tar.gz
342 1 Etienne Pallier
Building wheels for collected packages: mysqlclient
343 1 Etienne Pallier
  Running setup.py bdist_wheel for mysqlclient ... done
344 1 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/9b/06/50/d11418c26cf8f2156b13d4363b5afde8e7e75ebb8540d0228d
345 1 Etienne Pallier
Successfully built mysqlclient
346 1 Etienne Pallier
Installing collected packages: mysqlclient
347 1 Etienne Pallier
Successfully installed mysqlclient-1.3.7
348 1 Etienne Pallier
349 1 Etienne Pallier
YES !!!
350 1 Etienne Pallier
351 1 Etienne Pallier
</pre>
352 1 Etienne Pallier
353 107 Paul Carensac
   * => Issues under Ubuntu:
354 107 Paul Carensac
<pre>
355 107 Paul Carensac
$ pip install mysqlclient
356 107 Paul Carensac
Collecting mysqlclient
357 107 Paul Carensac
  Downloading mysqlclient-1.3.7.tar.gz (79kB)
358 107 Paul Carensac
    100% |████████████████████████████████| 81kB 1.5MB/s
359 107 Paul Carensac
    Complete output from command python setup.py egg_info:
360 107 Paul Carensac
    /bin/sh: 1: mysql_config: not found
361 107 Paul Carensac
    Traceback (most recent call last):
362 107 Paul Carensac
      File "<string>", line 1, in <module>
363 107 Paul Carensac
    [...]
364 107 Paul Carensac
    ----------------------------------------
365 107 Paul Carensac
Command "python setup.py egg_info" failed with error code 1 in /tmp/pip-build-q6j4inuz/mysqlclient/
366 1 Etienne Pallier
367 108 Paul Carensac
BOUH !!!
368 108 Paul Carensac
369 107 Paul Carensac
$ sudo apt-get install libmysqlclient-dev
370 108 Paul Carensac
371 107 Paul Carensac
$ pip install mysqlclient
372 107 Paul Carensac
Collecting mysqlclient
373 107 Paul Carensac
  Using cached mysqlclient-1.3.7.tar.gz
374 107 Paul Carensac
Building wheels for collected packages: mysqlclient
375 107 Paul Carensac
  Running setup.py bdist_wheel for mysqlclient ... error
376 107 Paul Carensac
377 107 Paul Carensac
    _mysql.c:40:20: fatal error: Python.h: No such file or directory
378 107 Paul Carensac
     #include "Python.h"
379 107 Paul Carensac
                        ^
380 107 Paul Carensac
    compilation terminated.
381 107 Paul Carensac
    error: command 'x86_64-linux-gnu-gcc' failed with exit status 1
382 107 Paul Carensac
    
383 107 Paul Carensac
    ----------------------------------------
384 107 Paul Carensac
Command "/home/carens_p/pyros/venv_py35_pyros/bin/python3.5 -u -c "import setuptools, tokenize;__file__='/tmp/pip-build-k3klv92j/mysqlclient/setup.py';exec(compile(getattr(tokenize, 'open', open)(__file__).read().replace('\r\n', '\n'), __file__, 'exec'))" install --record /tmp/pip-gz242xxs-record/install-record.txt --single-version-externally-managed --compile --install-headers /home/carens_p/pyros/venv_py35_pyros/include/site/python3.5/mysqlclient" failed with error code 1 in /tmp/pip-build-k3klv92j/mysqlclient/
385 107 Paul Carensac
386 108 Paul Carensac
BOUH !!!
387 108 Paul Carensac
388 107 Paul Carensac
$ sudo apt-get install python3.5-dev
389 108 Paul Carensac
390 107 Paul Carensac
$ pip install mysqlclient
391 107 Paul Carensac
392 107 Paul Carensac
YES !!!
393 107 Paul Carensac
394 107 Paul Carensac
</pre>
395 12 Etienne Pallier
396 82 Etienne Pallier
 * *Set Requirements*
397 82 Etienne Pallier
398 82 Etienne Pallier
<pre>
399 82 Etienne Pallier
$ pip freeze > REQUIREMENTS.txt
400 136 Etienne Pallier
401 136 Etienne Pallier
$ mv REQUIREMENTS.txt .../PYROS/private/
402 136 Etienne Pallier
403 82 Etienne Pallier
</pre>
404 12 Etienne Pallier
405 12 Etienne Pallier
---
406 28 Etienne Pallier
407 7 Etienne Pallier
h3. Create Django project pyros
408 38 Etienne Pallier
409 38 Etienne Pallier
<pre>
410 1 Etienne Pallier
411 83 Etienne Pallier
From inside the project:
412 83 Etienne Pallier
$ pwd
413 83 Etienne Pallier
.../PYROS/
414 83 Etienne Pallier
415 1 Etienne Pallier
$ django-admin startproject pyros
416 1 Etienne Pallier
417 149 Etienne Pallier
Rename the project folder "pyros/" as "src/"
418 149 Etienne Pallier
419 84 Etienne Pallier
$ mv pyros src
420 84 Etienne Pallier
421 86 Etienne Pallier
We have then this architecture:
422 86 Etienne Pallier
423 1 Etienne Pallier
PYROS
424 83 Etienne Pallier
├── private
425 86 Etienne Pallier
│   └── REQUIREMENTS.txt
426 137 Etienne Pallier
│   └── venv_py35_pyros
427 83 Etienne Pallier
├── public
428 83 Etienne Pallier
│   └── static
429 83 Etienne Pallier
├── src
430 83 Etienne Pallier
│   ├── manage.py
431 1 Etienne Pallier
│   ├── pyros
432 84 Etienne Pallier
│   │   ├── __init__.py
433 84 Etienne Pallier
│   │   ├── settings.py
434 84 Etienne Pallier
│   │   ├── urls.py
435 1 Etienne Pallier
│   │   └── wsgi.py
436 137 Etienne Pallier
437 142 Etienne Pallier
</pre>
438 3 Etienne Pallier
439 3 Etienne Pallier
440 1 Etienne Pallier
441 142 Etienne Pallier
442 142 Etienne Pallier
---
443 142 Etienne Pallier
444 142 Etienne Pallier
h3. Test the project
445 142 Etienne Pallier
446 142 Etienne Pallier
<pre>
447 142 Etienne Pallier
448 150 Etienne Pallier
$ cd src/
449 150 Etienne Pallier
450 1 Etienne Pallier
$ ./manage.py runserver
451 38 Etienne Pallier
(or gunicorn pyros.wsgi)
452 3 Etienne Pallier
==> http://localhost:8000
453 87 Etienne Pallier
...
454 87 Etienne Pallier
...
455 87 Etienne Pallier
Ctrl-c
456 87 Etienne Pallier
457 1 Etienne Pallier
</pre>
458 142 Etienne Pallier
459 142 Etienne Pallier
460 142 Etienne Pallier
461 142 Etienne Pallier
---
462 142 Etienne Pallier
463 142 Etienne Pallier
h3. The Web server
464 142 Etienne Pallier
465 142 Etienne Pallier
466 142 Etienne Pallier
Apache : gère tous les fichiers statiques (images, html…), et délègue les fichiers python au serveur django (par défaut)
467 142 Etienne Pallier
468 143 Etienne Pallier
Le fichier pyros/urls.py prend le relai pour tout ce qui est django
469 143 Etienne Pallier
470 142 Etienne Pallier
Le moteur web django sera soit du wsgi soit du unicorn
471 142 Etienne Pallier
472 142 Etienne Pallier
Par défaut, 1 seul worker, mais on peut en configurer plusieurs, l’idéal étant de faire "nb coeurs + 1" 
473 142 Etienne Pallier
(le worker maître qui fait le dispatching aux autres)
474 142 Etienne Pallier
475 142 Etienne Pallier
Frontend : Apache ou Ngininx
476 142 Etienne Pallier
477 142 Etienne Pallier
Backend : gunicorn (gère facilement des workers) ou uwsgi
478 142 Etienne Pallier
479 152 Etienne Pallier
<pre>
480 152 Etienne Pallier
$ gunicorn pyros.wsgi
481 1 Etienne Pallier
(à la place de manage runserver => A EVITER EN PROD)
482 152 Etienne Pallier
483 1 Etienne Pallier
Ou encore:
484 1 Etienne Pallier
485 152 Etienne Pallier
$ gunicorn --workers 5 library.wsgi
486 152 Etienne Pallier
</pre>
487 3 Etienne Pallier
488 42 Etienne Pallier
---
489 7 Etienne Pallier
490 3 Etienne Pallier
h3. Set Database engine as MySql
491 3 Etienne Pallier
492 41 Etienne Pallier
Edit src/pyros/settings.py
493 3 Etienne Pallier
494 3 Etienne Pallier
<pre>
495 3 Etienne Pallier
DATABASES = {
496 1 Etienne Pallier
    'default': {
497 3 Etienne Pallier
        'ENGINE': 'django.db.backends.mysql',
498 1 Etienne Pallier
        'NAME': 'pyros',
499 1 Etienne Pallier
        'USER': 'root',
500 1 Etienne Pallier
        'PASSWORD': ''
501 41 Etienne Pallier
    }
502 3 Etienne Pallier
}
503 7 Etienne Pallier
</pre>
504 3 Etienne Pallier
505 43 Etienne Pallier
---
506 7 Etienne Pallier
507 43 Etienne Pallier
h3. Import database into Django (with inspectdb)
508 3 Etienne Pallier
509 101 Etienne Pallier
From src/ :
510 94 Etienne Pallier
511 3 Etienne Pallier
<pre>
512 44 Etienne Pallier
$ ./manage.py inspectdb > models.py
513 94 Etienne Pallier
</pre>
514 44 Etienne Pallier
515 97 Etienne Pallier
Issue on Mac OS X:
516 3 Etienne Pallier
<pre>
517 3 Etienne Pallier
Traceback (most recent call last):
518 3 Etienne Pallier
  File "/Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/django/db/backends/mysql/base.py", line 25, in <module>
519 3 Etienne Pallier
    import MySQLdb as Database
520 3 Etienne Pallier
  File "/Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/MySQLdb/__init__.py", line 19, in <module>
521 3 Etienne Pallier
    import _mysql
522 3 Etienne Pallier
ImportError: dlopen(/Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so, 2): Library not loaded: libmysqlclient.18.dylib
523 3 Etienne Pallier
  Referenced from: /Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so
524 3 Etienne Pallier
  Reason: image not found
525 3 Etienne Pallier
526 3 Etienne Pallier
=> BOUH !!!
527 3 Etienne Pallier
528 3 Etienne Pallier
LA SOLUTION EST ICI : http://stackoverflow.com/questions/6383310/python-mysqldb-library-not-loaded-libmysqlclient-18-dylib
529 3 Etienne Pallier
530 124 Etienne Pallier
Il suffit de faire ceci:
531 3 Etienne Pallier
532 124 Etienne Pallier
$ sudo mkdir -p /usr/local/lib   
533 124 Etienne Pallier
$ sudo ln -s /Applications/XAMPP/xamppfiles/lib/libmysql* /usr/local/lib/
534 124 Etienne Pallier
535 124 Etienne Pallier
Mais on peut aussi faire ceci:
536 3 Etienne Pallier
537 123 Etienne Pallier
Okay, so the offending file is /Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so
538 123 Etienne Pallier
539 123 Etienne Pallier
Next, figure out where _mysql.so thinks it should find libmysqlclient.18.dylib:
540 123 Etienne Pallier
541 1 Etienne Pallier
$ otool -L /Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so
542 10 Etienne Pallier
/Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so:
543 3 Etienne Pallier
	libmysqlclient.18.dylib (compatibility version 18.0.0, current version 18.0.0)
544 3 Etienne Pallier
...
545 3 Etienne Pallier
546 123 Etienne Pallier
So, it's looking for libmysqlclient.18.dylib with no path information, let's fix that:
547 123 Etienne Pallier
548 1 Etienne Pallier
$ locate libmysqlclient.18.dylib
549 1 Etienne Pallier
/Applications/XAMPP/xamppfiles/lib/libmysqlclient.18.dylib
550 1 Etienne Pallier
/Library/SystemMigration/History/Migration-68137DFB-CB6A-4FBB-81E2-11BDB5D01E48/QuarantineRoot/usr/lib/libmysqlclient.18.dylib
551 1 Etienne Pallier
552 10 Etienne Pallier
$ sudo install_name_tool -change libmysqlclient.18.dylib /Applications/XAMPP/xamppfiles/lib/libmysqlclient.18.dylib /Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so
553 123 Etienne Pallier
554 123 Etienne Pallier
Now _mysql.so knows the full path to the library and everything works, regardless of environment variables.
555 10 Etienne Pallier
556 10 Etienne Pallier
$ otool -L /Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so
557 10 Etienne Pallier
/Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so:
558 3 Etienne Pallier
	/Applications/XAMPP/xamppfiles/lib/libmysqlclient.18.dylib (compatibility version 18.0.0, current version 18.0.0)
559 1 Etienne Pallier
...
560 1 Etienne Pallier
561 3 Etienne Pallier
$ ./manage.py inspectdb > models.py
562 44 Etienne Pallier
563 3 Etienne Pallier
=> YES !!!
564 3 Etienne Pallier
</pre>
565 7 Etienne Pallier
566 3 Etienne Pallier
567 48 Etienne Pallier
---
568 7 Etienne Pallier
569 3 Etienne Pallier
h3. Create a Django application pyrosapp
570 3 Etienne Pallier
571 102 Etienne Pallier
From src/ :
572 98 Etienne Pallier
573 102 Etienne Pallier
<pre>
574 1 Etienne Pallier
$ ./manage.py startapp pyrosapp
575 1 Etienne Pallier
</pre>
576 1 Etienne Pallier
577 103 Etienne Pallier
We obtain this structure:
578 103 Etienne Pallier
579 104 Etienne Pallier
<pre>
580 103 Etienne Pallier
581 103 Etienne Pallier
PYROS/
582 153 Etienne Pallier
├── private/
583 1 Etienne Pallier
│   └── REQUIREMENTS.txt
584 153 Etienne Pallier
│   └── venv_py35_pyros/
585 153 Etienne Pallier
├── public/
586 153 Etienne Pallier
│   └── static/
587 153 Etienne Pallier
├── src/
588 103 Etienne Pallier
│   ├── db.sqlite3
589 103 Etienne Pallier
│   ├── manage.py
590 153 Etienne Pallier
│   ├── pyros/
591 103 Etienne Pallier
│   │   ├── __init__.py
592 103 Etienne Pallier
│   │   ├── __pycache__
593 103 Etienne Pallier
│   │   ├── settings.py
594 103 Etienne Pallier
│   │   ├── urls.py
595 103 Etienne Pallier
│   │   └── wsgi.py
596 153 Etienne Pallier
│   └── pyrosapp/
597 1 Etienne Pallier
│       ├── __init__.py
598 103 Etienne Pallier
│       ├── admin.py
599 103 Etienne Pallier
│       ├── apps.py
600 103 Etienne Pallier
│       ├── migrations
601 103 Etienne Pallier
│       ├── models.py
602 103 Etienne Pallier
│       ├── tests.py
603 103 Etienne Pallier
│       └── views.py
604 153 Etienne Pallier
605 103 Etienne Pallier
606 7 Etienne Pallier
</pre>
607 1 Etienne Pallier
608 7 Etienne Pallier
---
609 7 Etienne Pallier
610 3 Etienne Pallier
h3. Replace the default pyrosapp models.py with the inspectdb generated one
611 3 Etienne Pallier
612 105 Etienne Pallier
From src/ :
613 1 Etienne Pallier
614 105 Etienne Pallier
<pre>
615 105 Etienne Pallier
$ mv models.py pyrosapp/
616 105 Etienne Pallier
</pre>
617 3 Etienne Pallier
618 139 Paul Carensac
Add pyrosapp to the project's applications :
619 7 Etienne Pallier
620 139 Paul Carensac
Edit src/pyros/settings.py
621 1 Etienne Pallier
622 139 Paul Carensac
<pre>
623 139 Paul Carensac
INSTALLED_APPS = [
624 139 Paul Carensac
    'django.contrib.admin',
625 139 Paul Carensac
    'django.contrib.auth',
626 139 Paul Carensac
    'django.contrib.contenttypes',
627 139 Paul Carensac
    'django.contrib.sessions',
628 139 Paul Carensac
    'django.contrib.messages',
629 139 Paul Carensac
    'django.contrib.staticfiles',
630 139 Paul Carensac
    'pyrosapp',
631 139 Paul Carensac
]
632 139 Paul Carensac
</pre>
633 9 Etienne Pallier
634 47 Etienne Pallier
---
635 3 Etienne Pallier
636 145 Paul Carensac
h3. Fix and improve the pyrosapp models.py file (generated by inspectdb)
637 1 Etienne Pallier
638 145 Paul Carensac
Once models.py file generated, we need to delete the database and create an empty one :
639 145 Paul Carensac
 
640 145 Paul Carensac
<pre>
641 145 Paul Carensac
$ mysql -u root [-p (if password needed)]
642 106 Etienne Pallier
643 145 Paul Carensac
mysql> DROP DATABSE pyros
644 145 Paul Carensac
mysql> CREATE SCHEMA IF NOT EXISTS 'pyros' DEFAULT CHARACTER SET utf8;
645 1 Etienne Pallier
646 145 Paul Carensac
</pre>
647 1 Etienne Pallier
648 145 Paul Carensac
Then edit pyrosapp/models.py :
649 1 Etienne Pallier
650 145 Paul Carensac
 * Change 'managed = False' to 'managed = True' for every model
651 145 Paul Carensac
652 145 Paul Carensac
 * Change classes names to CamelCase (do not change the 'db_table = ...' lines). *Be careful* : it is needed to change all occurences :
653 145 Paul Carensac
654 145 Paul Carensac
    * NrtAlanysis
655 145 Paul Carensac
    * ScheduleHistory
656 145 Paul Carensac
    * ScientificProgram
657 145 Paul Carensac
    * SequenceType
658 145 Paul Carensac
    * SiteWatch
659 145 Paul Carensac
    * SiteWatchHistory
660 145 Paul Carensac
    * StrategyObs
661 154 Paul Carensac
    * UserLevel
662 145 Paul Carensac
    * WeatherWatch
663 145 Paul Carensac
    * WeatherWatchHistory
664 145 Paul Carensac
665 145 Paul Carensac
 * Change the deleting mode from 'models.DO_NOTHING' to 'models.CASCADE' for the following foreign keys :
666 145 Paul Carensac
667 145 Paul Carensac
    * Image.plan
668 145 Paul Carensac
    * Plan.album
669 145 Paul Carensac
    * Album.sequence
670 145 Paul Carensac
    * Sequence.request
671 145 Paul Carensac
672 145 Paul Carensac
 * Change the 'ForeignKey' liaisons to 'OneToOneField' liaisons (just replace ForeignKey by OneToOneField), and change deleting mode to 'models.CASCADE' for the following foreign keys :
673 145 Paul Carensac
674 145 Paul Carensac
    * Alert.request
675 145 Paul Carensac
    * Detector.device
676 145 Paul Carensac
    * Filter.device
677 145 Paul Carensac
    * Telescope.device
678 145 Paul Carensac
679 145 Paul Carensac
 * We need to redefine many to many relationships for the following classes :
680 145 Paul Carensac
681 145 Paul Carensac
    * User - ScientificProgram :
682 145 Paul Carensac
683 145 Paul Carensac
        * add 'users = models.ManyToManyField('User')' in ScientificProgram class
684 145 Paul Carensac
        * delete UserHasScientificProgram class
685 145 Paul Carensac
686 145 Paul Carensac
    * Sequence - ScheduleHistory
687 145 Paul Carensac
688 145 Paul Carensac
        * add 'sequences = models.ManyToManyField('Sequence')' in ScheduleHistory class
689 145 Paul Carensac
        * delete ScheduleHasSequences class
690 145 Paul Carensac
691 145 Paul Carensac
 * Finally apply modifications to the database :
692 145 Paul Carensac
693 145 Paul Carensac
<pre>
694 145 Paul Carensac
$ pwd
695 145 Paul Carensac
.../PYROS/src
696 145 Paul Carensac
$ python manage.py makemigrations pyrosapp
697 145 Paul Carensac
$ python manage.py migrate
698 145 Paul Carensac
</pre>
699 109 Etienne Pallier
700 109 Etienne Pallier
---
701 111 Etienne Pallier
702 1 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}II - CONFIGURATION of the Django Back Office (administration interface)%
703 155 Paul Carensac
704 155 Paul Carensac
---
705 155 Paul Carensac
706 155 Paul Carensac
h3. Back Office setup
707 155 Paul Carensac
708 155 Paul Carensac
 * Prerequisites in src/pyros/settings.py :
709 155 Paul Carensac
710 155 Paul Carensac
    * INSTALLED_APPS must (at least) contain :
711 155 Paul Carensac
712 155 Paul Carensac
        * django.contrib.admin
713 155 Paul Carensac
        * django.contrib.auth
714 155 Paul Carensac
        * django.contrib.contenttypes
715 155 Paul Carensac
        * django.contrib.sessions
716 155 Paul Carensac
717 155 Paul Carensac
    * MIDDLEWARES must (at least) contain :
718 155 Paul Carensac
719 155 Paul Carensac
        * django.contrib.sessions.middleware.SessionMiddleware
720 155 Paul Carensac
        * django.middleware.common.CommonMiddleware
721 155 Paul Carensac
        * django.contrib.auth.middleware.AuthenticationMiddleware
722 155 Paul Carensac
723 155 Paul Carensac
 * At least one 'python manage.py migrate' must have been executed
724 155 Paul Carensac
725 155 Paul Carensac
 * Create a superuser for the administration :
726 155 Paul Carensac
727 155 Paul Carensac
<pre>
728 155 Paul Carensac
$ python manage.py createsuperuser
729 155 Paul Carensac
</pre>
730 155 Paul Carensac
731 155 Paul Carensac
 * For each app of the project, fill the admin.py file :
732 155 Paul Carensac
733 155 Paul Carensac
<pre>
734 155 Paul Carensac
Content of src/pyrosapp/admin.py
735 155 Paul Carensac
736 155 Paul Carensac
from django.contrib import admin
737 155 Paul Carensac
from app.models import Model1, Model2
738 155 Paul Carensac
739 155 Paul Carensac
admin.site.register(Model1)
740 155 Paul Carensac
admin.site.register(Model2)
741 155 Paul Carensac
</pre>
742 155 Paul Carensac
743 155 Paul Carensac
*Reminder* : each application must be registered in the settings.py INSTALLED_APPS variable.