-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathSolution.java
More file actions
110 lines (80 loc) · 4.51 KB
/
Solution.java
File metadata and controls
110 lines (80 loc) · 4.51 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
//He that overcometh shall inherit all things; and I will be his God, and he shall be my son. (Revelation 21:7)
package com.javarush.task.task32.task3208;
import java.rmi.AlreadyBoundException;
import java.rmi.NotBoundException;
import java.rmi.Remote;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
import java.rmi.server.UnicastRemoteObject;
/*
RMI-2
*/
public class Solution {
public static Registry registry;
public static final String BINDING_NAME1 = "server.cat";
public static final String BINDING_NAME2 = "server.dog";
//pretend we start rmi client as CLIENT_THREAD thread
public static Thread CLIENT_THREAD = new Thread(new Runnable() {
@Override
public void run() {
try {
for (String bindingName : registry.list()) {
Animal service = (Animal) registry.lookup(bindingName);
service.printName();
service.say();
}
} catch (RemoteException e) {
e.printStackTrace();
} catch (NotBoundException e) {
e.printStackTrace();
}
}
});
//pretend we start rmi server as SERVER_THREAD thread
public static Thread SERVER_THREAD = new Thread(new Runnable() {
@Override
public void run() {
//напишите тут ваш код
try {
//создание объекта для удаленного доступа
final Animal cat = new Cat("Barsik");
final Animal dog = new Dog("Palkan");
//создание реестра расшареных объетов
registry = LocateRegistry.createRegistry(2099);
//создание "заглушки" – приемника удаленных вызовов
Remote stubCat = UnicastRemoteObject.exportObject(cat, 0);
Remote stubDog = UnicastRemoteObject.exportObject(dog, 0);
//регистрация "заглушки" в реесте
registry.bind(BINDING_NAME1, stubCat);
registry.bind(BINDING_NAME2, stubDog);
} catch (RemoteException | AlreadyBoundException e) {
e.printStackTrace();
}
}
});
public static void main(String[] args) throws InterruptedException {
//start rmi server thread
SERVER_THREAD.start();
Thread.sleep(1000);
//start client
CLIENT_THREAD.start();
}
}
/*
RMI-2
Реализуй логику метода run в SERVER_THREAD. В нем будет имитироваться серверная часть:
1) Инициализируй поле registry, которое будет принимать и обрабатывать запросы на 2099 порту.
2) Создай два объекта - Cat и Dog.
3) Используй класс UnicastRemoteObject, чтобы создать Remote объекты для созданных Cat и Dog.
Remote объекты будут в состоянии принимать обращения к своим методам используя выбранный порт (2099).
4) Для Cat и Dog добавь в registry связь уникального текстового ключа и Remote объекта. Текстовый ключ придумай сам.
5) При возникновении любого исключения выведи его стек-трейс в поток System.err.
Метод main не участвует в тестировании.
Требования:
1. В методе run() необходимо инициализировать поле registry. Для этого используй LocateRegistry.createRegistry (2099).
2. В методе run() необходимо создать два объекта - Cat и Dog.
3. В методе run() необходимо создать Remote объекты для созданных Cat и Dog используя UnicastRemoteObject.exportObject (Remote, int).
4. Для Cat и Dog нужно добавить в registry связь уникального текстового ключа и Remote объекта используя registry.bind (String, Remote).
5. При возникновении любого исключения нужно вывести его стек-трейс в поток System.err используя метод printStackTrace ().
*/