draconisplusplus/subprojects/quill-4.2.0/examples/bounded_dropping_queue_frontend.cpp

54 lines
1.6 KiB
C++
Raw Normal View History

2024-06-02 06:03:21 -04:00
#include "quill/Backend.h"
#include "quill/Frontend.h"
#include "quill/LogMacros.h"
#include "quill/Logger.h"
#include "quill/sinks/ConsoleSink.h"
#include <cstdint>
#include <utility>
/**
* This example demonstrates how to change the type of the Single Producer Single Consumer (SPSC)
* queue used by the frontend.
*
* By default, the library uses an UnboundedBlocking queue, which starts small with
* initial_queue_capacity and reallocates up to 2GB as needed.
*/
/**
* Create a custom frontend config
*/
struct CustomFrontendOptions
{
// Set the queue to BoundedDropping
static constexpr quill::QueueType queue_type = quill::QueueType::BoundedDropping;
// Set small capacity to demonstrate dropping messages in this example
static constexpr uint32_t initial_queue_capacity = 256;
static constexpr uint32_t blocking_queue_retry_interval_ns = 800;
static constexpr bool huge_pages_enabled = false;
};
/**
* A new Frontend and Logger should be defined to use the custom frontend options.
*/
using CustomFrontend = quill::FrontendImpl<CustomFrontendOptions>;
using CustommLogger = quill::LoggerImpl<CustomFrontendOptions>;
int main()
{
// Start the backend thread
quill::BackendOptions backend_options;
quill::Backend::start(backend_options);
// Frontend
auto console_sink = CustomFrontend::create_or_get_sink<quill::ConsoleSink>("sink_id_1");
CustommLogger* logger = CustomFrontend::create_or_get_logger("root", std::move(console_sink));
for (int i = 0; i < 32; ++i)
{
LOG_INFO(logger, "Bounded queue example log message num {}", i);
}
}