mongo源码学习(四)服务入口点ServiceEntryPoint
在上一篇博客mongo源码学习(三)请求接收传输层中,稍微分析了一下TransportLayer的作用,这篇来看下ServiceEntryPoint是怎么做的。
首先ServiceEntryPoint的定义在mongo/src/mongo/transport目录下。
废话不过说,直接上代码。
service_entry_point.h
namespace mongo { /** * This is the entrypoint from the transport layer into mongod or mongos. * * The ServiceEntryPoint accepts new Sessions from the TransportLayer, and is * responsible for running these Sessions in a get-Message, run-Message, * reply-with-Message loop. It may not do this on the TransportLayer’s thread. */ /** * 这是从transport layer到mongod或者mongos的入口点。 * * ServiceEntryPoint从TransportLayer中接收新的Session,并且负责运行这些Sessions的 * get-Message,run-Message和reply-with-Message生命周期。它可能不会在TransportLayer的线程 * 中这些事情。 */ class ServiceEntryPoint { MONGO_DISALLOW_COPYING(ServiceEntryPoint); public: virtual ~ServiceEntryPoint() = default; /** * Begin running a new Session. This method returns immediately. */ /** * 开始一个新的Session。这个方法会马上返回。 */ ; /** * End all sessions that do not match the mask in tags. */ /** * 结束所有和tags中掩码不匹配的sessions。 */ ; /** * Starts the service entry point */ /** * 启动服务入口点。 */ ; /** * Shuts down the service entry point. */ /** * 关闭服务入口点。 */ ; /** * Append high-level stats to a BSONObjBuilder for serverStatus */ /** * 为serverStatus向BSONObjBuilder追加高级状态。 */ ; /** * Returns the number of sessions currently open. */ /** * 返回当前打开的sessions数量。 */ ; /** * Processes a request and fills out a DbResponse. */ /** * 处理一个请求并写入DbResponse。 * P. S. 敲黑板了, 同志们,这里就是处理请求的地方了啊! */ ; protected: ServiceEntryPoint() = default; }; } // namespace mongo
嗯,我觉得最重要的方法就是handleRequest了,接口中方法名字取的通俗易懂,没毛病。
service_entry_pioint_impl.h
namespace mongo { class ServiceContext; namespace transport { class Session; } // namespace transport /** * A basic entry point from the TransportLayer into a server. * * The server logic is implemented inside of handleRequest() by a subclass. * startSession() spawns and detaches a new thread for each incoming connection * (transport::Session). */ /** * 从TransportLayer到server的一个基本入口点。 * * 服务器处理请求的逻辑是通过子类的handleRequest()方法实现的。 * startSession()会spawns并且分配一个新的线程来处理每个到来的连接(transport:Session) * spawn: (鱼、蛙等)大量产(卵);引起,酿成 * */ class ServiceEntryPointImpl : public ServiceEntryPoint { MONGO_DISALLOW_COPYING(ServiceEntryPointImpl); public: // 构造函数 explicit ServiceEntryPointImpl(ServiceContext* svcCtx); void startSession(transport::SessionHandle session) override; void endAllSessions(transport::Session::TagMask tags) final; Status start() final; bool shutdown(Milliseconds timeout) final; void appendStats(BSONObjBuilder* bob) const final; size_t numOpenSessions() const final { return _currentConnections.load(); } private: using SSMList = stdx::list<std::shared_ptr<ServiceStateMachine>>; using SSMListIterator = SSMList::iterator; ServiceContext* const _svcCtx; AtomicWord<std::size_t> _nWorkers; mutable stdx::mutex _sessionsMutex; stdx::condition_variable _shutdownCondition; SSMList _sessions; size_t _maxNumConnections{DEFAULT_MAX_CONN}; AtomicWord<size_t> _currentConnections{}; AtomicWord<size_t> _createdConnections{}; std::unique_ptr<transport::ServiceExecutorReserved> _adminInternalPool; }; /* * Returns true if a session with remote/local addresses should be exempted from maxConns */ /* * 如果远程或本地的session可以从最大连接数约束中豁免则返回true */ bool shouldOverrideMaxConns(const transport::SessionHandle& session, const std::vector<stdx::variant<CIDR, std::string>>& exemptions); } // namespace mongo
似乎也没有太多好说的了。接下来的service_entry_point_impl.cpp是大头,这里开始要深入到方法内部去了。
service_entry_point_impl.cpp
mongo源码学习(四)服务入口点ServiceEntryPoint的更多相关文章
- mongo源码学习(三)请求接收传输层
在上一篇博客中(mongo源码学习(二)db.cpp之mongoDbMain方法分析),我们把db.cpp中的mongoDbMain的执行过程分析了一下,最后会调用initAndListen(serv ...
- mongo源码学习(四)invariant
前言 在看MongoDB源码的时候,经常会看到这个玩意儿:invariant. invariant的字面意思是:不变式. 在emacs上跳转到函数定义要安装一个插件,ggtags,费了老大劲儿.这都可 ...
- dubbo源码学习(四):暴露服务的过程
dubbo采用的nio异步的通信,通信协议默认为 netty,当然也可以选择 mina,grizzy.在服务端(provider)在启动时主要是开启netty监听,在zookeeper上注册服务节点, ...
- Dubbo源码学习之-服务导出
前言 忙的时候,会埋怨学习的时间太少,缺少个人的空间,于是会争分夺秒的工作.学习.而一旦繁忙的时候过去,有时间了之后,整个人又会不自觉的陷入一种懒散的状态中,时间也显得不那么重要了,随便就可以浪费掉几 ...
- mongo源码学习(二)db.cpp之mongoDbMain方法分析
mongo后台进程的入口:mongo/src/mongo/db/dbmain.cpp,wmain(for windows)和main函数,main函数也很简单,就是委托给db.cpp中的mongoDb ...
- [spring源码学习]四、IOC源码——普通bean初始化
一.代码例子 此节开始涉及到一个bean具体生成和保存的过程,仅仅涉及到最简单的bean,代码依旧是最简单的 public static void main(String[] args) { Defa ...
- dubbo 源码学习1 服务发布机制
1.源码版本:2.6.1 源码demo中采用的是xml式的发布方式,在dubbo的 DubboNamespaceHandler 中定义了Spring Framework 的扩展标签,即 <dub ...
- mongo源码学习(一)
在git上把mongo的源码给拉下来了,然后目录大概是这样的: 这个mongo是用C++写的,编译并没有用Makefile而是用的scons工具,这个好像是python写的. mongo后台进程的入口 ...
- 菜鸟系列Fabric源码学习—orderer服务启动
Fabric 1.4 orderer 服务启动流程 1.提要 orderer提供broadcast和deliver两个服务接口.orderer节点与各个peer节点通过grpc连接,orderer将所 ...
随机推荐
- Struts2之数据标签(二)
Struts2之数据标签(一):http://blog.csdn.net/u012561176/article/details/46848817 1.action标签:使用此标签能够同意在JSP页面中 ...
- 使用Openssl的AES加密算法
原文链接: http://blog.csdn.net/yasi_xi/article/details/13997337 Openssl是很常见的C接口的库,个人觉得易用.以下是AES加密的使用备忘.如 ...
- Java Nashorn--Part 1
伴随 Java 8 的发布,Oracle 也一同发布了 Nashorn,它是在 Java 虚拟机上运行 Javascript 语言的一个引擎.Nashorn 的设计是为了替换最初的运行在 JVM 上的 ...
- android 中 viewpager 滑动的指示器
先看下效果图: 这个需要用到1个开源的 库,这个后面也会说下的. 工程目录: 1. MainActivity.java public class MainActivity extends Fragme ...
- Android Developers:向其它应用发送用户
Android的一个非常重要的功能是,应用程序基于它要执行的一个“动作”想其它应用程序发送用户的能力.例如,如果你的应用程序要显示一个地图,你没有在你的应用程序中创建显示地图的Activity.相反, ...
- js前台取用后台传递过来的map集合方式
在处理有些特殊需求的时候,我们需要在前台页面的js中获取后台传递过来的map集合类型的参数,并且进行调用,代码如下: 在后台我们拼装出如下的集合: Map<String,Grade> gr ...
- mysql数据导入遇到的timestamp类型问题
今天准备把最新的表导入自己以前的机子上做临时开发,在数据库导入的时候遇到一个问题:Incorrect table definition; there can be only one TIMESTAMP ...
- Jenkins管理静态资源
这里我们的前端是使用webpack来管理静态资源的,把静态资源上传到svn上面来管理 这里我们把项目和静态资源剥离开来,然后静态资源接入CDN 我们的svn的结构是这样的 我们需要把这些目录都进行打包 ...
- nginx 有关防盗链的设置
http://blog.csdn.net/longjef/article/details/53284108 关于nginx防盗链的方法网上有很多教程,都可以用,但是我发现很多教程并不完整,所做的防盗链 ...
- [转载]Cortana 设计指导方针
来源:@微软中国MSDN,源地址:http://weibo.com/p/1001603898586285925224 使用语音命令,延伸 Cortana 与您的应用程序所提供的功能.启动应用程序,启动 ...