Merged branch 'json'.
Automatically prefix all log messages with the plugin name (if available).
plugin: Reset context on some error conditions.
Use sdb_log() in place of sdb_plugin_log().
It's up to the error module to decide how to log. Inside the daemon, both are
basically equivalent.
It's up to the error module to decide how to log. Inside the daemon, both are
basically equivalent.
sysdb: Don't pretty-print JSON in non-interactive mode.
This is a work-around to fix integration tests (which expect the entire
output on one line). A better solution will rely on configurable output
formats.
Also, disable interactive mode when using -c <cmd> options. It's not
interactive after all :-)
This is a work-around to fix integration tests (which expect the entire
output on one line). A better solution will rely on configurable output
formats.
Also, disable interactive mode when using -c <cmd> options. It's not
interactive after all :-)
Merge branch 'master' of git://git.tokkee.org/sysdb
OS utils: Use readdir() instead of the now deprecated readdir_r().
Cf. https://sourceware.org/ml/libc-alpha/2016-02/msg00093.html
Cf. https://sourceware.org/ml/libc-alpha/2016-02/msg00093.html
dbi_test: Fix tests for libdbi < 0.9.
sysdb: If available, use YAJL to pretty-print JSON output.
Don't fetch timeseries info when fetching the interval.
For this purpose, add query options to fine-tune the behavior. These are
passed in to sdb_plugin_query.
For this purpose, add query options to fine-tune the behavior. These are
passed in to sdb_plugin_query.
plugin: Dynamically populate timeseries information when querying metrics.
Do so by wrapping the query output writer into another writer which fetches
and adds these information.
Do so by wrapping the query output writer into another writer which fetches
and adds these information.
Let the JSON formatter include a metric's data_names.
For that purpose, let the metric store provide a reference to the timeseries
information object (to be populated on read). The JSON formatter compiles a
list of unique data_names and outputs that alongside the other metric
metadata.
For that purpose, let the metric store provide a reference to the timeseries
information object (to be populated on read). The JSON formatter compiles a
list of unique data_names and outputs that alongside the other metric
metadata.
plugin: Add a helper function to query timeseries information.
This is a wrapper around the registered timeseries fetcher plugin.
This is a wrapper around the registered timeseries fetcher plugin.
utils strings: Add stringv_append_if_missing().
Add more string utility functions and unit tests.
dbi_test: Add some more connection tests.
strings utilities: Add helper functions for common string operations.
plugin: Drop support for the old timeseries fetcher.
timeseries::rrdtool plugin: Switch to the new timeseries-fetcher.
t/integration/mock_timeseries: Switch to the new timeseries-fetcher.
plugin: Add a new type of timeseries-fetcher plugins.
The new type (soon to replace the old) bundles a DESCRIBE callback along with
the actual fetch callback. DESCRIBE can be used to retrieve information about
a timeseries.
The new type (soon to replace the old) bundles a DESCRIBE callback along with
the actual fetch callback. DESCRIBE can be used to retrieve information about
a timeseries.
timeseries: Add data-structures and helpers to manage timeseries information.
Currently, timeseries information objects provide the names of data sources.
Currently, timeseries information objects provide the names of data sources.
t/unit/core/timeseries_test: Add minimalistic test for timeseries.
plugin: Refactor callback registration to avoid code duplication.
Add support for multiple metric data-stores.
It did not make sense to only store one and let conflicting values override
each other on each iteration. Instead, track each separately, along with the
respective last_update timestamp. This will allow to read the right data on
access.
At the moment, when requesting a timeseries, the most up to date data store
will be used.
The network plugin does not support sending multiple data stores at the
moment. It will only send the first.
It did not make sense to only store one and let conflicting values override
each other on each iteration. Instead, track each separately, along with the
respective last_update timestamp. This will allow to read the right data on
access.
At the moment, when requesting a timeseries, the most up to date data store
will be used.
The network plugin does not support sending multiple data stores at the
moment. It will only send the first.
Let the network protocol and SysQL support last_update for metric stores.
Store a separate last_update timestamp for metric stores.
Currently, it is (at least) the same as the metric's last_update timestamp.
We'll need this later when supporting multiple metric stores.
Currently, it is (at least) the same as the metric's last_update timestamp.
We'll need this later when supporting multiple metric stores.
store.h: Reuse the sdb_metric_store_t type for a metric's store field.
unixsock_test: Fix a potential uninitialized memory access in mock_write.
SSL utils: Fixed a memory leak in a couple of error conditions.
t/valgrind.suppress: Fix deduplication of cond jump.
This was introduced in 7645df5e8ef. The actual call traces differed a bit.
This was introduced in 7645df5e8ef. The actual call traces differed a bit.
t/valgrind.suppress: Remove duplicate.
Also, catch further errors in gcov_exit. Depending on the version, the call
traces are different.
Also, catch further errors in gcov_exit. Depending on the version, the call
traces are different.
version-gen.sh: Added .git suffix to default version again.
Release SysDB 0.8.0.
ReleaseNotes: Added 0.8.0 release.
Fix compilation with GCC when _GNU_SOURCE isn't defined.
That is, add some missing headers and bump POSIX compliance to POSIX:2008
which will ensure that 'struct timespec' is defined without funny tricks.
That is, add some missing headers and bump POSIX compliance to POSIX:2008
which will ensure that 'struct timespec' is defined without funny tricks.
Include strings.h instead of defining _BSD_SOURCE to get strcasecmp.
_BSD_SOURCE is deprecated in favor of _DEFAULT_SOURCE but also it's not
needed for strcasecmp() when including strings.h in addition to string.h.
_BSD_SOURCE is deprecated in favor of _DEFAULT_SOURCE but also it's not
needed for strcasecmp() when including strings.h in addition to string.h.
frontend/query: Add the DATA type to TIMESERIES replies.
This was lost in 9a96acd759c31211aa512e174339a9c178c4eb83.
This was lost in 9a96acd759c31211aa512e174339a9c178c4eb83.
frontend/query: Simplified code a little.
Enable flex verbose output only in verbose build mode.
frontend/query: Fixed an uninitialized value.
Clean up after checking compiler flags and fix C++ tests.
They just happened to work fine when done right after C tests.
They just happened to work fine when done right after C tests.
Enable silent automake rules by default (if available).
Merged branch 'master' of git://git.tokkee.org/sysdb.
Handle last_update/interval in the core rather than in memstore.
For this purpose, let the sdb_plugin_store_* functions fetch the latest
revision of the object to determine the last update interval and last
recorded interval. The memstore now expects both values to be passed in
whenever storing/updating an object.
For this purpose, let the sdb_plugin_store_* functions fetch the latest
revision of the object to determine the last update interval and last
recorded interval. The memstore now expects both values to be passed in
whenever storing/updating an object.
memstore: Let get_child() support arbitrary parent and child elements.
Add support for fetching arbitrary objects, including attributes.
That is, the backend now supports this. The functionality is not yet exposed
via SysQL.
That is, the backend now supports this. The functionality is not yet exposed
via SysQL.
frontend/query_test: Simplified result checks.
Don't track the expected length since it always matches strlen() anyway. The
additional check would hide the diff if it failed, adding an unnecessary step
for debugging failures.
Don't track the expected length since it always matches strlen() anyway. The
additional check would hide the diff if it failed, adding an unnecessary step
for debugging failures.
Include strings.h which is required for strcasecmp().
FETCH: Add parameter for fetching the main object without children.
That is, exclude any attributes or child objects.
Use this to simplify the TIMESERIES fetcher which no longer requires an
attribute callback.
That is, exclude any attributes or child objects.
Use this to simplify the TIMESERIES fetcher which no longer requires an
attribute callback.
Split the memstore module from the store module.
Renamed in-memory store types and functions to sdb_memstore*.
connection: Drop old and unused conn_node* types.
This was part of the old parser implementation.
This was part of the old parser implementation.
Removed sdb_store_fetch_timeseries from headers; it's gone.
store: Use full initializers for store objects.
Older versions of GCC/CLANG don't handle "missing" field initializers well.
Older versions of GCC/CLANG don't handle "missing" field initializers well.
configure: Include rrd.h when checking for rrd_client.h.
Apparently, this is needed for RRDtool 1.5.
Apparently, this is needed for RRDtool 1.5.
Build a more generic/powerful query API which writes to a store-writer.
Instead of letting the query implementation write JSON directly, let them emit
objects to a store-writer. This allows for more powerful and centralized
post-processing of the data and avoids code-duplication by moving all logic of
how to write out the data to the core. Also, this had a couple of nice side
effects and allowed for further simplication:
- The TIMESERIES command is now handled by the front-end (based on a FETCH of
the respective metric data); query plugin no longer have to implement this.
- All protocol specific information is now handled by the frontend; query
plugins no longer have to handle this (response-type).
- Further separation of the memory-store and generic store code.
Instead of letting the query implementation write JSON directly, let them emit
objects to a store-writer. This allows for more powerful and centralized
post-processing of the data and avoids code-duplication by moving all logic of
how to write out the data to the core. Also, this had a couple of nice side
effects and allowed for further simplication:
- The TIMESERIES command is now handled by the front-end (based on a FETCH of
the respective metric data); query plugin no longer have to implement this.
- All protocol specific information is now handled by the frontend; query
plugins no longer have to handle this (response-type).
- Further separation of the memory-store and generic store code.
Move the timeseries serialize to the timeseries module.
store: Don't report an error if a missing writer callback isn't used.
That is, allow to emit store objects to an incomplete writer as long as all
required callbacks are present.
That is, allow to emit store objects to an incomplete writer as long as all
required callbacks are present.
store: Use the JSON writer when querying the in-memory store.
That is, instead of writing to a JSON formatter directly, access it through
it's writer API. This will allow for more flexible store access.
That is, instead of writing to a JSON formatter directly, access it through
it's writer API. This will allow for more flexible store access.
store_json: Base the memstore emitter on the store-writer API.
store_json: Let the formatter implement the store-writer interface.
Read-only store types: const char ** → const char * const *.
This makes it truely read-only.
This makes it truely read-only.
store_json: Remove any memstore-specific code.
This will allow to further separate the JSON code from the memstore
implementation.
This will allow to further separate the JSON code from the memstore
implementation.
store_json: Fix parent/child detection.
Rewinding the formatter state has to happen any time we see a parent object of
the current object. This happens every time the current context isn't HOST
(hosts don't have any parents) or the new object is an ATTRIBUTE (which are
always children of whatever other object type).
This broke in 3603db13105aefac4d6ceb356bcfd118a92fa654.
Rewinding the formatter state has to happen any time we see a parent object of
the current object. This happens every time the current context isn't HOST
(hosts don't have any parents) or the new object is an ATTRIBUTE (which are
always children of whatever other object type).
This broke in 3603db13105aefac4d6ceb356bcfd118a92fa654.
store_json: Split sdb_store_json_emit into private functions.
The public function will only handle memstore specific logic.
The public function will only handle memstore specific logic.
store_json: Moved special casing of parent objects into the caller.
This makes the JSON module more generic by removing a special case of the
memory store. The caller may now emit arbitrary objects and the formatter will
do the right thing as long as parent-child relationships are right.
This makes the JSON module more generic by removing a special case of the
memory store. The caller may now emit arbitrary objects and the formatter will
do the right thing as long as parent-child relationships are right.
store, plugin: Let the plugin module determine an objects backends.
The store writer plugins are only expected to record the provided backend
(after merging it with existing entries).
The store writer plugins are only expected to record the provided backend
(after merging it with existing entries).
store: Further abstract internal handling of new objects.
Add a new type representing a to-be-stored object to simplify storing new
objects.
Add a new type representing a to-be-stored object to simplify storing new
objects.
store: Simplified store-attribute callback.
There's no need anymore to split this across multiple functions. It's easier
to follow if the code is in one place.
There's no need anymore to split this across multiple functions. It's easier
to follow if the code is in one place.
store: Add separate store-object types for the store writer API.
The argument list of some of the callbacks has already gotten kinda long and
we'll want to add more (backends, etc.). Introduce new types which provide all
meta-data of the respective store types.
Also, only use a single callback to store all kinds of attributes, similar to
how it was already done in the "proto" module.
The argument list of some of the callbacks has already gotten kinda long and
we'll want to add more (backends, etc.). Introduce new types which provide all
meta-data of the respective store types.
Also, only use a single callback to store all kinds of attributes, similar to
how it was already done in the "proto" module.
store: Dropped sdb_ prefix from private store types.
store.h: Updated some documentation comments.
A store instance isn't synonym to "the database" anymore.
A store instance isn't synonym to "the database" anymore.
plugin, store: Add service/metric "hostname" attributes centrally.
That is, let the respective sdb_plugin_store* functions do that instead of
requiring each store implementation to do so.
That is, let the respective sdb_plugin_store* functions do that instead of
requiring each store implementation to do so.
frontend/query_test: Test some weird, special cases.
store: Fix execution of more complex iterators.
That is, follow "indirections" of typed expressions if the iterator is not on
the top-most level.
That is, follow "indirections" of typed expressions if the iterator is not on
the top-most level.
Remove unused sdb_store_expr_iterable().
Allow and implement iterating arbitrary (non-constant) array values.
That is, iterators may now work with arithmetic expressions that evaluate to
an array.
That is, iterators may now work with arithmetic expressions that evaluate to
an array.
analyzer: Support more flexible iterator expressions.
In particular, more complex typed expressions may now include an iterator on a
lower level, like `LOOKUP services MATCHING ANY host.backend =~ 'foo'`. This
is done by adding more information to the analyzer context and pushing it down
to child nodes in the AST if necessary.
As a nice side-effect, the iterator analyzer does not longer have to know
about the specific type of its child node.
In particular, more complex typed expressions may now include an iterator on a
lower level, like `LOOKUP services MATCHING ANY host.backend =~ 'foo'`. This
is done by adding more information to the analyzer context and pushing it down
to child nodes in the AST if necessary.
As a nice side-effect, the iterator analyzer does not longer have to know
about the specific type of its child node.
analyzer: Fixed some error messages.
parser: Require a context for each parser operation.
That is, let the caller provide the execution context (object type) when
parsing incomplete commands (conditionals / arithmetic expressions). This
removes the need to call the analyzer again and avoids some special code in
the analyzer.
That is, let the caller provide the execution context (object type) when
parsing incomplete commands (conditionals / arithmetic expressions). This
removes the need to call the analyzer again and avoids some special code in
the analyzer.
Let the front-end handle STORE commands.
… rather than requiring each reader plugin to do so which doesn't make any
sense at all.
… rather than requiring each reader plugin to do so which doesn't make any
sense at all.
t/integration/store.sh: Add integration tests for the STORE command.
store: Do not canonicalize the hostname when fetching a timeseries.
This decision should be made on a higher level.
This decision should be made on a higher level.
frontend: Connection-specific functions now use the sdb_conn_ prefix.
… instead of sdb_fe_.
… instead of sdb_fe_.
frontend/connection.h: Removed sdb_fe_parse, it has been dropped.
store: Removed obsolete TODO note.
plugin, store: Handle hostname canonicalization in the plugin module.
This is a high-level functionality. Each store implementation should not have
to worry about it.
This is a high-level functionality. Each store implementation should not have
to worry about it.
sysdb(7): Briefly mention the object store.
sysdbd-store-memory(5): Added a manpage for store::memory.
store::memory: Add a plugin providing an in-memory store.
This plugin replaces the default, built-in store. It is a simple wrapper
around the built-in store implementation and, thus, provides exactly the same
functionality but wrapped into a plugin.
This plugin replaces the default, built-in store. It is a simple wrapper
around the built-in store implementation and, thus, provides exactly the same
functionality but wrapped into a plugin.
t/Makefile: Drop unused, old frontend/parser_test.
plugin: Report an error when writing to the store with no writers.
store: Drop the global (default) store.
Instead, register a store from sysdbd and make sure to re-register it on
reconfigure. Previously, the store plugin would have been dropped in that
case.
Instead, register a store from sysdbd and make sure to re-register it on
reconfigure. Previously, the store plugin would have been dropped in that
case.
store: All store functions now accept a store object.
That is, instead of operating on a global, shared instance.
That is, instead of operating on a global, shared instance.
store: Add wrapper functions to store an object in an arbitrary store.
core: Export the sdb_store, sdb_store_reader, sdb_store_writer types.
This is in preparation to more flexible store handling.
This is in preparation to more flexible store handling.
t/valgrind.suppress: Refine the suppression in the libc exit handler.
frontend: Use the plugin query interface instead of direct store access.
The built-in store is registered as a reader automatically at the moment.
The built-in store is registered as a reader automatically at the moment.
core: Add support for reader/query plugins.
A reader plugin can be used to query a data-store based on a query described
by an AST. The plugin module provides a generic function for this purpose.
At the moment, only a single reader plugin can be used at a time. Supporting
multiple readers requires a good merge strategy. The challenge is to handle
filters and query conditions correctly which may evaluate differently after
two stores have been merged.
A reader plugin can be used to query a data-store based on a query described
by an AST. The plugin module provides a generic function for this purpose.
At the moment, only a single reader plugin can be used at a time. Supporting
multiple readers requires a good merge strategy. The challenge is to handle
filters and query conditions correctly which may evaluate differently after
two stores have been merged.
![[tokkee]](http://tokkee.org/images/avatar.png)
