Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yoshuawuyts/hyperlapse
Distributed process manager
https://github.com/yoshuawuyts/hyperlapse
Last synced: 7 days ago
JSON representation
Distributed process manager
- Host: GitHub
- URL: https://github.com/yoshuawuyts/hyperlapse
- Owner: yoshuawuyts
- License: mit
- Created: 2016-12-19T12:44:47.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2016-12-22T22:17:55.000Z (about 8 years ago)
- Last Synced: 2025-01-03T12:32:57.797Z (12 days ago)
- Language: JavaScript
- Size: 31.3 KB
- Stars: 23
- Watchers: 3
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-peer-to-peer - hyperlapse
- awesome-peer-to-peer - hyperlapse
- awesome-starred - yoshuawuyts/hyperlapse - Distributed process manager (others)
README
# hyperlapse [![stability][0]][1]
[![npm version][2]][3] [![build status][4]][5] [![test coverage][6]][7]
[![downloads][8]][9] [![js-standard-style][10]][11]Distributed process manager. Listens on a [hypercore][hypercore] feed for
[ndjson][ndjson] commands to execute on the host machine using [psy][psy].## CLI API
```txt
Usage:
$ hyperlapse [options]Commands:
init Create a new hypercore in the current dir
listen Listen for commands and print a log key
start Start a service on the host machine
stop Stop a service on the host machine
remove Remove a service on the host machine
restart Restart a service on the host machine
list List all services on the host machineOptions:
-h, --help Print usage
-v, --version Print version
-n, --name Provide an explicit name when starting a service
-k, --key Pass a hypercore directory, assumes cwd if not passedExamples:
$ hyperlapse init
$ hyperlapse listen <64 bit hypercore public key>
$ hyperlapse start \
hypercore-archiver-bot@^1.0.0 -n hypercore-archiver-bot \
-- hypercore-archiver-bot --channel=#dat --port=8080
$ hyperlapse list
```## JS API
```js
var hyperlapse = require('hyperlapse')
var normcore = require('normcore')var inFeed = normcore('in-feed')
var outFeed = normcore('out-feed')
hyperlapse(inFeed, outFeed)outFeed.createReadStream().pipe(process.stdout)
var outKey = outFeed.key.toString('hex')
console.log('outFeed key is ' + outKey)inFeed.append(JSON.stringify({
type: 'start',
name: 'hypercore-archiver-bot',
source: '[email protected]',
command: 'hypercore-archiver-bot --channel=#dat --port=8000'
}) + '\n')
```## Process commands
Each command should be valid [newline delimited json][ndjson].### Start
Start a new process on the machine.
```json
{
"type": "start",
"name": "what the process should be named on the machine",
"source": "e.g. [email protected]",
"env": {
"a bunch": "of env vars"
}
}
```### Stop
Stop a process on the machine
```json
{
"type": "stop",
"name": "my-cool-process"
}
```### Restart
Restart a process on the machine
```json
{
"type": "restart",
"name": "my-cool-process"
}
```### Remove
Remove a process on the machine
```json
{
"type": "remove",
"name": "my-cool-process"
}
```### List
List all processes on the machine
```json
{
"type": "list"
}
```## API
### hyperlapse(inFeed, outFeed)
Create a new agent that tails a `hypercore`. Reads commands from the `inFeed`
and logs its output to the `outFeed`.## Installation
```sh
$ npm install hyperlapse
```## See Also
- [mafintosh/hypercore][hypercore]
- [substack/psy][psy]## License
[MIT](https://tldrlegal.com/license/mit-license)[0]: https://img.shields.io/badge/stability-experimental-orange.svg?style=flat-square
[1]: https://nodejs.org/api/documentation.html#documentation_stability_index
[2]: https://img.shields.io/npm/v/hyperlapse.svg?style=flat-square
[3]: https://npmjs.org/package/hyperlapse
[4]: https://img.shields.io/travis/yoshuawuyts/hyperlapse/master.svg?style=flat-square
[5]: https://travis-ci.org/yoshuawuyts/hyperlapse
[6]: https://img.shields.io/codecov/c/github/yoshuawuyts/hyperlapse/master.svg?style=flat-square
[7]: https://codecov.io/github/yoshuawuyts/hyperlapse
[8]: http://img.shields.io/npm/dm/hyperlapse.svg?style=flat-square
[9]: https://npmjs.org/package/hyperlapse
[10]: https://img.shields.io/badge/code%20style-standard-brightgreen.svg?style=flat-square
[11]: https://github.com/feross/standard[hypercore]: https://github.com/mafintosh/hypercore
[psy]: https://github.com/substack/psy
[ndjson]: http://ndjson.org/