IXWebSocket/ws/ws_cobra_metrics_publish.cpp

78 lines
2.4 KiB
C++
Raw Normal View History

2019-09-19 21:51:34 +02:00
/*
* ws_cobra_metrics_publish.cpp
* Author: Benjamin Sergeant
* Copyright (c) 2019 Machine Zone, Inc. All rights reserved.
*/
#include <atomic>
2019-09-23 19:25:23 +02:00
#include <chrono>
#include <fstream>
2019-09-19 21:51:34 +02:00
#include <ixcobra/IXCobraMetricsPublisher.h>
#include <spdlog/spdlog.h>
2019-09-23 19:25:23 +02:00
#include <sstream>
#include <thread>
2019-09-19 21:51:34 +02:00
namespace ix
{
int ws_cobra_metrics_publish_main(const ix::CobraConfig& config,
2019-09-19 21:51:34 +02:00
const std::string& channel,
const std::string& path,
bool stress)
2019-09-19 21:51:34 +02:00
{
std::atomic<int> sentMessages(0);
std::atomic<int> ackedMessages(0);
CobraConnection::setPublishTrackerCallback(
2019-09-23 19:25:23 +02:00
[&sentMessages, &ackedMessages](bool sent, bool acked) {
2019-09-19 21:51:34 +02:00
if (sent) sentMessages++;
if (acked) ackedMessages++;
2019-09-23 19:25:23 +02:00
});
2019-09-19 21:51:34 +02:00
CobraMetricsPublisher cobraMetricsPublisher;
cobraMetricsPublisher.enable(true);
2020-03-21 01:00:18 +01:00
cobraMetricsPublisher.configure(config, channel);
2019-09-19 21:51:34 +02:00
2019-09-23 19:25:23 +02:00
while (!cobraMetricsPublisher.isAuthenticated())
;
2019-09-19 21:51:34 +02:00
std::ifstream f(path);
2019-09-23 19:25:23 +02:00
std::string str((std::istreambuf_iterator<char>(f)), std::istreambuf_iterator<char>());
2019-09-19 21:51:34 +02:00
Json::Value data;
Json::Reader reader;
if (!reader.parse(str, data)) return 1;
if (!stress)
{
auto msgId = cobraMetricsPublisher.push(channel, data);
spdlog::info("Sent message: {}", msgId);
2019-09-19 21:51:34 +02:00
}
else
{
// Stress mode to try to trigger server and client bugs
while (true)
{
2019-09-23 19:25:23 +02:00
for (int i = 0; i < 1000; ++i)
2019-09-19 21:51:34 +02:00
{
cobraMetricsPublisher.push(channel, data);
}
cobraMetricsPublisher.suspend();
cobraMetricsPublisher.resume();
// FIXME: investigate why without this check we trigger a lock
2019-09-23 19:25:23 +02:00
while (!cobraMetricsPublisher.isAuthenticated())
;
2019-09-19 21:51:34 +02:00
}
}
// Wait a bit for the message to get a chance to be sent
// there isn't any ack on publish right now so it's the best we can do
// FIXME: this comment is a lie now
std::this_thread::sleep_for(std::chrono::milliseconds(100));
spdlog::info("Sent messages: {} Acked messages {}", sentMessages, ackedMessages);
return 0;
}
2019-09-23 19:25:23 +02:00
} // namespace ix