global_pre_init

预初始化函数,解析ceph.conf配置文件, 初始化定义global_context 和 config的全局变量.

全局预初始化函数

CINIT_FLAG_UNPRIVILEGED_DAEMON_DEFAULTS  默认DAEMON ,相对于下面的选项而言,一般会采用这个.

CINIT_FLAG_NO_DEFAULT_CONFIG_FILE 不去读config_file

CINIT_FLAG_NO_CLOSE_STDERR   不关闭stderr

CINIT_FLAG_NO_DAEMON_ACTIONS :

不生成/var/run/ceph 和  不打印banner .

CINIT_FLAG_DEFER_DROP_PRIVILEGES 设置RGW 使用者.uid gid

启动类型:

#define CEPH_ENTITY_TYPE_MON    0x01   :   Monitor

#define CEPH_ENTITY_TYPE_MDS    0x02   :    MDS

#define CEPH_ENTITY_TYPE_OSD    0x04    :    OSD

#define CEPH_ENTITY_TYPE_CLIENT 0x08     :    CLIENT ,RGW网关

#define CEPH_ENTITY_TYPE_AUTH   0x20    : 认证授权类型

#define CEPH_ENTITY_TYPE_ANY    0xFF

CODE_ENVIRONMENT_UTILITY = 0,   工具

CODE_ENVIRONMENT_DAEMON = 1,  DAEMON

CODE_ENVIRONMENT_LIBRARY = 2,    库

CODE_ENVIRONMENT_UTILITY_NODOUT = 3, 工具类型没有stderr的输出

在该函数中进行了配置文件的解析,这是ceph的配置解析模块。整体读取配置文件,然后按照行进行解析。

global_init

初始化函数

作用:

初始化启动模式.

if (g_ceph_context->get_init_flags() != flags) {

g_ceph_context->set_init_flags(flags);

}

错误信号集处理器加载。

int siglist[] = { SIGPIPE, 0 };

block_signals(siglist, NULL);

退出时清空log

if (g_conf->log_flush_on_exit)

g_ceph_context->_log->set_flush_on_exit();

如果不是root用户,如果setuser和setgroup配置了,则将其置为””

// consider --setuser root a no-op, even if we're not root

if (getuid() != 0) {

if (g_conf->setuser.length()) {

cerr << "ignoring --setuser " << g_conf->setuser << " since I am not root"

<< std::endl;

g_conf->set_val("setuser", "", false, false);

}

if (g_conf->setgroup.length()) {

cerr << "ignoring --setgroup " << g_conf->setgroup

<< " since I am not root" << std::endl;

g_conf->set_val("setgroup", "", false, false);

}

}

设置run_dir的权限755

if (g_conf->run_dir.length() &&

code_env == CODE_ENVIRONMENT_DAEMON &&

!(flags & CINIT_FLAG_NO_DAEMON_ACTIONS)) {

int r = ::mkdir(g_conf->run_dir.c_str(), 0755);

if (r < 0 && errno != EEXIST) {

r = -errno;

cerr << "warning: unable to create " << g_conf->run_dir << ": " << cpp_strerror(r) << std::endl;

}

}

设置Assert中cct.

register_assert_context(g_ceph_context);

设置用户对run_dir的权限

if ((flags & CINIT_FLAG_DEFER_DROP_PRIVILEGES) &&

(g_ceph_context->get_set_uid() || g_ceph_context->get_set_gid())) {

// Fix ownership on log files and run directories if needed.

// Admin socket files are chown()'d during the common init path _after_

// the service thread has been started. This is sadly a bit of a hack :(

chown_path(g_conf->run_dir,

g_ceph_context->get_set_uid(),

g_ceph_context->get_set_gid(),

g_ceph_context->get_set_uid_string(),

g_ceph_context->get_set_gid_string());

g_ceph_context->_log->chown_log_file(

g_ceph_context->get_set_uid(),

g_ceph_context->get_set_gid());

}

内存泄漏检测

// test leak checking

if (g_conf->debug_deliberately_leak_memory) {

derr << "deliberately leaking some memory" << dendl;

char *s = new char[1234567];

(void)s;

// cppcheck-suppress memleak

}

打印banner

if (code_env == CODE_ENVIRONMENT_DAEMON && !(flags & CINIT_FLAG_NO_DAEMON_ACTIONS))

output_ceph_version();

common_init_finish函数

void common_init_finish(CephContext *cct)

{

cct->init_crypto();

//初始化压缩库

//如果不是CINIT_FLAG_NO_DAEMON_ACTIONS 启动service线程。

int flags = cct->get_init_flags(); 主要epoll接收外部的socket信号。

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());

}

}

start_service_thread

说明:

Service_thread 启动一些服务类线程,比如:socket_admin线程和RGWAsyncRadosProcessor 和AsyncCompressor::compressor_tp线程等等。

