feat: insertBatchSize
This commit is contained in:
parent
e62bb58362
commit
e5c8634c59
@ -13,7 +13,10 @@ export const Relay = new WorkerRelayInterface(
|
||||
);
|
||||
export async function initRelayWorker() {
|
||||
try {
|
||||
await Relay.init("relay.db");
|
||||
await Relay.init({
|
||||
databasePath: "relay.db",
|
||||
insertBatchSize: 100
|
||||
});
|
||||
} catch (e) {
|
||||
console.error(e);
|
||||
}
|
||||
|
@ -22,7 +22,10 @@ const workerScript = import.meta.env.DEV
|
||||
const workerRelay = new WorkerRelayInterface(workerScript);
|
||||
|
||||
// load sqlite database and run migrations
|
||||
await workerRelay.init("my-relay.db");
|
||||
await workerRelay.init({
|
||||
databasePath: "relay.db",
|
||||
insertBatchSize: 100
|
||||
});
|
||||
|
||||
// Query worker relay with regular nostr REQ command
|
||||
const results = await workerRelay.query(["REQ", "1", { kinds: [1], limit: 10 }]);
|
||||
|
@ -11,7 +11,10 @@ const workerScript = import.meta.env.DEV
|
||||
const workerRelay = new WorkerRelayInterface(workerScript);
|
||||
|
||||
// load sqlite database and run migrations
|
||||
await workerRelay.init("my-relay.db");
|
||||
await workerRelay.init({
|
||||
databasePath: "relay.db",
|
||||
insertBatchSize: 100
|
||||
});
|
||||
|
||||
// Query worker relay with regular nostr REQ command
|
||||
const results = await workerRelay.query(["REQ", "1", { kinds: [1], limit: 10 }]);
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@snort/worker-relay",
|
||||
"version": "1.0.9",
|
||||
"version": "1.0.10",
|
||||
"description": "A nostr relay in a service worker",
|
||||
"main": "dist/index.js",
|
||||
"types": "dist/index.d.ts",
|
||||
|
@ -1,6 +1,18 @@
|
||||
import { EventMetadata, NostrEvent, OkResponse, ReqCommand, WorkerMessage, WorkerMessageCommand } from "./types";
|
||||
import { v4 as uuid } from "uuid";
|
||||
|
||||
export interface InitAargs {
|
||||
/**
|
||||
* OPFS file path for the database
|
||||
*/
|
||||
databasePath: string,
|
||||
|
||||
/**
|
||||
* How many events to insert per batch
|
||||
*/
|
||||
insertBatchSize?: number
|
||||
}
|
||||
|
||||
export class WorkerRelayInterface {
|
||||
#worker: Worker;
|
||||
#commandQueue: Map<string, (v: unknown, ports: ReadonlyArray<MessagePort>) => void> = new Map();
|
||||
@ -35,8 +47,8 @@ export class WorkerRelayInterface {
|
||||
};
|
||||
}
|
||||
|
||||
async init(databasePath: string) {
|
||||
return await this.#workerRpc<Array<string | undefined>, boolean>("init", [databasePath]);
|
||||
async init(args: InitAargs) {
|
||||
return await this.#workerRpc<InitAargs, boolean>("init", args);
|
||||
}
|
||||
|
||||
async event(ev: NostrEvent) {
|
||||
|
@ -2,12 +2,13 @@
|
||||
|
||||
import { SqliteRelay } from "./sqlite-relay";
|
||||
import { InMemoryRelay } from "./memory-relay";
|
||||
import { debugLog, setLogging } from "./debug";
|
||||
import { setLogging } from "./debug";
|
||||
import { WorkQueueItem, barrierQueue, processWorkQueue } from "./queue";
|
||||
import { NostrEvent, RelayHandler, ReqCommand, ReqFilter, WorkerMessage, unixNowMs, EventMetadata } from "./types";
|
||||
import { getForYouFeed } from "./forYouFeed";
|
||||
|
||||
let relay: RelayHandler | undefined;
|
||||
let insertBatchSize = 10;
|
||||
|
||||
// Event inserter queue
|
||||
let eventWriteQueue: Array<NostrEvent> = [];
|
||||
@ -24,7 +25,7 @@ async function insertBatch() {
|
||||
//console.debug("Yield insert, queue length: ", eventWriteQueue.length, ", cmds: ", cmdQueue.length);
|
||||
break;
|
||||
}
|
||||
const batch = eventWriteQueue.splice(0, 10);
|
||||
const batch = eventWriteQueue.splice(0, insertBatchSize);
|
||||
eventWriteQueue = eventWriteQueue.slice(batch.length);
|
||||
relay.eventBatch(batch);
|
||||
}
|
||||
@ -42,6 +43,11 @@ try {
|
||||
console.error(e);
|
||||
}
|
||||
|
||||
interface InitAargs {
|
||||
databasePath: string,
|
||||
insertBatchSize?: number
|
||||
}
|
||||
|
||||
const handleMsg = async (port: MessagePort | DedicatedWorkerGlobalScope, ev: MessageEvent) => {
|
||||
async function reply<T>(id: string, obj?: T) {
|
||||
port.postMessage({
|
||||
@ -61,18 +67,19 @@ const handleMsg = async (port: MessagePort | DedicatedWorkerGlobalScope, ev: Mes
|
||||
}
|
||||
case "init": {
|
||||
await barrierQueue(cmdQueue, async () => {
|
||||
const [dbPath] = msg.args as Array<string>;
|
||||
const args = msg.args as InitAargs;
|
||||
insertBatchSize = args.insertBatchSize ?? 10;
|
||||
try {
|
||||
if ("WebAssembly" in self) {
|
||||
relay = new SqliteRelay();
|
||||
} else {
|
||||
relay = new InMemoryRelay();
|
||||
}
|
||||
await relay.init(dbPath);
|
||||
await relay.init(args.databasePath);
|
||||
} catch (e) {
|
||||
console.error("Fallback to InMemoryRelay", e);
|
||||
relay = new InMemoryRelay();
|
||||
await relay.init(dbPath);
|
||||
await relay.init(args.databasePath);
|
||||
}
|
||||
reply(msg.id, true);
|
||||
});
|
||||
|
Loading…
x
Reference in New Issue
Block a user