summaryrefslogtreecommitdiffstats
path: root/src/common/common_init.cc
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-27 18:24:20 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-27 18:24:20 +0000
commit483eb2f56657e8e7f419ab1a4fab8dce9ade8609 (patch)
treee5d88d25d870d5dedacb6bbdbe2a966086a0a5cf /src/common/common_init.cc
parentInitial commit. (diff)
downloadceph-483eb2f56657e8e7f419ab1a4fab8dce9ade8609.tar.xz
ceph-483eb2f56657e8e7f419ab1a4fab8dce9ade8609.zip
Adding upstream version 14.2.21.upstream/14.2.21upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--src/common/common_init.cc142
1 files changed, 142 insertions, 0 deletions
diff --git a/src/common/common_init.cc b/src/common/common_init.cc
new file mode 100644
index 00000000..09280493
--- /dev/null
+++ b/src/common/common_init.cc
@@ -0,0 +1,142 @@
+// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
+// vim: ts=8 sw=2 smarttab
+/*
+ * Ceph - scalable distributed file system
+ *
+ * Copyright (C) 2010-2011 Dreamhost
+ *
+ * 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 "include/compat.h"
+#include "common/common_init.h"
+#include "common/admin_socket.h"
+#include "common/ceph_argparse.h"
+#include "common/ceph_context.h"
+#include "common/config.h"
+#include "common/dout.h"
+#include "common/strtol.h"
+#include "common/valgrind.h"
+#include "common/zipkin_trace.h"
+
+#define dout_subsys ceph_subsys_
+
+#define _STR(x) #x
+#define STRINGIFY(x) _STR(x)
+
+#ifndef WITH_SEASTAR
+CephContext *common_preinit(const CephInitParameters &iparams,
+ enum code_environment_t code_env, int flags)
+{
+ // set code environment
+ ANNOTATE_BENIGN_RACE_SIZED(&g_code_env, sizeof(g_code_env), "g_code_env");
+ g_code_env = code_env;
+
+ // Create a configuration object
+ CephContext *cct = new CephContext(iparams.module_type, code_env, flags);
+
+ auto& conf = cct->_conf;
+ // add config observers here
+
+ // Set up our entity name.
+ conf->name = iparams.name;
+
+ // different default keyring locations for osd and mds. this is
+ // for backward compatibility. moving forward, we want all keyrings
+ // in these locations. the mon already forces $mon_data/keyring.
+ if (conf->name.is_mds()) {
+ conf.set_val_default("keyring", "$mds_data/keyring");
+ } else if (conf->name.is_osd()) {
+ conf.set_val_default("keyring", "$osd_data/keyring");
+ }
+
+ if ((flags & CINIT_FLAG_UNPRIVILEGED_DAEMON_DEFAULTS)) {
+ // make this unique despite multiple instances by the same name.
+ conf.set_val_default("admin_socket",
+ "$run_dir/$cluster-$name.$pid.$cctid.asok");
+ }
+
+ if (code_env == CODE_ENVIRONMENT_LIBRARY ||
+ code_env == CODE_ENVIRONMENT_UTILITY_NODOUT) {
+ conf.set_val_default("log_to_stderr", "false");
+ conf.set_val_default("err_to_stderr", "false");
+ conf.set_val_default("log_flush_on_exit", "false");
+ }
+
+ return cct;
+}
+#endif // #ifndef WITH_SEASTAR
+
+void complain_about_parse_errors(CephContext *cct,
+ std::deque<std::string> *parse_errors)
+{
+ if (parse_errors->empty())
+ return;
+ lderr(cct) << "Errors while parsing config file!" << dendl;
+ int cur_err = 0;
+ static const int MAX_PARSE_ERRORS = 20;
+ for (std::deque<std::string>::const_iterator p = parse_errors->begin();
+ p != parse_errors->end(); ++p)
+ {
+ lderr(cct) << *p << dendl;
+ if (cur_err == MAX_PARSE_ERRORS) {
+ lderr(cct) << "Suppressed " << (parse_errors->size() - MAX_PARSE_ERRORS)
+ << " more errors." << dendl;
+ break;
+ }
+ ++cur_err;
+ }
+}
+
+#ifndef WITH_SEASTAR
+
+/* Please be sure that this can safely be called multiple times by the
+ * same application. */
+void common_init_finish(CephContext *cct)
+{
+ // only do this once per cct
+ if (cct->_finished) {
+ return;
+ }
+ cct->_finished = true;
+ cct->init_crypto();
+ ZTracer::ztrace_init();
+
+ if (!cct->_log->is_started()) {
+ cct->_log->start();
+ }
+
+ int flags = cct->get_init_flags();
+ if (!(flags & CINIT_FLAG_NO_DAEMON_ACTIONS))
+ cct->start_service_thread();
+
+ if ((flags & CINIT_FLAG_DEFER_DROP_PRIVILEGES) &&
+ (cct->get_set_uid() || cct->get_set_gid())) {
+ cct->get_admin_socket()->chown(cct->get_set_uid(), cct->get_set_gid());
+ }
+
+ const auto& conf = cct->_conf;
+
+ if (!conf->admin_socket.empty() && !conf->admin_socket_mode.empty()) {
+ int ret = 0;
+ std::string err;
+
+ ret = strict_strtol(conf->admin_socket_mode.c_str(), 8, &err);
+ if (err.empty()) {
+ if (!(ret & (~ACCESSPERMS))) {
+ cct->get_admin_socket()->chmod(static_cast<mode_t>(ret));
+ } else {
+ lderr(cct) << "Invalid octal permissions string: "
+ << conf->admin_socket_mode << dendl;
+ }
+ } else {
+ lderr(cct) << "Invalid octal string: " << err << dendl;
+ }
+ }
+}
+
+#endif // #ifndef WITH_SEASTAR