Skip to main content

Spinning property workflows. Taking requests.

Project description

Propjockey helps you queue up workflows and dynamically change their priorities for running;
it's like having a [slipmat](https://en.wikipedia.org/wiki/Slipmat) for scientific computing.

Propjockey is a tool for staff managing scientific computing
resources to facilitate a user community voting to prioritize
calculation of properties across a database of known entities. For
example, across a database of entities corresponding to known
crystalline materials, the full elastic tensor may not already be
calculated for each material because such a calculation is
computationally expensive, not of interest for all materials, etc.

The staff managing the growth and dissemination of this database of
material structures and properties wishes to empower the community of
users consuming the data to help prioritize computational jobs in a
way that will dovetail with in-house priorities. Propjockey helps with
this, connecting users to details of running workflows and providing
email notification when property calculations complete.

* Former name: Interactive Leaderboard for Property Requests and Notification (ILPRN).

Example deployment: http://elastic.pj.materialsproject.org/.

[Science Gateways 2016](http://sciencegateways.org/gateways2016/) conference: [extended abstract](docs/gateways2016-extended-abstract.pdf) and [talk slides](docs/gateways2016-talk-slides.pdf).

## Development

In a fresh virtualenv:

```
pip install -e .
export FLASK_APP=propjockey
export FLASK_DEBUG=1
export PROPJOCKEY_SETTINGS=$(pwd)/local_settings.py
flask run
```

There is a provided `local_settings.example.py` to serve as a template
for your `local_settings.py`, which if stored at the root level will
be `.gitignore`d.

Ensure local settings are appropriate for your use case. Function
definitions are part of the settings. Hopefully, many of the various
settings, including some of the functions, will not need to change for
you to get started.

## Testing

You can make a test database derived from your real, live data. The
database will be located at mongodb://localhost:27017/propjockey_test and
have entries, votes, and workflows collections. All user emails in
your real data will be aliased to protect user identities. To drop any
existing test database and generate a new one using your data:

```
flask make_test_db
```

Then, to test the code against the test database:

```
python setup.py test
```

The `USE_TEST_CLIENTS` local setting enables you to use your test
database during development and not just when running automated
tests. This is nice when lacking a reliable/fast network connection.

To save your test database to a file for backup/sharing:

```
mongodump --db=propjockey_test --gzip --archive=propjockey_test.gz
```

and to restore it during development / on a testing server:

```
mongorestore --drop db=propjockey_test --gzip --archive=propjockey_test.gz
```

## Deployment

There are many officially documented
[options](http://flask.pocoo.org/docs/0.11/deploying/) for deploying a
Flask app such as this, for example [gunicorn](http://gunicorn.org/)
behind an [nginx](https://nginx.org/en/) proxy, e.g.

```
# activate the virtualenv
gunicorn -w 4 -b 0.0.0.0:4000 propjockey:app
# and ensure your nginx configuration `proxy_pass`es to 0.0.0.0:4000
```

An example proxy setup is described at the official Flask
documentation
[here](http://flask.pocoo.org/docs/0.11/deploying/wsgi-standalone/#proxy-setups).

## Running Email Notification as a Cron Job

```
# activate the virtualenv
# cd to directory with local_settings.py
# Ensure `USE_TEST_CLIENTS` local setting is False
export PROPJOCKEY_SETTINGS=$(pwd)/local_settings.py
python -m propjockey.notify
```

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

propjockey-0.1.0.tar.gz (17.3 kB view details)

Uploaded Source

Built Distributions

propjockey-0.1.0-py2.7.egg (35.2 kB view details)

Uploaded Source

propjockey-0.1.0-py2-none-any.whl (21.3 kB view details)

Uploaded Python 2

File details

Details for the file propjockey-0.1.0.tar.gz.

File metadata

  • Download URL: propjockey-0.1.0.tar.gz
  • Upload date:
  • Size: 17.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for propjockey-0.1.0.tar.gz
Algorithm Hash digest
SHA256 ce78858cab4e62560745e59a452edfd8be1271a993dd3ac7bae89a0124f02b42
MD5 60c6658231343fac800c2a2017959435
BLAKE2b-256 01566edd6531c4cd5800d1bb3603ca24733ca48373a5665b5a2f10c60e9978ef

See more details on using hashes here.

File details

Details for the file propjockey-0.1.0-py2.7.egg.

File metadata

File hashes

Hashes for propjockey-0.1.0-py2.7.egg
Algorithm Hash digest
SHA256 89b85a61beb9e84d2c4ff3be0ca2e906a7511e473958eb9421602ea7915b0571
MD5 d36e39a2e6c02853b3f73d09e9d4a8bc
BLAKE2b-256 cc7c4329a99dd6e4dee32aa1629e7e4ec066090695a31256800261bd7d64a023

See more details on using hashes here.

File details

Details for the file propjockey-0.1.0-py2-none-any.whl.

File metadata

File hashes

Hashes for propjockey-0.1.0-py2-none-any.whl
Algorithm Hash digest
SHA256 353d1857d34699fc9feb40684fcd132cbc4fe557533243e5bec6017ffff42485
MD5 eb50cb31217535188cacf1e8ff8a7d8b
BLAKE2b-256 771ea8adff0d6cafa2c3fc6f4ca23e82d10d4a7d9c08f96c7952a1b0fc89b554

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page