scheduler for python scripts
Project description
Skidward
Scheduler For Python Scripts
Prerequisites
The project was built with Python 3.6.7 and requires a working Postgres and Redis setup.
Please refer to your operating system's specific installation instructions per package.
- Python 3.6.7
- Postgres (tested on 11 and up)
- Redis (tested on 5 and up)
Installation
-
Install the requirements
$ pip install -r requirements.txt
-
Create user (called a 'role') in postgres and give it ownership over the new db Note: It is recommended to create a user with a password, even for development purposes.
$ createuser skidwarduser $ createdb skidwarddb -O skidwarduser
The application uses environment variables to offer flexible configuration options.
Before using the application, review the configuration in the .env
file to match your desired setup.
A typical connectionstring looks like this:
SQLALCHEMY_DATABASE_URI='postgresql://USER:PASSWORD@localhost/DATABASENAME'
-
Copy the
.env.default
file to the skidward module and rename to.env
.$ cp .env.default skidward/.env
-
Migrate the database
$ python -m skidward migrate
-
Publish available workers on the namespace in the database
$ python -m skidward publish-workers
-
Create an admin user for use in the application
$ python -m skidward create-admin USER_EMAIL
Development
-
Install the development requirements
$ pip install -r requirements-dev.txt
-
Set up the git pre-commit hook required for development
$ pre-commit install
Optional: If you want to install demo-workers from a proxy,
navigate to the root of your virtual environment and create a pip.conf
file.
$ touch pip.conf
$ echo "[global]" >> pip.conf
$ echo "extra-index-url = URL_TO_PROXY" >> pip.conf
Contributing to the documentation
All documentation is built with Sphix and can be found in the docs
folder,
with pages in docs/src
and images located in docs/src/images
.
-
Build the docs
$ cd docs $ make html
-
Open the result in a web browser (here Firefox is used)
$ firefox _build/html/index.html
Running the application
There's an admin interface provided to communicate with the application,
and then there's the backend side doing the operations.
1. Web interface
-
Point Flask to the location of the web application
$ export FLASK_APP=skidward.web
-
Run the default setup (in the same session as the previous command)
$ flask run
2. Scheduler side
-
Start a new scheduler process (in the fore- or background)
$ python -m skidward start-scheduler # Runs in your session $ python -m skidward start-scheduler true # Creates a new process running in the background
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file skidward-0.0.1.dev434.tar.gz
.
File metadata
- Download URL: skidward-0.0.1.dev434.tar.gz
- Upload date:
- Size: 66.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/39.0.1 requests-toolbelt/0.8.0 tqdm/4.29.1 CPython/3.6.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cf26f71c760ed3092b596d1ca99c3c9398fc57a94bae8559655b736e212388b8 |
|
MD5 | 406e8fd3e048ada32663440da08a1bac |
|
BLAKE2b-256 | 570ac9aa0a53e4cc2b90f5f4b3bb89e562ff3bfd5a2fcf4f1acf0950ec09475d |
File details
Details for the file skidward-0.0.1.dev434-py2.py3-none-any.whl
.
File metadata
- Download URL: skidward-0.0.1.dev434-py2.py3-none-any.whl
- Upload date:
- Size: 22.3 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/39.0.1 requests-toolbelt/0.8.0 tqdm/4.29.1 CPython/3.6.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4ff4f1857fa196484620f82375f011c12da0026a24795d7e13250c90dc883442 |
|
MD5 | 53f5a06fce76f8271bbebbf2c0881f35 |
|
BLAKE2b-256 | ffed753b21e7a374cfce0d60799ab49d30f4c3537bf21f669a353e53e4fa6afc |