1 #ifndef _MADARA_MULTICAST_TRANSPORT_READ_THREAD_H_ 2 #define _MADARA_MULTICAST_TRANSPORT_READ_THREAD_H_ 24 #include "ace/Mutex.h" 25 #include "ace/Barrier.h" 26 #include "ace/Atomic_Op_T.h" 27 #include "ace/Thread_Mutex.h" 28 #include "ace/SOCK_Dgram_Mcast.h" 30 #include "ace/Synch.h" 60 const ACE_INET_Addr & address,
61 ACE_SOCK_Dgram & write_socket,
62 ACE_SOCK_Dgram_Mcast & read_socket,
92 const char * print_prefix,
115 #ifndef _MADARA_NO_KARL_ 118 #endif // _MADARA_NO_KARL_ 135 #endif // _MADARA_MULTICAST_TRANSPORT_READ_THREAD_H_ MulticastTransportReadThread(const TransportSettings &settings, const std::string &id, const ACE_INET_Addr &address, ACE_SOCK_Dgram &write_socket, ACE_SOCK_Dgram_Mcast &read_socket, BandwidthMonitor &send_monitor, BandwidthMonitor &receive_monitor, PacketScheduler &packet_scheduler)
Constructor.
PacketScheduler & packet_scheduler_
scheduler for mimicking target network conditions
void run(void)
The main loop internals for the read thread.
This class stores variables and their values for use by any entity needing state information in a thr...
Provides scheduler for dropping packets.
const std::string id_
host:port identifier of this process
Thread for reading knowledge updates through a Multicast datagram socket.
knowledge::ThreadSafeContext * context_
knowledge context
void init(knowledge::KnowledgeBase &knowledge)
Initializes MADARA context-related items.
Holds basic transport settings.
Compiled, optimized KaRL logic.
ACE_SOCK_Dgram & write_socket_
underlying socket for sending
Abstract base class for implementing threads.
This class provides a distributed knowledge base to users.
BandwidthMonitor & receive_monitor_
monitor for receiving bandwidth usage
::std::map< std::string, KnowledgeRecord > KnowledgeMap
madara::knowledge::CompiledExpression on_data_received_
data received rules, defined in Transport settings
Container for quality-of-service settings.
void rebroadcast(const char *print_prefix, MessageHeader *header, const knowledge::KnowledgeMap &records)
Sends a rebroadcast packet.
Provides monitoring capability of a transport's bandwidth.
const QoSTransportSettings settings_
quality-of-service transport settings
Provides functions and classes for the distributed knowledge base.
ACE_SOCK_Dgram_Mcast & read_socket_
The multicast socket we are reading from.
BandwidthMonitor & send_monitor_
monitor for sending bandwidth usage
Copyright (c) 2015 Carnegie Mellon University.
void cleanup(void)
Cleanup function called by thread manager.
ACE_INET_Addr address_
The multicast address we are subscribing to.
madara::utility::ScopedArray< char > buffer_
buffer for receiving