forked from tsuyukimakoto/oozappa
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup.py
344 lines (237 loc) · 10.1 KB
/
setup.py
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
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
#!/usr/bin/env python
# -*- coding:utf8 -*-
u'''
Oozappa
============================================================
Fabric task runner and helper. Execute tasks via web browser.
oozappa is 大雑把.
Change logs.
-------------------------------------------
0.8.5
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Adding new feature, modify Jobsets sort order on jobsets page.
Adding new feature, modify a Job data on environ page.
Improve Fabric task's behavior better when failed.
You need db migration if you use 0.8.4 or below.
Download zip archive from https://github.com/tsuyukimakoto/oozappa/raw/master/migration/to_0.8.5.zip
::
$ unzip to_0.8.5.zip && cd oozappa_to_0_8_5
If you have not alembic installed. You need install it using pip or any way you like.
Open alembic.ini and modify sqlalchemy.url to indicate your own oozappa's db. then
$ alembic upgrade 1e26220da128
0.8.4
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Jobset runs exclusively from webui.
0.8.3
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
A zappa command added and removed oozappa.create_environment module.
0.8.2
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Oozappa finds tasks from imported modules, not recursive.
Install
-------------------------------------------
Install from Cheese Shop (pypi).
::
$ pip install oozappa
If you use Xcode 5.1(above) and failed with **clang: error: unknown argument: '-mno-fused-madd'** , export flags before install.
::
$ export CPPFLAGS=-Qunused-arguments
$ export CFLAGS=-Qunused-arguments
Oozappa data models.
-------------------------------------------
Environment
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Environment is a category that has fibfile directory and vars.py .
A problem about fabric with large project is, too many fabric tasks and complicated task orders.
So you should separate fabfile into domain category. That is Environment.
Job
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Job is like a normal fabric execution command.
note::
fab task1 task2 is a job.
Jobset
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Jobset is oozappa operation unit.
Jobset can contain multiple job, even extend over environments.
Oozappa fabric structures.
-------------------------------------------
See sample oozappa project( https://github.com/tsuyukimakoto/oozappa/tree/master/sample/ops ).
::
.
├── common
│ ├── __init__.py
│ ├── files
│ ├── functions
│ │ ├── common_multiple_fabric_environment.py
│ ├── templates
│ │ └── sample_a.txt
│ └── vars.py
├── construction
│ ├── fabfile
│ │ ├── __init__.py
│ │ └── cloud.py
│ ├── templates
│ └── vars.py
├── deployment
│ ├── fabfile
│ │ ├── __init__.py
│ ├── templates
│ └── vars.py
├── production
│ ├── fabfile
│ │ ├── __init__.py
│ ├── templates
│ └── vars.py
└── staging
├── fabfile
│ ├── __init__.py
├── templates
│ └── sample_a.txt
└── vars.py
**common** is reserved directory. **construction** and others are environment directory. These names except common are just example.
vars
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
common and each environment's vars.py might have oozappa.config.OozappaSetting instance named settings.
OozappaSetting is dict like object.
**common.vars.setting** is updated by executed environment's **vars.setting** , so you can set base configuration to common.vars.setting and environment's one overwrite it.
Check printsetting task on staging environment.
You can run fabric task within environment directory as usual.
::
$ cd sample/ops/staging
$ fab printsetting
{'instance_type': 't1.micro', 'domain': 'localhost', 'sample_template_vars': {'sample_a': {'key_a_2': "a's 2 value from common.vars", 'key_a_1': "a's 1 value from stging.vars"}}, 'email': 'mtsuyuki at gmail.com'}
See common/vars.py and staging/vars.py .
templates
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Same as vars, **oozappa.fabrictools.upload_template** search template. upload_template is almost same as **fabric.contrib.files.upload_template** . oozappa's upload_template doesn't accept use_jinja, because oozappa's upload_template pass use_jinja=True to fabric.contrib.files.upload_template.
Jinja2 has inheritance template system and search template from multipul paths. fabric's upload_template accept only one template_dir string not list. **fabric doesn't assume multiplu environment** , so it's reasonable.
Because of this, oozappa's upload_template search template path is limited only one template_dir that found filename.
It mean that you can't store child template and parent template separately.
common/functions
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Call **oozappa.config.procure_common_functions** () and add commons/functions directory to sys.path for convinient to using on multiple fabric environment.
Run fabric task via web browser.
-----------------------------------------------------------
Change directory to outside environment directory.
::
$ cd ..
$ ls
common production staging
$ gunicorn -t 3600 -k flask_sockets.worker oozappa.webui:app
Running oozappa:app creates **/tmp/oozappa.sqlite** .
Open your web browser and browse http://localhost:8000/ .
Rapid execution
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Modify *Run fabric in raw*'s left hand side input to **staging** and click *run_tasks*. You can see what tasks exists.
Then input **ls ps** to right hand side input and click *run_tasks* .
That's it.
Better way using sample
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
register environment to db.
___________________________
* Click environment button via top menu.
* Add new Environment
* name: constructiton
* sort_order: 1
* execute_path: constructiton
* Add 3 more.
.. image:: https://dl.dropboxusercontent.com/u/382460/oozappa/readme/environments.png
:alt: environments
create job in each environments.
_________________________________
* Click environment you created
* Create new Job.
* Click task from Possible tasks in order
.. image:: https://dl.dropboxusercontent.com/u/382460/oozappa/readme/create_job.png
:alt: job
create jobset
___________________________
* Click jobset button via top menu.
* Click jobs you'd like to execute once.
.. image:: https://dl.dropboxusercontent.com/u/382460/oozappa/readme/create_jobset.png
:alt: jobset
run jobset
___________________________
* Click navigation button or jobset button via top menu.
* Click jobset you'd like to execute.
* Click *run jobset* button.
* Running log displays **Running log**.
* Reload page when jobset done. or Go to top(via navigation button)
* You see Execute Logs and show raw log when you click success (or fail).
.. image:: https://dl.dropboxusercontent.com/u/382460/oozappa/readme/jobset.png
:alt: running jobset
How to create your own
-------------------------------------------
Create common directory
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Change directory your own oozappa.
::
$ mkdir devops
$ cd devops
Then run zappa command.
::
$ zappa init
Create common environment here? [y/N] : y
Sqlite database stored path. [/tmp/oozappa/data.sqlite] :
Log files stored path. [/tmp/oozappa] :
Create directory or exit? "/tmp/oozappa" [y/N] : y
created common directory. db/log file path and flask secret key are in common/vars.py.
.. attention:: Default stored path is not for production use.
You should input your own file/directory path. Or data/results disapear when you reboot your machine or server.
How to change settings
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Open `common/vars.py` and change settings.
* **OOZAPPA_DB**
sqlite's data store path.
* **OOZAPPA_LOG_BASEDIR**
Jobset execute log store directory path.
Create environment
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Run `zappa` command with names option.
::
$ zappa create_environment --names construction deployment
2014-04-20 16:43:26,543 INFO create environment : construction
2014-04-20 16:43:26,544 INFO create environment : deployment
Then you can write fabfile normally and execute via oozappa.
'''
import setuptools
from distutils.core import setup
from oozappa import __version__
setup(name='oozappa',
version=__version__,
description='Fabric task runner and helper. Executes and manages tasks via web browser.',
author='makoto tsuyuki',
author_email='[email protected]',
url='https://github.com/tsuyukimakoto/oozappa',
zip_safe=False,
entry_points='''
[console_scripts]
zappa = oozappa.zappa:main
''',
long_description=__doc__,
classifiers=['Development Status :: 3 - Alpha',
'Environment :: Console',
'Environment :: Web Environment',
'Intended Audience :: Developers',
'Intended Audience :: System Administrators',
'License :: OSI Approved :: MIT License',
'Operating System :: MacOS :: MacOS X',
'Operating System :: POSIX',
'Operating System :: Unix',
'Programming Language :: Python',
'Programming Language :: Python :: 2.7',
'Topic :: Software Development',
'Topic :: Software Development :: Build Tools',
'Topic :: Software Development :: Libraries',
'Topic :: Software Development :: Libraries :: Python Modules',
'Topic :: System :: Clustering',
'Topic :: System :: Software Distribution',
'Topic :: System :: Systems Administration',
],
packages=['oozappa', 'oozappa.records',],
package_data={'oozappa': ['_structure/_environment/vars.py','_structure/_environment/*/*', '_structure/_environment/templates/*',
'_structure/common/vars.py','_structure/common/__init__.py','_structure/common/*/*', 'static/css/*', 'templates/*']},
include_package_data=True,
install_requires=['Fabric>=1.8.3','Flask-WTF>=0.9.5','Flask-SQLAlchemy>=1.0','Flask-Sockets>=0.1',
'Jinja2>=2.7.2', 'Pygments>=1.6', 'gevent-websocket>=0.9.3','gunicorn>=18.0','filelock>=0.2.0'],
)