SpectatorD is a high-performance telemetry daemon that listens for metrics specified by a text-based protocol and publishes updates periodically to an Atlas aggregator service. It consolidates the logic required to apply common tagging to all metrics received, maintain metric lifetimes, and route metrics to the correct backend.
See the Atlas Documentation site for more details on SpectatorD.
- Start
spectatord
in debug mode (--debug
) to send metrics to a dev stack of the Atlas aggregator, which will perform validation and return the correct HTTP status codes for payloads, then drop the metrics on the floor. Alternatively, you can also configure it to send metrics to/dev/null
. - Use the
metrics_gen
binary to generate and send a stream of metrics to a running spectatord binary. - Use the
perf-record
andperf-report
Linux utilities to measure the performance of the running binary. - The
udp_numbers.pl
script is used to automate runningmetrics_gen
with different kernel settings for UDP sockets.
# setup python venv and activate, to gain access to conan cli
./setup-venv.sh
source venv/bin/activate
./build.sh # [clean|clean --confirm|skiptest]
# run the binary locally
./cmake-build/bin/spectatord_main --enable_external --no_common_tags
# test publish
echo "c:server.numRequests,nf.app=spectatord_$USER,id=failed:1" | nc -u -w0 localhost 1234
echo "c:server.numRequests,nf.app=spectatord_$USER,id=success:1" | nc -u -w0 localhost 1234
# parse errors
echo ":server.numRequests,nf.app=spectatord_$USER,id=failed:1" | nc -u -w0 localhost 1234
echo "c:server.numRequests,nf.app=spectatord_$USER,id=failed" | nc -u -w0 localhost 1234
echo "c::1" | nc -u -w0 localhost 1234
- Install the Conan plugin for CLion.
- CLion > Settings > Plugins > Marketplace > Conan > Install
- Configure the Conan plugin.
- The easiest way to configure CLion to work with Conan is to build the project first from the command line.
- This will establish the
$PROJECT_HOME/CMakeUserPresets.json
file, which will allow you to choose the custom CMake configuration created by Conan when creating a new CMake project. Using this custom profile will ensure that sources are properly indexed and explorable.
- This will establish the
- Open the project. The wizard will show three CMake profiles.
- Disable the default Cmake
Debug
profile. - Enable the CMake
conan-debug
profile.
- Disable the default Cmake
- CLion > View > Tool Windows > Conan > (gear) > Conan Executable:
$PROJECT_HOME/venv/bin/conan
- The easiest way to configure CLion to work with Conan is to build the project first from the command line.
The spectatord
project also supports a platform-agnostic build. The only prerequisite is the
installation of Docker
. Please see the file DOCKERBUILD.md in the docs
folder for more information.
When building locally on MacOS, you may see the following errors when running binaries compiled with ASAN:
malloc: nano zone abandoned due to inability to reserve vm space.
This warning can be turned off with export MallocNanoZone=0
(link).