• Dubbo源码分析


    Apache Dubbo 是一款 RPC 服务开发框架,用于解决微服务架构下的服务治理与通信问题。相比其他RPC框架,dubbo更加灵活,可以做到方法级别的服务治理,粒度更细。

    Dubbo作用域隔离

    Dubbo 3.x支持在一个进程中启动多个dubbo实例,通过ApplicationModel进行隔离。

    利用父委派机制/双亲委派模型进行类的加载,比如加载ModuleConfig,ModuleModel会先委派父级ApplicationModel,ApplicationModel会委派给它的父级FrameworkModel,FrameworkModel加载不了,然后会重新交给ApplicationModel,ApplicationModel也加载不了,又再次递回给ModuleModel去加载。

    父委派/双亲委派模型:某个特定的类加载器在接到加载类的请求时,首先将加载任务委派给父类加载器,依次递归到顶级父类,如果父类加载器可以完成类加载任务,就成功返回;如果父类加载器无法完成加载任务,再反向交给子类加载器去加载,依次反向递归,直到某个子类加载器完成加载任务。

    dubbo通过作用域ScopeModel对不同范围的配置数据进行作用域管理:

    Dubbo如何实现双亲委派

    new ServiceConfig() --> new AbstractServiceConfig() --> new AbstractServiceConfig()  --> new AbstractInterfaceConfig() --> new AbstractMethodConfig() --> ApplicationModel.defaultModel().getDefaultModule()

    1. public class FrameworkModel extends ScopeModel {
    2. public FrameworkModel() {
    3. super(null, ExtensionScope.FRAMEWORK, false);
    4. this.setInternalId(String.valueOf(index.getAndIncrement()));
    5. // register FrameworkModel instance early
    6. synchronized (globalLock) {
    7. allInstances.add(this);
    8. resetDefaultFrameworkModel();
    9. }
    10. initialize(); // 初始化framework范围的配置
    11. }
    12. @Override
    13. protected void initialize() {
    14. super.initialize();
    15. TypeDefinitionBuilder.initBuilders(this); // 定义作用域类型
    16. // 定义当前作用域范围内存仓库
    17. serviceRepository = new FrameworkServiceRepository(this);
    18. // 扩展点
    19. ExtensionLoader initializerExtensionLoader = this.getExtensionLoader(ScopeModelInitializer.class);
    20. Set initializers = initializerExtensionLoader.getSupportedExtensionInstances();
    21. for (ScopeModelInitializer initializer : initializers) {
    22. initializer.initializeFrameworkModel(this);
    23. }
    24. internalApplicationModel = new ApplicationModel(this, true);
    25. internalApplicationModel.getApplicationConfigManager().setApplication(
    26. new ApplicationConfig(internalApplicationModel, CommonConstants.DUBBO_INTERNAL_APPLICATION));
    27. internalApplicationModel.setModelName(CommonConstants.DUBBO_INTERNAL_APPLICATION);
    28. }
    29. // Get or create default framework model by DCL
    30. public static FrameworkModel defaultModel() {
    31. FrameworkModel instance = defaultInstance;
    32. if (instance == null) {
    33. synchronized (globalLock) {
    34. resetDefaultFrameworkModel();
    35. if (defaultInstance == null) {
    36. defaultInstance = new FrameworkModel();
    37. }
    38. instance = defaultInstance;
    39. }
    40. }
    41. Assert.notNull(instance, "Default FrameworkModel is null");
    42. return instance;
    43. }
    44. // Get or create default application model by DCL
    45. public ApplicationModel defaultApplication() {
    46. ApplicationModel appModel = this.defaultAppModel;
    47. if (appModel == null) {
    48. // check destroyed before acquire inst lock, avoid blocking during destroying
    49. checkDestroyed();
    50. resetDefaultAppModel();
    51. if ((appModel = this.defaultAppModel) == null) {
    52. synchronized (instLock) {
    53. if (this.defaultAppModel == null) {
    54. this.defaultAppModel = newApplication();
    55. }
    56. appModel = this.defaultAppModel;
    57. }
    58. }
    59. }
    60. Assert.notNull(appModel, "Default ApplicationModel is null");
    61. return appModel;
    62. }
    63. public ApplicationModel newApplication() {
    64. return new ApplicationModel(this);
    65. }
    66. }
    1. public class ApplicationModel extends ScopeModel {
    2. private volatile ModuleModel defaultModule;
    3. // internal module index is 0, default module index is 1
    4. private AtomicInteger moduleIndex = new AtomicInteger(0);
    5. private Object moduleLock = new Object();
    6. public ApplicationModel(FrameworkModel frameworkModel) {
    7. this(frameworkModel, false);
    8. }
    9. public ApplicationModel(FrameworkModel frameworkModel, boolean isInternal) {
    10. super(frameworkModel, ExtensionScope.APPLICATION, isInternal);
    11. Assert.notNull(frameworkModel, "FrameworkModel can not be null");
    12. this.frameworkModel = frameworkModel;
    13. frameworkModel.addApplication(this);
    14. initialize(); // 初始化application范围的配置
    15. }
    16. @Override
    17. protected void initialize() {
    18. super.initialize();
    19. internalModule = new ModuleModel(this, true);
    20. // 定义当前作用域范围内存仓库
    21. this.serviceRepository = new ServiceRepository(this);
    22. // 扩展点
    23. ExtensionLoader extensionLoader = this.getExtensionLoader(ApplicationInitListener.class);
    24. Set listenerNames = extensionLoader.getSupportedExtensions();
    25. for (String listenerName : listenerNames) {
    26. extensionLoader.getExtension(listenerName).init();
    27. }
    28. initApplicationExts();
    29. ExtensionLoader initializerExtensionLoader = this.getExtensionLoader(ScopeModelInitializer.class);
    30. Set initializers = initializerExtensionLoader.getSupportedExtensionInstances();
    31. for (ScopeModelInitializer initializer : initializers) {
    32. initializer.initializeApplicationModel(this);
    33. }
    34. }
    35. public static ApplicationModel defaultModel() {
    36. // should get from default FrameworkModel, avoid out of sync
    37. return FrameworkModel.defaultModel().defaultApplication();
    38. }
    39. // Get or create module model by DCL
    40. public ModuleModel getDefaultModule() {
    41. if (defaultModule == null) {
    42. synchronized (moduleLock) {
    43. if (defaultModule == null) {
    44. defaultModule = findDefaultModule();
    45. if (defaultModule == null) {
    46. defaultModule = this.newModule();
    47. }
    48. }
    49. }
    50. }
    51. return defaultModule;
    52. }
    53. public ModuleModel newModule() {
    54. return new ModuleModel(this);
    55. }
    56. }
    1. public class ModuleModel extends ScopeModel {
    2. public ModuleModel(ApplicationModel applicationModel) {
    3. this(applicationModel, false);
    4. }
    5. public ModuleModel(ApplicationModel applicationModel, boolean isInternal) {
    6. super(applicationModel, ExtensionScope.MODULE, isInternal);
    7. Assert.notNull(applicationModel, "ApplicationModel can not be null");
    8. this.applicationModel = applicationModel;
    9. applicationModel.addModule(this, isInternal);
    10. initialize();
    11. // notify application check state
    12. ApplicationDeployer applicationDeployer = applicationModel.getDeployer();
    13. if (applicationDeployer != null) {
    14. applicationDeployer.notifyModuleChanged(this, DeployState.PENDING);
    15. }
    16. }
    17. @Override
    18. protected void initialize() {
    19. super.initialize();
    20. this.serviceRepository = new ModuleServiceRepository(this);
    21. initModuleExt();
    22. ExtensionLoader initializerExtensionLoader = this.getExtensionLoader(ScopeModelInitializer.class);
    23. Set initializers = initializerExtensionLoader.getSupportedExtensionInstances();
    24. for (ScopeModelInitializer initializer : initializers) {
    25. initializer.initializeModuleModel(this);
    26. }
    27. }
    28. }

    Dubbo配置

    • dubbo/config目录:记录dubbo外部化配置信息
    • dubbo/xxxxxService:记录dubbo发布的服务以及协议地址
    • dubbo/mapping:记录接口和application名称的映射关系
    • dubbo/metadata:dubbo 2.7版本之后将服务的元数据信息分离出来记录在这里
    • dubbo/services:记录application实例信息和对应的ip地址,dubbo 3.x版本支持多实例

    Dubbo扩展点

    加载 -> 实例化 -> 注入 -> 缓存 -> 提供访问入口

    获取扩展点

    1. ExtensionLoader balanceExtensionLoader = ApplicationContext.defaultModel().getExtensionLoader(LoadBalance.class);
    2. System.out.println(balanceExtensionLoader.getSupportedExtensions());
    3. LoadBalance loadBalance = ApplicationModel.defaultModel().getExtensionLoader(LoadBalance.class).getExtension("myloadbalance");
    4. System.out.println(loadBalance);

  • 相关阅读:
    开源现场总线协议栈
    C之fopen/fclose/fread/fwrite/flseek
    LibTorch | 使用神经网络求解一维稳态对流扩散方程
    Linux——Linux用户管理、组管理和文件管理常用命令总结
    SAP SMARTFORMS打印文本内容手动换行
    代码更换了目录,没有任何变更,但Idea编辑器却提示所有代码都变更了?
    后缀数组复习
    Linux 安装5.7版本MySQL
    AdsPower RPA一些编写思路(进阶)
    MySQL⭐二、使用Navicat连接到服务器上的MySQL
  • 原文地址:https://blog.csdn.net/luciferlongxu/article/details/127779511