- infos = Mount the KDB as a FUSE-filesystem
- infos/author = Alexander Firbas [email protected]
- infos/licence = BSD
- infos/provides =
- infos/needs =
- infos/recommends =
- infos/placements =
- infos/status =
- infos/metadata =
- infos/description = Mount the KDB as a FUSE-filesystem
Mount elektra's KDB as a fuse(py) filesystem.
This tool enables the inspection and modification of the KDB, in the form of a classical filesystem, as it is observed by a given running process. In the simplest case, an Elektra key appears as a file with the key name as file path and with the key value as file content.
This enables users to interact with Elektra
- using standard Unix tooling, making Elektra more accessible
- with standard system/library procedures
- without the need to learn other tooling of libelektra
- with additional features: e.g. the ability to effortlessly write binary keys
The package comes with a preconfigured docker environment for expirimentation/debugging/developement.
Ensure docker is installed and run
cd src/tools/fuse/docker
./run_new_container.sh
This (re)creates the container if necessary and starts an interactive session with keys for testing already created (see docker/create_keys.sh
).
The filesystem is mounted below ~/mount
.
For debugging purposes, a logfile is written to ~/nohup.out
inside the container.
Install either libelektra5-fuse
or libelektra5-all
.
See also installation.
Alternatively, if
- all requirements for Elektras python binding are satisfied,
fuse
is available (for example via the debian packagefuse
) andpython3 >= 3.6
with packagespip
andwheel
are installed,
the tool can be compiled and installed as described here.
For this, the TOOLS
and BINDINGS
variables need to be set accordingly. (This tool is named fuse
, the binding is named python
).
After installation, to mount the filesystem below the (already existing) directory <mount point>
(as root-user), run:
sudo kdb fuse <mount point>
To view all available options, run
kdb fuse --help
Directly below the mount point, for every process running on the system (except those whose current working directory lies below said mountipoint, e.g. the shell exporing the hierarchy), a directory named after the respective process identifier is exposed.
For convinience, each such directory possesses numerous extened filesystem attributes that identify the process, user, etc., that can be listed by:
xattr -l <mount point>/<pid>
Below any such pid-directory, the elektra key database is mounted bidirectionally (i.e. read-write capable) using directories that correspond to the different namespaces:
user:
system:
dir:
spec:
proc:
cascading:
, corresponding to the/
namespace in Elektra: This is useful for inspection purposes, but beware that write operations in this namespace are disabled.
Exceptions:
default:
(only exists for cascading lookups)
These first two layers, (e.g mountpoint/12/system:
) are read only. Deeper layers (expect the cascading namespace) support writing: any change is directly updated in the backing Elektra-Key-Database.
All Elektra operations are performed "from the perspective" of the respective process. This is done by only calling libelektra/kdb from special "mock"-processes that mimic all of the relevant attributes Elektra uses to resolve its keys.
The mocked attributes are:
- the user and group (for the
user:
namespace) - working directory (for the
dir:
namespace) - environment variables (for the
proc:
namespace) - the process arguments (for the
proc:
namespace)
The filesystem structure mounted below the mountpoint could present as follows: (restructed to only one process with pid 41, with a maximum listing depth of 4)
|-- 41
| |-- cascading:
| | |-- dir_and_file_at_once
| | | `-- leaf
| | |-- dirkey
| | |-- elektra
| | | |-- modules
| | | `-- version
| | |-- info
| | `-- person
| | `-- name
| `-- user:
| |-- dir_and_file_at_once
| | |-- @elektra.value
| | `-- leaf
| |-- info
| `-- person
| `-- name
as obtained with
tree -L 4 mountpoint
Elektra cannot map perfectly to the structure of a classical filesystem as described here. Whenever deviations are necessary, the goal is to maximize usability and adhere to the expectations of common Unix tools.
In Elektra, there is no need to have a path
of continous keys between ancestors.
E.g. the existence of user:/a
and user:/a/b/c
does not imply the existence of user:/a/b
.
Such intermediate keys are mapped to "virtual" directories, s.t. navigation in an interactive manner is possible and the directory tree is continous.
A side effect is that creating/deleting a single key can create/delete multiple "virtual" directories at once.
For example, normally touch /does_not_exist/file
will not succeed if the directory "does_not_exist" does not exist, whereas here, a (virtual) directory "does_not_exist" will appear.
Another is that copies created with cp -r
will not have these vacuous intermediaries but instead empty keys.
For example, consider the situation of the key system:/A/B
being present, but not system:/A
. Then, copying the corresponding directory A
to A_copy
will result in the key system:/A_copy
being created, although it was not present, since to the filesystem (in this case cp
) there is no distinction between "virtual" and real keys.
In Elektra, there are only keys and no distinction between directories and files are made. To enable a bidirectional mapping into a classical file system, the following mechanism is employed:
If a key (A
) exists, and has some child key (B
), A
is treated as a directory containing B
and a special file @elektra.value
. This file is used to access the value of A
.
Some side effects arise:
E.g. recursively deleting directories with rm -r
containing @elektra.value
files raises (task uncritical) errors when attempting to delete a parent directory which was already deleted with the removal of an @elektra.value
file directly below.
Keys at the bottom of the hierarchy are normally treated as files. However in certain cases, like explicitly creating directories using mkdir
, this would result in files being displayed, making it impossible to expand the hierarchy using standard tools.
Therefore, when a directory is created, the special metakey fuse/directory
is set to override this behavior.
The filesystem attributes are sourced from the file obtained by kdb file
.
For some keys, no such file is returned, or the returned file does not exist in actuality. In these cases, fake attributes are used to preserve usability.
To increase compatibility, currently the timestamps from these files are not used, as this prompts software like vim
to produce warnings/errors.
Meta-keys are mapped bidirectionally to extended file attributes (xattrs).
To enable interoperability with other tools, the meta:/
prefix is must not be present and is added internally when reading/writing accessing meta keys. The listing of attributes however will show them prefix-less.
Furthermore, no binary values for these attributes are allowed. (As libelektra does not accept those).
An example usage might be:
#set the metadata metakeyname=metakeyvalue on the key keyname
xattr -w metakeyname metakeyvalue keyname
#(this is equivalent to this kdb call)
kdb meta-set keyname metakeyname metakeyvalue
#list meta-keys
xattr -l keyname
For futher reference, see xattr(1)
on how to read/write/list these attributes.
If a value is to be written that cannot be decoded using the systems default encoding, it is treated as binary, and the appropriate meta:/binary
metakey is set.
- Moving an
@elektra.value
-file corrupts the filesystem/key database (See this issue). As editors likevim
may move a file during editing, such editors cannot reliably be used on these pseudo-files. - Only works on POSIX-compatible systems with support for FUSE (via fusepy)
- chmod/chown is not implemented (i.e. does nothing and reports success) and does not signal a "not supported error" to enable compatibility with common tools like
cp
.