DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
ZmqContext.hpp
Go to the documentation of this file.
1#ifndef IPM_INCLUDE_IPM_ZMQCONTEXT_HPP_
2#define IPM_INCLUDE_IPM_ZMQCONTEXT_HPP_
3
13#include "ers/Issue.hpp"
14#include "logging/Logging.hpp" // NOTE: if ISSUES ARE DECLARED BEFORE include logging/Logging.hpp, TLOG_DEBUG<<issue wont work.
15#include "zmq.hpp"
16
17enum
18{
39};
40
41namespace dunedaq {
42
52 ZmqOperationError,
53 "An exception occured while calling " << operation << " on the ZMQ " << direction << " socket: "
54 << what << " (connection_string: " << connection_string << ")",
55 ((std::string)operation)((std::string)direction)((const char*)what)(
56 (std::string)connection_string)) // NOLINT
58
67 ZmqSendError,
68 "An exception occurred while sending " << N << " bytes to " << topic << ": " << what,
69 ((const char*)what)((int)N)((std::string)topic)) // NOLINT
71
79 ZmqReceiveError,
80 "An exception occured while receiving " << which << ": " << what,
81 ((const char*)what)((const char*)which)) // NOLINT
83
91 ZmqSubscribeError,
92 "An execption occured while subscribing to " << topic << ": " << what,
93 ((const char*)what)((std::string)topic)) // NOLINT
95
103 ZmqUnsubscribeError,
104 "An execption occured while unsubscribing from " << topic << ": " << what,
105 ((const char*)what)((std::string)topic)) // NOLINT
107
108namespace ipm {
110{
111public:
113 {
114 static ZmqContext s_ctx;
115 return s_ctx;
116 }
117
118 zmq::context_t& GetContext() { return m_context; }
119
120 void set_context_threads(int nthreads)
121 {
122 TLOG_DEBUG(TLVL_ZMQCONTEXT) << "Setting ZMQ Context IO thread count to " << nthreads;
123 m_context.set(zmq::ctxopt::io_threads, nthreads);
124 }
125 void set_context_maxsockets(int max_sockets)
126 {
127 TLOG_DEBUG(TLVL_ZMQCONTEXT) << "Setting ZMQ Context max sockets to " << max_sockets;
128 m_context.set(zmq::ctxopt::max_sockets, max_sockets);
129 }
130
131private:
133 {
134 auto threads_c = getenv("IPM_ZMQ_IO_THREADS");
135 if (threads_c != nullptr) {
136 auto threads = std::atoi(threads_c); // NOLINT If a conversion error occurs, we discard the result
137 if (threads > 1) {
138 set_context_threads(threads);
139 }
140 }
141
142 bool sockets_set = false;
143 auto sockets_c = getenv("IPM_ZMQ_MAX_SOCKETS");
144 if (sockets_c != nullptr) {
145 auto sockets = std::atoi(sockets_c); // NOLINT If a conversion error occurs, we discard the result
146 if (sockets > s_minimum_sockets) {
147 set_context_maxsockets(sockets);
148 sockets_set = true;
149 }
150 }
151 if (!sockets_set) {
153 }
154 }
156 TLOG_DEBUG(TLVL_ZMQCONTEXT) << "Closing ZMQ Context";
157 m_context.close();
158 TLOG_DEBUG(TLVL_ZMQCONTEXT) << "ZMQ Context closed";
159 }
160 zmq::context_t m_context;
161 static constexpr int s_minimum_sockets = 16636;
162
163 ZmqContext(ZmqContext const&) = delete;
165 ZmqContext& operator=(ZmqContext const&) = delete;
167};
168} // namespace ipm
169} // namespace dunedaq
170
171#endif // IPM_INCLUDE_IPM_ZMQCONTEXT_HPP_
#define ERS_DECLARE_ISSUE(namespace_name, class_name, message, attributes)
@ TLVL_ZMQSUBSCRIBER_RECV_DATA_2
@ TLVL_ZMQSUBSCRIBER_RECV_HDR
@ TLVL_ZMQSUBSCRIBER_RECV_END
@ TLVL_ZMQRECEIVER_RECV_HDR_2
@ TLVL_ZMQSUBSCRIBER_RECV_DATA
@ TLVL_ZMQSENDER_SEND_END
@ TLVL_ZMQRECEIVER_RECV_DATA
@ TLVL_ZMQSUBSCRIBER_RECV_HDR_2
@ TLVL_ZMQCONTEXT
@ TLVL_ZMQSENDER_DESTRUCTOR
@ TLVL_ZMQPUBLISHER_DESTRUCTOR
@ TLVL_ZMQPUBLISHER_SEND_START
@ TLVL_ZMQPUBLISHER_SEND_ERR
@ TLVL_CONNECTIONSTRING
@ TLVL_ZMQRECEIVER_RECV_END
@ TLVL_ZMQRECEIVER_RECV_HDR
@ TLVL_ZMQRECEIVER_RECV_DATA_2
@ TLVL_ZMQSENDER_SEND_ERR
@ TLVL_ZMQPUBLISHER_SEND_END
@ TLVL_ZMQSENDER_SEND_START
void set_context_threads(int nthreads)
static ZmqContext & instance()
ZmqContext & operator=(ZmqContext &&)=delete
void set_context_maxsockets(int max_sockets)
ZmqContext(ZmqContext const &)=delete
static constexpr int s_minimum_sockets
ZmqContext(ZmqContext &&)=delete
zmq::context_t & GetContext()
ZmqContext & operator=(ZmqContext const &)=delete
#define TLOG_DEBUG(lvl,...)
Definition Logging.hpp:112
The DUNE-DAQ namespace.