blob: 9377defd4e358a9e6353ad649692ecca4974d7ca (
plain)
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
|
// **********************************************************************
//
// Copyright (c) 2003-2015 ZeroC, Inc. All rights reserved.
//
// This copy of Ice is licensed to you under the terms described in the
// ICE_LICENSE file included in this distribution.
//
// **********************************************************************
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class Server extends Ice.Application
{
@Override
public int
run(String[] args)
{
if(args.length > 0)
{
System.err.println(appName() + ": too many arguments");
return 1;
}
//
// If ^C is pressed we want to interrupt all running upcalls from the
// dispatcher and destroy the communicator.
//
setInterruptHook(new Thread() {
@Override
public void
run()
{
//
// Call shutdownNow on the executor. This interrupts all
// executor threads causing any running servant dispatch threads
// to terminate quickly.
//
_executor.shutdownNow();
try
{
communicator().shutdown();
}
catch(Ice.LocalException ex)
{
ex.printStackTrace();
}
}
});
Ice.ObjectAdapter adapter = communicator().createObjectAdapter("TaskManager");
adapter.add(new TaskManagerI(_executor), communicator().stringToIdentity("manager"));
adapter.activate();
communicator().waitForShutdown();
return 0;
}
public static void
main(String[] args)
{
final Server app = new Server();
Ice.InitializationData initData = new Ice.InitializationData();
initData.properties = Ice.Util.createProperties();
initData.properties.load("config.server");
//
// This demo uses a dispatcher to execute any invocations on the server.
// By using an executor it is straightforward to interrupt any servant
// dispatch threads by using ExecutorService.shutdownNow.
//
initData.dispatcher = new Ice.Dispatcher() {
@Override
public void dispatch(Runnable runnable, Ice.Connection con)
{
app.getExecutor().submit(runnable);
}
};
int status = app.main("Server", args, initData);
System.exit(status);
}
ExecutorService getExecutor()
{
return _executor;
}
private ExecutorService _executor = Executors.newFixedThreadPool(5);
}
|