Hessian学习之(二):Hessian集成到Spring
来源:互联网 发布:淘宝退货原因有哪些 编辑:程序博客网 时间:2024/05/16 09:05
1 为什么集成Hessian到Spring中?
2 开发步骤:
(1) 下载spring(包含hessian)
下载地址:http://sourceforge.net/projects/springframework/files/springframework-2/2.5.5/
或者从我的云盘上下载: http://pan.baidu.com/s/1tfBQS
(2) 创建动态web工程
注意选择tomcat服务器,以及选择生成web.xml
这是最终的工程视图:
(3) 引入jar
右击工程,选择configure build path,add external jars,将所需的jar文件都加进来。
在我提供的源码下载中有需要的所有jar文件。
(4) 创建接口和实现类
参考我这篇博文: http://blog.csdn.net/jiyiqinlovexx/article/details/17284559
(5) 配置
主要是配置文件,服务的话随便写接口方法即可。由于是基于http,必须起web服务,通过spring的mvc适配器把请求转发给hessian。
web.xml
<?xml version="1.0" encoding="UTF-8"?><web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0"> <display-name>HessianProject</display-name> <welcome-file-list> <welcome-file>index.html</welcome-file> <welcome-file>index.htm</welcome-file> <welcome-file>index.jsp</welcome-file> <welcome-file>default.html</welcome-file> <welcome-file>default.htm</welcome-file> <welcome-file>default.jsp</welcome-file> </welcome-file-list> <servlet> <servlet-name>hello</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>hello</servlet-name> <url-pattern>/hello/*</url-pattern> </servlet-mapping> </web-app>
hello-servlet.xml(命名格式: ServletName-servlet.xml)
<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd"> <bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/><bean id="helloService" class="com.jiq.hessian.HelloService"> <!-- IOC,any additional properties, maybe a DAO? --></bean><bean name="/helloService" class="org.springframework.remoting.caucho.HessianServiceExporter"><property name="service" ref="helloService"/><property name="serviceInterface" value="com.jiq.hessian.IHelloService"/></bean></beans>
(6) 创建server,部署项目
先写一个jsp来测试服务是否正确(hello.jsp):
<%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEncoding="ISO-8859-1"%><%@ page import="com.caucho.hessian.client.HessianProxyFactory" %><%@ page import="com.jiq.hessian.IHelloService" %><%HessianProxyFactory factory = new HessianProxyFactory();String url = "http://localhost:80/HessianProject/hello/helloService";IHelloService proxy = (IHelloService)factory.create(IHelloService.class, url);out.print(proxy.SayHello());%>
在view中打开servers试图,空白处右击,创建server,选择你的tomcat,启动服务器
浏览器中输出入: http://localhost/HessianProject/hello.jsp 访问。
(7) 启动,classNotFound(DispatcherServlet等)错误,修改部署路径
右击工程,properties,选择deployment Assembly,点击add,选择java build path entries,将所需的spring的jar文件都加进去。
然后再启动server就不会有这个问题了。
(8) 开发客户端
配置文件:hello-client.xml(名字任取)。
<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd"><bean id="helloService" class="org.springframework.remoting.caucho.HessianProxyFactoryBean"> <property name="serviceUrl" value="http://localhost:80/HessianProject/hello/helloService"/> <property name="serviceInterface" value="com.jiq.hessian.IHelloService"/> </bean></beans>
测试程序:
package com.jiq.clientTest;import java.net.MalformedURLException;import org.springframework.beans.factory.BeanFactory;import org.springframework.beans.factory.xml.XmlBeanFactory;import org.springframework.context.ApplicationContext;import org.springframework.context.support.ClassPathXmlApplicationContext;import org.springframework.core.io.ClassPathResource;import com.caucho.hessian.client.HessianProxyFactory;import com.jiq.hessian.IHelloService;public class HessianClient {public static void main(String[] args) {// TODO Auto-generated method stub//调用方式1//String url = "http://localhost:80/HessianProject/hello/helloService"; //HessianProxyFactory factory = new HessianProxyFactory(); ////try //{ //IHelloService proxy =(IHelloService)factory.create(IHelloService.class, url); //System.out.println(proxy.SayHello()); //} //catch (MalformedURLException e) { //e.printStackTrace(); //} //调用方式2BeanFactory factory = new XmlBeanFactory(new ClassPathResource("./com/jiq/clientTest/hello-client.xml")); IHelloService helloService = (IHelloService)factory.getBean("helloService");System.out.print(helloService.SayHello());//调用方式3//ApplicationContext context=new ClassPathXmlApplicationContext("hello-client.xml"); // IHelloService service1=(IHelloService)context.getBean("helloService"); // System.out.print(service1.SayHello());}}
3 工程源码下载:
其中包含了工程zip文件,以及所需的所有jar文件。
下载地址
====================================== 问题自我总结 =================================================
把我的问题理一下,下一步解决:
1、 为什么集成到Spring?为了方便利用Spring的IoC容器进行管理么?
2、Hessian的服务端能够脱离Tomcat等Web容器?安装为Windows服务可能么?
不过好像没必要,因为我的服务端是要跨平台的,既要在windows上部署,也要在Linux上部署。
脱离Web容器也没必要。
3、如何与Mina结合,利用Mina的快速,长连接等特点?
4、那个什么Invoker是怎么回事?
5、离我的高性能分布式服务框架还有多远?
梁飞说过一句话: 在分布式服务框架中,RPC只是基石,当应用全面服务化后,服务治理才是关键,这也是Dubbo的一个工作重心,但这一次开源的不包含治理模块。
顿时让我觉得走向高性能分布式服务框架的路,还有好长,好长。。。 希望环境对我有利!!!
我今天突然想到,对服务做负载均衡了,数据库呢?所有这些不同机器上的服务访问同一个数据库也是问题吧。据说mysql能同时处理几十万的请求,不大清楚,如果要更好的性能是不是需要针对数据库进行分表,分库呢? 需要继续研究。。。。。。。 果然路很长
- Hessian学习之(二):Hessian集成到Spring
- 二、hessian与spring集成
- (二)spring 远程服务之Hessian
- Spring集成Hessian
- Spring集成Hessian
- spring hessian 集成开发
- Spring 集成 Hessian
- spring 集成 Hessian
- spring集成Hessian
- Hessian与Spring集成
- Spring集成Hessian
- hessian入门,spring集成
- Hessian入门(与Spring集成)
- Hessian入门(与Spring集成)
- Hessian入门(与Spring集成)
- Hessian入门(与Spring集成)
- Hessian入门(与Spring集成)
- Hessian入门(与Spring集成)
- 原来我以前实现过AVL树
- jquery 跨域POST信息问题解决方案
- a=b
- hdu2289Cup(神坑题,精度+二分,以半径二分不能过,以高度为二分就过了)
- MySQL表常用操作
- Hessian学习之(二):Hessian集成到Spring
- Jackson 框架使用教程,轻易转换JSON
- QPS、PV和需要部署机器数量计算公式
- 在CentOS中实现AP 初步小结
- CommonLisp(四)----宏
- rm命令替换脚本
- 买三送一(某外企面试题)
- 2013移动APP界面设计趋势与设计理念
- 让VMware的ubuntu可以上网