基于XML实现Dubbo简例

##服务端
dubbo框架是面向接口的rpc调用框架,需要提供接口EchoService来作为服务暴露使用

1.接口定义

public interface EchoService{
  String echo(String message);
}

public class EchoServiceImpl implements EchoService{

  public String echo(String message){
    String now = new SimpleDateFormat("HH:mm:ss").
      format(new Date());
    System.out.println(RpcContext.getContext().gerRemoteAddress());
    return message;
  }

}

//关键配置

<!-- service provider name-->
<dubbo:application name="echo-provider">

<!--register address-->
<dubbo:registry address="zookeeper://127.0.0.1">

<!--protocol for rpc-->
<dubbo:protocol name="dubbo" port="20880">

<!--bean container-->
<bean id="echoService" class="com.alibaba.dubbo.samples.echo.impl.EchoServiceImpl"/>

<--interface for provide service-->
<dubbo:service interface="com.alibaba.dubbo.samples.echo.api.EchoService" ref="echoService">


//启动dubbo服务
public class EchoProvider{

  public static void main(String[] args)throws Exception{
     ClassPathXmlApplicationContext context = 
       ClassPathXmlApplicationContext(new String[]{"spring/echo-provider.xml"});

    context.start();
    System.in.read();
  }

}

客户端

//主要配置

<!--service consumer name-->
<dubbo:application name="echo-consumer">

<!--register center-->
<dubbo:registry address="zookeeper://127.0.0.1:2181"/>

<service for consumer>
<dubbo:reference id="echoService" check="false" 
interface="com.alibaba.dubbo.samples.echo.api.EchoService">

//启动
public class EchoConsumer{
  
  publci static void main(String args[]){
    cLasspathXmlApplicationContext context = 
      new ClassPathXmlApplicationContext("new String[]{spring/echo-consumer.xml}");
      context.start();
      EchoService.echoService = (EchoService)context.getBean("echoService");
      String status = echoService.echo("hello world!");
      System.out.println("echo result:"+status);
  }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值