Tuscany作为SCA Spec1.0实现,现在已接近Release 1.0的尾声,在近期将发布。本文将针对其最新代码,通过对其启动过程进行分析,来了解Tuscany中对资源的加载及模型组装的处理。 
                                    
                                    Tuscany作为SCA Spec1.0实现,现在已接近Release 1.0的尾声,在近期将发布。其结构相对7月份发布的0.91版本进行了较大的调整,优化了代码的结构并且增加了部分新功能。本文将针对其最新代码,通过对其启动过程进行分析,来了解Tuscany中对资源的加载及模型组装的处理。
                                    一、启动前准备
                                    1、 扩展点注册器实例化
                                    Tuscany的实现采用了扩展点机制,所有的可重用对象都会在其中注册,因此把扩展点注册器作为参数来回传递,通过它可以从中拿到所有的已注册对象。
                                    2、 注册对象到扩展点注册器
                                    Tuscany的现有版本与以前版本进行了较大改进,由原来在代码中指定改为了由配置文件中指定,加载的方式也改为了Lazy 
                                      Loading,在从注册器中取得对象时加载配置文件,然后把实例放入注册器的集合中,以便下次直接从中取得需要的对象,不再解析配置文件。
                                    最先注册的对象有:WorkScheduler,ModelFactoryExtensionPoint,ContextFactoryExtensionPoint,ProxyFactory,InterfaceContractMapper。
                                    3、加载ModuleActivator
                                    遍历所有定义的ModuleActivator文件,解析其中的内容作为ModuleActivator接口的实现,然后执行其中的start方法。
                                    ModuleActivator现有接口已经去掉了扩展点注册的方法。
                                    4、解析策略配置文件definitions.xml
                                    策略配置文件配置了针对binding,implementation所使用的策略,其使用方式可参考其SCA 
                                      spec中的 Policy Framework一节。
                                    二、资源加载
                                    Tuscany对资源的划分是以Contribution为单位的,Contribution作为一组资源的集合,包含了SCA的配置文件如*.composite,*.componentType,sca-contribution.xml,以及用到的一些附加文件如*.wsdl等。
                                    现在说明一下Tuscany对单个Contribution的资源加载处理。
                                    1、资源查找
                                    在Tuscany中定义了两种Processor,Dir Processor和Jar 
                                      Processor,分别对目录及Jar中资源进行遍历,返回其中包含的资源列表。
                                    2、资源解析
                                    针对Contribution中的每一个资源都会生成DeployedArtifact对象,在其属性Model中保存着资源的元模型数据。
                                    每个资源解析成元模型主要是依据针对每一资源有一对应的Processor,在其中包含有Read方法负责解析提供URL对应的资源。已提供的解析器有针对*.composite,*.componentType,*.wsdl,*.xsd类型文件的解析。同时针对文件中的不同结点也定义了相应的解析器,如对composite,reference,property,service等结点的解析。Tuscany中采用流XStream方式解析。
                                    3、可发布资源解析
                                    每一个Contribution中都可以定义对外发布的资源列表,通过META-INF/sca-contribution.xml进行定义。同时,在其中也可以定义对外引用和对外暴露的服务。
                                    其Schema格式如下:
                                    
                                    示例:4@5l@4@11@9@11@9@5xe" o:preferrelative="t" 
                                      o:spt="75" coordsize="21600,21600">
                                      4@5l@4@11@9@11@9@5xe" o:preferrelative="t" 
                                      o:spt="75" coordsize="21600,21600">
                                      4@5l@4@11@9@11@9@5xe" o:preferrelative="t" 
                                      o:spt="75" coordsize="21600,21600">
                                      4@5l@4@11@9@11@9@5xe" o:preferrelative="t" 
                                      o:spt="75" coordsize="21600,21600">
                                    
                                      4@5l@4@11@9@11@9@5xe" o:preferrelative="t" 
                                      o:spt="75" coordsize="21600,21600">
                                      Contribution的结构图如下:
                                    
                                    三、资源组装
                                    针对每个Contribution中的可发布资源,如果类型为composite,则进行各个composite,component之间的关联(Wire)。
                                    组装的过程分为三个步骤:build, activate, start。
                                    1、build过程
                                    build主要完成Composite之间的关联,包括compoiste文件中Include元素的解析,Component实现为Compoiste的处理,以及Service,binding,Reference的处理等等。
                                    2、activate过程
                                    主要完成component的ImplementationProvider的赋值,同时针对component中Service的binding进行设置BindingProvider,并针对每一Service,设置其RuntimeWire。
                                    3、start过程
                                    主要完成Component对应的ServiceBindingProvider,ImplementationProvider,ScopeContainer完成启动,通过执行方法start完成。
                                    形成RuntimeWire过程图如下:
                                    