-
-
Save obonyojimmy/55be76da161cfaff7ab0899b5612a39e to your computer and use it in GitHub Desktop.
A python script which starts celery worker and auto reload it when any code change happens.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
''' | |
A python script which starts celery worker and auto reload it when any code change happens. | |
I did this because Celery worker's "--autoreload" option seems not working for a lot of people. | |
''' | |
import time | |
from watchdog.observers import Observer ##pip install watchdog | |
from watchdog.events import PatternMatchingEventHandler | |
import psutil ##pip install psutil | |
import os | |
import subprocess | |
code_dir_to_monitor = "/path/to/your/code/dir" | |
celery_working_dir = code_dir_to_monitor #happen to be the same. It may be different on your machine | |
celery_cmdline = 'celery worker -A some_project -l INFO'.split(" ") | |
class MyHandler(PatternMatchingEventHandler): | |
def on_any_event(self, event): | |
print("detected change. event = {}".format(event)) | |
for proc in psutil.process_iter(): | |
proc_cmdline = self._get_proc_cmdline(proc) | |
if not proc_cmdline or len(proc_cmdline) < len(celery_cmdline): | |
continue | |
is_celery_worker = 'python' in proc_cmdline[0].lower() \ | |
and celery_cmdline[0] == proc_cmdline[1] \ | |
and celery_cmdline[1] == proc_cmdline[2] | |
if not is_celery_worker: | |
continue | |
proc.kill() | |
print("Just killed {} on working dir {}".format(proc_cmdline, proc.cwd())) | |
run_worker() | |
def _get_proc_cmdline(self, proc): | |
try: | |
return proc.cmdline() | |
except Exception as e: | |
return [] | |
def run_worker(): | |
print("Ready to call {} ".format(celery_cmdline)) | |
os.chdir(celery_working_dir) | |
subprocess.Popen(celery_cmdline) | |
print("Done callling {} ".format(celery_cmdline)) | |
if __name__ == "__main__": | |
run_worker() | |
event_handler = MyHandler(patterns = ["*.py"]) | |
observer = Observer() | |
observer.schedule(event_handler, code_dir_to_monitor, recursive=True) | |
observer.start() | |
print("file change observer started") | |
try: | |
while True: | |
time.sleep(1) | |
except KeyboardInterrupt: | |
observer.stop() | |
observer.join() |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment