Tuscany SCA 引导和装配的过程

2024-03-21 00:32
文章标签 过程 引导 装配 sca tuscany

本文主要是介绍Tuscany SCA 引导和装配的过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Tuscany SCA在运行的时候进行各种服务的装配,根据XML格式的SCA元素的定义,从SCDL和其他格式的文件中读取装配的信息。

一、装配过程

主要分成三个步骤:

1、载入(load)阶段从SCDL读取配置信息处理后,生成内存中的模型。

2、创建(build)阶段评估模型并将模型组成单独的组件元素,如Service,Reference,Component。

3、连接(connect)阶段连接Reference到相应的Service。

 

二、装配过程由部署发起,按照顺序逐步执行。

三个步骤包含在部署当中,由部署发起。

这是代码的片段:

.
.
.
        
//  load the model
        load(parent, componentDefinition, deploymentContext);
 
       
//  resolve autowires
        resolver.resolve( null , componentDefinition);

        
//  build runtime artifacts
        build(parent, componentDefinition, deploymentContext);

        Collection
< Component >  components  =  deploymentContext.getComponents().values();
       connector.connect(componentDefinition);
.
.
.

 

三、Loader通过Loader接口实现。

有两种类型的loader:ComponentTypeLoader和StAXElementTypeLoader,通过Loader接口来实现对两中类型的loaer进行载入。

1、ComponentTypeLoader 类型loader负责载入和运行环境相关的信息,即系统环境的实现

2、StAXElementLoader 类型loader负责载入在系统环境运行的应用相关的信息

A) Loader的继承关系图:

B) ComponentTypeLoader的继承关系图:

C) StAXElementLoader的继承关系图:

D)  相关代码片段如下:

        //  register component type loaders
        loaderRegistry.registerLoader(SystemImplementation. class new  SystemComponentTypeLoader(introspector));
        loaderRegistry.registerLoader(SystemCompositeImplementation.
class ,
            
new  SystemCompositeComponentTypeLoader(loaderRegistry));

        
//  register element loaders
        registerLoader(loaderRegistry,  new  ComponentLoader(loaderRegistry, propertyFactory));
        registerLoader(loaderRegistry, 
new  ComponentTypeElementLoader(loaderRegistry));
        registerLoader(loaderRegistry, 
new  CompositeLoader(loaderRegistry,  null ));

 

四、宿主环境的引导

SCA是在主机环境下引导,所谓宿主环境就是引导SCA环境所在的系统环境。

默认的引导过程是在 DefaultBootstrapper 中实现的,过程如下:

 

相对应的代码片段:

1、Create Runtime Component

//       创建StandaloneRuntimeImpl 实例
        StandaloneRuntime runtime  =  (StandaloneRuntime)DirectoryHelper.createRuntime(runtimeInfo);

TuscanyRuntime继承关系图:

2、Create Bootstrap Deployer

.
.
.
Bootstrapper bootstrapper 
=  createBootstrapper();
.
.
.
bootstrapper.createDeployer()
.
.
.

Bootstrapper的继承关系图:

3、Locate System Assembly和Deploy System Assembly

就是前面提到的load、build和connect处理过程,这部分在前面已经说过,不再重复。

4、Locate Application Assemblies、Deploy Application Assembly和Start Server

从当前CVS下载的版本,这一部分是临时实现。在后面的开发过程中可能还会有变化。

.
.
.
int  status  =  runtime.deployAndRun(applicationScdlURL, applicationClassLoader, appArgs);
.
.
.

后面结合实际的例子逐步细化。

 

这篇关于Tuscany SCA 引导和装配的过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/831232

相关文章

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

python运用requests模拟浏览器发送请求过程

《python运用requests模拟浏览器发送请求过程》模拟浏览器请求可选用requests处理静态内容,selenium应对动态页面,playwright支持高级自动化,设置代理和超时参数,根据需... 目录使用requests库模拟浏览器请求使用selenium自动化浏览器操作使用playwright

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin

java内存泄漏排查过程及解决

《java内存泄漏排查过程及解决》公司某服务内存持续增长,疑似内存泄漏,未触发OOM,排查方法包括检查JVM配置、分析GC执行状态、导出堆内存快照并用IDEAProfiler工具定位大对象及代码... 目录内存泄漏内存问题排查1.查看JVM内存配置2.分析gc是否正常执行3.导出 dump 各种工具分析4.

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于