void * logfile_thread(void *arg) { DB_ENV *dbenv; int ret; char **begin, **list; dbenv = arg; dbenv->errx(dbenv, "Log file removal thread: %lu", (u_long)pthread_self()); /* Check once every 5 minutes. */ for (;; sleep(300)) { /* Get the list of log files. */ if ((ret = dbenv->log_archive(dbenv, &list, DB_ARCH_ABS)) != 0) { dbenv->err(dbenv, ret, "DB_ENV->log_archive"); exit (1); } /* Remove the log files. */ if (list != NULL) { for (begin = list; *list != NULL; ++list) if ((ret = remove(*list)) != 0) { dbenv->err(dbenv, ret, "remove %s", *list); exit (1); } free (begin); } } /* NOTREACHED */ }
static void *bdb_chkpoint_thread(void *arg) { DB_ENV *dbenv; int ret; dbenv = arg; if (settings.verbose > 1) { dbenv->errx(dbenv, "checkpoint thread created: %lu, every %d seconds", (u_long)pthread_self(), bdb_settings.chkpoint_val); } for (;; sleep(bdb_settings.chkpoint_val)) { if ((ret = dbenv->txn_checkpoint(dbenv, 0, 0, 0)) != 0) { dbenv->err(dbenv, ret, "checkpoint thread"); } dbenv->errx(dbenv, "checkpoint thread: a txn_checkpoint is done"); } return (NULL); }
static void *bdb_memp_trickle_thread(void *arg) { DB_ENV *dbenv; int ret, nwrotep; dbenv = arg; if (settings.verbose > 1) { dbenv->errx(dbenv, "memp_trickle thread created: %lu, every %d seconds, %d%% pages should be clean.", (u_long)pthread_self(), bdb_settings.memp_trickle_val, bdb_settings.memp_trickle_percent); } for (;; sleep(bdb_settings.memp_trickle_val)) { if ((ret = dbenv->memp_trickle(dbenv, bdb_settings.memp_trickle_percent, &nwrotep)) != 0) { dbenv->err(dbenv, ret, "memp_trickle thread"); } dbenv->errx(dbenv, "memp_trickle thread: writing %d dirty pages", nwrotep); } return (NULL); }
static void *bdb_qstats_dump_thread(void *arg){ DB_ENV *dbenv; int ret; dbenv = arg; for (;; sleep(bdb_settings.qstats_dump_val)) { dump_qstats_to_db(); dbenv->errx(dbenv, "qstats dump thread: a qstats is dump."); } return (NULL); }
static void *bdb_dl_detect_thread(void *arg) { DB_ENV *dbenv; struct timeval t; dbenv = arg; if (settings.verbose > 1) { dbenv->errx(dbenv, "deadlock detecting thread created: %lu, every %d millisecond", (u_long)pthread_self(), bdb_settings.dldetect_val); } while (!daemon_quit) { t.tv_sec = bdb_settings.dldetect_val / 1000000; t.tv_usec = bdb_settings.dldetect_val % 1000000; (void)dbenv->lock_detect(dbenv, 0, DB_LOCK_YOUNGEST, NULL); /* select is a more accurate sleep timer */ if (settings.verbose > 0) dbenv->errx(dbenv, "deadlock detecting thread: done (daemon_quit=%d)",daemon_quit); (void)select(0, NULL, NULL, NULL, &t); } return (NULL); }
static void *bdb_mempool_trickle_thread(void *arg){ DB_ENV *dbenv; int ret, nwrotep; dbenv = arg; for (;; sleep(bdb_settings.mempool_trickle_val)) { if ((ret = dbenv->memp_trickle(dbenv, bdb_settings.mempool_trickle_percent, &nwrotep)) != 0) { dbenv->err(dbenv, ret, "mempool_trickle thread"); } dbenv->errx(dbenv, "mempool_trickle thread: writing %d dirty pages", nwrotep); } return (NULL); }
static void *bdb_checkpoint_thread(void *arg){ DB_ENV *dbenv; int ret; dbenv = arg; for (;; sleep(bdb_settings.checkpoint_val)) { if ((ret = dbenv->txn_checkpoint(dbenv, 0, 0, 0)) != 0) { dbenv->err(dbenv, ret, "checkpoint thread"); } dbenv->errx(dbenv, "checkpoint thread: a txn_checkpoint is done"); } return (NULL); }
void * checkpoint_thread(void *arg) { DB_ENV *dbenv; int ret; dbenv = arg; dbenv->errx(dbenv, "Checkpoint thread: %lu", (u_long)pthread_self()); /* Checkpoint once a minute. */ for (;; sleep(60)) if ((ret = dbenv->txn_checkpoint(dbenv, 0, 0, 0)) != 0) { dbenv->err(dbenv, ret, "checkpoint thread"); exit (1); } /* NOTREACHED */ }
int main(int argc, char *const* argv) { const char *progname = "dbxml_dump"; DB_ENV *dbenv; XmlManager *xmlDb; u_int32_t cache; int ch, exitval, is_private, keyflag, nflag, ret, Rflag, rflag; char *home, *passwd; if ((ret = version_check(progname)) != 0) return (ret); dbenv = NULL; xmlDb = NULL; exitval = nflag = rflag = Rflag = 0; keyflag = 0; cache = MEGABYTE; is_private = 0; home = passwd = NULL; while ((ch = getopt(argc, argv, "f:h:NP:rRV")) != EOF) switch (ch) { case 'f': if (freopen(optarg, "wb", stdout) == NULL) { fprintf(stderr, "%s: %s: reopen: %s\n", progname, optarg, strerror(errno)); return (EXIT_FAILURE); } break; case 'h': home = optarg; break; case 'N': nflag = 1; break; case 'P': passwd = strdup(optarg); memset(optarg, 0, strlen(optarg)); if (passwd == NULL) { fprintf(stderr, "%s: strdup: %s\n", progname, strerror(errno)); return (EXIT_FAILURE); } break; case 'R': Rflag = 1; /* DB_AGGRESSIVE requires DB_SALVAGE */ /* FALLTHROUGH */ case 'r': rflag = 1; break; case 'V': printf("%s\n", DbXml::dbxml_version(NULL, NULL, NULL)); printf("%s\n", db_version(NULL, NULL, NULL)); return (EXIT_SUCCESS); case '?': default: return (usage()); } argc -= optind; argv += optind; if (argc != 1) return (usage()); /* Handle possible interruptions. */ SigBlock sb; /* * Create an environment object and initialize it for error * reporting. */ if ((ret = db_env_create(&dbenv, 0)) != 0) { fprintf(stderr, "%s: db_env_create: %s\n", progname, db_strerror(ret)); goto err; } dbenv->set_errfile(dbenv, stderr); dbenv->set_errpfx(dbenv, progname); if (nflag) { if ((ret = dbenv->set_flags(dbenv, DB_NOLOCKING, 1)) != 0) { dbenv->err(dbenv, ret, "set_flags: DB_NOLOCKING"); goto err; } if ((ret = dbenv->set_flags(dbenv, DB_NOPANIC, 1)) != 0) { dbenv->err(dbenv, ret, "set_flags: DB_NOPANIC"); goto err; } } if (passwd != NULL && (ret = dbenv->set_encrypt(dbenv, passwd, DB_ENCRYPT_AES)) != 0) { dbenv->err(dbenv, ret, "set_passwd"); goto err; } /* Initialize the environment. */ if ((ret = db_init(dbenv, home, rflag, cache, &is_private)) != 0) { dbenv->err(dbenv, ret, "db_init"); goto err; } xmlDb = new XmlManager(dbenv); if (rflag) { try { xmlDb->verifyContainer(argv[0], &cout, DB_SALVAGE | (Rflag ? DB_AGGRESSIVE : 0)); } catch (XmlException &e) { dbenv->errx(dbenv, "verify %s: %s", argv[0], e.what()); goto err; } goto done; } try { xmlDb->dumpContainer(argv[0], &cout); } catch (XmlException &e) { dbenv->errx(dbenv, "dump %s: %s", argv[0], e.what()); goto err; } if (0) { err: exitval = 1; } done: if (xmlDb) delete xmlDb; if ((ret = dbenv->close(dbenv, 0)) != 0) { exitval = 1; fprintf(stderr, "%s: dbenv->close: %s\n", progname, db_strerror(ret)); } return (exitval == 0 ? EXIT_SUCCESS : EXIT_FAILURE); }