- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试创建一个基于java RMI的文件共享应用程序。它抛出一个ConnectException
,尽管我能够分别从对方 ping 客户端和服务器的 IP 地址。
使用本地主机时整个代码工作正常,但失败了 同时在由 2 个系统和一个组成的专用网络中执行相同的操作路由器。
FileClientInitialise(服务器)来源:-
import java.rmi.Remote;
import java.rmi.RemoteException;
public interface FileClientInitialise extends Remote{
public boolean sendData(String fileName, byte[] data, int len) throws RemoteException;
public String getName() throws RemoteException;
}
FileServerInitialise(服务器)的来源:-
import java.rmi.Remote;
import java.rmi.RemoteException;
public interface FileServerInitialise extends Remote{
public boolean login(FileClientInitialise fci) throws RemoteException;
}
文件服务器(服务器)的来源:-
import java.io.File;
import java.io.FileInputStream;
import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;
public class FileServer extends UnicastRemoteObject implements FileServerInitialise{
private String file="";
protected FileServer() throws RemoteException{
super();
}
public void setFile(String f){
file=f;
}
@Override
public boolean login(FileClientInitialise fci) throws RemoteException {
try{
File f1 = new File(file);
FileInputStream fis = new FileInputStream(f1);
byte[] myData = new byte[4096];
int dataLen = fis.read(myData);
while(dataLen>0){
fci.sendData(f1.getName(),myData,dataLen);
dataLen = fis.read(myData);
}
}
catch(Exception e){
e.printStackTrace();
}
return true;
}
}
StartFileServer(服务器)来源:-
import java.net.InetAddress;
import java.rmi.Naming;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
public class StartFileServer {
public static void main(String[] args) {
// TODO Auto-generated method stub
try{
System.setProperty("java.rmi.server.hostname","192.168.1.8");
Registry registry=LocateRegistry.createRegistry(1099);
System.out.println("Server Started--- GO,GO,GO--- "+"\nThis Server's IP --- "+InetAddress.getByName("SERVER-1")+"\n");
FileServer fs=new FileServer();
fs.setFile("/root/Downloads/XSS.mp4");
registry.rebind("asad",fs);
System.out.println("File Server is Ready");
String sa[]=Naming.list("Uploaded");
for(String s: sa){
System.out.println("Value of s=" + s);
}
}
catch(Exception e){
e.printStackTrace();
}
}
}
FileClientInitialise.java 和 FileClientInitialise.java 的客户端代码相同文件服务器初始化.java。其余的客户端代码是:-
FileClient.java(Client) 的来源:-
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.rmi.*;
import java.rmi.server.UnicastRemoteObject;
import java.util.*;
public class FileClient extends UnicastRemoteObject implements FileClientInitialise {
/**
*
*/
private static final long serialVersionUID = 1L;
public String name;
public FileClient (String n) throws RemoteException {
super();
name=n;
}
@Override
public String getName() throws RemoteException{
return name;
}
@Override
public boolean sendData(String filename, byte[] data, int len) throws RemoteException{
try{
File f=new File(filename);
f.createNewFile();
FileOutputStream out=new FileOutputStream(f,true);
out.write(data,0,len);
out.flush();
out.close();
System.out.println("Done writing data...");
}catch(Exception e){
e.printStackTrace();
}
return true;
}
}
StartFileClient.java(Client) 的源代码:-
import java.rmi.Naming;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
import java.util.Scanner;
public class StartFileClient {
public static void main(String[] args) {
try{
Registry registry=LocateRegistry.getRegistry(1099);
FileClient c=new FileClient("imed");
FileServerInitialise server=(FileServerInitialise)registry.lookup("asad");
//exception being thrown here in above line ---> registry.lookup("asad") method...
server.login(c) ;
System.out.println("Listening.....");
Scanner s=new Scanner(System.in);
/*while(true){
String line=s.nextLine();
}*/
}
catch(Exception e){
e.printStackTrace();
}
}
}
客户端抛出的异常的堆栈跟踪是:-
java.rmi.ConnectException: Connection refused to host: 192.168.1.8;
nested exception is: java.net.ConnectException: Connection refused
at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:619)
at
sun.rmi.transport.tcp.TCPChannel.createConnection(TCPChannel.java:216)
at
sun.rmi.transport.tcp.TCPChannel.newConnection(TCPChannel.java:202)
at sun.rmi.server.UnicastRef.newCall(UnicastRef.java:342) at
sun.rmi.registry.RegistryImpl_Stub.lookup(Unknown Source) at
StartFileClient.main(StartFileClient.java:23)
Caused by: java.net.ConnectException: Connection refused at java.net.PlainSocketImpl.socketConnect(Native Method) at
java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:345)
at
java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206)
at
java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188)
at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) at
java.net.Socket.connect(Socket.java:589) at
java.net.Socket.connect(Socket.java:538) at
java.net.Socket.<init>(Socket.java:434) at
java.net.Socket.<init>(Socket.java:211) at
sun.rmi.transport.proxy.RMIDirectSocketFactory.createSocket(RMIDirectSocketFactory.java:40)
at
sun.rmi.transport.proxy.RMIMasterSocketFactory.createSocket(RMIMasterSocketFactory.java:148)
at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:613)
... 5 more
最佳答案
您需要将服务器中的Registry
引用变量设置为静态。否则它可能会被垃圾收集,最终导致一切退出。
关于java.rmi.ConnectException : Connection refused to host: 192. 168.1.8;嵌套异常是:,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29893837/
这个问题已经有答案了: AWS RDS How to set up a MySQL Database (1 个回答) 已关闭 6 年前。 我有一个AWS Elastic Beanstalk实例 Tom
我正在 Mean.js 版本 4.2 上运行 npm test,它在 Protractor e2e 测试中给出了“连接被拒绝”错误。我尝试更新 Selenium 像 this says to.现在它的
我购买了一台服务器(新加坡地区,512 MB RAM)我试图在该服务器中设置单节点集群。我从这个 link当我检查 $ sudo service Cassandra status它正在显示 nodet
我正在使用 spring cloud 来配置微服务。我使用 Jhipster 来生成应用程序。 我有三个应用程序 JHipster-Registry、Gateway 和 admin 应用程序 所有三个
我有 2 个 java 文件 Server.java 和 Client.java。两者都在不同的容器中。 DOCKER 文件:我用于服务器的 dockerfile(在名为“Server”的文件夹中)是
客户端应用程序将 json 数据发送到 localhost:8080 上的服务器,该数据打包并作为 Docker 镜像运行。使用 Postman chrome 应用程序手动发送 json 时,服务器工
我正在尝试关注 celery tutorial ,但是当我运行 python manage.py celeryd 时遇到了一个问题:我的 RabbitMQ 服务器(安装在我开发箱的虚拟机上)不允许我的
我清理了~/.ivy2/cache目录。 我的project/plugins.sbt文件: $ cat project/plugins.sbt // Comment to get more infor
ELK 与销售人员 URL:http://localhost:9200/>, :error_type=>LogStash::Outputs::ElasticSearch::HttpClient::Po
我正在另一个容器中使用 Dockerize spring boot 应用程序和 redis。 我使用 docker compose 在同一网络中运行两个容器,这是我的 docker-compose.y
我试图从我的应用程序访问 Rest API。当该 API 不在线时,我的应用程序发生了上述错误。我正在使用 Spring Boot 。我想知道,有什么方法可以在访问该网址之前检查该网址的可用性。 S
在我的 flutter 应用程序中,我使用 flask 服务器进行测试。我启动了我的服务器并在我的 flutter 应用程序中运行 API url。但是 SocketException: Connec
我正在 Mac 上的 IntelliJ 中设置远程调试器。我没有做任何修改就遵循了模板。然后我单击“调试 xxx”按钮。表明 "Error running 'Remote Debugger': Una
我有一个 linux box,jenkins 服务器在上面运行并从 git 中拉取脚本并开始执行 我有一台 Windows 电脑,我从它打开 jenkins url 说 xyz:8080 并尝试从我的
我在 tomcat 7.50 上有一个应用程序,在单个请求上工作正常,但在许多同时请求 (~1200) 上我得到: 2014-11-02 11:22:48,485 ERROR [MONITOR-AG
当我尝试重新配置我的 gitlab 实例时,出现了这个错误。sudo gitlab-ctl reconfigure 工作正常但是当我尝试启动 gitlab 时我看到 502 错误并且当我跟踪日志时我看
我在 3 个 n1-standard-4 GKE 实例上运行了大约 200 个 pod。流量水平较低,因此每台机器上都有大量备用 CPU 和 RAM。通常当服务尝试相互连接时,连接失败并显示“CONN
我在unbundu机器中使用JMeter设置了分布式负载测试环境。 ->主站:系统运行JMeter GUI,控制每个从站。 ->从站:运行jmeter-server的系统,从主站接收命令,并向被测服务
我需要帮助来解决被拒绝的状态。我查看了 named.conf,一切正常。 我什至把allow-query改成了any,原来是localhost。 dig xxx.com @ns1.xxx.com ;
我正在使用Laravel。当我dd($request->all())时,其中的数据涉及文件和其他一些数据。它返回错误 [2019-02-22 19:40:24] local.ERROR: stream
我是一名优秀的程序员,十分优秀!