mongod是mongodb的存储服务器,其代码入口在mongo/db/db.cpp中,mongod的大部分代码都在mongo/db这个文件夹中。
跟随源码来到这里
int main(int argc, char* argv[]) {
int exitCode = mongoDbMain(argc, argv);
::_exit(exitCode);
}
static int mongoDbMain(int argc, char* argv[]) {
static StaticObserver staticObserver;
getcurns = ourgetns;
//下面几部分就是mongod的主要启动选项类别,具体有哪些选项可以参考mongodb相应的文档。
po::options_description general_options("General options");
#if defined(_WIN32)
po::options_description windows_scm_options("Windows Service Control Manager options");
#endif
po::options_description replication_options("Replication options");
po::options_description ms_options("Master/slave options");
po::options_description rs_options("Replica set options");
po::options_description sharding_options("Sharding options");
po::options_description visible_options("Allowed options");
po::options_description hidden_options("Hidden options");
po::options_description ssl_options("SSL options");
跟随源码来到这里
Module::configAll( params );//这里module的配置,mms是其中部分,但是调试时发现module中没有任何模块,没有设置实例吧。
dataFileSync.go();//mongodb使用内存文件映射管理数据,所以过一段时间有必要把脏数据写回磁盘,这里开启一个线程干的就是这个事情
//默认是60s刷一次,启动时可以用--syncdelay加秒数来设置多少时间刷新一次若设置为0则反而不刷新,而只是执行5s的睡眠,然后继续
if (params.count("command")) {//睡眠5s,直到通过db.adminCommand({"setParameter":1,syncdelay:20})设置时间后再刷新
vector<string> command = params["command"].as< vector<string> >();
if (command[0].compare("run") == 0) {
if (command.size() > 1) {
cout << "Too many parameters to 'run' command" << endl;
cout << visible_options << endl;
return 0;
}
initAndListen(cmdLine.port);
return 0;
}
最后到这里:
Startup