• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Error

            C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
              217 Posts :: 61 Stories :: 32 Comments :: 0 Trackbacks
            LogServer
            日志服務器看起來是一個完全獨立的服務器,啟動以后直接向某個邏輯服務器發(fā)起一個連接,然后根據如下的映射表工作起來:
            QLOG_MSG_ENTRY( GMSG_LOG_SERVER_INFO,gmsg_log_server_info)
            QLOG_MSG_ENTRY( GMSG_LOG_ITEM,gmsg_log_item)
            QLOG_MSG_ENTRY( GMSG_LOG_CHAT,gmsg_log_chat)
            QLOG_MSG_ENTRY( GMSG_LOG_ACCOUNT,gmsg_log_account)
            QLOG_MSG_ENTRY( GMSG_LOG_SYS,gmsg_log_sys)
            QLOG_MSG_ENTRY(GMSG_LOG_PLAYER,gmsg_log_player)
            QLOG_MSG_ENTRY(GMSG_LOG_SAMPLE,gmsg_log_sample)
            QLOG_MSG_ENTRY( GMSG_LOG_STAT,gmsg_log_stat)
            QLOG_MSG_ENTRY( GMSG_LOG_GM,gmsg_log_gm)
            QLOG_MSG_ENTRY(GMSG_LOG_QUEST,gmsg_log_quest)
            QLOG_MSG_ENTRY(GMSG_LOG_MAIL,gmsg_log_mail)
            QLOG_MSG_ENTRY(GMSG_LOG_SCRIPT,gmsg_log_script)
            QLOG_MSG_ENTRY(GMSG_LOG_TENCENT_CLIENT_WG, gmsg_log_tencent_client_wg)
            QLOG_MSG_ENTRY(GMSG_LOG_PING, gmsg_log_ping)
            key是網絡協(xié)議,value是對應的處理函數,對應的邏輯類是QLoggerHandler
            QLoggerHandler管理著LogServer唯一的socket句柄,連接建立后就做一件事,把接受到的數據塞到日志數據庫囧。
            日志服務器協(xié)議命令碼
            enum EServerLogProtocol
            {
            GMSG_LOG_SERVER_INFO = 1,
            LMSG_LOG_SERVER_CLOSE = 2,
            LMSG_LOG_SERVER_ERROR = 3,
            GMSG_LOG_ITEM = 4,//物品相關log
            GMSG_LOG_CHAT = 5,//聊天log
            GMSG_LOG_ACCOUNT = 6,//account活動log
            GMSG_LOG_SYS = 7,//系統(tǒng)警告log
            GMSG_LOG_PLAYER = 8,//玩家log
            GMSG_LOG_SAMPLE = 9,//玩家log
            GMSG_LOG_STAT = 10,//系統(tǒng)統(tǒng)計log
            GMSG_LOG_GM = 11,//gm log
            GMSG_LOG_QUEST = 12,//quest log
            GMSG_LOG_MAIL = 13,//mail log
            GMSG_LOG_SCRIPT = 14,//script log
            GMSG_LOG_CLIENT_WG = 15,//客戶端檢測外掛
            GMSG_LOG_TENCENT_CLIENT_WG = 16,//騰訊的檢測外掛log
            GMSG_LOG_PING = 17,//檢測LogServer是否死掉
            };
            編碼技巧:
            1.在網絡協(xié)議風暴解包中MSG_X系列宏算一個亮點。
            用法舉例:
            msg標識一個消息數據,實際上一個ACE_Message_Block
            MSG_NEW(MSG_OP_CODE, msg)  // 定義一個消息包,opcode是MSG_OP_CODE
            MSG_SET_STR(  // 調用ACE_Message_Block相關接口寫入需要攜帶的數據,數據大小變化會被ace自動感知到
            MSG_DEL(smsg);  // 銷毀消息
            2.利用map做的消息映射表:
            #define QLOG_MSG_MAP_BEGIN \
            class __LOG_MSG_MAP__{ public:__LOG_MSG_MAP__(); }; \
            static __LOG_MSG_MAP__  __log_msg_map__; \
            __LOG_MSG_MAP__::__LOG_MSG_MAP__(){ \
            QLoggerHandler::msg_map_.clear();
            #define QLOG_MSG_ENTRY( QMSG, FUNC ) \
            if(QLoggerHandler::msg_map_.find(QMSG)==QLoggerHandler::msg_map_.end()) \
            { QLoggerHandler::msg_map_.insert(QLoggerHandler::Msg_Map::value_type(QMSG,QLoggerHandler::FUNC));}
            #define QLOG_MSG_MAP_END }
            #define QLOG_MSG_ENTRY( QMSG, FUNC ) bool FUNC( ACE_Message_Block* msg );
            這種設計要求網絡響應函數參數是一致的,函數內部各自做解包操作。
            3.統(tǒng)一分離出來的數據庫操作:
            class DBProxy
            {
            public:
            static bool save_sys_log(const char* sys_l
            static bool save_item_log(const char* serv
            int left_credit,int item_guid,int item
            static bool save_gm_log(int gm_log_type, c
            static bool save_chat_log(int chat_type,co
            static bool save_account_log( int log_type
            static bool save_player_log(int log_type,c
            static bool save_sample_log(int log_type,c
            static bool save_stat_log(const char* serv
            static bool save_quest_log(int log_type, c
            static bool save_mail_log(int log_type, co
            static bool save_script_log(int log_type, 
            const char* log_p_2,const char* log_p_
            static bool save_tencent_wg_log(const char
            };
            #endif//__DBProxy_H_
            整個設計顯得非常清晰:
            QLoggerHandler接受到網絡消息通過映射表static Msg_Map msg_map_;分解到各自的解包函數,然后通過DBProxy執(zhí)行最終的數據庫操作。
            posted on 2015-03-18 00:26 Enic 閱讀(230) 評論(0)  編輯 收藏 引用 所屬分類: 從零開始寫棋牌游戲平臺
            亚洲国产精品嫩草影院久久| 亚洲狠狠婷婷综合久久蜜芽 | 久久久久久亚洲精品影院| 久久99精品免费一区二区| 武侠古典久久婷婷狼人伊人| 亚洲狠狠婷婷综合久久久久| 国产精品99久久久精品无码| 一本一道久久精品综合| 亚洲午夜无码久久久久小说| 国产精品久久免费| 国内精品人妻无码久久久影院导航| 亚洲va中文字幕无码久久不卡| 亚洲综合婷婷久久| 少妇内射兰兰久久| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 色天使久久综合网天天| 欧美777精品久久久久网| 蜜桃麻豆WWW久久囤产精品| 91精品国产91热久久久久福利 | 99久久国产免费福利| 国产美女亚洲精品久久久综合| 久久av高潮av无码av喷吹| 麻豆成人久久精品二区三区免费| 中文字幕久久精品| 国产免费福利体检区久久| 久久被窝电影亚洲爽爽爽| 午夜天堂av天堂久久久| 久久国语露脸国产精品电影| 免费一级做a爰片久久毛片潮| 色综合久久久久| 四虎国产精品免费久久5151| 久久大香香蕉国产| 国产精品禁18久久久夂久| 亚洲精品国精品久久99热一| 性做久久久久久久久浪潮| 一97日本道伊人久久综合影院| 欧美日韩精品久久久免费观看| 99久久精品国产一区二区| 国产精品久久久天天影视香蕉 | 国内精品久久久久久久久电影网 | 囯产精品久久久久久久久蜜桃|