summaryrefslogtreecommitdiff
path: root/ACE/examples/Monitor/Group/group.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'ACE/examples/Monitor/Group/group.cpp')
-rw-r--r--ACE/examples/Monitor/Group/group.cpp168
1 files changed, 168 insertions, 0 deletions
diff --git a/ACE/examples/Monitor/Group/group.cpp b/ACE/examples/Monitor/Group/group.cpp
new file mode 100644
index 00000000000..5f34bd8ec62
--- /dev/null
+++ b/ACE/examples/Monitor/Group/group.cpp
@@ -0,0 +1,168 @@
+// $Id$
+
+#include "ace/OS_NS_unistd.h"
+#include "ace/streams.h"
+#include "ace/Monitor_Point_Registry.h"
+#include "ace/Monitor_Admin_Manager.h"
+
+#include "ace/Monitor_Control/Monitor_Control.h"
+
+#include "examples/Monitor/MC_Test_Utilities.h"
+
+#if defined (ACE_HAS_MONITOR_FRAMEWORK) && (ACE_HAS_MONITOR_FRAMEWORK == 1)
+
+using namespace ACE_VERSIONED_NAMESPACE_NAME::ACE::Monitor_Control;
+
+/// Subclass of ACE_Task_Base, meaning that the override of
+/// the svc() method below will run in a new thread when
+/// activate() is called on a class instance.
+class Monitor_Checker : public ACE_Task_Base
+{
+public:
+ int svc (void)
+ {
+ /// Get an instance of the MC service singleton.
+ MC_ADMINMANAGER* mgr =
+ ACE_Dynamic_Service<Monitor_Admin_Manager>::instance ("MC_ADMINMANAGER");
+
+ ACE::Monitor_Control::Monitor_Base *cpu_monitor =
+ mgr->admin ().monitor_point ("OS/Processor/CPULoad");
+
+ ACE::Monitor_Control::Monitor_Base *memory_monitor =
+ mgr->admin ().monitor_point ("OS/Memory/TotalUsage");
+
+ ACE::Monitor_Control::Monitor_Base *bytes_monitor =
+ mgr->admin ().monitor_point ("OS/Network/BytesSent");
+
+ /// Query the monitor for its data every 2 seconds, and call the
+ /// appropriate display function.
+ for (int i = 0; i < 10; ++i)
+ {
+ ACE_OS::sleep (2);
+
+ Monitor_Control_Types::Data cpu_data (cpu_monitor->type ());
+ cpu_monitor->retrieve (cpu_data);
+ MC_Test_Utilities::display_cpu_load (cpu_data);
+
+ Monitor_Control_Types::Data mem_data (memory_monitor->type ());
+ memory_monitor->retrieve (mem_data);
+ MC_Test_Utilities::display_memory_usage (mem_data);
+
+ Monitor_Control_Types::Data bytes_data (bytes_monitor->type ());
+ bytes_monitor->retrieve (bytes_data);
+ MC_Test_Utilities::display_bytes_sent (bytes_data);
+
+ cout << endl;
+ }
+
+ cpu_monitor->remove_ref ();
+ memory_monitor->remove_ref ();
+ bytes_monitor->remove_ref ();
+
+ return 0;
+ }
+};
+
+#endif /* ACE_HAS_MONITOR_FRAMEWORK==1 */
+
+int
+ACE_TMAIN (int /* argc */, ACE_TCHAR * /* argv */ [])
+{
+#if defined (ACE_HAS_MONITOR_FRAMEWORK) && (ACE_HAS_MONITOR_FRAMEWORK == 1)
+
+ /// Creates these future group members without automatic update.
+ Monitor_Base *cpu_load_monitor =
+ create_os_monitor<CPU_LOAD_MONITOR> ();
+ Monitor_Base *bytes_sent_monitor =
+ create_os_monitor<BYTES_SENT_MONITOR> ();
+ Monitor_Base *memory_usage_monitor =
+ create_os_monitor<MEMORY_USAGE_MONITOR> ();
+
+ Monitor_Group *group = new Monitor_Group ("Test_Group");
+
+ group->add_member (cpu_load_monitor);
+ group->add_member (bytes_sent_monitor);
+ group->add_member (memory_usage_monitor);
+
+ /// Register the group as an auto-updated monitor point.
+ MC_ADMINMANAGER* mgr =
+ ACE_Dynamic_Service<MC_ADMINMANAGER>::instance ("MC_ADMINMANAGER");
+ bool good_add = mgr->admin ().monitor_point (group, ACE_Time_Value (2));
+
+ if (!good_add)
+ {
+ ACE_ERROR ((LM_ERROR,
+ "Group monitor \"%s\" registration failed.\n",
+ group->name ()));
+ }
+
+ /// A quick test of the registry's name cache.
+ Monitor_Control_Types::NameList mc_names =
+ Monitor_Point_Registry::instance ()->names ();
+
+ cout << "stored in monitor point registry:" << endl << endl;
+
+ for (Monitor_Control_Types::NameList::Iterator i (mc_names);
+ !i.done ();
+ i.advance ())
+ {
+ ACE_CString *item = 0;
+ i.next (item);
+
+ cout << item->c_str () << endl;
+ }
+
+ cout << endl;
+
+ /// Runs the reactor's event loop in a separate thread so the timer(s)
+ /// can run concurrently with the application.
+ START_PERIODIC_MONITORS;
+
+ /// Run the monitor checker in a separate thread.
+ Monitor_Checker monitor_checker;
+ monitor_checker.activate ();
+
+ char * str_array[5] = {0};
+
+ for (int i = 0; i < 10; ++i)
+ {
+ ACE_OS::sleep (1);
+
+ /// Alternate between letting the CPU sleep and keeping it
+ /// busy.
+ if (i % 2 == 0)
+ {
+ ACE_OS::sleep (1);
+ }
+ else
+ {
+ for (unsigned long j = 0; j < 5050505; j++)
+ {
+ (void) ACE::gcd (2419233733UL, 567715713UL);
+ }
+ }
+
+ /// Allocate a large string in each of the first 5 loops,
+ /// free them in the last 5 loops.
+ if (i < 5)
+ {
+ str_array[i] = new char[1024*1024*10];
+ }
+ else
+ {
+ delete [] str_array[i - 5];
+ }
+ }
+
+ /// End the reactor's event loop, stopping the timer(s).
+ STOP_PERIODIC_MONITORS;
+
+ cpu_load_monitor->remove_ref ();
+ bytes_sent_monitor->remove_ref ();
+ memory_usage_monitor->remove_ref ();
+ group->remove_ref ();
+
+#endif /* ACE_HAS_MONITOR_FRAMEWORK==1 */
+
+ return 0;
+}