微博RPC框架Motan

微博RPC框架Motan原文来自 http blog csdn net autfish article details 从 14 年开始就陆续看到新浪微博 RPC 框架 Motan 的介绍 时隔两年后 微博团队终于宣布开源轻量级 RPC 框架 Motan 项目地址 https github com weibocom motan 项目文档介绍比较详细 搭建开发环境非常简单 如果只是使用

原文来自:http://blog.csdn.net/autfish/article/details/

从14年开始就陆续看到新浪微博RPC框架Motan的介绍,时隔两年后,微博团队终于宣布开源轻量级RPC框架Motan,项目地址:

项目文档介绍比较详细,搭建开发环境非常简单,如果只是使用而不需要源码的话,只配置maven依赖项目即可,按照示例几分钟就可以搭建起一个Hello world。当然这也是官方介绍中的优点之一。

我们来扩展一下官方的示例,并测试一下集群式部署。首先创建一个maven项目

1 公共部分

pom.xml

[java] view plain copy print ?
在CODE上查看代码片
派生到我的代码片

  1. <dependencies>  
  2.     <dependency>  
  3.         <groupId>com.weibo</groupId>  
  4.         <artifactId>motan-core</artifactId>  
  5.         <version>0.0.1</version>  
  6.     </dependency>  
  7.     <dependency>  
  8.         <groupId>com.weibo</groupId>  
  9.         <artifactId>motan-transport-netty</artifactId>  
  10.         <version>0.0.1</version>  
  11.     </dependency>  
  12.     <!– only needed for spring-based features –>  
  13.     <dependency>  
  14.         <groupId>com.weibo</groupId>  
  15.         <artifactId>motan-springsupport</artifactId>  
  16.         <version>0.0.1</version>  
  17.     </dependency>  
  18.     <dependency>  
  19.         <groupId>org.springframework</groupId>  
  20.         <artifactId>spring-context</artifactId>  
  21.         <version>4.2.4.RELEASE</version>  
  22.     </dependency>  
  23.     <dependency>  
  24.         <groupId>com.weibo</groupId>  
  25.         <artifactId>motan-registry-zookeeper</artifactId>  
  26.         <version>0.0.1</version>  
  27.     </dependency>  
  28. </dependencies>  

项目结构如图

微博RPC框架Motan

User类,注意必须实现Serializable

[java] view plain copy print ?
在CODE上查看代码片
派生到我的代码片

  1. public class User implements Serializable {  
  2.   
  3.     private static final long serialVersionUID = L;  
  4.   
  5.     public User(int id, String name) {  
  6.         this.id = id;  
  7.         this.name = name;  
  8.     }  
  9.       
  10.     private int id;  
  11.     private String name;  
  12.       
  13.     public int getId() {  
  14.         return id;  
  15.     }  
  16.     public void setId(int id) {  
  17.         this.id = id;  
  18.     }  
  19.     public String getName() {  
  20.         return name;  
  21.     }  
  22.     public void setName(String name) {  
  23.         this.name = name;  
  24.     }  
  25.     public String toString() {  
  26.         return String.format(“{id=%d,name=%s}”this.id, this.name);  
  27.     }  
  28. }  

UserService

[java] view plain copy print ?
在CODE上查看代码片
派生到我的代码片

  1. public interface UserService {  
  2.     public User find(int id);  
  3. }  

2 服务器部分

UserServiceImpl

[java] view plain copy print ?
在CODE上查看代码片
派生到我的代码片

  1. public class UserServiceImpl implements UserService {  
  2.     public User find(int id) {  
  3.         System.out.println(id + ” invoked rpc service”);  
  4.         return new User(id, “name” + id);  
  5.     }  
  6. }  

motan_server.xml

[java] view plain copy print ?
在CODE上查看代码片
派生到我的代码片

  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” xmlns:motan=“http://api.weibo.com/schema/motan”  
  4.     xsi:schemaLocation=”http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd  
  5.    http://api.weibo.com/schema/motan http://api.weibo.com/schema/motan.xsd”>  
  6.   
  7.     <motan:protocol name=“motan” loadbalance=“roundrobin” maxWorkerThread=“500” minWorkerThread=“20” />  
  8.     <bean id=“serviceImpl” class=“quickstart.UserServiceImpl” />  
  9.     <motan:registry regProtocol=“zookeeper” name=“my_zookeeper” address=“127.0.0.1:2181”/>  
  10.     <motan:service interface=“quickstart.UserService” ref=“serviceImpl” registry=“my_zookeeper” export=“8002” />  
  11. </beans>  

