@lde/sparql-qlever 0.12.1 → 0.13.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -9,3 +9,41 @@ Building a QLever index is slow. To avoid rebuilding it on every pipeline run, t
9
9
  Only **one** index is cached at a time. In a multi-dataset pipeline, each dataset overwrites the previous index. On re-run, the last-indexed dataset gets a cache hit while the others rebuild.
10
10
 
11
11
  Caching is enabled by default. Disable it by passing `cacheIndex: false` to `createQlever()` or the `Importer` constructor (e.g. driven by a `QLEVER_CACHE_INDEX=false` environment variable).
12
+
13
+ ## Configuration
14
+
15
+ `createQlever()` accepts `indexOptions` and `serverOptions` to tune QLever's index builder and server respectively.
16
+
17
+ ### Server options (`serverOptions`)
18
+
19
+ Passed to `qlever-server` at startup.
20
+
21
+ | Option | Description | Default |
22
+ | ----------------------- | ------------------------------------------------ | ------- |
23
+ | `memory-max-size` | Maximum memory for query processing and caching. | `'4G'` |
24
+ | `default-query-timeout` | Default query timeout. | `'30s'` |
25
+
26
+ Example:
27
+
28
+ ```ts
29
+ const { importer, server } = createQlever({
30
+ mode: 'docker',
31
+ image: 'adfreiburg/qlever:latest',
32
+ serverOptions: {
33
+ 'memory-max-size': '12G',
34
+ 'default-query-timeout': '120s',
35
+ },
36
+ });
37
+ ```
38
+
39
+ ### Index options (`indexOptions`)
40
+
41
+ Passed to `qlever-index` during import.
42
+
43
+ | Option | Description | Default |
44
+ | ------------------------------- | --------------------------------------------------------------------------------------------- | ----------- |
45
+ | `ascii-prefixes-only` | Enable faster parsing for well-behaved TTL files. | `true` |
46
+ | `num-triples-per-batch` | Triples per batch; lower values reduce memory usage. | `3_000_000` |
47
+ | `stxxl-memory` | Memory budget for sorting during the index build. | `'10G'` |
48
+ | `parse-parallel` | Parse input in parallel. | `true` |
49
+ | `only-pso-and-pos-permutations` | Build only PSO and POS permutations. Faster, but queries with predicate variables won't work. | `false` |
@@ -1,6 +1,6 @@
1
1
  import { Downloader } from '@lde/distribution-downloader';
2
2
  import { Importer, QleverIndexOptions } from './importer.js';
3
- import { Server } from './server.js';
3
+ import { QleverServerOptions, Server } from './server.js';
4
4
  export type QleverOptions = {
5
5
  /** Directory where downloaded data files are stored. */
6
6
  dataDir?: string;
@@ -10,7 +10,10 @@ export type QleverOptions = {
10
10
  downloader?: Downloader;
11
11
  /** Cache QLever indices and skip re-indexing when source data is unchanged. @default true */
12
12
  cacheIndex?: boolean;
13
- qleverOptions?: QleverIndexOptions;
13
+ /** Options for `qlever-index` (index building). */
14
+ indexOptions?: QleverIndexOptions;
15
+ /** Options for `qlever-server` (query processing). */
16
+ serverOptions?: QleverServerOptions;
14
17
  } & ({
15
18
  mode: 'docker';
16
19
  image: string;
@@ -1 +1 @@
1
- {"version":3,"file":"createQlever.d.ts","sourceRoot":"","sources":["../src/createQlever.ts"],"names":[],"mappings":"AAGA,OAAO,EACL,UAAU,EAEX,MAAM,8BAA8B,CAAC;AACtC,OAAO,EAAE,QAAQ,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AAC7D,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAErC,MAAM,MAAM,aAAa,GAAG;IAC1B,wDAAwD;IACxD,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,oBAAoB;IACpB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,6FAA6F;IAC7F,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,aAAa,CAAC,EAAE,kBAAkB,CAAC;CACpC,GAAG,CACA;IACE,IAAI,EAAE,QAAQ,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,GACD;IAAE,IAAI,EAAE,QAAQ,CAAA;CAAE,CACrB,CAAC;AAEF;;;;;GAKG;AACH,wBAAgB,YAAY,CAAC,OAAO,EAAE,aAAa;;;EA2BlD"}
1
+ {"version":3,"file":"createQlever.d.ts","sourceRoot":"","sources":["../src/createQlever.ts"],"names":[],"mappings":"AAGA,OAAO,EACL,UAAU,EAEX,MAAM,8BAA8B,CAAC;AACtC,OAAO,EAAE,QAAQ,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AAC7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAE1D,MAAM,MAAM,aAAa,GAAG;IAC1B,wDAAwD;IACxD,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,oBAAoB;IACpB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,6FAA6F;IAC7F,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,mDAAmD;IACnD,YAAY,CAAC,EAAE,kBAAkB,CAAC;IAClC,sDAAsD;IACtD,aAAa,CAAC,EAAE,mBAAmB,CAAC;CACrC,GAAG,CACA;IACE,IAAI,EAAE,QAAQ,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,GACD;IAAE,IAAI,EAAE,QAAQ,CAAA;CAAE,CACrB,CAAC;AAEF;;;;;GAKG;AACH,wBAAgB,YAAY,CAAC,OAAO,EAAE,aAAa;;;EA4BlD"}
@@ -25,12 +25,13 @@ export function createQlever(options) {
25
25
  indexName: options.indexName,
26
26
  downloader: options.downloader ?? new LastModifiedDownloader(options.dataDir),
27
27
  cacheIndex: options.cacheIndex,
28
- qleverOptions: options.qleverOptions,
28
+ qleverOptions: options.indexOptions,
29
29
  }),
30
30
  server: new Server({
31
31
  taskRunner,
32
32
  indexName: options.indexName ?? 'data',
33
33
  port,
34
+ qleverOptions: options.serverOptions,
34
35
  }),
35
36
  };
36
37
  }
