X-Git-Url: http://git.vrable.net/?a=blobdiff_plain;f=nfs3%2Fnfsd.c;h=fc1f955e91a229288962731bfe6979dc744a64e3;hb=accff993b8c8c2f89708dc110344cfddca2fc103;hp=e4beac1ad37e7a72e815341b33558778937597b8;hpb=98effa493bca2b6e97d98035be602993da27d26b;p=bluesky.git diff --git a/nfs3/nfsd.c b/nfs3/nfsd.c index e4beac1..fc1f955 100644 --- a/nfs3/nfsd.c +++ b/nfs3/nfsd.c @@ -26,24 +26,34 @@ void register_rpc(); BlueSkyFS *fs; BlueSkyStore *store; +static void shutdown_handler(int num) +{ + g_print("SIGINT caught, shutting down...\n"); + g_print("Proxy statistics:\n"); + bluesky_stats_dump_all(); + exit(1); +} + int main(int argc, char *argv[]) { int i; + + signal(SIGPIPE, SIG_IGN); + signal(SIGINT, shutdown_handler); + bluesky_init(); - register_rpc(); + g_set_prgname("nfsd"); + + const char *target = getenv("BLUESKY_TARGET"); + if (target == NULL) + target = "s3"; - store = bluesky_store_new("file"); + store = bluesky_store_new(target); fs = bluesky_init_fs("export", store); - BlueSkyInode *root; - root = bluesky_get_inode(fs, BLUESKY_ROOT_INUM); - if (root == NULL) { - printf("Initializing fresh root inode...\n"); - root = bluesky_new_inode(BLUESKY_ROOT_INUM, fs, BLUESKY_DIRECTORY); - root->nlink = 1; - root->mode = 0755; - bluesky_insert_inode(fs, root); - } + register_rpc(); + + bluesky_debug_dump(fs); svc_run(); fprintf(stderr, "%s", "svc_run returned");