dubbo 学习笔记 -- provider端

服务端的配置文件:    provider.xml

[html] view plain copy

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
  5. xsi:schemaLocation="http://www.springframework.org/schema/beans
  6. http://www.springframework.org/schema/beans/spring-beans.xsd
  7. http://code.alibabatech.com/schema/dubbo
  8. http://code.alibabatech.com/schema/dubbo/dubbo.xsd         ">
  9. <!-- Application name -->
  10. <dubbo:application name="Frame"  />
  11. <!-- registry address, used for service to register itself -->
  12. <dubbo:registry address="multicast://224.5.6.7:1234" />
  13. <!-- expose this service through dubbo protocol, through port 20880 -->
  14. <dubbo:protocol name="dubbo" port="20880" />
  15. <!-- which service interface do we expose? -->
  16. <dubbo:service interface="merchant.shop.service.IHelloService" ref="helloService" />
  17. <!-- bean配置 -->
  18. <bean id="helloService"
  19. class="merchant.shop.service.impl.HelloServiceImpl">
  20. </bean>
  21. </beans>

此处interface的地址要与consumer端的一致,所以在服务端工程中新建了和客户端工程一样的路径来保存service

spring 配置文件 : providerApplicationContext.xml

[html] view plain copy

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">
  5. <!-- spring 与 ibatis 衔接 -->
  6. <bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
  7. <property name="configLocation" value="provider-sql-map-config.xml"></property>
  8. <property name="dataSource" ref="dataSource"/>
  9. </bean>
  10. <!-- 数据源基本配置 -->
  11. <bean id="dataSource"
  12. class="org.springframework.jndi.JndiObjectFactoryBean">
  13. <property name="jndiName">
  14. <value>java:/comp/env/test</value>
  15. </property>
  16. </bean>
  17. <!-- 事务配置 -->
  18. <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
  19. <property name="dataSource" ref="dataSource"></property>
  20. </bean>
  21. <!-- 声明式事务管理 -->
  22. <bean id="baseTransactionProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean" abstract="true">
  23. <property name="transactionManager" ref="transactionManager"></property>
  24. <property name="transactionAttributes">
  25. <props>
  26. <prop key="add*">PROPAGATION_REQUIRED</prop>
  27. <prop key="edit*">PROPAGATION_REQUIRED</prop>
  28. <prop key="*">PROPAGATION_REQUIRED,readOnly</prop>
  29. </props>
  30. </property>
  31. </bean>
  32. </beans>

服务端需要启动的两个文件如下 :

[java] view plain copy

  1. package com.sitech.comm.dubbo;
  2. import org.springframework.context.ApplicationContext;
  3. import org.springframework.context.support.ClassPathXmlApplicationContext;
  4. public class Provider {
  5. public static void init() throws Exception {
  6. ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(new String[] {"provider.xml"});
  7. context.start();
  8. singleton();
  9. }
  10. public static ApplicationContext context = null;
  11. public static ApplicationContext singleton() {
  12. if (context == null) {
  13. context = new ClassPathXmlApplicationContext(new String[] {"providerApplicationContext.xml"});
  14. }
  15. return context;
  16. };
  17. }

[java] view plain copy

  1. package com.sitech.comm.dubbo;
  2. import javax.servlet.ServletException;
  3. import javax.servlet.http.HttpServlet;
  4. import com.sitech.comm.log.LogWritter;
  5. public class ProviderInit extends HttpServlet {
  6. public void init() throws ServletException {
  7. try {
  8. System.out.println("初始化dubbo服务端");
  9. Provider.init();
  10. } catch (Exception e) {
  11. System.out.println("初始化dubbo服务端失败");
  12. }
  13. }
  14. }

web.xml 中增加启动如下 :

[html] view plain copy

  1. <servlet>
  2. <servlet-name>ProviderInit</servlet-name>
  3. <servlet-class>
  4. com.sitech.comm.dubbo.ProviderInit
  5. </servlet-class>
  6. <load-on-startup>1</load-on-startup>
  7. </servlet>

consumer客户端就可以远程调用另一个工程的服务了

这里出问题,一般都是配置文件的问题,如数据库的连接,spring 与 ibatis 衔接

