Python Live Development tool.
I created PyLiveDev because I work a lot in the microservices/REST space and found constantly having to run/restart services while developing and keeping track of multiple logs in separate windows, to be, quite frankly, a pain in my ass.
Inspired by live updates while using create-react-app in development, I wanted to see if there was a way I could make a python program run multiple services and keep track of the files imported. This way if anything changed it could automatically restart those services and save time while developing. As a bonus, piping all stdout/stderr to one screen so I could immediately see if I wrote bad code or was returning something unexpected.
It works by you creating a JSON configuration file called .pylivedev
in the root of your python project and adding an Object member for each unique process, then running pylivedev
from the root of your project.
foo@bar:~$ pip install pylivedev
If you are using PyLiveDev on a Linux kernel 2.6+, you may at some point run into an issue where the program quits, either quite immediately, or as more and more files are added to your project. This is due to a hard limit in an underlying library. When this happens add/adjust the following setting in your /etc/sysctl.conf
file (will require root access):
fs.inotify.max_user_watches=16384
The default value is 8192, so adjust accordingly then reboot. Increase as necessary until PyLiveDev stops crashing.
foo@bar:~$ pylivedev
{
"rest": {
"command": "rest",
"mode": "module",
"tracked": false,
"python": "/venv/my_project/bin/python",
"arguments": ["-v"],
"additional_files": ["config.json"],
"unbuffered": true,
"verbose": false
}
}
Name | Type | Mandatory | Description |
---|---|---|---|
command | String | Yes | The name of the script or module to run as a process. e.g. "services.rest", "main.py" |
mode | "module" | "script" | "exe" | No | Tells pylivedev whether you are trying to run a stand alone script, a python module, or a binary (or non-parsable) application. Defaults to "script". |
tracked | Boolean | No | When true, proccess is tracked via file changes. Use false for static or external modules. Defaults to true. Will be ignored if mode is set to "exe". |
python | String | No | The full path to the python intepreter to use to run your process. Defaults to the python interpreter running pylivedev. |
arguments | String[] | No | An array of additional arguments passed to the process. |
additional_files | String[] | No | An array of additional files to be watched/observed for changes. |
unbuffered | Boolean | No | Run the processed unbuffered, defaults to true. |
verbose | Boolean | No | Runs pylivedev in verbose mode to give more information on what is happening, what imports were found, what files have changed, etc. Defaults to false. |
You can also use the special __default__
member to store values that will be the same across processes. Anything in the proccess config will always overwrite the defaults.
{
"__default__": {
"python": "/venv/my_project/bin/python",
"mode": "module",
"additional_files": ["config.json"],
},
"main": {
"command": "nodes.rest.main"
},
"admin": {
"command": "nodes.rest.admin"
},
"external": {
"command": "nodes.external"
},
"websocket": {
"command": "daemons.websocket"
}
}
The above would work for a file structure like the following
my_project/
|-- daemons/
|-- __init__.py
|-- websocket.py
|-- nodes/
|-- rest/
|-- __init__.py
|-- admin.py
|-- main.py
|-- __init__.py
|-- external.py
|-- records/
|-- __init__.py
|-- .pylivedev
|-- config.json
If, for example, nodes/rest/main.py imported the following:
from time import time
from . import Rest
from records import User
class Main(Rest):
pass
The PyLiveDev would end up with the following list of files to watch/observe for changes
- config.json
- nodes/rest/main.py
- nodes/rest/__init__.py
- records/__init__.py
Any time any of these files is saved/changed on the system, PyLiveDev would shut down the "main" process, re-parse the module looking for imports, and then restart the process.
Note system and pip imports will not be added to the list, like time
in the above example. In most cases system files don't change often and it would waste resources to watch them. If you update a pip library, or update python, it's best to shut down PyLiveDev [CRTL-C] and restart it.