2007-02-08 03:41:56 +00:00
|
|
|
// -*- 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.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "MonitorStore.h"
|
|
|
|
#include "common/Clock.h"
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
#undef dout
|
|
|
|
#define dout(l) if (l<=g_conf.debug || l<=g_conf.debug_mon) cout << g_clock.now() << " store(" << dir <<") "
|
|
|
|
#define derr(l) if (l<=g_conf.debug || l<=g_conf.debug_mon) cerr << g_clock.now() << " store(" << dir <<") "
|
|
|
|
|
|
|
|
#include <stdio.h>
|
2007-02-08 19:16:23 +00:00
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <fcntl.h>
|
2007-02-08 03:41:56 +00:00
|
|
|
|
|
|
|
|
2007-02-23 23:27:19 +00:00
|
|
|
void MonitorStore::mount()
|
2007-02-08 03:41:56 +00:00
|
|
|
{
|
2007-02-23 23:27:19 +00:00
|
|
|
dout(1) << "mount" << endl;
|
2007-02-08 03:41:56 +00:00
|
|
|
// verify dir exists
|
2007-02-08 19:16:23 +00:00
|
|
|
DIR *d = ::opendir(dir.c_str());
|
2007-02-08 03:41:56 +00:00
|
|
|
if (!d) {
|
2007-02-08 19:16:23 +00:00
|
|
|
derr(1) << "basedir " << dir << " dne" << endl;
|
|
|
|
assert(0);
|
2007-02-08 03:41:56 +00:00
|
|
|
}
|
|
|
|
::closedir(d);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-02-08 19:16:23 +00:00
|
|
|
void MonitorStore::mkfs()
|
|
|
|
{
|
|
|
|
dout(1) << "mkfs" << endl;
|
|
|
|
|
|
|
|
char cmd[200];
|
2007-02-23 23:27:19 +00:00
|
|
|
sprintf(cmd, "test -d %s && /bin/rm -r %s ; mkdir -p %s", dir.c_str(), dir.c_str(), dir.c_str());
|
2007-02-08 19:16:23 +00:00
|
|
|
dout(1) << cmd << endl;
|
2007-02-23 22:47:21 +00:00
|
|
|
system(cmd);
|
2007-02-08 19:16:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-02-08 03:41:56 +00:00
|
|
|
version_t MonitorStore::get_int(const char *a, const char *b)
|
|
|
|
{
|
|
|
|
char fn[200];
|
|
|
|
if (b)
|
2007-02-08 19:16:23 +00:00
|
|
|
sprintf(fn, "%s/%s/%s", dir.c_str(), a, b);
|
2007-02-08 03:41:56 +00:00
|
|
|
else
|
2007-02-08 19:16:23 +00:00
|
|
|
sprintf(fn, "%s/%s", dir.c_str(), a);
|
|
|
|
|
2007-02-08 03:41:56 +00:00
|
|
|
FILE *f = ::fopen(fn, "r");
|
|
|
|
if (!f)
|
2007-02-08 19:16:23 +00:00
|
|
|
return 0;
|
|
|
|
|
2007-02-08 03:41:56 +00:00
|
|
|
char buf[20];
|
|
|
|
::fgets(buf, 20, f);
|
|
|
|
::fclose(f);
|
2007-02-08 19:16:23 +00:00
|
|
|
|
2007-02-08 03:41:56 +00:00
|
|
|
version_t val = atoi(buf);
|
2007-02-08 19:16:23 +00:00
|
|
|
|
2007-02-08 03:41:56 +00:00
|
|
|
if (b) {
|
2007-02-23 22:47:21 +00:00
|
|
|
dout(15) << "get_int " << a << "/" << b << " = " << val << endl;
|
2007-02-08 03:41:56 +00:00
|
|
|
} else {
|
2007-02-23 22:47:21 +00:00
|
|
|
dout(15) << "get_int " << a << " = " << val << endl;
|
2007-02-08 03:41:56 +00:00
|
|
|
}
|
|
|
|
return val;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-02-08 19:16:23 +00:00
|
|
|
void MonitorStore::put_int(version_t val, const char *a, const char *b)
|
2007-02-08 03:41:56 +00:00
|
|
|
{
|
|
|
|
char fn[200];
|
2007-02-08 19:16:23 +00:00
|
|
|
sprintf(fn, "%s/%s", dir.c_str(), a);
|
2007-02-08 03:41:56 +00:00
|
|
|
if (b) {
|
2007-02-08 19:16:23 +00:00
|
|
|
::mkdir(fn, 0755);
|
2007-02-23 22:47:21 +00:00
|
|
|
dout(15) << "set_int " << a << "/" << b << " = " << val << endl;
|
2007-02-08 19:16:23 +00:00
|
|
|
sprintf(fn, "%s/%s/%s", dir.c_str(), a, b);
|
2007-02-08 03:41:56 +00:00
|
|
|
} else {
|
2007-02-23 22:47:21 +00:00
|
|
|
dout(15) << "set_int " << a << " = " << val << endl;
|
2007-02-08 03:41:56 +00:00
|
|
|
}
|
|
|
|
|
2007-02-23 22:47:21 +00:00
|
|
|
char vs[30];
|
|
|
|
sprintf(vs, "%lld\n", val);
|
|
|
|
|
2007-02-08 19:16:23 +00:00
|
|
|
char tfn[200];
|
|
|
|
sprintf(tfn, "%s.new", fn);
|
2007-02-23 22:47:21 +00:00
|
|
|
|
|
|
|
int fd = ::open(tfn, O_WRONLY|O_CREAT);
|
|
|
|
assert(fd > 0);
|
|
|
|
::fchmod(fd, 0644);
|
|
|
|
::write(fd, vs, strlen(vs));
|
|
|
|
::close(fd);
|
2007-02-08 19:16:23 +00:00
|
|
|
::rename(tfn, fn);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ----------------------------------------
|
|
|
|
// buffers
|
|
|
|
|
2007-02-23 23:27:19 +00:00
|
|
|
bool MonitorStore::exists_bl_ss(const char *a, const char *b)
|
2007-02-08 19:16:23 +00:00
|
|
|
{
|
|
|
|
char fn[200];
|
|
|
|
if (b) {
|
2007-02-23 22:47:21 +00:00
|
|
|
dout(15) << "exists_bl " << a << "/" << b << endl;
|
2007-02-08 19:16:23 +00:00
|
|
|
sprintf(fn, "%s/%s/%s", dir.c_str(), a, b);
|
|
|
|
} else {
|
2007-02-23 22:47:21 +00:00
|
|
|
dout(15) << "exists_bl " << a << endl;
|
2007-02-08 19:16:23 +00:00
|
|
|
sprintf(fn, "%s/%s", dir.c_str(), a);
|
|
|
|
}
|
|
|
|
|
|
|
|
struct stat st;
|
|
|
|
int r = ::stat(fn, &st);
|
|
|
|
return r == 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-02-23 23:27:19 +00:00
|
|
|
int MonitorStore::get_bl_ss(bufferlist& bl, const char *a, const char *b)
|
2007-02-08 19:16:23 +00:00
|
|
|
{
|
|
|
|
char fn[200];
|
|
|
|
if (b) {
|
|
|
|
sprintf(fn, "%s/%s/%s", dir.c_str(), a, b);
|
|
|
|
} else {
|
|
|
|
sprintf(fn, "%s/%s", dir.c_str(), a);
|
|
|
|
}
|
|
|
|
|
|
|
|
int fd = ::open(fn, O_RDONLY);
|
|
|
|
if (!fd) {
|
|
|
|
if (b) {
|
2007-02-23 22:47:21 +00:00
|
|
|
dout(15) << "get_bl " << a << "/" << b << " DNE" << endl;
|
2007-02-08 19:16:23 +00:00
|
|
|
} else {
|
2007-02-23 22:47:21 +00:00
|
|
|
dout(15) << "get_bl " << a << " DNE" << endl;
|
2007-02-08 19:16:23 +00:00
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
// read size
|
|
|
|
__int32_t len = 0;
|
|
|
|
::read(fd, &len, sizeof(len));
|
|
|
|
|
|
|
|
// read buffer
|
|
|
|
bl.clear();
|
|
|
|
bufferptr bp(len);
|
|
|
|
::read(fd, bp.c_str(), len);
|
|
|
|
bl.append(bp);
|
|
|
|
::close(fd);
|
|
|
|
|
|
|
|
if (b) {
|
2007-02-23 22:47:21 +00:00
|
|
|
dout(15) << "get_bl " << a << "/" << b << " = " << bl.length() << " bytes" << endl;
|
2007-02-08 19:16:23 +00:00
|
|
|
} else {
|
2007-02-23 22:47:21 +00:00
|
|
|
dout(15) << "get_bl " << a << " = " << bl.length() << " bytes" << endl;
|
2007-02-08 19:16:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return len;
|
|
|
|
}
|
|
|
|
|
2007-02-23 23:27:19 +00:00
|
|
|
int MonitorStore::put_bl_ss(bufferlist& bl, const char *a, const char *b)
|
2007-02-08 19:16:23 +00:00
|
|
|
{
|
|
|
|
char fn[200];
|
|
|
|
sprintf(fn, "%s/%s", dir.c_str(), a);
|
|
|
|
if (b) {
|
|
|
|
::mkdir(fn, 0755);
|
2007-02-23 22:47:21 +00:00
|
|
|
dout(15) << "put_bl " << a << "/" << b << " = " << bl.length() << " bytes" << endl;
|
2007-02-08 19:16:23 +00:00
|
|
|
sprintf(fn, "%s/%s/%s", dir.c_str(), a, b);
|
|
|
|
} else {
|
2007-02-23 22:47:21 +00:00
|
|
|
dout(15) << "put_bl " << a << " = " << bl.length() << " bytes" << endl;
|
2007-02-08 19:16:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
char tfn[200];
|
|
|
|
sprintf(tfn, "%s.new", fn);
|
|
|
|
int fd = ::open(tfn, O_WRONLY|O_CREAT);
|
|
|
|
assert(fd);
|
|
|
|
|
|
|
|
// write size
|
|
|
|
__int32_t len = bl.length();
|
|
|
|
::write(fd, &len, sizeof(len));
|
|
|
|
|
|
|
|
// write data
|
|
|
|
for (list<bufferptr>::const_iterator it = bl.buffers().begin();
|
|
|
|
it != bl.buffers().end();
|
|
|
|
it++)
|
|
|
|
::write(fd, it->c_str(), it->length());
|
2007-02-24 21:52:10 +00:00
|
|
|
|
2007-02-23 22:47:21 +00:00
|
|
|
::fchmod(fd, 0644);
|
2007-02-08 19:16:23 +00:00
|
|
|
::fsync(fd);
|
|
|
|
::close(fd);
|
|
|
|
::rename(tfn, fn);
|
|
|
|
|
|
|
|
return 0;
|
2007-02-08 03:41:56 +00:00
|
|
|
}
|