时间: 2024-10-17 13:49:32

dubbo 学习笔记 -- provider端的相关文章

CCIE学习笔记之端到端QOS

Class-map默认行为match-all Match protocol http mime "*/audio/*" Match protocol http mime "*/video/*"  //分类器寻找特殊类型的音频和视频mime流量 Match protocol http "*.jpg|*.jpeg"     //匹配图片流量 注:MIME类型就是设定某种扩展名的文件用一种应用程序来打开的方式类型,当该扩展名文件被访问的时候,浏览器会自

Angular 学习笔记——$provider

<!DOCTYPE HTML> <html ng-app="myApp"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>无标题文档</title> <script src="angular.min.js"></scrip

dubbo学习笔记

一.网站架构演变 二.dubbo架构 三.

【计算机网络学习笔记】端口号

一 什么是端口? 如果把IP地址比作一间房子 ,端口就是出入这间房子的门.端口号就是打开门的钥匙.真正的房子只有几个门,但是一个IP地址的端口 可以有65536个之多!端口是通过端口号来标记的,端口号只有整数,范围是从0 到65535. 二 端口有什么作用? 主机是怎样区分不同的网络服务呢?显然不能只靠IP地址,因为IP 地址与网络服务的关系是一对多的关系.实际上是通过“IP地址+端口号”来区 分不同的服务的.服务器一般都是通过知名端口号来识别的. 到1992年为止,知名端口号介于1-255之间

《Redis设计与实现》学习笔记-服务端

Redis服务器负责与多个客户端建立连接,处理客户端请求,保存各个数据库状态.通过使用由I/O多路复用技术实现的事件处理器,Redis服务器采用单线程单进程处理客户端命令请求.Redis通过redisServer结构来记录服务端的各种状态. 命令请求执行过程 1.客户端发送命令请求,客户端将命令请求转换成协议格式. 2.服务端读取命令请求,将命令请求缓存在客户端输入缓冲区中,对输入缓冲区中的命令进行分析把参数和参数个数分别保存到客户端状态的argv属性和argc属性中,然后调用命令执行器执行指定

dubbo学习笔记 ——ExtensionLoader

dubbo扩展点加载器,用于加载用@SPI修饰的接口 提供对外静态方法: ExtensionLoader<T> getExtensionLoader(Class<T> type) EXTENSION_LOADERS缓存已有扩展点加载器,这种模式可用于当程序启动后便不再修改更新的配置,当多线程同时进入if中,不会出现ExtensionLoder被更新问题,线程安全 若当前类型不存在缓存中,新建一个ExtensionLoader,构造方法被私有化,并存入缓存 构造方法中记录当前指定类对

springmvc学习笔记(4)-前端控制器

springmvc学习笔记(4)-前端控制器 springmvc学习笔记4-前端控制器 本文通过前端控制器源码分析springmvc执行过程 1.前端控制器接收请求 调用doDispatch方法 protected void doDispatch(HttpServletRequest request, HttpServletResponse response) throws Exception { HttpServletRequest processedRequest = request; Ha

Dubbo -- 系统学习 笔记 -- 示例 -- 多注册中心

Dubbo -- 系统学习 笔记 -- 目录 示例 想完整的运行起来,请参见:快速启动,这里只列出各种场景的配置方式 多注册中心 可以自行扩展注册中心,参见:注册中心扩展 (1) 多注册中心注册 比如:中文站有些服务来不及在青岛部署,只在杭州部署,而青岛的其它应用需要引用此服务,就可以将服务同时注册到两个注册中心. XML : provider.xml <?xml version="1.0" encoding="UTF-8"?> <beans xm

Dubbo -- 系统学习 笔记 -- 示例 -- 集群容错

Dubbo -- 系统学习 笔记 -- 目录 示例 想完整的运行起来,请参见:快速启动,这里只列出各种场景的配置方式 集群容错 在集群调用失败时,Dubbo提供了多种容错方案,缺省为failover重试. 各节点关系: 这里的Invoker是Provider的一个可调用Service的抽象,Invoker封装了Provider地址及Service接口信息. Directory代表多个Invoker,可以把它看成List<Invoker>,但与List不同的是,它的值可能是动态变化的,比如注册中