-
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbuild.sbt
85 lines (61 loc) · 2.99 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
enablePlugins(SbtProguard)
proguardOptions in Proguard ++= Seq("-dontnote", "-dontwarn", "-ignorewarnings")
proguardOptions in Proguard += ProguardOptions.keepMain("cian911.Job")
proguardOptions in Proguard ++= Seq(
"-keep class org.eclipse.paho.client.mqttv3.internal.* { *; }",
"-keep class org.eclipse.paho.client.mqttv3.spi.* { *; }",
"-dontshrink",
"-dontoptimize",
"-dontobfuscate"
)
ThisBuild / resolvers ++= Seq(
"Apache Development Snapshot Repository" at "https://repository.apache.org/content/repositories/snapshots/",
"MVN Repo" at "https://mvnrepository.com/artifact/",
"JFrog" at "https://repo.spring.io/plugins-release/",
Resolver.mavenLocal
)
name := "flink-home"
version := "0.1-SNAPSHOT"
organization := "cian911"
ThisBuild / scalaVersion := "2.12.15"
val flinkVersion = "1.15.2"
val flinkDependencies = Seq(
"org.apache.flink" %% "flink-scala" % flinkVersion % "provided",
"org.apache.flink" %% "flink-streaming-scala" % flinkVersion % "provided")
// https://mvnrepository.com/artifact/org.apache.flink/flink-clients
libraryDependencies += "org.apache.flink" % "flink-clients" % "1.16.0"
val AkkaVersion = "2.7.0"
libraryDependencies ++= Seq(
"com.lightbend.akka" %% "akka-stream-alpakka-mqtt" % "5.0.0",
"com.typesafe.akka" %% "akka-stream" % AkkaVersion,
"org.eclipse.paho" % "org.eclipse.paho.client.mqttv3" % "1.2.4"
)
// https://mvnrepository.com/artifact/com.hivemq/hivemq-mqtt-client
libraryDependencies += "com.hivemq" % "hivemq-mqtt-client" % "1.3.0"
libraryDependencies += ("org.apache.bahir" % "flink-connector-influxdb_2.12" % "1.1.0").exclude("org.apache.flink", "flink-streaming-java_2.12")
// https://mvnrepository.com/artifact/org.influxdb/influxdb-java
libraryDependencies += "org.influxdb" % "influxdb-java" % "2.23"
lazy val scalaSettings = Seq(
scalacOptions --= Seq("-Xmx1536M --add-exports=java.base/sun.nio.ch=ALL-UNNAMED --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.lang.reflect=ALL-UNNAMED --add-opens=java.base/java.io=ALL-UNNAMED --add-exports=jdk.unsupported/sun.misc=ALL-UNNAMED")
)
lazy val root = (project in file(".")).
settings(
libraryDependencies ++= flinkDependencies,
scalaSettings
)
Proguard/proguard/javaOptions := Seq("-Xmx4g")
assemblyMergeStrategy in assembly := {
case PathList("META-INF", _*) => MergeStrategy.discard
case _ => MergeStrategy.first
}
assembly / mainClass := Some("cian911.Job")
// make run command include the provided dependencies
Compile / run := Defaults.runTask(Compile / fullClasspath,
Compile / run / mainClass,
Compile / run / runner
).evaluated
// stays inside the sbt console when we press "ctrl-c" while a Flink programme executes with "run" or "runMain"
Compile / run / fork := true
Global / cancelable := true
// exclude Scala library from assembly
assembly / assemblyOption := (assembly / assemblyOption).value.copy(includeScala = false)