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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
|
/*
* This file was generated by the Gradle 'init' task.
*
* This generated file contains a sample Java project to get you started.
* For more details take a look at the Java Quickstart chapter in the Gradle
* User Manual available at https://docs.gradle.org/5.6.2/userguide/tutorial_java_projects.html
*/
plugins {
// Apply the java plugin to add support for Java
id 'java'
// Apply the application plugin to add support for building a CLI application
id 'application'
}
ext.hostname = {
return System.getProperty("hostname") ?: "localhost"
}
ext.freshnessPeriod = {
return System.getProperty("freshnessPeriod") ?: 60 * 1000
}
ext.queryPeriod = {
return System.getProperty("queryPeriod") ?: 5 * 1000
}
ext.gossipPeriod = {
return System.getProperty("gossipPeriod") ?: 5 * 1000
}
ext.UDUPServerHostname = {
return System.getProperty("hostname") ?: "localhost"
}
ext.UDUPServerPort = {
return System.getProperty("port") ?: 5999;
}
ext.UDUPServerTimeout = {
return System.getProperty("timeout") ?: 5000;
}
ext.UDUPServerBufsize = {
return System.getProperty("bufsize") ?: 512;
}
ext.querySignerHostname = {
return System.getProperty("querySignerHostname") ?: "localhost"
}
/*
Example: -DfallbackContacts=\{\"/uw/violet07\":[192,168,0,11]}
escape at the beginning and before "
*/
ext.fallbackContacts = {
return System.getProperty("fallbackContacts") ?: "{}"
}
ext.ownAddr = {
return System.getProperty("ownAddr") ?: "localhost"
}
/*
Possible options:
RoundRobinExp
RoundRobinUniform
RandomExp
RandomUniform
*/
ext.zoneSelectionStrategy = {
return System.getProperty("zoneStrategy") ?: "RandomUniform"
}
ext.zonePath = {
return System.getProperty("zonePath") ?: "/uw/violet07"
}
ext.publicKeyFilename = {
return System.getProperty("publicKeyFilename") ?: "build/tmp/query_signer.pub"
}
ext.privateKeyFilename = {
return System.getProperty("privateKeyFilename") ?: "build/tmp/query_signer"
}
repositories {
// Use jcenter for resolving dependencies.
// You can declare any Maven/Ivy/file repository here.
jcenter()
mavenCentral()
}
dependencies {
// This dependency is used by the application.
implementation 'com.google.guava:guava:28.0-jre'
implementation 'org.springframework.boot:spring-boot-starter-web:2.2.1.RELEASE'
implementation 'org.springframework.boot:spring-boot-starter-thymeleaf:2.2.1.RELEASE'
implementation 'org.springframework.boot:spring-boot-starter-test:2.2.1.RELEASE'
implementation 'org.apache.commons:commons-math3:3.6.1'
// Use JUnit test framework
testImplementation 'junit:junit:4.12'
implementation 'com.esotericsoftware:kryo:4.0.2'
// For query language parser
implementation files('./lib/JLex.jar')
implementation files('./lib/cup.jar')
implementation 'com.google.code.gson:gson:2.8.6'
}
application {
// Define the main class for the application
mainClassName = 'pl.edu.mimuw.cloudatlas.interpreter.Main'
}
task runAgent(type: JavaExec) {
classpath = sourceSets.main.runtimeClasspath
main = 'pl.edu.mimuw.cloudatlas.agent.Agent'
systemProperty 'java.rmi.server.hostname', hostname()
systemProperty 'freshness_period', freshnessPeriod()
systemProperty 'query_period', queryPeriod()
systemProperty 'gossip_period', gossipPeriod()
systemProperty 'UDUPServer.hostname', UDUPServerHostname()
systemProperty 'UDUPServer.port', UDUPServerPort()
systemProperty 'UDUPServer.timeout', UDUPServerTimeout()
systemProperty 'UDUPServer.bufsize', UDUPServerBufsize()
systemProperty 'Gossip.zone_strategy', zoneSelectionStrategy()
systemProperty 'zone_path', zonePath()
systemProperty 'public_key_file', publicKeyFilename()
}
task runClient(type: JavaExec) {
classpath = sourceSets.main.runtimeClasspath
main = 'pl.edu.mimuw.cloudatlas.client.Client'
systemProperty 'agent_hostname', hostname()
systemProperty 'zone_path', zonePath()
systemProperty 'query_signer_hostname', querySignerHostname()
}
task runFetcher(type: JavaExec) {
classpath = sourceSets.main.runtimeClasspath
main = 'pl.edu.mimuw.cloudatlas.fetcher.Fetcher'
args(hostname() , 1099)
systemProperty 'zone_path', zonePath()
systemProperty 'fallback_contacts', fallbackContacts()
systemProperty 'own_addr', ownAddr()
}
task runInterpreter(type: JavaExec) {
classpath = sourceSets.main.runtimeClasspath
main = 'pl.edu.mimuw.cloudatlas.interpreter.Main'
standardInput = System.in
}
task runQuerySigner(type: JavaExec) {
classpath = sourceSets.main.runtimeClasspath
main = 'pl.edu.mimuw.cloudatlas.querysigner.QuerySigner'
systemProperty 'query_signer_hostname', querySignerHostname()
systemProperty 'public_key_file', publicKeyFilename()
systemProperty 'private_key_file', privateKeyFilename()
}
|