-
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathdefault.nix
44 lines (41 loc) · 1.45 KB
/
default.nix
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
{nixpkgs, ...}: let
masterPortsServer = "7077";
masterPortsWeb = "7078";
baseConfig = {
image = "apache/spark-py:v3.2.2";
extraOptions = ["--network" "host" "--user" "185"];
environment = {
SPARK_NO_DAEMONIZE = "true";
SPARK_MASTER_HOST = "0.0.0.0";
SPARK_MASTER_PORT = masterPortsServer;
SPARK_MASTER_WEBUI_PORT = masterPortsWeb;
SPARK_WORKER_CORES = "1";
SPARK_WORKER_MEMORY = "4g";
};
};
makeMaster = nixpkgs.lib.recursiveUpdate baseConfig {
cmd = ["/opt/spark/sbin/start-master.sh"];
volumes = ["/var/log/spark-coordinator:/opt/spark/logs"];
};
makeWorker = workerID:
nixpkgs.lib.recursiveUpdate baseConfig {
cmd = ["/opt/spark/sbin/start-worker.sh" "spark://0.0.0.0:${masterPortsServer}"];
volumes = [
"/var/log/spark-worker-${workerID}:/opt/spark/logs"
"/var/run/spark-worker-${workerID}:/opt/spark/work"
];
};
in {
containers.spark = {
autoStart = false;
config = {
virtualisation.oci-containers.backend = "docker";
virtualisation.oci-containers.containers.spark-master = makeMaster;
virtualisation.oci-containers.containers.spark-worker1 = makeWorker "1";
virtualisation.oci-containers.containers.spark-worker2 = makeWorker "2";
virtualisation.oci-containers.containers.spark-worker3 = makeWorker "3";
virtualisation.oci-containers.containers.spark-worker4 = makeWorker "4";
};
ephemeral = true;
};
}