Sirikata
libspace/include/sirikata/space/LoadMonitor.hpp
Go to the documentation of this file.
00001 /*  Sirikata
00002  *  LoadMonitor.hpp
00003  *
00004  *  Copyright (c) 2009, Tahir Azim.
00005  *  All rights reserved.
00006  *
00007  *  Redistribution and use in source and binary forms, with or without
00008  *  modification, are permitted provided that the following conditions are
00009  *  met:
00010  *  * Redistributions of source code must retain the above copyright
00011  *    notice, this list of conditions and the following disclaimer.
00012  *  * Redistributions in binary form must reproduce the above copyright
00013  *    notice, this list of conditions and the following disclaimer in
00014  *    the documentation and/or other materials provided with the
00015  *    distribution.
00016  *  * Neither the name of Sirikata nor the names of its contributors may
00017  *    be used to endorse or promote products derived from this software
00018  *    without specific prior written permission.
00019  *
00020  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
00021  * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
00022  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
00023  * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
00024  * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
00025  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
00026  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
00027  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
00028  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
00029  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
00030  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00031  */
00032 
00033 #ifndef _SIRIKATA_LOAD_MONITOR_HPP_
00034 #define _SIRIKATA_LOAD_MONITOR_HPP_
00035 
00036 
00037 #include <sirikata/space/ServerMessage.hpp>
00038 #include <sirikata/core/service/PollingService.hpp>
00039 
00040 #include "Protocol_CSeg.pbj.hpp"
00041 
00042 namespace Sirikata {
00043 
00044 class SpaceContext;
00045 class CoordinateSegmentation;
00046 
00047 typedef struct ServerLoadInfo{
00048   ServerID mServerID;
00049   float mLoadReading;
00050 
00051   float mNetworkCapacity;
00052 
00053   ServerLoadInfo(ServerID svrID, float load, float capacity)
00054     : mServerID(svrID), mLoadReading(load), mNetworkCapacity(capacity)
00055   {
00056   }
00057 
00058 } ServerLoadInfo;
00059 
00060 
00061 
00062 class SIRIKATA_SPACE_EXPORT LoadMonitor : public MessageRecipient, public PollingService {
00063 public:
00064     LoadMonitor(SpaceContext* ctx, CoordinateSegmentation* cseg);
00065     ~LoadMonitor();
00066 
00067   void addLoadReading();
00068 
00069   void sendLoadReadings();
00070 
00071   float getCurrentLoadReading();
00072 
00073   float getAveragedLoadReading();
00074 
00075     // From MessageRecipient
00076     void receiveMessage(Message* msg);
00077 
00078 private:
00079     virtual void poll();
00080 
00081     void loadStatusMessage(const ServerID source, const Sirikata::Protocol::CSeg::LoadMessage& load_status_msg);
00082 
00083   enum {
00084     SEND_TO_NEIGHBORS,
00085     SEND_TO_ALL,
00086     SEND_TO_NONE,
00087     SEND_TO_CENTRAL,
00088     SEND_TO_DHT,
00089   };
00090 
00091   bool handlesAdjacentRegion(ServerID server_id);
00092 
00093   bool isAdjacent(BoundingBox3f& box1, BoundingBox3f& box2);
00094 
00095     SpaceContext* mContext;
00096     Router<Message*>* mLoadServerMessageService;
00097     CoordinateSegmentation* mCoordinateSegmentation;
00098 
00099     TimeProfiler::Stage* mProfiler;
00100 
00101     float mCurrentLoadReading;
00102     float mAveragedLoadReading;
00103 
00104     std::map<ServerID, float> mRemoteLoadReadings;
00105 };
00106 
00107 }
00108 
00109 
00110 #endif