-
ServiceBean中各种属性设置完成之后就会调用一个**afterPropertiesSet()**方法,该方法会将我们配置的属性信息都封装在ServiceBean中,
-
在afterPropertiesSet()执行完IOC容器创建刷新完成后就实现并调用ApplicationListener接口的onApplicationEvent() 方法,在该方法中会调用一个export() 方法, 也就是暴露的意思,
-
这个export()会进入到ServiceConfig中的export()方法中;里面会调用本类(ServiceConfig)中的 doexport() 方法(执行暴露);doexport()中又调用doexpotrUrls() (执行暴露Url ); 这个方法中有 doExportUrlsFor1Protocol() 方法,(暴露协议的URL)
-
doExportUrlsFor1Protocol()中先通过协议工厂(ProxyFactory)对象的 getInvoker() 方法得到一个Invoker,(具体是:获取接口对象的invoker,将接口实现和URL等等一些东西通过代理工厂对象进行包装组合成了Invoker)
-
对上面获得的Invoker再次包装,然后又通过(Protocol)协议的对象调用export()方法,将这个包装后的Invoker暴露;protpcol.export(invoker)
-
上述protpcol.export(invoker)会返回一个Exporter对象(暴露器);
-
第六步通过Protocol调用export方法时会先去RegistryProcol(注册器协议)中的export()中进行Localexport() (本地暴露),但是 Localexport()中还是调用protpcol.export()也就是export()包裹export()。
-
RegistryProcol中的暴露器export()除了本地暴露外还会注册到注册中心;ProviderConsumerRegTable.registerProvider()(把URL地址跟服务的执行器(Invoker)保存在注册表中,执行器中保存着真正的服务,这样的话当20880端口启动时就会根据URL地址在注册表中找到对应的执行器(Invoker)就能进行调用服务了)
-
第六步中除了调用注册中心的暴露器还会调用Dubbo的暴露器;在Dubbo的export()中会进行开启服务;也就是执行openService() openServer做的就是启动Netty服务器,监听20880端口;
-
至此服务暴露完成~