ceph 初始化函数解析的更多相关文章

  1. java中main函数解析(转载)

    从写java至今,写的最多的可能就是主函数 public static void main(String[] args) {} 但是以前一直都没有问自己,为什么要这么写,因为在c语言中就没有这样子的要 ...

  2. driver_register()函数解析

    driver_register()函数解析 /** * driver_register - register driver with bus * @drv: driver to register *  ...

  3. 第3阶段——内核启动分析之start_kernel初始化函数(5)

    内核启动分析之start_kernel初始化函数(init/main.c) stext函数启动内核后,就开始进入start_kernel初始化各个函数, 下面只是浅尝辄止的描述一下函数的功能,很多函数 ...

  4. java中main函数解析

    从写java至今,写的最多的可能就是主函数 public static void main(String[] args) {} 但是以前一直都没有问自己,为什么要这么写,因为在c语言中就没有这样子的要 ...

  5. C语言指定初始化器解析及其应用

    指定初始化器的概念 C90 标准要求初始化程序中的元素以固定的顺序出现,与要初始化的数组或结构体中的元素顺序相同.但是在新标准 C99 中,增加了一个新的特性:指定初始化器.利用该特性可以初始化指定的 ...

  6. c语言中的c语言中realloc()函数解析

    c语言中realloc()函数解析 真是有点惭愧,这些内容本应该很早就掌握的,以前只是糊里糊涂的用,不知道在内存中具体是怎么回事,现在才弄清楚. realloc(void *__ptr, size_t ...

  7. 大括号之谜:C++的列表初始化语法解析

    有朋友在使用std::array时发现一个奇怪的问题:当元素类型是复合类型时,编译通不过. struct S { int x; int y; }; int main() { int a1[3]{1, ...

  8. CAD调试时抛出“正试图在 os 加载程序锁内执行托管代码。不要尝试在 DllMain 或映像初始化函数内运行托管代码”异常的解决方法

    这些天重装了电脑Win10系统,安装了CAD2012和VS2012,准备进行软件开发.在调试程序的时候,CAD没有进入界面就抛出 “正试图在 os 加载程序锁内执行托管代码.不要尝试在 DllMain ...

  9. 正尝试在 OS 加载程序锁内执行托管代码。不要尝试在 DllMain 或映像初始化函数内运行托管代码,这样...

    出错提示: 正尝试在 OS 加载程序锁内执行托管代码.不要尝试在 DllMain 或映像初始化函数内运行托管代码,这样做会导致应用程序挂起. 原因分析: .NET2.0中增加了42种非常强大的调试助手 ...

随机推荐

  1. 使用docker运行GitLab

    从docker镜像拉取代码,docker pull gitlab/gitlab-ce:latest. 创建/srv/gitlab目录sudo mkdir /srv/gitlab 启动GitLab CE ...

  2. python argparse模块的使用

    import argparse def get_parse(): # 初始化 parse = argparse.ArgumentParser() # 添加选项,类型为str,默认为空 parse.ad ...

  3. 最牛MongoDB灾难恢复(WiredTiger.wt文件损坏,Mongo无法启动)

    WiredTiger.wt文件是mongoDB的元数据文件,存储了其他数据库表的元数据信息.笔者最近遇到了WiredTiger.wt文件损坏的情况,MongoDB无法启动,数据库中的重要数据危在旦夕. ...

  4. Net Core 2.1 日志记录框架NLog+Mysql配置

    NLog是什么? 这里还是简单介绍一下吧,为了让小白也知道.NLog是一个灵活的免费日志记录平台,适用于各种.NET平台,包括.NET Core.NLog可以通过简单地配置就可以可以很方便的写入多个日 ...

  5. C++ hdu 例题:不要62 题解

    例题:不要62 同步数位DP 需要统计区间[l,r]的满足题意的数的个数,这往往可以转换成求[0,r]-[0,l) 基本思想与方法 有了上述性质,我们就可以从高到低枚举第一次<n对应位是哪一位. ...

  6. windows安装TensorFlow和Keras遇到的问题及其解决方法

    安装TensorFlow在Windows上,真是让我心力交瘁,想死的心都有了,在Windows上做开发真的让人发狂. 首先说一下我的经历,本来也就是起初,网上说python3.7不支持TensorFl ...

  7. sql锁的类型介绍:悲观锁,乐观锁,行锁,表锁,页锁,共享锁,排他锁,意向锁

    1 悲观锁,乐观锁 悲观锁:顾名思义,很悲观,就是每次拿数据的时候都认为别的线程会修改数据,所以在每次拿的时候都会给数据上锁.上锁之后,当别的线程想要拿数据时,就会阻塞,直到给数据上锁的线程将事务提交 ...

  8. HDU 5113:Black And White(DFS)

    题目链接 题意 给出一个n*m的图,现在有k种颜色让你对这个图每个格子染色,每种颜色最多可以使用col[i]次,问是否存在一种染色方案使得相邻格子的颜色不同. 思路 以为是构造题,结果是爆搜.对于每一 ...

  9. SPOJ:NPC2016A(数学)

    http://www.spoj.com/problems/NPC2016A/en/ 题意:在一个n*n的平面里面,初始在(x,y)需要碰到每条边一次,然后返回(x,y),问最短路径是多长. 思路:像样 ...

  10. pod update更新error: RPC failed; curl 18 transfer closed with outstanding read data remaining

    1. pod update 的时候出现下边的错误 error: RPC failed; curl 18 transfer closed with outstanding read data remai ...