mirror of
https://github.com/ceph/ceph
synced 2025-01-12 14:10:27 +00:00
07ac5d3e74
git-svn-id: https://ceph.svn.sf.net/svnroot/ceph@1068 29311d96-e01e-0410-9327-a35deaab8ce9
111 lines
2.6 KiB
C++
111 lines
2.6 KiB
C++
// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
|
|
/*
|
|
* Ceph - scalable distributed file system
|
|
*
|
|
* Copyright (C) 2004-2006 Sage Weil <sage@newdream.net>
|
|
*
|
|
* This is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License version 2.1, as published by the Free Software
|
|
* Foundation. See file COPYING.
|
|
*
|
|
*/
|
|
|
|
|
|
#ifndef __TCPDIRECTORY_H
|
|
#define __TCPDIRECTORY_H
|
|
|
|
/*
|
|
* rank -- a process (listening on some host:port)
|
|
* entity -- a logical entity (osd123, mds3, client3245, etc.)
|
|
*
|
|
* multiple entities can coexist on a single rank.
|
|
*/
|
|
|
|
#include "Dispatcher.h"
|
|
#include "TCPMessenger.h"
|
|
|
|
#include <map>
|
|
using namespace std;
|
|
#include <ext/hash_map>
|
|
using namespace __gnu_cxx;
|
|
|
|
#include <sys/types.h>
|
|
//#include <sys/stat.h>
|
|
#include <fcntl.h>
|
|
|
|
class TCPDirectory : public Dispatcher {
|
|
protected:
|
|
// how i communicate
|
|
TCPMessenger *messenger;
|
|
|
|
// directory
|
|
hash_map<msg_addr_t, int> dir; // entity -> rank
|
|
hash_map<int, tcpaddr_t> rank_addr; // rank -> ADDR (e.g. host:port)
|
|
|
|
__uint64_t version;
|
|
map<__uint64_t, msg_addr_t> update_log;
|
|
|
|
int nrank;
|
|
int nclient, nmds, nosd;
|
|
|
|
set<msg_addr_t> hold;
|
|
map<msg_addr_t, list<Message*> > waiting;
|
|
|
|
// messages
|
|
void handle_connect(class MNSConnect*);
|
|
void handle_register(class MNSRegister *m);
|
|
void handle_started(Message *m);
|
|
void handle_lookup(class MNSLookup *m);
|
|
void handle_unregister(Message *m);
|
|
|
|
public:
|
|
TCPDirectory(TCPMessenger *m) :
|
|
messenger(m),
|
|
version(0),
|
|
nrank(0), nclient(0), nmds(0), nosd(0) {
|
|
messenger->set_dispatcher(this);
|
|
|
|
// i am rank 0!
|
|
dir[MSG_ADDR_DIRECTORY] = 0;
|
|
rank_addr[0] = m->get_tcpaddr();
|
|
++nrank;
|
|
|
|
// announce nameserver
|
|
cout << "export CEPH_NAMESERVER=" << m->get_tcpaddr() << endl;
|
|
|
|
int fd = ::open(".ceph_ns", O_WRONLY|O_CREAT);
|
|
::write(fd, (void*)&m->get_tcpaddr(), sizeof(tcpaddr_t));
|
|
::fchmod(fd, 0755);
|
|
::close(fd);
|
|
}
|
|
~TCPDirectory() {
|
|
::unlink(".ceph_ns");
|
|
}
|
|
|
|
void dispatch(Message *m) {
|
|
switch (m->get_type()) {
|
|
case MSG_NS_CONNECT:
|
|
handle_connect((class MNSConnect*)m);
|
|
break;
|
|
case MSG_NS_REGISTER:
|
|
handle_register((class MNSRegister*)m);
|
|
break;
|
|
case MSG_NS_STARTED:
|
|
handle_started(m);
|
|
break;
|
|
case MSG_NS_UNREGISTER:
|
|
handle_unregister(m);
|
|
break;
|
|
case MSG_NS_LOOKUP:
|
|
handle_lookup((class MNSLookup*)m);
|
|
break;
|
|
|
|
default:
|
|
assert(0);
|
|
}
|
|
}
|
|
};
|
|
|
|
#endif
|