-
Notifications
You must be signed in to change notification settings - Fork 8
/
build.sbt
178 lines (148 loc) · 5.67 KB
/
build.sbt
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
170
171
172
173
174
175
176
177
178
import sbt.{ExclusionRule, _}
import sbt.Keys._
import sbtassembly.AssemblyPlugin.autoImport.{ShadeRule, _}
name := "ADAMpro"
lazy val commonSettings = Seq(
organization := "org.vitrivr",
version := "0.1.0",
scalaVersion := "2.11.8"
)
//projects
lazy val root = (project in file(".")).
settings(commonSettings: _*)
lazy val grpc = project.
settings(commonSettings ++ Seq(assemblyOutputPath in assembly := baseDirectory.value / ".." / "lib" / "grpc-assembly-0.1-SNAPSHOT.jar"): _*)
lazy val grpcclient = project.
settings(commonSettings: _*)
lazy val web = project.dependsOn(grpcclient).
settings(commonSettings: _*)
//build
lazy val buildSettings = Seq(
scalaVersion := "2.11.8",
crossScalaVersions := Seq("2.11.8"),
ivyScala := ivyScala.value.map(_.copy(overrideScalaVersion = true))
)
mainClass in(Compile, run) := Some("org.vitrivr.adampro.main.Startup")
unmanagedResourceDirectories in Compile += baseDirectory.value / "conf"
javacOptions ++= Seq("-encoding", "UTF-8")
scalacOptions ++= Seq()
//lib resolvers
resolvers ++= Seq(
"Sonatype Releases" at "https://oss.sonatype.org/content/repositories/releases/",
"Restlet Repositories" at "http://maven.restlet.org",
"Hortonworks Repositories" at "http://repo.hortonworks.com/content/repositories/releases/"
)
resolvers += Resolver.sonatypeRepo("snapshots")
resolvers += DefaultMavenRepository
//base libs
val baseLibs = Seq(
"org.scala-lang" % "scala-compiler" % "2.11.8",
"org.scala-lang" % "scala-reflect" % "2.11.8"
)
//adampro core libs
val coreLibs = Seq(
"org.apache.spark" %% "spark-core" % "2.4.0" % "provided" excludeAll ExclusionRule("org.apache.hadoop"), //make sure that you use the same spark version as in your deployment!
"org.apache.spark" %% "spark-sql" % "2.4.0" % "provided",
"org.apache.spark" %% "spark-hive" % "2.4.0" % "provided",
"org.apache.spark" %% "spark-mllib" % "2.4.0" % "provided",
"org.apache.hadoop" % "hadoop-client" % "2.7.3" excludeAll ExclusionRule("javax.servlet") //make sure that you use the same hadoop version as in your deployment!
).map(
_.excludeAll(
ExclusionRule("org.scala-lang"),
ExclusionRule("io.netty") //remove this line if running locally within IDE
)
)
//TODO: add multiple configurations to sbt, one which has coreLibs as provided (as they do not have to be submitted to spark)
//secondary libs
val secondaryLibs = Seq(
"org.scalanlp" %% "breeze" % "0.13.1",
"org.scalanlp" %% "breeze-natives" % "0.13.1",
"com.typesafe.slick" %% "slick" % "3.1.1",
"com.mchange" % "c3p0" % "0.9.5.2",
"com.h2database" % "h2" % "1.4.196",
"it.unimi.dsi" % "fastutil" % "7.0.12",
"commons-io" % "commons-io" % "2.6",
"org.apache.commons" % "commons-lang3" % "3.8.1",
"org.apache.commons" % "commons-math3" % "3.6.1",
"com.googlecode.javaewah" % "JavaEWAH" % "1.1.6",
"com.google.guava" % "guava" % "21.0",
"org.jgrapht" % "jgrapht-core" % "1.0.1",
"io.grpc" % "grpc-netty" % "1.16.1"
).map(
_.excludeAll(
ExclusionRule("org.scala-lang"),
ExclusionRule("org.slf4j"),
ExclusionRule("log4j"),
ExclusionRule("ch.qos.logback"),
ExclusionRule("io.netty")
)
)
//tertiary libs
val tertiaryLibs = Seq(
"com.lucidworks.spark" % "spark-solr" % "3.6.0",
"org.postgresql" % "postgresql" % "9.4.1208",
"com.datastax.spark" %% "spark-cassandra-connector" % "2.3.2",
"net.postgis" % "postgis-jdbc" % "2.2.1",
"com.databricks" %% "spark-avro" % "4.0.0",
"org.iq80.leveldb" % "leveldb" % "0.9",
"com.linkedin.paldb" % "paldb" % "1.2.0",
"org.alluxio" % "alluxio-core-client-fs" % "1.5.0",
"com.hortonworks" % "shc-core" % "1.1.1-2.1-s_2.11",
"org.apache.hbase" % "hbase-client" % "1.3.1"
).map(
_.excludeAll(
ExclusionRule("org.scala-lang"),
ExclusionRule("org.slf4j"),
ExclusionRule("log4j"),
ExclusionRule("ch.qos.logback"),
ExclusionRule("io.netty")
)
)
//test libs
val testLibs = Seq(
"org.scalatest" %% "scalatest" % "2.2.6"
).map(
_.excludeAll(
ExclusionRule("org.scala-lang"),
ExclusionRule("org.slf4j"),
ExclusionRule("log4j"),
ExclusionRule("ch.qos.logback"),
ExclusionRule("io.netty")
)
)
//assembly
assemblyShadeRules in assembly := Seq(
ShadeRule.rename("io.netty.**" -> "adampro.grpc.shaded.io.netty.@1").inAll,
ShadeRule.rename("com.google.**" -> "adampro.grpc.shaded.com.google.@1").inAll
)
libraryDependencies := baseLibs ++ coreLibs ++ secondaryLibs ++ tertiaryLibs ++ testLibs
dependencyOverrides ++= Set(
"org.apache.hadoop" % "hadoop-hdfs" % "2.7.3"
)
unmanagedBase <<= baseDirectory { base => base / "lib" }
unmanagedResourceDirectories in Compile += baseDirectory.value / "conf"
//assembly
assemblyOption in assembly :=
(assemblyOption in assembly).value.copy(includeScala = true)
val meta = """META.INF(.)*""".r
assemblyMergeStrategy in assembly := {
case PathList("application.conf") => MergeStrategy.discard
case PathList("javax", "servlet", xs@_*) => MergeStrategy.last
case PathList(ps@_*) if ps.last endsWith ".html" => MergeStrategy.last
case n if n.startsWith("reference.conf") => MergeStrategy.concat
case n if n.endsWith(".conf") => MergeStrategy.concat
case meta(_) => MergeStrategy.discard
case x => MergeStrategy.last
}
mainClass in assembly := Some("org.vitrivr.adampro.main.Startup")
test in assembly := {}
//provided libraries should be included in "run"
run in Compile <<= Defaults.runTask(fullClasspath in Compile, mainClass in(Compile, run), runner in(Compile, run))
parallelExecution in Test := false
concurrentRestrictions in Global += Tags.limit(Tags.Test, 1)
//custom commands
addCommandAlias("proto", "; grpc/assembly")
lazy val setupDocker = taskKey[Unit]("Setup and start docker container to run ADAMpro.")
setupDocker := {
"./scripts/setupDocker.sh" !
}