DihSwitchReplica.hpp
上传用户:romrleung
上传日期:2022-05-23
资源大小:18897k
文件大小:2k
源码类别:

MySQL数据库

开发平台:

Visual C++

  1. /* Copyright (C) 2003 MySQL AB
  2.    This program is free software; you can redistribute it and/or modify
  3.    it under the terms of the GNU General Public License as published by
  4.    the Free Software Foundation; either version 2 of the License, or
  5.    (at your option) any later version.
  6.    This program is distributed in the hope that it will be useful,
  7.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  8.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  9.    GNU General Public License for more details.
  10.    You should have received a copy of the GNU General Public License
  11.    along with this program; if not, write to the Free Software
  12.    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
  13. #ifndef DIH_SWITCH_REPLICA_HPP
  14. #define DIH_SWITCH_REPLICA_HPP
  15. /**
  16.  * This signal is sent from master DIH to all DIH's 
  17.  *   switches primary / backup nodes for replica(s)
  18.  *
  19.  */
  20. class DihSwitchReplicaReq {
  21.   /**
  22.    * Sender/Reciver
  23.    */
  24.   friend class Dbdih;
  25. public:
  26.   STATIC_CONST( SignalLength = 4 + MAX_REPLICAS );
  27.   
  28. private:
  29.   /**
  30.    * Request Info
  31.    *
  32.    */
  33.   Uint32 senderRef;
  34.   Uint32 tableId;
  35.   Uint32 fragNo; 
  36.   Uint32 noOfReplicas;
  37.   Uint32 newNodeOrder[MAX_REPLICAS];
  38. };
  39. class DihSwitchReplicaRef {
  40.   /**
  41.    * Sender/Reciver
  42.    */
  43.   friend class Dbdih;
  44.   
  45. public:
  46.   STATIC_CONST( SignalLength = 2 );
  47.   
  48. private:
  49.   Uint32 senderNode;
  50.   Uint32 errorCode; // See StopPermRef::ErrorCode
  51. };
  52. class DihSwitchReplicaConf {
  53.   /**
  54.    * Sender/Reciver
  55.    */
  56.   friend class Dbdih;
  57.   
  58. public:
  59.   STATIC_CONST( SignalLength = 1 );
  60.   
  61. private:
  62.   Uint32 senderNode;
  63. };
  64. #endif