{ "info": { "author": "Parashar Dhapola", "author_email": "parashar.dhapola@gmail.com", "bugtrack_url": null, "classifiers": [ "Development Status :: 4 - Beta", "License :: OSI Approved :: MIT License", "Natural Language :: English", "Operating System :: POSIX :: Linux", "Programming Language :: Python :: 3", "Programming Language :: Python :: 3.5", "Topic :: System :: Distributed Computing" ], "description": "==========\npscheduler\n==========\n\n.. image:: https://travis-ci.org/parashardhapola/pscheduler.svg?branch=master\n :target: https://travis-ci.org/parashardhapola/pscheduler\n.. image:: https://img.shields.io/pypi/l/pscheduler.svg\n :target: https://pypi.python.org/pypi/pscheduler\n.. image:: https://img.shields.io/pypi/v/pscheduler.svg\n :target: https://pypi.python.org/pypi/pscheduler\n.. image:: https://img.shields.io/pypi/wheel/pscheduler.svg\n :target: https://pypi.python.org/pypi/pscheduler\n.. image:: https://landscape.io/github/parashardhapola/pscheduler/master/landscape.svg?style=flat\n :target: https://landscape.io/github/parashardhapola/pscheduler/master\n :alt: Code Health\n\n\nSetup\n-----\n\n* This pscheduler service is critical dependent upon the usage of shared filesystem across the remote machines. Setup NFS for all the remote machines.\n* Have same login credentials for all the remote machines.\n* Basic Linux utilities like *ssh* and *nohup* should be installed on all the remote machines.\n\nInstall\n-------\n\n**pscheduler** is a Python 3 only module and can be easily installed using pip:\n\n ``pip install pscheduler``\n\nConfiguration\n-------------\n\n* Start the service using ``pscheduler service start``. This will create a directory **.pscheduler** under your home directory.\n* Edit file **~/.pscheduler/hosts.cfg** and add all the IP addresses/domain aliases of the remote machines in each line. Save and exit. Alternately if you are in an HPC environment and LSF is already installed, then you can use the provided script ``bhostsWrapper.py`` to directly populate the remote machine. You should then edit it to remove the head node machine from the list and any other required host.\n* If you have not already setup password-less login into remote machines, then use the provided script ``batchSetupLoginKeys.py`` to set it up. \n\nUsage\n-----\n\n* There are four basic utilities:\n\n +-------------+-----------------------------------+\n | **service** | start/stop the background service |\n +-------------+-----------------------------------+\n | **hosts** | get information on remote machines|\n +-------------+-----------------------------------+\n | **sub** | submit jobs |\n +-------------+-----------------------------------+\n | **jobs** | monitor running/pending job |\n +-------------+-----------------------------------+\n\n *See helpfiles of individual subcommands for further details*\n\n* It is critical that the background service is started before the submitting any job\n\n* Examples:\n\n * Start service: ``pscheduler service start``\n * Submit job: ``pscheduler sub \"sleep 10\"``\n\n* Pending and running job configuration files are stored under **~/.pscheduler/jobs** in PEND and RUN directory respectively. By default the finished job configuration file containing standard output(JSON format) are stored under **~/.pscheduler/jobs/FINISH**, but users can choose a custom location for this file by using **-o** flag while submitting job and providing the output location path.\n\n* **~/.pscheduler/DAEMON.log** contains the log of the background service. You should have a look at this file to see if any error messages have been thrown.\n\n* Note that pscheduler *will not* will ignore the scheduling by other schedulers and simply launch jobs based on availability of resources (currently only number of CPU cores).\n\nRoadmap for future versions\n^^^^^^^^^^^^^^^^^^^^^^^^^^^\n\n* Implement ``jobs`` subcommand\n* Job restart in case of resource spike\n* Improve code for catching fatal exceptions\n\nHISTORY\n^^^^^^^\n\n* 0.0.1:\n * FIRST PRE ALPHA RELEASE\n* 0.0.2:\n * CLI CREATED using wrapper.py\n * BHOST wrapper script separated form phosts module\n * Introduced hosts.cfg: A user editable list of hosts\n * Batch script made for creating login keys\n * PSUB now saves in JSON format\n * DEV: Submit to PyPi using python script\n * DEV: Automatic update of version in setup.py\n* 0.0.3:\n * Added ``pscheduler`` in scripts for command line invocation\n* 0.0.4:\n * Deployment fix\n* 0.0.5:\n * Import fix\n* 0.0.6:\n * Json fix\n* 0.0.7:\n * jobs subcommand implemented\n * phosts doublehost check issue rectified\n * submission process improved in daemon\n * class naming convention changed\n * default host fixed to localhost. passwordless loging into localhost created\n * DEV: Travis CI now being used for testing\n* 0.1.0:\n * pdaemon fix\n * Rolledback SSH keygen\n\n\nContributors\n============\nParashar Dhapola (parashar.dhapola@gmail.com)", "description_content_type": null, "docs_url": null, "download_url": "https://github.com/parashardhapola/pscheduler/tarball/0.1.0", "downloads": { "last_day": -1, "last_month": -1, "last_week": -1 }, "home_page": "https://github.com/parashardhapola/pscheduler", "keywords": "scheduler", "license": "MIT", "maintainer": "", "maintainer_email": "", "name": "pscheduler", "package_url": "https://pypi.org/project/pscheduler/", "platform": "UNKNOWN", "project_url": "https://pypi.org/project/pscheduler/", "project_urls": { "Download": "https://github.com/parashardhapola/pscheduler/tarball/0.1.0", "Homepage": "https://github.com/parashardhapola/pscheduler" }, "release_url": "https://pypi.org/project/pscheduler/0.1.0/", "requires_dist": [ "psutil", "terminaltables" ], "requires_python": "", "summary": "A pure Python remote job scheduler system", "version": "0.1.0" }, "last_serial": 2464077, "releases": { "0.0.2": [ { "comment_text": "", "digests": { "md5": "0a19ece08f851890da625473b2ee8c6f", "sha256": "4a627660e32b9c23ac0849f905ea3dfc9dd14032222254ed0e675b211601f219" }, "downloads": -1, "filename": "pscheduler-0.0.2-py3-none-any.whl", "has_sig": false, "md5_digest": "0a19ece08f851890da625473b2ee8c6f", "packagetype": "bdist_wheel", "python_version": "py3", "requires_python": null, "size": 9203, "upload_time": "2016-11-14T11:55:18", "url": "https://files.pythonhosted.org/packages/6b/1b/24188ce75a8abd3043c31936d8501b72202fc44d0665a565f9f636eeb7bf/pscheduler-0.0.2-py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "10b69de0140fb88b6ffb88c13cd69d9d", "sha256": "56979a286ac92c6b7ebd71abe13599f60ff54a582c2ffe094078ae5bf3430b15" }, "downloads": -1, "filename": "pscheduler-0.0.2.tar.gz", "has_sig": false, "md5_digest": "10b69de0140fb88b6ffb88c13cd69d9d", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 6986, "upload_time": "2016-11-14T11:55:21", "url": "https://files.pythonhosted.org/packages/b3/04/f95b85452d550cb133355aad59e3c40bea88f1555f3fca3ddf44a2a71253/pscheduler-0.0.2.tar.gz" } ], "0.0.3": [ { "comment_text": "", "digests": { "md5": "d00458ae8c746f2053ff929255c334d8", "sha256": "76e4900b0c477f54d1a385323f83ba0c7d96a917aa87638b111af0d402ddcec3" }, "downloads": -1, "filename": "pscheduler-0.0.3.tar.gz", "has_sig": false, "md5_digest": "d00458ae8c746f2053ff929255c334d8", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 7050, "upload_time": "2016-11-14T17:34:06", "url": "https://files.pythonhosted.org/packages/90/9c/8db97c659b2d8350e1dafbef7b095f1765d24dd6d144ed8da1273b500ed7/pscheduler-0.0.3.tar.gz" } ], "0.0.4": [ { "comment_text": "", "digests": { "md5": "cf2d6f42ddc2123d4932d360eea4646d", "sha256": "34c21688096d02e654e0b8c2821643283ecaf98127f4303f480fd2397a20177b" }, "downloads": -1, "filename": "pscheduler-0.0.4-py3-none-any.whl", "has_sig": false, "md5_digest": "cf2d6f42ddc2123d4932d360eea4646d", "packagetype": "bdist_wheel", "python_version": "py3", "requires_python": null, "size": 9506, "upload_time": "2016-11-14T17:45:36", "url": "https://files.pythonhosted.org/packages/45/99/d818b3b5f281c4bbce08a5e21d034f450549f7b27fd039251461e9f517ec/pscheduler-0.0.4-py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "48816b528a1d2aa54ff8e72e2e3f16b8", "sha256": "eda8ad6ce7cdd7b090067e4649daf711940b873a7cd365bc85088f7ea213174d" }, "downloads": -1, "filename": "pscheduler-0.0.4.tar.gz", "has_sig": false, "md5_digest": "48816b528a1d2aa54ff8e72e2e3f16b8", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 7031, "upload_time": "2016-11-14T17:45:40", "url": "https://files.pythonhosted.org/packages/9e/37/a228147bfd4c409c366603854a02ab53abb020c50ae63b6fcd027a2ec972/pscheduler-0.0.4.tar.gz" } ], "0.0.5": [ { "comment_text": "", "digests": { "md5": "9969c976eb9a6b67086b19a199db49cc", "sha256": "ce6e3ad5e284d506d6c5d77e995e062442d46e7530af04bc410ae5dae7be4ffa" }, "downloads": -1, "filename": "pscheduler-0.0.5-py3-none-any.whl", "has_sig": false, "md5_digest": "9969c976eb9a6b67086b19a199db49cc", "packagetype": "bdist_wheel", "python_version": "py3", "requires_python": null, "size": 9525, "upload_time": "2016-11-14T17:54:24", "url": "https://files.pythonhosted.org/packages/52/b7/58b1aa29a8b0084e8a5223814e0ed62de7f8321b5de551fae3fe7447a7c0/pscheduler-0.0.5-py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "7008aecf4b3d93b10ec06fb9f47c3a8e", "sha256": "e478e79100d84b0cbdea3270fc24c7bfdddfacaba7be1323c2804f6856561fef" }, "downloads": -1, "filename": "pscheduler-0.0.5.tar.gz", "has_sig": false, "md5_digest": "7008aecf4b3d93b10ec06fb9f47c3a8e", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 7029, "upload_time": "2016-11-14T17:54:28", "url": "https://files.pythonhosted.org/packages/98/f7/9a5fee03f2476260e0cbd9919edbcb0f0b5bffc8289366d29f4cc58d8958/pscheduler-0.0.5.tar.gz" } ], "0.0.6": [ { "comment_text": "", "digests": { "md5": "f897bb3bd08812857f1b3ad7b46244b1", "sha256": "149581888718f1faa33a8c44950f1288f15886ea48236d552cc4822e9472d0c4" }, "downloads": -1, "filename": "pscheduler-0.0.6-py3-none-any.whl", "has_sig": false, "md5_digest": "f897bb3bd08812857f1b3ad7b46244b1", "packagetype": "bdist_wheel", "python_version": "py3", "requires_python": null, "size": 9532, "upload_time": "2016-11-14T18:08:14", "url": "https://files.pythonhosted.org/packages/b3/38/b39d5d3a7a859909edfd2e325ed92c05631305728f9ea5f8e38f0a8ac628/pscheduler-0.0.6-py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "c3226b0df14dd0dfafc182863da158eb", "sha256": "f004ba34158ea6c9809d29095948d653f2df081efc7885ef0b60ad40e80b4c4b" }, "downloads": -1, "filename": "pscheduler-0.0.6.tar.gz", "has_sig": false, "md5_digest": "c3226b0df14dd0dfafc182863da158eb", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 7034, "upload_time": "2016-11-14T18:08:17", "url": "https://files.pythonhosted.org/packages/5c/6b/e6d19db7334eaea54ee5455cc8e87a26bffec89d08a2bacef3d0f605d70f/pscheduler-0.0.6.tar.gz" } ], "0.0.7": [ { "comment_text": "", "digests": { "md5": "0fc9be794c2da2d9462daf30c7cb2417", "sha256": "110c105c89b32988a9e2252f083c8bab88bcbaa54e346a8c8f59433056d14bb9" }, "downloads": -1, "filename": "pscheduler-0.0.7-py3-none-any.whl", "has_sig": false, "md5_digest": "0fc9be794c2da2d9462daf30c7cb2417", "packagetype": "bdist_wheel", "python_version": "py3", "requires_python": null, "size": 9925, "upload_time": "2016-11-16T05:09:21", "url": "https://files.pythonhosted.org/packages/23/e9/8c81d7fa4d1e415c0af46a3dfcd1a98adab41914f39321873a4671846c93/pscheduler-0.0.7-py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "71e34b0ffb5679241d38a28732551ca3", "sha256": "a543639b40291301c06a791b1afe05f55294ab96ba95384b0b8b2af94b408473" }, "downloads": -1, "filename": "pscheduler-0.0.7.tar.gz", "has_sig": false, "md5_digest": "71e34b0ffb5679241d38a28732551ca3", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 8844, "upload_time": "2016-11-16T05:09:24", "url": "https://files.pythonhosted.org/packages/11/d7/b38ca8aa222e7146392eebd2a4fe8741be50a70888ff459cbbaa668b54f1/pscheduler-0.0.7.tar.gz" } ], "0.1.0": [ { "comment_text": "", "digests": { "md5": "f07d6190cbf2e62b232a2cd9498c7d5b", "sha256": "62cd373a6cd5b83033f851782fa59cab9d8fc3477001cdd42525b3dc55ea82c1" }, "downloads": -1, "filename": "pscheduler-0.1.0-py3-none-any.whl", "has_sig": false, "md5_digest": "f07d6190cbf2e62b232a2cd9498c7d5b", "packagetype": "bdist_wheel", "python_version": "py3", "requires_python": null, "size": 14214, "upload_time": "2016-11-16T12:48:11", "url": "https://files.pythonhosted.org/packages/19/07/5cea868158dc767986dc3121c5da5141f79689dfbec8db36c72db1ab65c1/pscheduler-0.1.0-py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "57dc6400692e2948be57eb8bde5db097", "sha256": "18c13ee405503493e89870538b766c5af8462cecbd1c11fbf21e8949e27e6b1e" }, "downloads": -1, "filename": "pscheduler-0.1.0.tar.gz", "has_sig": false, "md5_digest": "57dc6400692e2948be57eb8bde5db097", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 11296, "upload_time": "2016-11-16T12:48:14", "url": "https://files.pythonhosted.org/packages/a8/70/8a2fdc3637b7c4879200e11bf9f31b64b13a3d221fd27f7e4b27b81e7632/pscheduler-0.1.0.tar.gz" } ], "0.1.0rc1": [ { "comment_text": "", "digests": { "md5": "99bd2ae253ddb731fc8d0f0fbbe56f42", "sha256": "26f35fbce6c3f36ff35e22a29c406d18f641a5a4c5745d17ef2f35343adf4866" }, "downloads": -1, "filename": "pscheduler-0.1.0rc1-py3-none-any.whl", "has_sig": false, "md5_digest": "99bd2ae253ddb731fc8d0f0fbbe56f42", "packagetype": "bdist_wheel", "python_version": "py3", "requires_python": null, "size": 14393, "upload_time": "2016-11-16T12:00:43", "url": "https://files.pythonhosted.org/packages/2e/5e/75d928ad9d0f66b6d79c5c2ade84609168d2a7d94346aab8033eac288969/pscheduler-0.1.0rc1-py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "a12d60d1e349448efdfa6a2e89edd654", "sha256": "9be044c55f4547a504720d129aa5c50204c96216e907974a0bfaa15c7ef9f58c" }, "downloads": -1, "filename": "pscheduler-0.1.0rc1.tar.gz", "has_sig": false, "md5_digest": "a12d60d1e349448efdfa6a2e89edd654", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 11206, "upload_time": "2016-11-16T12:00:46", "url": "https://files.pythonhosted.org/packages/b2/f9/32b3d85d51cc7bff98eedc85758cafcdfa0d0c40776e2a8bf2e5f2153f07/pscheduler-0.1.0rc1.tar.gz" } ], "0.1.0rc2": [ { "comment_text": "", "digests": { "md5": "d6af294a3879362de1463c8c4b118792", "sha256": "2dcd578147dcd914e578dd06824afcb524bb7ecf6a2c1317551cce6eee9e3eb9" }, "downloads": -1, "filename": "pscheduler-0.1.0rc2-py3-none-any.whl", "has_sig": false, "md5_digest": "d6af294a3879362de1463c8c4b118792", "packagetype": "bdist_wheel", "python_version": "py3", "requires_python": null, "size": 14394, "upload_time": "2016-11-16T12:31:05", "url": "https://files.pythonhosted.org/packages/45/88/ed318f4b5997d1a2089141fb7deb50120599f14efbbf99aa77ecaf82f760/pscheduler-0.1.0rc2-py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "17cd615b41ef99e7cad6e8530857f69a", "sha256": "6ce2e030e7f57c07ea2d2ee89f2f644f59eed4c003fc9a6cbbc3c86f89beb35a" }, "downloads": -1, "filename": "pscheduler-0.1.0rc2.tar.gz", "has_sig": false, "md5_digest": "17cd615b41ef99e7cad6e8530857f69a", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 11291, "upload_time": "2016-11-16T12:31:07", "url": "https://files.pythonhosted.org/packages/88/10/3b0e13622cf942f36c0654eeb8bdd0e5b3f2d91d3a93d25679e2fe4f9095/pscheduler-0.1.0rc2.tar.gz" } ], "0.1.0rc3": [ { "comment_text": "", "digests": { "md5": "60b2809327e464ff53ef3cd7fff6f73c", "sha256": "c9bc62cf4eef4220032b5c03930bb938d0cecd76092e1e6defeb2b3d510d6cf7" }, "downloads": -1, "filename": "pscheduler-0.1.0rc3-py3-none-any.whl", "has_sig": false, "md5_digest": "60b2809327e464ff53ef3cd7fff6f73c", "packagetype": "bdist_wheel", "python_version": "py3", "requires_python": null, "size": 14395, "upload_time": "2016-11-16T12:32:32", "url": "https://files.pythonhosted.org/packages/ae/bd/d1c0cf95af1ecc0db90ea10c014df9659c2f3e8a658d3e38cb4993defb24/pscheduler-0.1.0rc3-py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "2623dc30575d89754b54db1cbd851e24", "sha256": "be28e9be81065f4a4498c59e6403af413ebf47bec3fc34a25c8a13921423dc45" }, "downloads": -1, "filename": "pscheduler-0.1.0rc3.tar.gz", "has_sig": false, "md5_digest": "2623dc30575d89754b54db1cbd851e24", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 11300, "upload_time": "2016-11-16T12:32:35", "url": "https://files.pythonhosted.org/packages/35/88/7a398ff3bcb8f7a9ebf4672d50b253bc83e92c8140c0f5b8728342762872/pscheduler-0.1.0rc3.tar.gz" } ], "0.1.0rc4": [ { "comment_text": "", "digests": { "md5": "ffaa777a9ffc34c6b363fd8975e294f7", "sha256": "324ef1d4fe4740320208e690e65244fff3622c4222444bd2f8ba2c39b38f795c" }, "downloads": -1, "filename": "pscheduler-0.1.0rc4-py3-none-any.whl", "has_sig": false, "md5_digest": "ffaa777a9ffc34c6b363fd8975e294f7", "packagetype": "bdist_wheel", "python_version": "py3", "requires_python": null, "size": 14277, "upload_time": "2016-11-16T12:43:19", "url": "https://files.pythonhosted.org/packages/e4/68/2de89584d297b85d2aa9efb8f4571d1f6385ec4c3199dde6ede5792fca3a/pscheduler-0.1.0rc4-py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "ed267f1e8119e56deb9a1964b1ee1871", "sha256": "fe6f8385f0e13f8aa65e73aa7a1b35a84a6e1abdb913ad2c7b7d304ab6210d4b" }, "downloads": -1, "filename": "pscheduler-0.1.0rc4.tar.gz", "has_sig": false, "md5_digest": "ed267f1e8119e56deb9a1964b1ee1871", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 11310, "upload_time": "2016-11-16T12:43:22", "url": "https://files.pythonhosted.org/packages/a0/0f/4884689d63c360d95b85959e1ee367ff2a809ae26034333b5b2d189c26aa/pscheduler-0.1.0rc4.tar.gz" } ] }, "urls": [ { "comment_text": "", "digests": { "md5": "f07d6190cbf2e62b232a2cd9498c7d5b", "sha256": "62cd373a6cd5b83033f851782fa59cab9d8fc3477001cdd42525b3dc55ea82c1" }, "downloads": -1, "filename": "pscheduler-0.1.0-py3-none-any.whl", "has_sig": false, "md5_digest": "f07d6190cbf2e62b232a2cd9498c7d5b", "packagetype": "bdist_wheel", "python_version": "py3", "requires_python": null, "size": 14214, "upload_time": "2016-11-16T12:48:11", "url": "https://files.pythonhosted.org/packages/19/07/5cea868158dc767986dc3121c5da5141f79689dfbec8db36c72db1ab65c1/pscheduler-0.1.0-py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "57dc6400692e2948be57eb8bde5db097", "sha256": "18c13ee405503493e89870538b766c5af8462cecbd1c11fbf21e8949e27e6b1e" }, "downloads": -1, "filename": "pscheduler-0.1.0.tar.gz", "has_sig": false, "md5_digest": "57dc6400692e2948be57eb8bde5db097", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 11296, "upload_time": "2016-11-16T12:48:14", "url": "https://files.pythonhosted.org/packages/a8/70/8a2fdc3637b7c4879200e11bf9f31b64b13a3d221fd27f7e4b27b81e7632/pscheduler-0.1.0.tar.gz" } ] }