Java RMI 使用例子
1.创建协议接口(UserService)
/**
*
*/
package com.junge.demo.rmi.protocol.service; import java.io.Serializable;
import java.rmi.Remote;
import java.rmi.RemoteException; import com.junge.demo.rmi.protocol.model.User; /**
* @author Administrator
*
*/
public interface UserService extends Remote, Serializable { Integer addUser(User user) throws RemoteException; void delUser(Integer userid) throws RemoteException; void modifyUser(User user) throws RemoteException; User getUserByUserId(Integer userid) throws RemoteException;
}
User.java
/**
*
*/
package com.junge.demo.rmi.protocol.model; import java.io.Serializable; /**
* @author Administrator
*
*/
public class User implements Serializable { /**
*
*/
private static final long serialVersionUID = -8967262939434460765L; private Integer userid;
private String username; public Integer getUserid() {
return userid;
} public void setUserid(Integer userid) {
this.userid = userid;
} public String getUsername() {
return username;
} public void setUsername(String username) {
this.username = username;
} @Override
public String toString() {
return "User [userid=" + userid + ", username=" + username + "]";
}
}
2、创建服务实现类UserServiceProvider.java
package com.junge.demo.rmi.server.service.provider; import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject; import com.junge.demo.rmi.protocol.model.User;
import com.junge.demo.rmi.protocol.service.UserService; public class UserServiceProvider extends UnicastRemoteObject implements UserService {
/**
*
*/
private static final long serialVersionUID = 1L; public UserServiceProvider() throws RemoteException {
super();
} public Integer addUser(User user) throws RemoteException {
System.out.println("addUser:" + user);
return user.getUserid();
} public void delUser(Integer userid) throws RemoteException {
System.out.println("delUser,userid=" + userid); } public void modifyUser(User user) throws RemoteException {
System.out.println("modifyUser:" + user); } public User getUserByUserId(Integer userid) throws RemoteException {
System.out.println("getUserByUserId,userid={}" + userid); User user = new User();
user.setUserid(userid);
user.setUsername("寮犱笁");
return user;
}
}
3.启动注册表,注册服务(ServiceStartServlet.java)
/**
*
*/
package com.junge.demo.rmi.server.service.start; import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry; import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet; import com.alibaba.fastjson.JSONObject;
import com.junge.demo.rmi.server.service.provider.UserServiceProvider; /**
* @author Administrator
*
*/
public class ServiceStartServlet extends HttpServlet { private static final long serialVersionUID = 1L; private Registry registry; private static final String BIND_NAME = "com.junge.demo.rmi.protocol.service.UserService"; private Registry getRegistry() throws RemoteException {
return LocateRegistry.createRegistry(1099);
} @Override
public void init() throws ServletException { try {
registry = getRegistry();
System.out.println(JSONObject.toJSON(registry.list()));
registry.rebind(BIND_NAME, new UserServiceProvider()); } catch (RemoteException e) {
e.printStackTrace();
}
} @Override
public void destroy() {
if (null != registry) {
try {
registry.unbind(BIND_NAME);
} catch (Exception e) {
e.printStackTrace();
}
}
} }
4.创建客户端调用rmi(RmiClient.java)
/**
*
*/
package com.junge.demo.rmi; import java.rmi.Naming;
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit; import com.junge.demo.rmi.protocol.model.User;
import com.junge.demo.rmi.protocol.service.UserService; /**
* @author Administrator
*
*/
public class RmiClient { /**
* @param args
*/
public static void main(String[] args) {
addUserBatch(); } public static void addUserBatch() { Long btime = System.currentTimeMillis(); ThreadPoolExecutor executor = new ThreadPoolExecutor(10, 1000, 200L, TimeUnit.SECONDS, new ArrayBlockingQueue<Runnable>(50000)); try {
UserService userService = (UserService)Naming.lookup("com.junge.demo.rmi.protocol.service.UserService");
for (int i = 0; i < 50000; i++) {
executor.submit(new OperUser(userService));
}
} catch (Exception e) {
e.printStackTrace();
} finally {
executor.shutdown();
} Long etime = System.currentTimeMillis(); System.out.println(etime - btime);
} } class OperUser implements Runnable {
private UserService userService; public OperUser(UserService userService) {
this.userService = userService;
} @Override
public void run() {
try {
// 增加、详情、修改、删除
User user = new User();
user.setUserid(1);
user.setUsername("名字");
userService.addUser(user); User user2 = userService.getUserByUserId(1); userService.modifyUser(user2); userService.delUser(user2.getUserid());
} catch (Exception e) {
e.printStackTrace();
} }
}
5.注意实现
a.协议接口需要继承Remote接口,对外提供的接口需要抛出RemoteException异常
b.协议接口中使用的对象需要实现序列化接口Serializable
c.服务端实现类需要继承UnicastRemoteObject类
6.问题
1.使用maven工程创建的服务端,直接使用java application运行服务端,找不到协议接口
Java RMI 使用例子的更多相关文章
- Java RMI简单例子HelloWorld
Java RMI 指的是远程方法调用 (Remote Method Invocation).它是一种机制,能够让在某个 Java 虚拟机上的对象调用另一个 Java 虚拟机中的对象上的方法.可以用此方 ...
- JAVA RMI例子
RMI 是java语言的一个RPC框架,本文给出基础例子如下: 1.实现接口: public interface ICalc extends Remote { public int add(int p ...
- Java RMI 介绍和例子以及Spring对RMI支持的实际应用实例
RMI 相关知识 RMI全称是Remote Method Invocation-远程方法调用,Java RMI在JDK1.1中实现的,其威力就体现在它强大的开发分布式网络应用的能力上,是纯Java的网 ...
- Java RMI之HelloWorld篇
Java RMI 指的是远程方法调用 (Remote Method Invocation).它是一种机制,能够让在某个 Java 虚拟机上的对象调用另一个 Java 虚拟机中的对象上的方法.可以用此方 ...
- java.rmi.NoSuchObjectException: no such object in table
jmx链接的时候,最简单的例子都行不通,郁闷,出现了: 参考:http://reiz6153.blog.163.com/blog/static/401089152009442723208/ 代码: M ...
- Java学习笔记(十六)——Java RMI
[前面的话] 最近过的好舒服,每天过的感觉很充实,一些生活和工作的技巧注意了就会发现,其实生活也是可以过的如此的有滋有味,满足现在的状况,并且感觉很幸福. 学习java RMI的原因是最近在使用dub ...
- JAVA RMI helloworld入门
Java RMI 指的是远程方法调用 (Remote Method Invocation).它是一种机制,能够让在某个 Java 虚拟机上的对象调用另一个 Java 虚拟机中的对象上的方法.可以用此方 ...
- Java RMI 远程方法调用
Java RMI 指的是远程方法调用 (Remote Method Invocation).它是一种机制,能够让在某个 Java 虚拟机上的对象调用另一个 Java 虚拟机中的对象上的方法.可以用此方 ...
- java rmi 小记
最近在搞Quartz任务监控管理,碰到了jmx,后来发现Quartz对jmx的支持不是很好,介绍的文档也比较少,另外Quartz可以很方便的支持rmi于是就看了一下rmi.下面把写的一些测试小例子附上 ...
随机推荐
- ORA-01219: 数据库未打开: 仅允许在固定表/视图中查询解决之道
参考文章:https://blog.csdn.net/Trigl/article/details/50933495 解决.
- javaweb项目编译错误
Eclipse Maven 开发一个 jee 项目时,编译时遇到以下错误:Description Resource Path Location TypeDynamic Web Module 3.0 r ...
- leetcode1
public class Solution { public int[] TwoSum(int[] nums, int target) { ]; ; i < nums.Length; i++) ...
- leetcode101
/** * Definition for a binary tree node. * public class TreeNode { * public int val; * public TreeNo ...
- SpringBoot 试手(简易的SpringBoot搭建步骤)
SpringBoot 也算AI吧,它根据您架构中引用的依赖,自动化地按默认方案帮您完成了Spring那些复杂繁琐的配置工作.为了让您不会看低此 AI 水平,还特地喊出了“约定大于配置”的口号.从这个角 ...
- c#随机生成英文名
private static string GenerateSurname() { string name = string.Empty; string[] currentConson ...
- 【Noip模拟 20160929】树林
题目描述 现在有一片树林,小B很想知道,最少需要多少步能围绕树林走一圈,最后回到起点.他能上下左右走,也能走对角线格子. 土地被分成RR行CC列1≤R≤50,1≤C≤501≤R≤50,1≤C≤50,下 ...
- PHP对接微信支付采坑
第一次做PHP商城项目对接微信支付接口,踩了N次坑,这也不对,那也不对,搞了很久,查了一些资料,终于实现了支付功能,小小总结一下,万一下次遇到就不用到处找资料了. 微信扫码支付 前期准备: 1.微信公 ...
- 并发中的volatile
目录 1. 概述 2. volatile的特性 3. volatile写-读的内存语义 4. volatile内存语义的实现 5. JSR-133为什么要增强volatile的内存语义 6. 总结 1 ...
- Pushlet实现后台信息推送(一)
Pushlet是使用较多的后台向前台推送信息的工具.前台订阅某个感兴趣的事件joinListen,触发后台的Pushlet的servlet,为该请求会话建立session,默认这个sessionID是 ...