Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/metwork-framework/circus_autorestart_plugin
circus plugin to autorestart a watcher if a FS change is observed (with inotify) inside its workdir (with .gitignore like exclusions)
https://github.com/metwork-framework/circus_autorestart_plugin
autoreadme autorestart circus github-actions inotify integration-level-3 plugin python3
Last synced: 1 day ago
JSON representation
circus plugin to autorestart a watcher if a FS change is observed (with inotify) inside its workdir (with .gitignore like exclusions)
- Host: GitHub
- URL: https://github.com/metwork-framework/circus_autorestart_plugin
- Owner: metwork-framework
- License: bsd-3-clause
- Created: 2019-01-03T09:32:30.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2024-09-20T16:59:05.000Z (4 months ago)
- Last Synced: 2024-11-11T12:14:10.551Z (2 months ago)
- Topics: autoreadme, autorestart, circus, github-actions, inotify, integration-level-3, plugin, python3
- Language: Python
- Homepage:
- Size: 41 KB
- Stars: 0
- Watchers: 3
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# circus_autorestart_plugin
[//]: # (automatically generated from https://github.com/metwork-framework/github_organization_management/blob/master/common_files/README.md)
**Status (master branch)**
[![GitHub CI](https://github.com/metwork-framework/circus_autorestart_plugin/actions/workflows/ci.yml/badge.svg?branch=master)](https://github.com/metwork-framework/circus_autorestart_plugin/actions?query=workflow%3ACI+branch%3Amaster)
[![Maintenance](https://raw.githubusercontent.com/metwork-framework/resources/master/badges/maintained.svg)](https://github.com/metwork-framework/resources/blob/master/badges/maintained.svg)## What is it ?
This is a [circus](https://circus.readthedocs.io) plugin to automatically restart
a watcher if a FS change is observed (with inotify) inside the watcher workdir.You can provide some inclusions and exclusions to avoid restart for changes on specific files/directories
with a `gitignore` like syntax.## Install
Add this to your `circus` configuration:
```
[plugin:autorestart]
use = circus_autorestart_plugin.CircusAutorestartPlugin
```## Configure
To use this feature, your watcher must set (in its `circus` configuration) a `working_dir` with:
- `.autorestart_includes`
- (and/or) `.autorestart_excludes`Both files follow `gitignore` syntax even there are some specific limitations to the [python wrapper used](https://github.com/mherrmann/gitignore_parser/issues/1).
The plugin add inotify watches to every subdirectories of the configured `working_dir` which don't
match with `.autorestart_excludes` (if it exists). The `working_dir` itself is always watched.When a FS event is received, if the corresponding file matches `.autorestart_includes` (if it exists) and not matches `.autorestart_excludes` (if it exists), the watcher is killed (and
`circus` should restart it).## Limitations
At this moment:
- we just kill the watcher (`SIGKILL`) and we hope than `circus` will relaunch it (be careful if your `circus` is not configured to do that).
- if a new directory is created, it's not automatically watched itself.
- it seems that the `gitignore` parser used [is not perfect](https://github.com/mherrmann/gitignore_parser/issues/1).## Contributing guide
See [CONTRIBUTING.md](CONTRIBUTING.md) file.
## Code of Conduct
See [CODE_OF_CONDUCT.md](CODE_OF_CONDUCT.md) file.
## Sponsors
*(If you are officially paid to work on MetWork Framework, please contact us to add your company logo here!)*
[![logo](https://raw.githubusercontent.com/metwork-framework/resources/master/sponsors/meteofrance-small.jpeg)](http://www.meteofrance.com)