Running
Running ws4sqlite can be done via the commandline, and it's possible to specify its behaviour via commandline parameters.
Databases, id
's and Config (Companion) Files
id
's and Config (Companion) Filesws4sqlite behaviour when serving databases is configured with a mix of commandline parameters and naming conventions. You specify directly on the commandline the databases to serve, either specifying the path of the file (for file-based databases) or the id of the in-memory database. Then, for file paths, ws4sqlite will look for a "companion" configuration file in YAML format that have the same base name of the database filename, but with .yaml
extension. When present, it is used to load the serving parameters for that database.
For in-memory dbs, you indicate an id to be used for that database, followed - if needed - by the path of the companion file for the in-memory database, separated by a colon (:
).
In both cases, if the companion file is not present, default values will be used.
For example, if you run ws4sqlite as such:
It will:
serve a db from
~/file1.db
, creating it if absent, with an id offile1
;look for
~/file1.yaml
, and - if present - load from there the configuration for this db;serve a db from memory, with an id of
mem1
;load its configuration from
~/mem1.yaml
;serve a db from memory, with an id of
mem2
, and default configuration.
Since version 0.11.3, any extension can be used database file. Before that version, only .db
could be used.
Commandline Parameters
This is a complete commandline for ws4sqlite:
Of course, the usual --help
and --version
are supported. Let's discuss the other commandline parameters one by one.
--bind-host
--bind-host
Host to bind to. Defaults to 0.0.0.0
, meaning to accept connections from any local network interface. Different values are possible to restrict connections to a particular subnet.
--port
--port
Port to use for incoming network communication. Defaults to 12321
.
--db
--db
Can be repeated.
Specifies one or more file paths to load and serve as SQLite db's. It will use the base name (without the .db
suffix) as the id of the database, to use in the URL of the request , and will look for a configuration/companion file in the same path, named <id>.yaml
.
It is also possible to specify a companion file at a different path, by specifying it after a colon (:
). Example: --db myFile.db:/another/path/myFileConfig.yaml
.
--mem-db
--mem-db
Can be repeated.
Specifies one or more id for in-memory databases. Optionally, it's possible to specify also the path of the configuration file, after a colon (:
).
See the example above for a clearer explanation.
--serve-dir
--serve-dir
Specifies a directory to serve via the internal web server. See the relevant docs page.
Output
ws4sqlite will parse the commandline and the (eventual) config files, attempt to open and connect to the various databases, creating their respective files as needed. Then it will output a summary of all the configurations, like this:
Last updated