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
|
package moe.yuuta.dn42peering;
import io.vertx.core.*;
import io.vertx.core.impl.logging.Logger;
import io.vertx.core.impl.logging.LoggerFactory;
import io.vertx.core.json.JsonObject;
import moe.yuuta.dn42peering.asn.ASNHttpVerticle;
import moe.yuuta.dn42peering.asn.ASNVerticle;
import moe.yuuta.dn42peering.database.DatabaseMigration;
import moe.yuuta.dn42peering.database.DatabaseUtils;
import moe.yuuta.dn42peering.node.NodeVerticle;
import moe.yuuta.dn42peering.peer.PeerVerticle;
import moe.yuuta.dn42peering.portal.HTTPPortalVerticle;
import moe.yuuta.dn42peering.provision.ProvisionVerticle;
import moe.yuuta.dn42peering.whois.WhoisVerticle;
import javax.annotation.Nonnull;
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.Arrays;
public class Main {
public static void main(@Nonnull String... args) throws Throwable {
if(args.length != 1) {
System.err.println("Usage: central <path/to/config.json>");
System.exit(64);
return;
}
System.setProperty("vertx.logger-delegate-factory-class-name",
"io.vertx.core.logging.JULLogDelegateFactory");
final InputStream in = new FileInputStream(args[0]);
final JsonObject config = new JsonObject(IOUtils.read(in));
in.close();
final Vertx vertx = Vertx.vertx(new VertxOptions());
final DeploymentOptions options = new DeploymentOptions()
.setConfig(config)
.setInstances(Runtime.getRuntime().availableProcessors() * 2);
Logger logger = LoggerFactory.getLogger("Main");
// Migrate database first
DatabaseMigration.autoMigrate(vertx, DatabaseUtils.getConfiguration(config))
.onComplete(_v -> {
start(vertx, options, res -> {
if (res.succeeded()) {
logger.info("The server started.");
} else {
logger.error("Cannot deploy the server.", res.cause());
}
});
})
.onFailure(err -> {
if(err instanceof DatabaseMigration.ShutdownException) {
System.exit(0);
return;
}
logger.error("Cannot migrate database.", err);
System.exit(1);
});
}
private static void start(@Nonnull Vertx vertx,
@Nonnull DeploymentOptions options,
@Nonnull Handler<AsyncResult<CompositeFuture>> handler) {
CompositeFuture.all(Arrays.asList(
Future.<String>future(f -> vertx.deployVerticle(PeerVerticle.class.getName(), options, f)),
Future.<String>future(f -> vertx.deployVerticle(WhoisVerticle.class.getName(), options, f)),
Future.<String>future(f -> vertx.deployVerticle(ASNVerticle.class.getName(), options, f)),
Future.<String>future(f -> vertx.deployVerticle(ASNHttpVerticle.class.getName(), options, f)),
Future.<String>future(f -> vertx.deployVerticle(NodeVerticle.class.getName(), options, f)),
Future.<String>future(f -> vertx.deployVerticle(ProvisionVerticle.class.getName(), options, f)),
Future.<String>future(f -> vertx.deployVerticle(HTTPPortalVerticle.class.getName(), options, f))
)).onComplete(handler);
}
}
|