天天看点

dubbo启动检查

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

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

     主要有三个参数配置:

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

[html] view plain copy

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

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

      注:启动类测试类为: 

[java] view plain copy

import org.springframework.context.support.ClassPathXmlApplicationContext;  

import com.alibaba.dubbo.demo.DemoService;  

public class Consumer {  

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

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

        context.start();  

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

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

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

    }  

}  

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

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}" 应有左引号。  

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    at Consumer.main(Consumer.java:8)  

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    ... 14 more  

2、关闭所有服务检查

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

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

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

<code>4、使用dubbo.properties配置:</code>

<code></code>

[plain] view plain copy

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

dubbo.reference.check=false  

dubbo.consumer.check=false  

dubbo.registry.check=false  

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

下一篇: CSS3 2D 转换