Server.java

[java] view plain copy print ?
在CODE上查看代码片
派生到我的代码片

  1. public class Server {  
  2.     public static void main(String[] args) throws InterruptedException {  
  3.         ApplicationContext applicationContext = new ClassPathXmlApplicationContext(  
  4.                 “classpath:motan_server.xml”);  
  5.         System.out.println(“server start…”);  
  6.     }  
  7. }  

集群部署需要使用Zookeeper做注册中心

3 部署Zookeeper

以windows环境为例

下载地址 http://zookeeper.apache.org/

下载后得到gz包如zookeeper-3.4.8.tar.gz,解压到任意目录如d:\zookeeper-3.4.8

在zookeeper-3.4.8目录下建立data文件夹

进入zookeeper-3.4.8/conf目录,把zoo_sample.cfg重命名为zoo.cfg,并修改dataDir选项

进入zookeeper-3.4.8/bin目录,执行zkServer.cmd

运行Server.java测试,启动成功

微博RPC框架Motan

4 部署多服务器实例

下面把服务器端部署两个实例,修改pom.xml,添加

[java] view plain copy print ?
在CODE上查看代码片
派生到我的代码片

  1. <build>  
  2.         <finalName>motan-examples</finalName>  
  3.         <plugins>  
  4.             <plugin>  
  5.                 <groupId>org.apache.maven.plugins</groupId>  
  6.                 <artifactId>maven-jar-plugin</artifactId>  
  7.                 <version>2.4</version>  
  8.                 <configuration>  
  9.                     <archive>  
  10.                         <manifest>  
  11.                             <addClasspath>true</addClasspath>  
  12.                             <classpathPrefix>.</classpathPrefix>  
  13.                             <mainClass>quickstart.Server</mainClass>  
  14.                         </manifest>  
  15.                     </archive>  
  16.                 </configuration>  
  17.             </plugin>  
  18.         </plugins>  
  19.     </build>  

注意正确配置mainClass的类全路径

进入项目目录执行

mvn clean package

把生成的可执行jar和依赖jar包复制到一起,并执行

java -jar motan-examples.jar

5 客户端部分

motan_client.xml

[java] view plain copy print ?
在CODE上查看代码片
派生到我的代码片

  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” xmlns:motan=“http://api.weibo.com/schema/motan”  
  4.     xsi:schemaLocation=”http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd  
  5.    http://api.weibo.com/schema/motan http://api.weibo.com/schema/motan.xsd”>  
  6.   
  7.     <motan:protocol name=“motan” haStrategy=“failover” />  
  8.     <motan:registry regProtocol=“zookeeper” name=“my_zookeeper” address=“127.0.0.1:2181”/>  
  9.     <motan:referer id=“remoteService” interface=“quickstart.UserService” registry=“my_zookeeper”/>  
  10. </beans>  

Client.java

[java] view plain copy print ?
在CODE上查看代码片
派生到我的代码片

  1. public class Client {  
  2.   
  3.     public static void main(String[] args) throws InterruptedException {  
  4.         ApplicationContext ctx = new ClassPathXmlApplicationContext(  
  5.                 “classpath:motan_client.xml”);  
  6.         final UserService service = (UserService) ctx.getBean(“remoteService”);  
  7.   
  8.         final int SIZE = 100;  
  9.         final AtomicInteger atom = new AtomicInteger();  
  10.         ExecutorService exec = Executors.newFixedThreadPool(SIZE);  
  11.         for(int i = 0; i < SIZE; i++) {  
  12.             exec.execute(new Thread(){  
  13.                 public void run() {  
  14.                     User user = service.find(atom.addAndGet(1));  
  15.                     System.out.println(user);  
  16.                 }  
  17.             });  
  18.         }  
  19.     }  
  20. }  