package/dist/server.d.ts CHANGED
@@ -1,11 +1,18 @@
1
1
  import { SparqlServer } from '@lde/sparql-server';
2
2
  import { TaskRunner } from '@lde/task-runner';
3
+ export interface QleverServerOptions {
4
+ /** Maximum memory for query processing and caching. @default '4G' */
5
+ 'memory-max-size'?: string;
6
+ /** Default query timeout. @default '30s' */
7
+ 'default-query-timeout'?: string;
8
+ }
3
9
  export declare class Server<Task> implements SparqlServer {
4
10
  private readonly taskRunner;
5
11
  private readonly indexName;
6
12
  private task?;
7
13
  private readonly port;
8
- constructor({ taskRunner, indexName, port }: Arguments<Task>);
14
+ private readonly qleverOptions;
15
+ constructor({ taskRunner, indexName, port, qleverOptions }: Arguments<Task>);
9
16
  start(): Promise<void>;
10
17
  stop(): Promise<void>;
11
18
  get queryEndpoint(): URL;
@@ -13,6 +20,8 @@ export declare class Server<Task> implements SparqlServer {
13
20
  export interface Arguments<Task> {
14
21
  taskRunner: TaskRunner<Task>;
15
22
  indexName: string;
23
+ /** @default 7001 */
16
24
  port?: number;
25
+ qleverOptions?: QleverServerOptions;
17
26
  }
18
27
  //# sourceMappingURL=server.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../src/server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAG9C,qBAAa,MAAM,CAAC,IAAI,CAAE,YAAW,YAAY;IAC/C,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAmB;IAC9C,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,IAAI,CAAC,CAAO;IACpB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAS;gBAElB,EAAE,UAAU,EAAE,SAAS,EAAE,IAAI,EAAE,EAAE,SAAS,CAAC,IAAI,CAAC;IAM/C,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAStB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAOlC,IAAW,aAAa,IAAI,GAAG,CAE9B;CACF;AAED,MAAM,WAAW,SAAS,CAAC,IAAI;IAC7B,UAAU,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf"}
1
+ {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../src/server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAG9C,MAAM,WAAW,mBAAmB;IAClC,qEAAqE;IACrE,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,4CAA4C;IAC5C,uBAAuB,CAAC,EAAE,MAAM,CAAC;CAClC;AAOD,qBAAa,MAAM,CAAC,IAAI,CAAE,YAAW,YAAY;IAC/C,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAmB;IAC9C,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,IAAI,CAAC,CAAO;IACpB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAS;IAC9B,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAgC;gBAElD,EAAE,UAAU,EAAE,SAAS,EAAE,IAAI,EAAE,aAAa,EAAE,EAAE,SAAS,CAAC,IAAI,CAAC;IAO9D,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAStB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAOlC,IAAW,aAAa,IAAI,GAAG,CAE9B;CACF;AAED,MAAM,WAAW,SAAS,CAAC,IAAI;IAC7B,UAAU,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,oBAAoB;IACpB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,aAAa,CAAC,EAAE,mBAAmB,CAAC;CACrC"}
package/dist/server.js CHANGED
@@ -1,17 +1,23 @@
1
1
  import { waitForSparqlEndpointAvailable } from '@lde/wait-for-sparql';
2
+ const defaultQleverServerOptions = {
3
+ 'memory-max-size': '4G',
4
+ 'default-query-timeout': '30s',
5
+ };
2
6
  export class Server {
3
7
  taskRunner;
4
8
  indexName;
5
9
  task;
6
10
  port;
7
- constructor({ taskRunner, indexName, port }) {
11
+ qleverOptions;
12
+ constructor({ taskRunner, indexName, port, qleverOptions }) {
8
13
  this.taskRunner = taskRunner;
9
14
  this.indexName = indexName;
10
15
  this.port = port ?? 7001;
16
+ this.qleverOptions = { ...defaultQleverServerOptions, ...qleverOptions };
11
17
  }
12
18
  async start() {
13
19
  // TODO prevent double starts.
14
- this.task = await this.taskRunner.run(`qlever-server --index-basename ${this.indexName} --memory-max-size 6G --port ${this.port}`);
20
+ this.task = await this.taskRunner.run(`qlever-server --index-basename ${this.indexName} --memory-max-size ${this.qleverOptions['memory-max-size']} --default-query-timeout ${this.qleverOptions['default-query-timeout']} --port ${this.port}`);
15
21
  await waitForSparqlEndpointAvailable(this.queryEndpoint.toString());
16
22
  }
17
23
  async stop() {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lde/sparql-qlever",
3
- "version": "0.12.1",
3
+ "version": "0.13.0",
4
4
  "repository": {
5
5
  "url": "git+https://github.com/ldelements/lde.git",
6
6
  "directory": "packages/sparql-qlever"