[go: up one dir, main page]

Menu

[r74]: / routing / routing.h  Maximize  Restore  History

Download this file

129 lines (99 with data), 3.2 kB

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
/*****************************************************************************
Copyright © 2006, 2007, The Board of Trustees of the University of Illinois.
All Rights Reserved.
Sector: A Distributed Storage and Computing Infrastructure
National Center for Data Mining (NCDM)
University of Illinois at Chicago
http://www.ncdm.uic.edu/
Sector is free software: you can redistribute it and/or modify it under
the terms of the GNU General Public License as published by the Free
Software Foundation, either version 3 of the License, or (at your option)
any later version.
Sector is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along
with this program. If not, see <http://www.gnu.org/licenses/>.
*****************************************************************************/
/*****************************************************************************
written by
Yunhong Gu [gu@lac.uic.edu], last updated 02/23/2007
*****************************************************************************/
#ifndef __ROUTING_H__
#define __ROUTING_H__
#include <vector>
#include <dhash.h>
#include <gmp.h>
#include <node.h>
using namespace std;
namespace cb
{
struct FTItem
{
unsigned int m_uiStart;
Node m_Node;
};
struct KeyItem
{
unsigned int m_uiKey;
char m_pcName[64];
char m_pcIP[64];
int m_iPort;
};
class CRouting
{
public:
CRouting();
~CRouting();
public:
int start(const char* ip, const int& port = 0);
int join(const char* ip, const char* peer_ip, const int& port = 0, const int& peer_port = 0);
public:
int lookup(const unsigned int& key, Node* n);
void setAppPort(const int& port);
bool has(const unsigned int& id);
private:
int find_successor(const unsigned int& id, Node* n);
void closest_preceding_finger(const unsigned int& id, Node* n);
private:
void init_finger_table(const Node* n = NULL);
void print_finger_table();
void stabilize();
void notify(Node* n);
void fix_fingers();
void check_predecessor();
void check_successor();
uint32_t hash(const char* ip, const int& port);
private:
struct Param
{
CRouting* r;
char ip[64];
int port;
int32_t id;
CRTMsg* msg;
};
static void* run(void* r);
static void* process(void* p);
static void* stabilize(void* r);
private:
char m_pcIP[64]; // IP address
int m_iPort; // port
uint32_t m_uiID; // DHash ID
int m_iAppPort; // Application port
int m_iKeySpace; // DHash key space
private:
vector<FTItem> m_vFingerTable; // route table
Node m_Successor; // successor
Node m_Predecessor; // predecessor
vector<Node> m_vBackupSuccessors; // backup successor
private:
CGMP* m_pGMP; // GMP messenger
private:
pthread_mutex_t m_PKeyLock; // synchronize predecessor access
pthread_mutex_t m_SKeyLock; // synchronize successor access
public:
static const int m_iRouterPort; // default router port
};
}; // namespace
#endif