dubbo对于依赖的服务默认采取了启动的时候就做服务可用性检查,若是不可用将会抛出异常。

     dubbo文档中有以下叙述:如果你的spring容器是懒加载的,或者通过API编程延迟引用服务,请关闭check,否则服务临时不可用时,会抛出异常,拿到null引用,如果check=false,总是会返回引用,当服务恢复时,能自动连上。

     主要有三个参数配置:

    1、关闭某个服务的启动时检查:(没有提供者时报错)

[html] view plain copy

  1. <dubbo:reference id="demoService" interface="com.alibaba.dubbo.demo.DemoService"  check="false" />  


      若是此时关闭掉服务提供者的服务器,此时启动客户端的服务器,可以正常启动,

      注:启动类测试类为: 

[java] view plain copy

  1. import org.springframework.context.support.ClassPathXmlApplicationContext;  

  2. import com.alibaba.dubbo.demo.DemoService;  

  3. public class Consumer {  

  4.    

  5.     public static void main(String[] args) throws Exception {  

  6.         ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(new String[] {"applicationContext.xml"});  

  7.         context.start();  

  8.         DemoService demoService = (DemoService)context.getBean("demoService"); // 获取远程服务代理  

  9. //        String hello = demoService.sayHello("world"); // 执行远程方法  

  10. //        System.out.println( hello ); // 显示调用结果  

  11.     }  

  12.    

  13. }  



     若将 check="false"改为true,启动客户端服务器报错,信息如下:

     

[java] view plain copy

  1. Exception in thread "main" org.springframework.beans.factory.xml.XmlBeanDefinitionStoreException: Line 14 in XML document from class path resource [applicationContext.xml] is invalid; nested exception is org.xml.sax.SAXParseException; lineNumber: 14; columnNumber: 93; 与元素类型 "check" 相关联的属性 "{1}" 应有左引号。  

  2.     at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.doLoadBeanDefinitions(XmlBeanDefinitionReader.java:404)  

  3.     at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:342)  

  4.     at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:310)  

  5.     at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:143)  

  6.     at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:178)  

  7.     at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:149)  

  8.     at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:212)  

  9.     at org.springframework.context.support.AbstractXmlApplicationContext.loadBeanDefinitions(AbstractXmlApplicationContext.java:113)  

  10.     at org.springframework.context.support.AbstractXmlApplicationContext.loadBeanDefinitions(AbstractXmlApplicationContext.java:80)  

  11.     at org.springframework.context.support.AbstractRefreshableApplicationContext.refreshBeanFactory(AbstractRefreshableApplicationContext.java:123)  

  12.     at org.springframework.context.support.AbstractApplicationContext.obtainFreshBeanFactory(AbstractApplicationContext.java:422)  

  13.     at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:352)  

  14.     at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:139)  

  15.     at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:93)  

  16.     at Consumer.main(Consumer.java:8)  

  17. Caused by: org.xml.sax.SAXParseException; lineNumber: 14; columnNumber: 93; 与元素类型 "check" 相关联的属性 "{1}" 应有左引号。  

  18.     at com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.createSAXParseException(ErrorHandlerWrapper.java:198)  

  19.     at com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.fatalError(ErrorHandlerWrapper.java:177)  

  20.     at com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:441)  

  21.     at com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:368)  

  22.     at com.sun.org.apache.xerces.internal.impl.XMLScanner.reportFatalError(XMLScanner.java:1436)  

  23.     at com.sun.org.apache.xerces.internal.impl.XMLScanner.scanAttributeValue(XMLScanner.java:829)  

  24.     at com.sun.org.apache.xerces.internal.impl.XMLNSDocumentScannerImpl.scanAttribute(XMLNSDocumentScannerImpl.java:439)  

  25.     at com.sun.org.apache.xerces.internal.impl.XMLNSDocumentScannerImpl.scanStartElement(XMLNSDocumentScannerImpl.java:255)  

  26.     at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl$FragmentContentDriver.next(XMLDocumentFragmentScannerImpl.java:2786)  

  27.     at com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl.next(XMLDocumentScannerImpl.java:606)  

  28.     at com.sun.org.apache.xerces.internal.impl.XMLNSDocumentScannerImpl.next(XMLNSDocumentScannerImpl.java:117)  

  29.     at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanDocument(XMLDocumentFragmentScannerImpl.java:510)  

  30.     at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:848)  

  31.     at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:777)  

  32.     at com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(XMLParser.java:141)  

  33.     at com.sun.org.apache.xerces.internal.parsers.DOMParser.parse(DOMParser.java:243)  

  34.     at com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:347)  

  35.     at org.springframework.beans.factory.xml.DefaultDocumentLoader.loadDocument(DefaultDocumentLoader.java:75)  

  36.     at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.doLoadBeanDefinitions(XmlBeanDefinitionReader.java:396)  

  37.     ... 14 more  



2、关闭所有服务检查

[html] view plain copy

  1. <dubbo:consumercheckdubbo:consumercheck="false"/>  



3、关闭注册中心启动时检查



[html] view plain copy

  1. <dubbo:registrycheckdubbo:registrycheck="false"/>  




4、使用dubbo.properties配置:

[plain] view plain copy

  1. dubbo.reference.com.foo.BarService.check=false  

  2. dubbo.reference.check=false  

  3. dubbo.consumer.check=false  

  4. dubbo.registry.check=false  


5、注解服务接口时,怎么配置check 一直没找到方法,以后再研究?