运行Client.java

微博RPC框架Motan

从输出结果可以看出,客户端请求被分配到两个服务器实例中。

关闭其中一个服务器实例,重新运行客户端

微博RPC框架Motan

因为Zookeeper处理服务器断开的消息有一定延时,一部分请求仍然被提交到已关闭的端口上,导致抛出异常。但是这里并没有按配置执行失败切换服务器的策略,是配置问题还是不支持网络拒绝连接的失败类型,限于时间关系,没有做更多测试,暂时打个问号。

6 总结

同是RPC框架,就不可避免的要和另一个优秀开源框架dubbo/dubbox比较

缺点:

1 功能较少,不支持跨语言调用

2 年轻,稳定性和可能出现的问题尚待检验

优点:

1 轻量级,开发和学习简单

2 年轻,有无限的发展可能性。dubbo因为原创团队的原因已经停止更新,motan能否后来居上,让我们拭目以待。


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233753.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 等价类划分法设计用例(超详细)「建议收藏」

    等价类划分法设计用例(超详细)「建议收藏」等价类划分法等价类:1、解决了不能穷举测试的问题、控制成本、控制测试用例数量2、数据值要明确,对文字敏感3、依据需求将输入划分为若干个等价类,划分等价类(需求、数据特征)等价类设计用例的难点:如何根据时间成本划分等价类等价类分为:           1、有效等价类           2、无效等价类如上图可以划分为:                 有效等价类1:[-99,99]                 无效等价类2:<-99                 无效等

    2022年10月18日
    2
  • pycharm 安装库_基础笼安装视频

    pycharm 安装库_基础笼安装视频进入Settings打开选项卡,库右侧有一个加号,点击加号在输入框里搜索要安装的库就行(已经安装过的颜色会改变)点击会出现这里面是一些常用库的下载地址,可以自己添加附上我的常用地址:http://mirrors.aliyun.com/pypi/simple/https://pypi.tuna.tsinghua.edu.cn/simple/以上,就是Pycharm安装库的…

    2022年8月25日
    8
  • Layui 弹窗 -全面使用

    Layui 弹窗 -全面使用在源码中用了相对较大的篇幅来定制了这个 msg 目的是想将其打造成露脸率最高的提示框 而事实上我的确也在大量地使用它 因为它简单 而且足够得自觉 它不仅占据很少的面积 而且默认还会 3 秒后自动消失所有这一切都决定了我对 msg 的爱 因此我赋予了它许多可能在外形方面 它坚持简陋的变化 在作用方面 它坚持零用户操作 而且它的参数也是自动补齐的 eg1layer msg 只想弱弱提示 eg

    2025年6月21日
    2
  • 优先队列「建议收藏」

    优先队列「建议收藏」优先队列比如现实生活中的排队,就符合这种先进先出的队列形式,但是像急诊医院排队,就不可能按照先到先治疗的规则,所以需要使用优先队列。实现优先队列其实都是基于下面这些实现的:可以看出来实现优先队列最

    2022年7月3日
    24
  • MATLAB实现线性插值interp1的功能

    MATLAB实现线性插值interp1的功能1.关于插值插值,它根据已知的数据序列(也可以理解为坐标中一连串离散的点),找到其中的规律;然后根据找到的这个规律,来对其中尚未有数据记录的点进数值的估计。2.关于线性插值线性插值是一种针对一维数据的插值方法,它根据一维数据序列中需要插值的点的左右邻近两个数据点来进行数值的估计。当然了它不是求这两个点数据大小的平均值(当然也有求平均值的情况),而是根据到这两个点的距离来分配它们的比重的。而对于一些边缘处的点也需要使用到外插:即通过找出最近的两个点,通过建立该两点之间的一元一次线性方程通过带入x即可以得

    2022年5月20日
    31
  • 通达OA工作流不可编辑

    通达OA工作流不可编辑找到表:flow_run搜索自增长ID=流水号,查看该条记录的用户是否ok找到表:flow_run_prcs搜索流水号:run_id=***查看结果的PRCS_ID数字最大的那一条记录的OP_FLAG是否为1,如果不为1则改为1即可。

    2022年6月23日
    28

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号