Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mcollina/undici-thread-interceptor
An Undici interceptor that routes requests over a worker thread
https://github.com/mcollina/undici-thread-interceptor
Last synced: 3 months ago
JSON representation
An Undici interceptor that routes requests over a worker thread
- Host: GitHub
- URL: https://github.com/mcollina/undici-thread-interceptor
- Owner: mcollina
- License: mit
- Created: 2024-05-27T16:11:37.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-10-14T08:38:19.000Z (3 months ago)
- Last Synced: 2024-10-16T23:05:41.150Z (3 months ago)
- Language: JavaScript
- Homepage:
- Size: 62.5 KB
- Stars: 25
- Watchers: 3
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# undici-thread-interceptor
An Undici agent that routes requests to a worker thread.
Supports:
- load balancing (round robin)
- mesh networking between the worker threads## Installation
```bash
npm install undici undici-thread-interceptor
```## Usage
### Main (main.js)
```javascript
import { Worker } from "node:worker_threads";
import { join } from "node:path";
import { createThreadInterceptor } from "undici-thread-interceptor";
import { Agent, request } from "undici";const worker = new Worker(join(import.meta.dirname, "worker.js"));
const interceptor = createThreadInterceptor({
domain: ".local", // The prefix for all local domains
});
interceptor.route("myserver", worker);const agent = new Agent().compose(interceptor);
const { statusCode, body } = await request("http://myserver.local", {
dispatcher: agent,
});console.log(statusCode, await body.json());
// worker.terminate()
```### Worker (worker.js)
#### Generic node HTTP application
```javascript
import { wire } from "undici-thread-interceptor";
import { parentPort } from "node:worker_threads";function app(req, res) {
res.writeHead(200, { "Content-Type": "application/json" });
res.end(JSON.stringify({ hello: "world" }));
}// App can optionally be a string in the form `http://HOST:PORT`. In that case the interceptor
// will use the network to perform the request.
wire({ server: app, port: parentPort });
```#### Fastify
```javascript
import { wire } from "undici-thread-interceptor";
import { parentPort } from "node:worker_threads";
import fastify from "fastify";const app = fastify();
app.get("/", (req, reply) => {
reply.send({ hello: "world" });
});wire({ server: app, port: parentPort });
```#### Express
```javascript
import { wire } from "undici-thread-interceptor";
import { parentPort } from "node:worker_threads";
import express from "express";const app = express();
app.get("/", (req, res) => {
res.send({ hello: "world" });
});wire({ server: app, port: parentPort });
```#### Koa
```javascript
import { wire } from "undici-thread-interceptor";
import { parentPort } from "node:worker_threads";
import Koa from "koa";const app = new Koa();
app.use((ctx) => {
ctx.body = { hello: workerData?.message || "world" };
});wire({ server: app.callback(), port: parentPort });
```#### Replace the server at runtime
```javascript
import { wire } from "undici-thread-interceptor";
import { parentPort } from "node:worker_threads";
import fastify from "fastify";const app1 = fastify();
app1.get("/", (req, reply) => {
reply.send({ hello: "this is app 1" });
});const app2 = fastify();
app2.get("/", (req, reply) => {
reply.send({ hello: "this is app 2" });
});const { replaceServer } = wire({ server: app1, port: parentPort });
setTimeout(() => {
replaceServer(app2);
}, 5000);
```#### Gracefully close the worker thread
If you want to gracefully close the worker thread, remember to call the `close` function of the interceptor.
```javascript
import { wire } from "undici-thread-interceptor";// ...
const { interceptor } = wire({ server: app, port: parentPort });
// ...
interceptor.close()
```## API
TBD
## License
MIT