Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/metarhia/noroutine
Goroutine analogue for Node.js, spreads I/O-bound routine calls to utilize thread pool (worker_threads) using balancer with event loop utilization. 🌱
https://github.com/metarhia/noroutine
balancer concurrency goroutine metarhia multithreading parallel routine threads workers
Last synced: about 1 month ago
JSON representation
Goroutine analogue for Node.js, spreads I/O-bound routine calls to utilize thread pool (worker_threads) using balancer with event loop utilization. 🌱
- Host: GitHub
- URL: https://github.com/metarhia/noroutine
- Owner: metarhia
- License: mit
- Created: 2021-10-23T18:22:33.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-01-11T16:13:47.000Z (about 1 year ago)
- Last Synced: 2025-01-03T13:14:26.414Z (about 2 months ago)
- Topics: balancer, concurrency, goroutine, metarhia, multithreading, parallel, routine, threads, workers
- Language: JavaScript
- Homepage: https://metarhia.com
- Size: 148 KB
- Stars: 120
- Watchers: 15
- Forks: 11
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Security: SECURITY.md
- Authors: AUTHORS
Awesome Lists containing this project
README
# Node Routine (noroutine)
[](https://github.com/metarhia/noroutine/actions?query=workflow%3A%22Testing+CI%22+branch%3Amaster)
[](https://snyk.io/test/github/metarhia/noroutine)
[](https://badge.fury.io/js/noroutine)
[](https://www.npmjs.com/package/noroutine)
[](https://www.npmjs.com/package/noroutine)
[](https://github.com/metarhia/noroutine/blob/master/LICENSE)Goroutine analogue for Node.js, spreads I/O-bound routine (tasks) to utilize
thread pool with `worker_threads` using balancer with event loop utilization
(see `perf_hooks` API).## Usage
Install: `npm install noroutine`
```js
const noroutine = require('noroutine');
const module1 = require('./module1.js');
const module2 = require('./module2.js');
noroutine.init({ modules: [module1, module2] });(async () => {
const res1 = await module1.method1('value1');
const res2 = await module2.method2('value2');
console.log({ res1, res2 });
})();
```## Initialization options
```js
noroutine.init({
modules: [module1, module2],
pool: 5, // number of workers in thread pool
wait: 2000, // maximum delay to wait for a free thread
timeout: 5000, // maximum timeout for executing a functions
monitoring: 5000, // event loop utilization monitoring interval
});
```## License & Contributors
Copyright (c) 2021-2024 [Metarhia contributors](https://github.com/metarhia/noroutine/graphs/contributors).
Noroutine is [MIT licensed](./LICENSE).\
Noroutine is a part of [Metarhia](https://github.com/metarhia) technology stack.