forked from VOLTTRON/openeis
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathINSTALL
201 lines (124 loc) · 5.96 KB
/
INSTALL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
Requirements
============
Python version 3.3 (or greater) is required because in it was introduced the
venv package (for creating virtual environments), implicit namespace packaging,
and improved import machinery which are all used by OpenEIS.
Getting the Source Code
=======================
The best way to get the source code is with Git:
git clone https://github.com/VOLTTRON/openeis.git
Building
========
Execute the bootstrap.py script with the desired version of Python (>= 3.3).
On Windows:
C:\openeis> C:\Python33\python.exe bootstrap.py
On Linux, OS-X, and other Unix-like systems:
[openeis]$ python3.3 bootstrap.py
The bootstrap.py script performs three tasks:
1. Creates a Python virtual environment (using venv) in the env directory.
2. Installs pip and setuptools by downloading and executing the get-pip.py
script from the Pip repository.
3. Uses pip to install openeis and dependencies into the virtual
environment.
Updating
========
After the environment is bootstrapped it may be updated by rerunning bootstrap
with the python executable in the virtual environment.
On Windows:
(openeis)C:\openeis> env\Scripts\python.exe bootstrap.py
On Linux, OS-X, and other Unix-like systems:
[openeis]$ env/bin/python bootstrap.py
Working
=======
Two openeis items are added to the env/bin (env/Scripts on Windows) directory:
activate or activate.bat (on Windows)
Used to activate the virtual environment, this script adds the bin
directory to the PATH environment variable and sets the shell prompt to
indicate the virtual environment is active. Adding the bin directory to the
PATH allows one to execute commands in that directory without prefixing it
with a path.
On Windows, activate.bat should be run directly. On other systems, activate
should be sourced to include the changes in the current shell.
On Windows:
C:\openeis> env\Scripts\activate.bat
On other systems:
[openeis]$ . env/bin/activate
The effects of activation can be reversed by executing deactivate or
deactivate.bat (on Windows).
openeis or openeis.exe (on Windows)
This is the manage.py equivalent script used to interact with the OpenEIS
Django installation. Its settings file defaults to
openeis.server.settings.desktop.
Developing
==========
You can run the Django development server using the openeis executable
discussed above. Simple run `openeis runserver` and the web server will serve
pages on localhost port 8000. The development server will pick up most changes
to the project and automatically reload.
Check out the Django documentation for further help:
https://docs.djangoproject.com/en/1.6/
Synchronizing the Database
==========================
After initial installation, and whenever the project's models change, the
database must be synchronized using the syncdb command to add missing
tables.
On Windows:
C:\openeis> env\Scripts\openeis.exe syncdb
On other systems:
[openeis]$ env/bin/openeis syncdb
The first time syncdb is run, it will ask to create a superuser account. This
bootstraps the user table with an administrator user. You can add additional
superusers with the createsuperuser command.
Updating
=========
As updates are made available in VCS, it may be necessary to perform certain
tasks to update the local installation to use those changes. After pulling
changes from the Git repository, the bootstrap process should be re-executed if
setup.py or bootstrap.py were modified. Database synchronization should be
preformed if either settings.py or _settings.py in openeis/server changed or if
any models (model.py) were added or modified.
Cleaning
=========
The virtual environment can be rebuilt by first removing the env directory and
then rerunning bootstrap. A pristine copy of the source code can be had by
running `git clean -xdf` followed by `git reset`. But please be warned that
executing the first command will remove all untracked files from the working
copy and the second will revert any changes to tracked files.
Deployment Quickstart (on Ubuntu with Nginx, uWSGI, and PostgreSQL)
===================================================================
1. Install Nginx:
$ sudo apt-get install nginx
Note: Ubuntu's Nginx packages are generally out-of-date. You
should consider using the built packages at http://nginx.org.
3. Install PostgreSQL and create a database and user for OpenEIS:
$ sudo apt-get install postgresql
$ sudo pgadmin2 # Create database and user
3. Checkout OpenEIS:
$ git clone https://git.pnnl.gov/openeis
4. Bootstrap OpenEIS:
$ cd openeis
openeis$ python3.3 bootstrap.py
5. Install uWSGI and database packages into virtual environment:
openeis$ env/bin/pip install uwsgi
openeis$ env/bin/pip install psycopg2 # For PostgreSQL databases
5. Generate the openeis.local.settings module and customize it:
openeis$ env/bin/openeis localsettings
openeis$ ${EDITOR:-nano} openeis/local/settings.py
6. Generate nginx.conf and copy it to nginx configuration directory:
openeis$ env/bin/openeis nginxconfig openeis.conf
openeis$ cp openeis.conf /etc/nginx/conf.d/
7. Copy and edit uWSGI and Upstart configuration templates:
openeis$ cp openeis/server/templates/server/management/uwsgi.ini \
openeis/local/
openeis$ sudo cp openeis/server/templates/server/management/upstart.conf \
/etc/init/openeis.conf
8. Start openeis service and start/restart nginx:
$ sudo initctl start openeis
$ sudo service nginx restart
For more information, see the following resources:
https://docs.djangoproject.com/en/1.6/howto/deployment/wsgi/uwsgi/
https://docs.djangoproject.com/en/1.6/howto/deployment/checklist/
https://uwsgi.readthedocs.org/en/latest/tutorials/Django_and_nginx.html
https://uwsgi.readthedocs.org/en/latest/Upstart.html
http://nginx.org/en/docs/http/configuring_https_servers.html
http://upstart.ubuntu.com/cookbook/