aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEvans Ye <evansye@apache.org>2017-07-01 12:54:29 +0000
committerEvans Ye <evansye@apache.org>2017-07-01 12:54:29 +0000
commitd80b82dab3ea335d71e9a44094b178596ac5abd8 (patch)
treec5c7dbc94c8b587364dd69611a2862c789880f28
parent5a2a1a86b17f73260229137b0b008385fd32bfae (diff)
parent58f3f5365b4e184aa3cb0287f570a91870ee1f0e (diff)
merge master into branch-1.2 for 1.2.1 release
-rw-r--r--.dockerignore1
-rw-r--r--README.md2
-rw-r--r--bigtop-bigpetstore/bigpetstore-mapreduce/build.gradle2
-rwxr-xr-xbigtop-bigpetstore/bigpetstore-mapreduce/src/test/java/org/apache/bigtop/bigpetstore/generator/TestPetStoreTransactionGeneratorJob.java4
-rwxr-xr-xbigtop-ci/build.sh54
-rwxr-xr-xbigtop-ci/entrypoint.sh4
-rw-r--r--bigtop-deploy/juju/hadoop-hbase/README.md67
-rw-r--r--bigtop-deploy/juju/hadoop-hbase/bundle-dev.yaml14
-rw-r--r--bigtop-deploy/juju/hadoop-hbase/bundle-local.yaml14
-rw-r--r--bigtop-deploy/juju/hadoop-hbase/bundle.yaml26
-rwxr-xr-xbigtop-deploy/juju/hadoop-hbase/tests/01-bundle.py2
-rw-r--r--bigtop-deploy/juju/hadoop-hbase/tests/tests.yaml2
-rw-r--r--bigtop-deploy/juju/hadoop-kafka/README.md49
-rw-r--r--bigtop-deploy/juju/hadoop-kafka/bundle-dev.yaml15
-rw-r--r--bigtop-deploy/juju/hadoop-kafka/bundle-local.yaml15
-rw-r--r--bigtop-deploy/juju/hadoop-kafka/bundle.yaml27
-rwxr-xr-xbigtop-deploy/juju/hadoop-kafka/tests/01-bundle.py2
-rw-r--r--bigtop-deploy/juju/hadoop-kafka/tests/tests.yaml2
-rw-r--r--bigtop-deploy/juju/hadoop-processing/README.md45
-rw-r--r--bigtop-deploy/juju/hadoop-processing/bundle-dev.yaml11
-rw-r--r--bigtop-deploy/juju/hadoop-processing/bundle-local.yaml11
-rw-r--r--bigtop-deploy/juju/hadoop-processing/bundle.yaml19
-rwxr-xr-xbigtop-deploy/juju/hadoop-processing/tests/01-bundle.py2
-rw-r--r--bigtop-deploy/juju/hadoop-processing/tests/tests.yaml2
-rw-r--r--bigtop-deploy/juju/hadoop-spark/README.md146
-rw-r--r--bigtop-deploy/juju/hadoop-spark/bundle-dev.yaml45
-rw-r--r--bigtop-deploy/juju/hadoop-spark/bundle-local.yaml45
-rw-r--r--bigtop-deploy/juju/hadoop-spark/bundle.yaml55
-rwxr-xr-xbigtop-deploy/juju/hadoop-spark/tests/01-bundle.py7
-rw-r--r--bigtop-deploy/juju/hadoop-spark/tests/tests.yaml10
-rw-r--r--bigtop-deploy/juju/spark-processing/README.md109
-rw-r--r--bigtop-deploy/juju/spark-processing/bundle-dev.yaml10
-rw-r--r--bigtop-deploy/juju/spark-processing/bundle-local.yaml10
-rw-r--r--bigtop-deploy/juju/spark-processing/bundle.yaml17
-rw-r--r--bigtop-deploy/juju/spark-processing/tests/tests.yaml10
-rw-r--r--bigtop-deploy/puppet/README.md1
-rw-r--r--bigtop-deploy/puppet/hieradata/bigtop/cluster.yaml5
-rw-r--r--bigtop-deploy/puppet/hieradata/site.yaml14
-rw-r--r--bigtop-deploy/puppet/manifests/bigtop_repo.pp70
-rw-r--r--bigtop-deploy/puppet/manifests/cluster.pp9
-rw-r--r--bigtop-deploy/puppet/manifests/jdk.pp72
-rw-r--r--bigtop-deploy/puppet/manifests/site.pp76
-rw-r--r--bigtop-deploy/puppet/modules/flink/manifests/init.pp14
-rw-r--r--bigtop-deploy/puppet/modules/ignite_hadoop/templates/default-config.xml27
-rw-r--r--bigtop-deploy/puppet/modules/kerberos/manifests/init.pp13
-rw-r--r--bigtop-deploy/puppet/modules/spark/manifests/init.pp12
-rw-r--r--bigtop-deploy/puppet/modules/spark/templates/spark-defaults.conf15
-rwxr-xr-xbigtop-deploy/puppet/modules/spark/templates/spark-env.sh8
-rw-r--r--bigtop-deploy/puppet/modules/zeppelin/manifests/init.pp1
-rw-r--r--bigtop-packages/src/charm/README.md23
-rw-r--r--bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/README.md39
-rw-r--r--bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/layer.yaml1
-rw-r--r--bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/metadata.yaml5
-rw-r--r--bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/metrics.yaml6
-rw-r--r--bigtop-packages/src/charm/hadoop/layer-hadoop-plugin/README.md35
-rw-r--r--bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/README.md39
-rwxr-xr-xbigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/mrbench1
-rwxr-xr-xbigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/nnbench1
-rwxr-xr-xbigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/parseBenchmark.py3
-rwxr-xr-xbigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/smoke-test10
-rwxr-xr-xbigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/teragen1
-rwxr-xr-xbigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/terasort1
-rwxr-xr-xbigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/testdfsio1
-rw-r--r--bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/metadata.yaml5
-rw-r--r--bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/metrics.yaml2
-rw-r--r--bigtop-packages/src/charm/hadoop/layer-hadoop-slave/README.md40
-rwxr-xr-xbigtop-packages/src/charm/hadoop/layer-hadoop-slave/actions/smoke-test10
-rw-r--r--bigtop-packages/src/charm/hadoop/layer-hadoop-slave/metadata.yaml4
-rw-r--r--bigtop-packages/src/charm/hbase/layer-hbase/README.md174
-rwxr-xr-xbigtop-packages/src/charm/hbase/layer-hbase/actions/perf-test3
-rwxr-xr-xbigtop-packages/src/charm/hbase/layer-hbase/actions/smoke-test4
-rw-r--r--bigtop-packages/src/charm/hbase/layer-hbase/config.yaml6
-rw-r--r--bigtop-packages/src/charm/hbase/layer-hbase/icon.svg293
-rw-r--r--bigtop-packages/src/charm/hbase/layer-hbase/layer.yaml17
-rwxr-xr-xbigtop-packages/src/charm/hbase/layer-hbase/lib/charms/layer/bigtop_hbase.py75
-rw-r--r--bigtop-packages/src/charm/hbase/layer-hbase/metadata.yaml6
-rw-r--r--bigtop-packages/src/charm/hbase/layer-hbase/reactive/hbase.py172
-rwxr-xr-xbigtop-packages/src/charm/hbase/layer-hbase/tests/01-basic-deployment.py2
-rwxr-xr-xbigtop-packages/src/charm/hbase/layer-hbase/tests/02-smoke-test.py10
-rw-r--r--bigtop-packages/src/charm/hive/layer-hive/README.md237
-rw-r--r--bigtop-packages/src/charm/hive/layer-hive/actions.yaml4
-rwxr-xr-xbigtop-packages/src/charm/hive/layer-hive/actions/restart36
-rwxr-xr-xbigtop-packages/src/charm/hive/layer-hive/actions/smoke-test49
-rw-r--r--bigtop-packages/src/charm/hive/layer-hive/config.yaml6
-rw-r--r--bigtop-packages/src/charm/hive/layer-hive/copyright16
-rw-r--r--bigtop-packages/src/charm/hive/layer-hive/icon.svg75
-rw-r--r--bigtop-packages/src/charm/hive/layer-hive/layer.yaml31
-rwxr-xr-xbigtop-packages/src/charm/hive/layer-hive/lib/charms/layer/bigtop_hive.py138
-rw-r--r--bigtop-packages/src/charm/hive/layer-hive/metadata.yaml19
-rw-r--r--bigtop-packages/src/charm/hive/layer-hive/reactive/hive.py184
-rwxr-xr-x[-rw-r--r--]bigtop-packages/src/charm/hive/layer-hive/tests/01-basic-deployment.py (renamed from docker/bigtop-deploy/ubuntu-14.04/Dockerfile)34
-rwxr-xr-xbigtop-packages/src/charm/hive/layer-hive/tests/02-smoke-test.py60
-rw-r--r--bigtop-packages/src/charm/hive/layer-hive/tests/tests.yaml3
-rw-r--r--bigtop-packages/src/charm/kafka/layer-kafka/README.md50
-rwxr-xr-xbigtop-packages/src/charm/kafka/layer-kafka/actions/create-topic7
-rw-r--r--bigtop-packages/src/charm/kafka/layer-kafka/actions/kafkautils.py4
-rwxr-xr-xbigtop-packages/src/charm/kafka/layer-kafka/actions/list-topics7
-rwxr-xr-xbigtop-packages/src/charm/kafka/layer-kafka/actions/list-zks9
-rwxr-xr-xbigtop-packages/src/charm/kafka/layer-kafka/actions/read-topic7
-rwxr-xr-xbigtop-packages/src/charm/kafka/layer-kafka/actions/smoke-test9
-rwxr-xr-xbigtop-packages/src/charm/kafka/layer-kafka/actions/write-topic7
-rw-r--r--bigtop-packages/src/charm/kafka/layer-kafka/icon.svg107
-rw-r--r--bigtop-packages/src/charm/kafka/layer-kafka/metadata.yaml25
-rwxr-xr-xbigtop-packages/src/charm/kafka/layer-kafka/tests/01-deploy.py4
-rwxr-xr-xbigtop-packages/src/charm/kafka/layer-kafka/tests/02-smoke-test.py4
-rwxr-xr-xbigtop-packages/src/charm/kafka/layer-kafka/tests/10-config-changed.py12
-rw-r--r--bigtop-packages/src/charm/mahout/layer-mahout/README.md54
-rwxr-xr-xbigtop-packages/src/charm/mahout/layer-mahout/actions/smoke-test1
-rw-r--r--bigtop-packages/src/charm/mahout/layer-mahout/metadata.yaml7
-rwxr-xr-xbigtop-packages/src/charm/mahout/layer-mahout/tests/01-mahout-test.py12
-rw-r--r--bigtop-packages/src/charm/pig/layer-pig/README.md98
-rwxr-xr-xbigtop-packages/src/charm/pig/layer-pig/actions/smoke-test15
-rw-r--r--bigtop-packages/src/charm/pig/layer-pig/metadata.yaml5
-rwxr-xr-xbigtop-packages/src/charm/pig/layer-pig/tests/01-deploy.py2
-rw-r--r--bigtop-packages/src/charm/spark/layer-spark/README.md200
-rw-r--r--bigtop-packages/src/charm/spark/layer-spark/actions.yaml45
-rwxr-xr-xbigtop-packages/src/charm/spark/layer-spark/actions/list-jobs11
-rwxr-xr-x[l---------]bigtop-packages/src/charm/spark/layer-spark/actions/pagerank137
-rwxr-xr-xbigtop-packages/src/charm/spark/layer-spark/actions/restart-spark-job-history-server26
-rwxr-xr-xbigtop-packages/src/charm/spark/layer-spark/actions/spark-submit44
-rwxr-xr-xbigtop-packages/src/charm/spark/layer-spark/actions/sparkbench10
-rwxr-xr-xbigtop-packages/src/charm/spark/layer-spark/actions/sparkpi43
-rwxr-xr-xbigtop-packages/src/charm/spark/layer-spark/actions/start-spark-job-history-server26
-rwxr-xr-xbigtop-packages/src/charm/spark/layer-spark/actions/stop-spark-job-history-server26
l---------[-rwxr-xr-x]bigtop-packages/src/charm/spark/layer-spark/actions/submit58
-rw-r--r--bigtop-packages/src/charm/spark/layer-spark/config.yaml20
-rw-r--r--bigtop-packages/src/charm/spark/layer-spark/icon.svg850
-rw-r--r--bigtop-packages/src/charm/spark/layer-spark/layer.yaml13
-rw-r--r--[-rwxr-xr-x]bigtop-packages/src/charm/spark/layer-spark/lib/charms/layer/bigtop_spark.py192
-rw-r--r--bigtop-packages/src/charm/spark/layer-spark/metadata.yaml6
-rw-r--r--bigtop-packages/src/charm/spark/layer-spark/reactive/spark.py245
-rwxr-xr-xbigtop-packages/src/charm/spark/layer-spark/scripts/sparkpi.sh7
-rwxr-xr-xbigtop-packages/src/charm/spark/layer-spark/tests/01-basic-deployment.py2
-rwxr-xr-xbigtop-packages/src/charm/spark/layer-spark/tests/02-smoke-test.py2
-rwxr-xr-xbigtop-packages/src/charm/spark/layer-spark/tests/03-scale-standalone.py7
-rwxr-xr-xbigtop-packages/src/charm/spark/layer-spark/tests/10-test-ha.py13
-rw-r--r--bigtop-packages/src/charm/zeppelin/layer-zeppelin/README.md105
-rwxr-xr-xbigtop-packages/src/charm/zeppelin/layer-zeppelin/actions/restart7
-rwxr-xr-xbigtop-packages/src/charm/zeppelin/layer-zeppelin/actions/smoke-test16
-rw-r--r--bigtop-packages/src/charm/zeppelin/layer-zeppelin/icon.svg502
-rw-r--r--bigtop-packages/src/charm/zeppelin/layer-zeppelin/layer.yaml6
-rw-r--r--bigtop-packages/src/charm/zeppelin/layer-zeppelin/lib/charms/layer/bigtop_zeppelin.py87
-rw-r--r--bigtop-packages/src/charm/zeppelin/layer-zeppelin/metadata.yaml7
-rw-r--r--bigtop-packages/src/charm/zeppelin/layer-zeppelin/reactive/zeppelin.py116
-rwxr-xr-xbigtop-packages/src/charm/zeppelin/layer-zeppelin/tests/01-basic-deployment.py2
-rwxr-xr-xbigtop-packages/src/charm/zeppelin/layer-zeppelin/tests/02-zeppelin-smoke.py7
-rwxr-xr-xbigtop-packages/src/charm/zeppelin/layer-zeppelin/tests/03-zeppelin-spark-smoke.py51
-rw-r--r--bigtop-packages/src/charm/zeppelin/layer-zeppelin/wheelhouse.txt2
-rw-r--r--bigtop-packages/src/charm/zookeeper/layer-zookeeper/README.md50
-rwxr-xr-xbigtop-packages/src/charm/zookeeper/layer-zookeeper/actions/restart11
-rwxr-xr-xbigtop-packages/src/charm/zookeeper/layer-zookeeper/actions/smoke-test10
-rw-r--r--bigtop-packages/src/charm/zookeeper/layer-zookeeper/icon.svg673
-rw-r--r--bigtop-packages/src/charm/zookeeper/layer-zookeeper/metadata.yaml7
-rwxr-xr-xbigtop-packages/src/charm/zookeeper/layer-zookeeper/tests/01-deploy-smoke.py5
-rwxr-xr-xbigtop-packages/src/charm/zookeeper/layer-zookeeper/tests/10-bind-address.py4
-rw-r--r--bigtop-packages/src/common/ambari/do-component-build2
-rw-r--r--bigtop-packages/src/common/ambari/patch0-AMBARI.diff25
-rw-r--r--bigtop-packages/src/common/ambari/patch1-AMBARI-storm.diff12
-rw-r--r--bigtop-packages/src/common/ambari/patch2-AMBARI-ConcurrentHashMap.diff19
-rw-r--r--bigtop-packages/src/common/apex/do-component-build3
-rw-r--r--bigtop-packages/src/common/apex/patch1-for-hadoop27x.diff20
-rwxr-xr-xbigtop-packages/src/common/flume/do-component-build2
-rw-r--r--bigtop-packages/src/common/hadoop/init-hcfs.json3
-rw-r--r--bigtop-packages/src/common/hama/do-component-build2
-rw-r--r--bigtop-packages/src/common/hbase/patch0-jline-jrub.diff15
-rw-r--r--bigtop-packages/src/common/hive/do-component-build2
-rw-r--r--bigtop-packages/src/common/ignite-hadoop/do-component-build2
-rw-r--r--bigtop-packages/src/common/ignite-hadoop/ignite-hadoop.default2
-rw-r--r--bigtop-packages/src/common/kafka/do-component-build2
-rwxr-xr-xbigtop-packages/src/common/oozie/do-component-build2
-rw-r--r--bigtop-packages/src/common/spark/do-component-build2
-rwxr-xr-xbigtop-packages/src/common/spark/spark-env.sh2
-rw-r--r--bigtop-packages/src/common/spark1/do-component-build2
-rw-r--r--bigtop-packages/src/common/zeppelin/do-component-build39
-rw-r--r--bigtop-packages/src/deb/flink/flink.preinst3
-rw-r--r--bigtop-packages/src/deb/flume/flume.preinst3
-rw-r--r--bigtop-packages/src/deb/hadoop/hadoop-hdfs.preinst3
-rw-r--r--bigtop-packages/src/deb/hadoop/hadoop-httpfs.preinst3
-rw-r--r--bigtop-packages/src/deb/hadoop/hadoop-mapreduce.preinst3
-rw-r--r--bigtop-packages/src/deb/hadoop/hadoop-yarn.preinst3
-rw-r--r--bigtop-packages/src/deb/hama/hama.preinst3
-rw-r--r--bigtop-packages/src/deb/hbase/hbase.preinst3
-rw-r--r--bigtop-packages/src/deb/hive/hive.preinst3
-rw-r--r--bigtop-packages/src/deb/hue/control2
-rw-r--r--bigtop-packages/src/deb/hue/hue-common.preinst3
-rw-r--r--bigtop-packages/src/deb/ignite-hadoop/ignite-hadoop.preinst3
-rw-r--r--bigtop-packages/src/deb/oozie/oozie.preinst3
-rw-r--r--bigtop-packages/src/deb/phoenix/phoenix.preinst9
-rw-r--r--bigtop-packages/src/deb/solr/solr.preinst3
-rw-r--r--bigtop-packages/src/deb/spark/control2
-rw-r--r--bigtop-packages/src/deb/spark/rules21
-rw-r--r--bigtop-packages/src/deb/spark/spark-core.preinst3
-rw-r--r--bigtop-packages/src/deb/spark1/spark-core.preinst3
-rw-r--r--bigtop-packages/src/deb/sqoop/sqoop.preinst3
-rw-r--r--bigtop-packages/src/deb/tajo/tajo.preinst3
-rw-r--r--bigtop-packages/src/deb/zeppelin/zeppelin.preinst3
-rw-r--r--bigtop-packages/src/deb/zookeeper/zookeeper.preinst3
-rw-r--r--bigtop-packages/src/rpm/ambari/SPECS/ambari.spec5
-rw-r--r--bigtop-packages/src/rpm/hbase/SPECS/hbase.spec3
-rw-r--r--bigtop-packages/src/rpm/ignite-hadoop/SPECS/ignite-hadoop.spec15
-rw-r--r--bigtop-packages/src/rpm/spark/SPECS/spark.spec21
-rw-r--r--bigtop-packages/src/rpm/ycsb/SPECS/ycsb.spec5
-rw-r--r--bigtop.bom17
-rwxr-xr-xbigtop_toolchain/bin/puppetize.sh8
-rw-r--r--bigtop_toolchain/manifests/gradle.pp2
-rw-r--r--bigtop_toolchain/manifests/jdk.pp10
-rw-r--r--bigtop_toolchain/manifests/packages.pp16
-rw-r--r--bigtop_toolchain/manifests/puppet-modules.pp7
-rw-r--r--build.gradle4
-rw-r--r--buildSrc/src/main/groovy/org/apache/bigtop/NullOutputStream.groovy27
-rw-r--r--buildSrc/src/test/groovy/org/apache/bigtop/TestNullOutputStream.groovy29
-rw-r--r--docker/bigtop-deploy/centos-6/Dockerfile28
-rwxr-xr-xdocker/bigtop-deploy/centos-6/build.sh18
-rw-r--r--docker/bigtop-deploy/centos-7/Dockerfile28
-rw-r--r--docker/bigtop-deploy/debian-8/Dockerfile34
-rw-r--r--[-rwxr-xr-x]docker/bigtop-puppet/debian-9/Dockerfile (renamed from docker/bigtop-deploy/ubuntu-14.04/build.sh)8
-rwxr-xr-xdocker/bigtop-puppet/debian-9/build.sh (renamed from docker/bigtop-deploy/debian-8/build.sh)6
-rw-r--r--[-rwxr-xr-x]docker/bigtop-slaves/debian-9/Dockerfile (renamed from docker/bigtop-deploy/centos-7/build.sh)13
-rw-r--r--docker/pseudo-cluster/config/hieradata/site.yaml1
-rw-r--r--docker/sandbox/README.md42
-rwxr-xr-xdocker/sandbox/build.sh35
-rw-r--r--docker/sandbox/sandbox-env.sh18
-rw-r--r--docker/sandbox/site.yaml.template.centos-6_hadoop3
-rw-r--r--docker/sandbox/site.yaml.template.debian-8_hadoop3
-rw-r--r--gradle/wrapper/gradle-wrapper.properties2
-rw-r--r--packages.gradle7
-rw-r--r--pom.xml3
l---------provisioner/docker/config.yaml2
-rw-r--r--provisioner/docker/config/hiera.yaml1
-rw-r--r--provisioner/docker/config/hieradata/PLACEHOLDER0
-rw-r--r--provisioner/docker/config/hosts1
-rw-r--r--provisioner/docker/config_centos-6.yaml (renamed from provisioner/docker/config_centos6.yaml)1
-rw-r--r--provisioner/docker/config_centos-7.yaml (renamed from provisioner/docker/config_centos7.yaml)1
-rw-r--r--provisioner/docker/config_debian-8.yaml (renamed from provisioner/docker/config_debian8.yaml)1
-rw-r--r--provisioner/docker/config_ubuntu-16.04.yaml (renamed from provisioner/docker/config_ubuntu_xenial.yaml)1
-rwxr-xr-xprovisioner/docker/docker-hadoop.sh21
-rwxr-xr-xprovisioner/vagrant/Vagrantfile4
-rw-r--r--provisioner/vagrant/vagrantconfig.yaml1
238 files changed, 3645 insertions, 4227 deletions
diff --git a/.dockerignore b/.dockerignore
index a7b219a4..150d143f 100644
--- a/.dockerignore
+++ b/.dockerignore
@@ -15,5 +15,4 @@
build
output
-bigtop-packages
dl
diff --git a/README.md b/README.md
index ca5671e7..40da1c7c 100644
--- a/README.md
+++ b/README.md
@@ -239,7 +239,7 @@ Example for HBase:
```
name = 'hbase'
- version { base = '1.1.3'; pkg = base; release = 1 }
+ version { base = '1.1.9'; pkg = base; release = 1 }
git { repo = "https://github.com/apache/hbase.git"
ref = "${version.base}"
dir = "${name}-${version.base}" }
diff --git a/bigtop-bigpetstore/bigpetstore-mapreduce/build.gradle b/bigtop-bigpetstore/bigpetstore-mapreduce/build.gradle
index 16cc7f83..24c9a01d 100644
--- a/bigtop-bigpetstore/bigpetstore-mapreduce/build.gradle
+++ b/bigtop-bigpetstore/bigpetstore-mapreduce/build.gradle
@@ -190,8 +190,6 @@ task integrationTest(type: Test, dependsOn: test) {
//memory requirements.
minHeapSize = "1000m"
maxHeapSize = "4000m"
- // set JVM arguments for the test JVM(s)
- jvmArgs '-XX:MaxPermSize=256m'
break
case "crunch":
patternsToInclude = "*CrunchIT*"
diff --git a/bigtop-bigpetstore/bigpetstore-mapreduce/src/test/java/org/apache/bigtop/bigpetstore/generator/TestPetStoreTransactionGeneratorJob.java b/bigtop-bigpetstore/bigpetstore-mapreduce/src/test/java/org/apache/bigtop/bigpetstore/generator/TestPetStoreTransactionGeneratorJob.java
index 76de3d06..dc235621 100755
--- a/bigtop-bigpetstore/bigpetstore-mapreduce/src/test/java/org/apache/bigtop/bigpetstore/generator/TestPetStoreTransactionGeneratorJob.java
+++ b/bigtop-bigpetstore/bigpetstore-mapreduce/src/test/java/org/apache/bigtop/bigpetstore/generator/TestPetStoreTransactionGeneratorJob.java
@@ -34,7 +34,7 @@ import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
- * run this test with vm options -XX:MaxPermSize=256m -Xms512m -Xmx1024m
+ * run this test with vm options -Xms512m -Xmx1024m
*
*/
public class TestPetStoreTransactionGeneratorJob {
@@ -101,4 +101,4 @@ public class TestPetStoreTransactionGeneratorJob {
+ fs.getFileStatus(new Path(output, "part-r-00000")).getLen()
+ " bytes.");
}
-} \ No newline at end of file
+}
diff --git a/bigtop-ci/build.sh b/bigtop-ci/build.sh
new file mode 100755
index 00000000..fc1f52f6
--- /dev/null
+++ b/bigtop-ci/build.sh
@@ -0,0 +1,54 @@
+#!/bin/bash
+
+while [[ $# -gt 1 ]]
+do
+key="$1"
+case $key in
+ -t|--target)
+ TARGET="$2"
+ shift
+ ;;
+ -o|--os)
+ OS="$2"
+ shift
+ ;;
+ -n|--nexus)
+ NEXUS="--net=container:nexus"
+ CONFIGURE_NEXUS="configure-nexus"
+ shift
+ ;;
+ *)
+ echo "usage build.sh --os debian-8|centos-7|... --target hadoop|tez|..."
+ exit 1 # unknown option
+ ;;
+esac
+shift
+done
+
+# prepare source image
+cat >Dockerfile <<EOF
+FROM bigtop/slaves:$OS
+# copy source to container
+COPY . /var/lib/jenkins/bigtop
+# make it belong to compile account
+RUN chown -R jenkins /var/lib/jenkins/bigtop
+# define default user jenkins
+USER jenkins
+WORKDIR /var/lib/jenkins/bigtop
+ENTRYPOINT [ "bigtop-ci/entrypoint.sh" ]
+# initialize gradle
+RUN bigtop-ci/entrypoint.sh
+# make it a volume, performancewise
+VOLUME /var/lib/jenkins
+EOF
+
+# build source image
+docker build -t image-$OS .
+
+# run build
+docker run --name container-$OS-$TARGET-$$ $NEXUS image-$OS $CONFIGURE_NEXUS $TARGET
+
+# save result
+mkdir -p output
+docker cp container-$OS-$TARGET-$$:/var/lib/jenkins/bigtop/output .
+docker rm -v container-$OS-$TARGET-$$
diff --git a/bigtop-ci/entrypoint.sh b/bigtop-ci/entrypoint.sh
new file mode 100755
index 00000000..bc580e10
--- /dev/null
+++ b/bigtop-ci/entrypoint.sh
@@ -0,0 +1,4 @@
+#!/bin/sh
+
+. /etc/profile.d/bigtop.sh
+exec ./gradlew "$@"
diff --git a/bigtop-deploy/juju/hadoop-hbase/README.md b/bigtop-deploy/juju/hadoop-hbase/README.md
index b45bf7bc..28253277 100644
--- a/bigtop-deploy/juju/hadoop-hbase/README.md
+++ b/bigtop-deploy/juju/hadoop-hbase/README.md
@@ -26,14 +26,20 @@ to deliver high-availability, Hadoop can detect and handle failures at the
application layer. This provides a highly-available service on top of a cluster
of machines, each of which may be prone to failure.
-HBase is the Hadoop database. Think of it as a distributed, scalable Big Data
-store.
+Apache HBase is the Hadoop database. Think of it as a distributed, scalable
+Big Data store.
-This bundle provides a complete deployment of Hadoop and HBase components from
-[Apache Bigtop][] that performs distributed data processing at scale. Ganglia
-and rsyslog applications are also provided to monitor cluster health and syslog
-activity.
+Use HBase when you need random, realtime read/write access to your Big Data.
+This project's goal is the hosting of very large tables -- billions of rows X
+millions of columns -- atop clusters of commodity hardware. Learn more at
+[hbase.apache.org][].
+This bundle provides a complete deployment of Hadoop and HBase components
+from [Apache Bigtop][] that performs distributed data processing at scale.
+Ganglia and rsyslog applications are also provided to monitor cluster health
+and syslog activity.
+
+[hbase.apache.org]: http://hbase.apache.org/
[Apache Bigtop]: http://bigtop.apache.org/
## Bundle Composition
@@ -41,14 +47,14 @@ activity.
The applications that comprise this bundle are spread across 8 units as
follows:
- * NameNode (HDFS)
- * ResourceManager (YARN)
+ * NameNode v2.7.3
+ * ResourceManager v2.7.3
* Colocated on the NameNode unit
- * Zookeeper
+ * Zookeeper v3.4.6
* 3 separate units
- * Slave (DataNode and NodeManager)
+ * Slave (DataNode and NodeManager) v2.7.3
* 3 separate units
- * HBase
+ * HBase v1.1.9
* 3 units colocated with the Hadoop Slaves
* Client (Hadoop endpoint)
* Plugin (Facilitates communication with the Hadoop cluster)
@@ -65,9 +71,8 @@ demands.
# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the [getting-started][] instructions prior to deploying this
-bundle.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this bundle.
> **Note**: This bundle requires hardware resources that may exceed limits
of Free-tier or Trial accounts on some clouds. To deploy to these
@@ -79,18 +84,10 @@ Deploy this bundle from the Juju charm store with the `juju deploy` command:
juju deploy hadoop-hbase
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-hadoop-hbase`.
-
Alternatively, deploy a locally modified `bundle.yaml` with:
juju deploy /path/to/bundle.yaml
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-/path/to/bundle.yaml`.
-
The charms in this bundle can also be built from their source layers in the
[Bigtop charm repository][]. See the [Bigtop charm README][] for instructions
on building and deploying these charms locally.
@@ -102,7 +99,6 @@ mirror options. See [Configuring Models][] for more information.
[getting-started]: https://jujucharms.com/docs/stable/getting-started
[bundle.yaml]: https://github.com/apache/bigtop/blob/master/bigtop-deploy/juju/hadoop-hbase/bundle.yaml
-[juju-quickstart]: https://launchpad.net/juju-quickstart
[Bigtop charm repository]: https://github.com/apache/bigtop/tree/master/bigtop-packages/src/charm
[Bigtop charm README]: https://github.com/apache/bigtop/blob/master/bigtop-packages/src/charm/README.md
[Configuring Models]: https://jujucharms.com/docs/stable/models-config
@@ -138,25 +134,16 @@ complete. Run the smoke-test actions as follows:
juju run-action hbase/0 smoke-test
juju run-action zookeeper/0 smoke-test
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do <application>/0 smoke-test`.
-
Watch the progress of the smoke test actions with:
watch -n 2 juju show-action-status
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
-
Eventually, all of the actions should settle to `status: completed`. If
any report `status: failed`, that application is not working as expected. Get
more information about a specific smoke test with:
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
-
## Utilities
Applications in this bundle include command line and web utilities that
can be used to verify information about the cluster.
@@ -314,6 +301,18 @@ Multiple units may be added at once. For example, add four more slave units:
juju add-unit -n4 slave
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this bundle at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
+
+Ensure `Bigtop` is selected as the project. Typically, bundle issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
+
+
# Contact Information
- <bigdata@lists.ubuntu.com>
@@ -324,6 +323,6 @@ Multiple units may be added at once. For example, add four more slave units:
- [Apache Bigtop home page](http://bigtop.apache.org/)
- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-deploy/juju/hadoop-hbase/bundle-dev.yaml b/bigtop-deploy/juju/hadoop-hbase/bundle-dev.yaml
index e4737e16..f7bcf561 100644
--- a/bigtop-deploy/juju/hadoop-hbase/bundle-dev.yaml
+++ b/bigtop-deploy/juju/hadoop-hbase/bundle-dev.yaml
@@ -34,7 +34,7 @@ services:
gui-x: "1000"
gui-y: "400"
client:
- charm: "cs:xenial/hadoop-client-3"
+ charm: "cs:xenial/hadoop-client-8"
constraints: "mem=3G"
num_units: 1
annotations:
@@ -65,7 +65,7 @@ services:
- "6"
- "7"
ganglia:
- charm: "cs:~bigdata-dev/xenial/ganglia-5"
+ charm: "cs:xenial/ganglia-12"
num_units: 1
annotations:
gui-x: "0"
@@ -73,7 +73,7 @@ services:
to:
- "4"
ganglia-node:
- charm: "cs:~bigdata-dev/xenial/ganglia-node-7"
+ charm: "cs:xenial/ganglia-node-7"
annotations:
gui-x: "250"
gui-y: "400"
@@ -115,17 +115,25 @@ relations:
machines:
"0":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"1":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"2":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"3":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"4":
series: "xenial"
+ constraints: "mem=3G"
"5":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"6":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"7":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
diff --git a/bigtop-deploy/juju/hadoop-hbase/bundle-local.yaml b/bigtop-deploy/juju/hadoop-hbase/bundle-local.yaml
index 7ae57f66..26e0f3ea 100644
--- a/bigtop-deploy/juju/hadoop-hbase/bundle-local.yaml
+++ b/bigtop-deploy/juju/hadoop-hbase/bundle-local.yaml
@@ -34,7 +34,7 @@ services:
gui-x: "1000"
gui-y: "400"
client:
- charm: "cs:xenial/hadoop-client-3"
+ charm: "cs:xenial/hadoop-client-8"
constraints: "mem=3G"
num_units: 1
annotations:
@@ -65,7 +65,7 @@ services:
- "6"
- "7"
ganglia:
- charm: "cs:~bigdata-dev/xenial/ganglia-5"
+ charm: "cs:xenial/ganglia-12"
num_units: 1
annotations:
gui-x: "0"
@@ -73,7 +73,7 @@ services:
to:
- "4"
ganglia-node:
- charm: "cs:~bigdata-dev/xenial/ganglia-node-7"
+ charm: "cs:xenial/ganglia-node-7"
annotations:
gui-x: "250"
gui-y: "400"
@@ -115,17 +115,25 @@ relations:
machines:
"0":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"1":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"2":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"3":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"4":
series: "xenial"
+ constraints: "mem=3G"
"5":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"6":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"7":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
diff --git a/bigtop-deploy/juju/hadoop-hbase/bundle.yaml b/bigtop-deploy/juju/hadoop-hbase/bundle.yaml
index 95b63d70..b51712a5 100644
--- a/bigtop-deploy/juju/hadoop-hbase/bundle.yaml
+++ b/bigtop-deploy/juju/hadoop-hbase/bundle.yaml
@@ -1,6 +1,6 @@
services:
namenode:
- charm: "cs:xenial/hadoop-namenode-12"
+ charm: "cs:xenial/hadoop-namenode-24"
constraints: "mem=7G root-disk=32G"
num_units: 1
annotations:
@@ -9,7 +9,7 @@ services:
to:
- "0"
resourcemanager:
- charm: "cs:xenial/hadoop-resourcemanager-13"
+ charm: "cs:xenial/hadoop-resourcemanager-26"
constraints: "mem=7G root-disk=32G"
num_units: 1
annotations:
@@ -18,7 +18,7 @@ services:
to:
- "0"
slave:
- charm: "cs:xenial/hadoop-slave-12"
+ charm: "cs:xenial/hadoop-slave-25"
constraints: "mem=7G root-disk=32G"
num_units: 3
annotations:
@@ -29,12 +29,12 @@ services:
- "2"
- "3"
plugin:
- charm: "cs:xenial/hadoop-plugin-12"
+ charm: "cs:xenial/hadoop-plugin-24"
annotations:
gui-x: "1000"
gui-y: "400"
client:
- charm: "cs:xenial/hadoop-client-3"
+ charm: "cs:xenial/hadoop-client-8"
constraints: "mem=3G"
num_units: 1
annotations:
@@ -43,7 +43,7 @@ services:
to:
- "4"
hbase:
- charm: "cs:xenial/hbase-10"
+ charm: "cs:xenial/hbase-25"
constraints: "mem=7G root-disk=32G"
num_units: 3
annotations:
@@ -54,7 +54,7 @@ services:
- "2"
- "3"
zookeeper:
- charm: "cs:xenial/zookeeper-16"
+ charm: "cs:xenial/zookeeper-30"
constraints: "mem=3G root-disk=32G"
num_units: 3
annotations:
@@ -65,7 +65,7 @@ services:
- "6"
- "7"
ganglia:
- charm: "cs:~bigdata-dev/xenial/ganglia-5"
+ charm: "cs:xenial/ganglia-12"
num_units: 1
annotations:
gui-x: "0"
@@ -73,7 +73,7 @@ services:
to:
- "4"
ganglia-node:
- charm: "cs:~bigdata-dev/xenial/ganglia-node-7"
+ charm: "cs:xenial/ganglia-node-7"
annotations:
gui-x: "250"
gui-y: "400"
@@ -115,17 +115,25 @@ relations:
machines:
"0":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"1":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"2":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"3":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"4":
series: "xenial"
+ constraints: "mem=3G"
"5":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"6":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"7":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
diff --git a/bigtop-deploy/juju/hadoop-hbase/tests/01-bundle.py b/bigtop-deploy/juju/hadoop-hbase/tests/01-bundle.py
index 166ac546..bb726050 100755
--- a/bigtop-deploy/juju/hadoop-hbase/tests/01-bundle.py
+++ b/bigtop-deploy/juju/hadoop-hbase/tests/01-bundle.py
@@ -27,8 +27,6 @@ class TestBundle(unittest.TestCase):
@classmethod
def setUpClass(cls):
- # classmethod inheritance doesn't work quite right with
- # setUpClass / tearDownClass, so subclasses have to manually call this
cls.d = amulet.Deployment(series='xenial')
with open(cls.bundle_file) as f:
bun = f.read()
diff --git a/bigtop-deploy/juju/hadoop-hbase/tests/tests.yaml b/bigtop-deploy/juju/hadoop-hbase/tests/tests.yaml
index a3b7803f..b9517421 100644
--- a/bigtop-deploy/juju/hadoop-hbase/tests/tests.yaml
+++ b/bigtop-deploy/juju/hadoop-hbase/tests/tests.yaml
@@ -1,5 +1,5 @@
reset: false
-bundle_deploy: false
+deployment_timeout: 3600
sources:
- 'ppa:juju/stable'
packages:
diff --git a/bigtop-deploy/juju/hadoop-kafka/README.md b/bigtop-deploy/juju/hadoop-kafka/README.md
index 4c7a5818..4caf7744 100644
--- a/bigtop-deploy/juju/hadoop-kafka/README.md
+++ b/bigtop-deploy/juju/hadoop-kafka/README.md
@@ -44,15 +44,15 @@ activity.
The applications that comprise this bundle are spread across 9 units as
follows:
- * NameNode (HDFS)
- * ResourceManager (YARN)
+ * NameNode v2.7.3
+ * ResourceManager v2.7.3
* Colocated on the NameNode unit
- * Slave (DataNode and NodeManager)
+ * Slave (DataNode and NodeManager) v2.7.3
* 3 separate units
- * Kafka
+ * Kafka v0.10.1
* Flume-Kafka
* Colocated on the Kafka unit
- * Zookeeper
+ * Zookeeper v3.4.6
* 3 separate units
* Client (Hadoop endpoint)
* Plugin (Facilitates communication with the Hadoop cluster)
@@ -76,9 +76,8 @@ demands.
# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the [getting-started][] instructions prior to deploying this
-bundle.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this bundle.
> **Note**: This bundle requires hardware resources that may exceed limits
of Free-tier or Trial accounts on some clouds. To deploy to these
@@ -90,18 +89,10 @@ Deploy this bundle from the Juju charm store with the `juju deploy` command:
juju deploy hadoop-kafka
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-hadoop-kafka`.
-
Alternatively, deploy a locally modified `bundle.yaml` with:
juju deploy /path/to/bundle.yaml
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-/path/to/bundle.yaml`.
-
The charms in this bundle can also be built from their source layers in the
[Bigtop charm repository][]. See the [Bigtop charm README][] for instructions
on building and deploying these charms locally.
@@ -113,7 +104,6 @@ mirror options. See [Configuring Models][] for more information.
[getting-started]: https://jujucharms.com/docs/stable/getting-started
[bundle.yaml]: https://github.com/apache/bigtop/blob/master/bigtop-deploy/juju/hadoop-kafka/bundle.yaml
-[juju-quickstart]: https://launchpad.net/juju-quickstart
[Bigtop charm repository]: https://github.com/apache/bigtop/tree/master/bigtop-packages/src/charm
[Bigtop charm README]: https://github.com/apache/bigtop/blob/master/bigtop-packages/src/charm/README.md
[Configuring Models]: https://jujucharms.com/docs/stable/models-config
@@ -166,25 +156,16 @@ complete. Run the smoke-test actions as follows:
juju run-action kafka/0 smoke-test
juju run-action zookeeper/0 smoke-test
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do <application>/0 smoke-test`.
-
Watch the progress of the smoke test actions with:
watch -n 2 juju show-action-status
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
-
Eventually, all of the actions should settle to `status: completed`. If
any report `status: failed`, that application is not working as expected. Get
more information about a specific smoke test with:
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
-
## Utilities
Applications in this bundle include command line and web utilities that
can be used to verify information about the cluster.
@@ -314,6 +295,18 @@ Multiple units may be added at once. For example, add four more slave units:
juju add-unit -n4 slave
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this bundle at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
+
+Ensure `Bigtop` is selected as the project. Typically, bundle issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
+
+
# Contact Information
- <bigdata@lists.ubuntu.com>
@@ -324,6 +317,6 @@ Multiple units may be added at once. For example, add four more slave units:
- [Apache Bigtop home page](http://bigtop.apache.org/)
- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-deploy/juju/hadoop-kafka/bundle-dev.yaml b/bigtop-deploy/juju/hadoop-kafka/bundle-dev.yaml
index 45b821fa..f715f788 100644
--- a/bigtop-deploy/juju/hadoop-kafka/bundle-dev.yaml
+++ b/bigtop-deploy/juju/hadoop-kafka/bundle-dev.yaml
@@ -34,7 +34,7 @@ services:
gui-x: "1000"
gui-y: "400"
client:
- charm: "cs:xenial/hadoop-client-3"
+ charm: "cs:xenial/hadoop-client-8"
constraints: "mem=3G"
num_units: 1
annotations:
@@ -81,7 +81,7 @@ services:
to:
- "8"
ganglia:
- charm: "cs:~bigdata-dev/xenial/ganglia-5"
+ charm: "cs:xenial/ganglia-12"
num_units: 1
annotations:
gui-x: "0"
@@ -89,7 +89,7 @@ services:
to:
- "4"
ganglia-node:
- charm: "cs:~bigdata-dev/xenial/ganglia-node-7"
+ charm: "cs:xenial/ganglia-node-7"
annotations:
gui-x: "250"
gui-y: "400"
@@ -133,19 +133,28 @@ relations:
machines:
"0":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"1":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"2":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"3":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"4":
series: "xenial"
+ constraints: "mem=3G"
"5":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"6":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"7":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"8":
series: "xenial"
+ constraints: "mem=3G"
diff --git a/bigtop-deploy/juju/hadoop-kafka/bundle-local.yaml b/bigtop-deploy/juju/hadoop-kafka/bundle-local.yaml
index bd898728..82bfb164 100644
--- a/bigtop-deploy/juju/hadoop-kafka/bundle-local.yaml
+++ b/bigtop-deploy/juju/hadoop-kafka/bundle-local.yaml
@@ -34,7 +34,7 @@ services:
gui-x: "1000"
gui-y: "400"
client:
- charm: "cs:xenial/hadoop-client-3"
+ charm: "cs:xenial/hadoop-client-8"
constraints: "mem=3G"
num_units: 1
annotations:
@@ -81,7 +81,7 @@ services:
to:
- "8"
ganglia:
- charm: "cs:~bigdata-dev/xenial/ganglia-5"
+ charm: "cs:xenial/ganglia-12"
num_units: 1
annotations:
gui-x: "0"
@@ -89,7 +89,7 @@ services:
to:
- "4"
ganglia-node:
- charm: "cs:~bigdata-dev/xenial/ganglia-node-7"
+ charm: "cs:xenial/ganglia-node-7"
annotations:
gui-x: "250"
gui-y: "400"
@@ -133,19 +133,28 @@ relations:
machines:
"0":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"1":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"2":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"3":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"4":
series: "xenial"
+ constraints: "mem=3G"
"5":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"6":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"7":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"8":
series: "xenial"
+ constraints: "mem=3G"
diff --git a/bigtop-deploy/juju/hadoop-kafka/bundle.yaml b/bigtop-deploy/juju/hadoop-kafka/bundle.yaml
index 80aa8951..832d50d1 100644
--- a/bigtop-deploy/juju/hadoop-kafka/bundle.yaml
+++ b/bigtop-deploy/juju/hadoop-kafka/bundle.yaml
@@ -1,6 +1,6 @@
services:
namenode:
- charm: "cs:xenial/hadoop-namenode-12"
+ charm: "cs:xenial/hadoop-namenode-24"
constraints: "mem=7G root-disk=32G"
num_units: 1
annotations:
@@ -9,7 +9,7 @@ services:
to:
- "0"
resourcemanager:
- charm: "cs:xenial/hadoop-resourcemanager-13"
+ charm: "cs:xenial/hadoop-resourcemanager-26"
constraints: "mem=7G root-disk=32G"
num_units: 1
annotations:
@@ -18,7 +18,7 @@ services:
to:
- "0"
slave:
- charm: "cs:xenial/hadoop-slave-12"
+ charm: "cs:xenial/hadoop-slave-25"
constraints: "mem=7G root-disk=32G"
num_units: 3
annotations:
@@ -29,12 +29,12 @@ services:
- "2"
- "3"
plugin:
- charm: "cs:xenial/hadoop-plugin-12"
+ charm: "cs:xenial/hadoop-plugin-24"
annotations:
gui-x: "1000"
gui-y: "400"
client:
- charm: "cs:xenial/hadoop-client-3"
+ charm: "cs:xenial/hadoop-client-8"
constraints: "mem=3G"
num_units: 1
annotations:
@@ -52,7 +52,7 @@ services:
to:
- "4"
zookeeper:
- charm: "cs:xenial/zookeeper-16"
+ charm: "cs:xenial/zookeeper-30"
constraints: "mem=3G root-disk=32G"
num_units: 3
annotations:
@@ -63,7 +63,7 @@ services:
- "6"
- "7"
kafka:
- charm: "cs:xenial/kafka-11"
+ charm: "cs:xenial/kafka-27"
constraints: "mem=3G"
num_units: 1
annotations:
@@ -81,7 +81,7 @@ services:
to:
- "8"
ganglia:
- charm: "cs:~bigdata-dev/xenial/ganglia-5"
+ charm: "cs:xenial/ganglia-12"
num_units: 1
annotations:
gui-x: "0"
@@ -89,7 +89,7 @@ services:
to:
- "4"
ganglia-node:
- charm: "cs:~bigdata-dev/xenial/ganglia-node-7"
+ charm: "cs:xenial/ganglia-node-7"
annotations:
gui-x: "250"
gui-y: "400"
@@ -133,19 +133,28 @@ relations:
machines:
"0":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"1":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"2":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"3":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"4":
series: "xenial"
+ constraints: "mem=3G"
"5":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"6":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"7":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"8":
series: "xenial"
+ constraints: "mem=3G"
diff --git a/bigtop-deploy/juju/hadoop-kafka/tests/01-bundle.py b/bigtop-deploy/juju/hadoop-kafka/tests/01-bundle.py
index fb113fc6..24f8bede 100755
--- a/bigtop-deploy/juju/hadoop-kafka/tests/01-bundle.py
+++ b/bigtop-deploy/juju/hadoop-kafka/tests/01-bundle.py
@@ -27,8 +27,6 @@ class TestBundle(unittest.TestCase):
@classmethod
def setUpClass(cls):
- # classmethod inheritance doesn't work quite right with
- # setUpClass / tearDownClass, so subclasses have to manually call this
cls.d = amulet.Deployment(series='xenial')
with open(cls.bundle_file) as f:
bun = f.read()
diff --git a/bigtop-deploy/juju/hadoop-kafka/tests/tests.yaml b/bigtop-deploy/juju/hadoop-kafka/tests/tests.yaml
index a3b7803f..b9517421 100644
--- a/bigtop-deploy/juju/hadoop-kafka/tests/tests.yaml
+++ b/bigtop-deploy/juju/hadoop-kafka/tests/tests.yaml
@@ -1,5 +1,5 @@
reset: false
-bundle_deploy: false
+deployment_timeout: 3600
sources:
- 'ppa:juju/stable'
packages:
diff --git a/bigtop-deploy/juju/hadoop-processing/README.md b/bigtop-deploy/juju/hadoop-processing/README.md
index 896a7936..9ad44b6a 100644
--- a/bigtop-deploy/juju/hadoop-processing/README.md
+++ b/bigtop-deploy/juju/hadoop-processing/README.md
@@ -38,10 +38,10 @@ and syslog activity.
The applications that comprise this bundle are spread across 5 machines as
follows:
- * NameNode (HDFS)
- * ResourceManager (YARN)
+ * NameNode v2.7.3
+ * ResourceManager v2.7.3
* Colocated on the NameNode unit
- * Slave (DataNode and NodeManager)
+ * Slave (DataNode and NodeManager) v2.7.3
* 3 separate units
* Client (Hadoop endpoint)
* Plugin (Facilitates communication with the Hadoop cluster)
@@ -57,9 +57,8 @@ demands.
# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the [getting-started][] instructions prior to deploying this
-bundle.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this bundle.
> **Note**: This bundle requires hardware resources that may exceed limits
of Free-tier or Trial accounts on some clouds. To deploy to these
@@ -70,18 +69,10 @@ Deploy this bundle from the Juju charm store with the `juju deploy` command:
juju deploy hadoop-processing
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-hadoop-processing`.
-
Alternatively, deploy a locally modified `bundle.yaml` with:
juju deploy /path/to/bundle.yaml
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-/path/to/bundle.yaml`.
-
The charms in this bundle can also be built from their source layers in the
[Bigtop charm repository][]. See the [Bigtop charm README][] for instructions
on building and deploying these charms locally.
@@ -93,7 +84,6 @@ mirror options. See [Configuring Models][] for more information.
[getting-started]: https://jujucharms.com/docs/stable/getting-started
[bundle.yaml]: https://github.com/apache/bigtop/blob/master/bigtop-deploy/juju/hadoop-processing/bundle.yaml
-[juju-quickstart]: https://launchpad.net/juju-quickstart
[Bigtop charm repository]: https://github.com/apache/bigtop/tree/master/bigtop-packages/src/charm
[Bigtop charm README]: https://github.com/apache/bigtop/blob/master/bigtop-packages/src/charm/README.md
[Configuring Models]: https://jujucharms.com/docs/stable/models-config
@@ -127,25 +117,16 @@ Run the smoke-test actions as follows:
juju run-action resourcemanager/0 smoke-test
juju run-action slave/0 smoke-test
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do <application>/0 smoke-test`.
-
Watch the progress of the smoke test actions with:
watch -n 2 juju show-action-status
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
-
Eventually, all of the actions should settle to `status: completed`. If
any report `status: failed`, that application is not working as expected. Get
more information about a specific smoke test with:
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
-
## Utilities
Applications in this bundle include Hadoop command line and web utilities that
can be used to verify information about the cluster.
@@ -270,6 +251,18 @@ Multiple units may be added at once. For example, add four more slave units:
juju add-unit -n4 slave
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this bundle at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
+
+Ensure `Bigtop` is selected as the project. Typically, bundle issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
+
+
# Contact Information
- <bigdata@lists.ubuntu.com>
@@ -280,6 +273,6 @@ Multiple units may be added at once. For example, add four more slave units:
- [Apache Bigtop home page](http://bigtop.apache.org/)
- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-deploy/juju/hadoop-processing/bundle-dev.yaml b/bigtop-deploy/juju/hadoop-processing/bundle-dev.yaml
index 20ae8afc..42b5f383 100644
--- a/bigtop-deploy/juju/hadoop-processing/bundle-dev.yaml
+++ b/bigtop-deploy/juju/hadoop-processing/bundle-dev.yaml
@@ -34,7 +34,7 @@ services:
gui-x: "1000"
gui-y: "400"
client:
- charm: "cs:xenial/hadoop-client-3"
+ charm: "cs:xenial/hadoop-client-8"
constraints: "mem=3G"
num_units: 1
annotations:
@@ -43,7 +43,7 @@ services:
to:
- "4"
ganglia:
- charm: "cs:~bigdata-dev/xenial/ganglia-5"
+ charm: "cs:xenial/ganglia-12"
num_units: 1
annotations:
gui-x: "0"
@@ -51,7 +51,7 @@ services:
to:
- "4"
ganglia-node:
- charm: "cs:~bigdata-dev/xenial/ganglia-node-7"
+ charm: "cs:xenial/ganglia-node-7"
annotations:
gui-x: "250"
gui-y: "400"
@@ -87,11 +87,16 @@ relations:
machines:
"0":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"1":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"2":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"3":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"4":
series: "xenial"
+ constraints: "mem=3G"
diff --git a/bigtop-deploy/juju/hadoop-processing/bundle-local.yaml b/bigtop-deploy/juju/hadoop-processing/bundle-local.yaml
index b277df4d..736f73bd 100644
--- a/bigtop-deploy/juju/hadoop-processing/bundle-local.yaml
+++ b/bigtop-deploy/juju/hadoop-processing/bundle-local.yaml
@@ -34,7 +34,7 @@ services:
gui-x: "1000"
gui-y: "400"
client:
- charm: "cs:xenial/hadoop-client-3"
+ charm: "cs:xenial/hadoop-client-8"
constraints: "mem=3G"
num_units: 1
annotations:
@@ -43,7 +43,7 @@ services:
to:
- "4"
ganglia:
- charm: "cs:~bigdata-dev/xenial/ganglia-5"
+ charm: "cs:xenial/ganglia-12"
num_units: 1
annotations:
gui-x: "0"
@@ -51,7 +51,7 @@ services:
to:
- "4"
ganglia-node:
- charm: "cs:~bigdata-dev/xenial/ganglia-node-7"
+ charm: "cs:xenial/ganglia-node-7"
annotations:
gui-x: "250"
gui-y: "400"
@@ -87,11 +87,16 @@ relations:
machines:
"0":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"1":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"2":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"3":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"4":
series: "xenial"
+ constraints: "mem=3G"
diff --git a/bigtop-deploy/juju/hadoop-processing/bundle.yaml b/bigtop-deploy/juju/hadoop-processing/bundle.yaml
index fcd1017e..fbd973d7 100644
--- a/bigtop-deploy/juju/hadoop-processing/bundle.yaml
+++ b/bigtop-deploy/juju/hadoop-processing/bundle.yaml
@@ -1,6 +1,6 @@
services:
namenode:
- charm: "cs:xenial/hadoop-namenode-12"
+ charm: "cs:xenial/hadoop-namenode-24"
constraints: "mem=7G root-disk=32G"
num_units: 1
annotations:
@@ -9,7 +9,7 @@ services:
to:
- "0"
resourcemanager:
- charm: "cs:xenial/hadoop-resourcemanager-13"
+ charm: "cs:xenial/hadoop-resourcemanager-26"
constraints: "mem=7G root-disk=32G"
num_units: 1
annotations:
@@ -18,7 +18,7 @@ services:
to:
- "0"
slave:
- charm: "cs:xenial/hadoop-slave-12"
+ charm: "cs:xenial/hadoop-slave-25"
constraints: "mem=7G root-disk=32G"
num_units: 3
annotations:
@@ -29,12 +29,12 @@ services:
- "2"
- "3"
plugin:
- charm: "cs:xenial/hadoop-plugin-12"
+ charm: "cs:xenial/hadoop-plugin-24"
annotations:
gui-x: "1000"
gui-y: "400"
client:
- charm: "cs:xenial/hadoop-client-3"
+ charm: "cs:xenial/hadoop-client-8"
constraints: "mem=3G"
num_units: 1
annotations:
@@ -43,7 +43,7 @@ services:
to:
- "4"
ganglia:
- charm: "cs:~bigdata-dev/xenial/ganglia-5"
+ charm: "cs:xenial/ganglia-12"
num_units: 1
annotations:
gui-x: "0"
@@ -51,7 +51,7 @@ services:
to:
- "4"
ganglia-node:
- charm: "cs:~bigdata-dev/xenial/ganglia-node-7"
+ charm: "cs:xenial/ganglia-node-7"
annotations:
gui-x: "250"
gui-y: "400"
@@ -87,11 +87,16 @@ relations:
machines:
"0":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"1":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"2":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"3":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"4":
series: "xenial"
+ constraints: "mem=3G"
diff --git a/bigtop-deploy/juju/hadoop-processing/tests/01-bundle.py b/bigtop-deploy/juju/hadoop-processing/tests/01-bundle.py
index 51d1c3d1..2127cfc2 100755
--- a/bigtop-deploy/juju/hadoop-processing/tests/01-bundle.py
+++ b/bigtop-deploy/juju/hadoop-processing/tests/01-bundle.py
@@ -27,8 +27,6 @@ class TestBundle(unittest.TestCase):
@classmethod
def setUpClass(cls):
- # classmethod inheritance doesn't work quite right with
- # setUpClass / tearDownClass, so subclasses have to manually call this
cls.d = amulet.Deployment(series='xenial')
with open(cls.bundle_file) as f:
bun = f.read()
diff --git a/bigtop-deploy/juju/hadoop-processing/tests/tests.yaml b/bigtop-deploy/juju/hadoop-processing/tests/tests.yaml
index a3b7803f..b9517421 100644
--- a/bigtop-deploy/juju/hadoop-processing/tests/tests.yaml
+++ b/bigtop-deploy/juju/hadoop-processing/tests/tests.yaml
@@ -1,5 +1,5 @@
reset: false
-bundle_deploy: false
+deployment_timeout: 3600
sources:
- 'ppa:juju/stable'
packages:
diff --git a/bigtop-deploy/juju/hadoop-spark/README.md b/bigtop-deploy/juju/hadoop-spark/README.md
index cc956e9d..edd04634 100644
--- a/bigtop-deploy/juju/hadoop-spark/README.md
+++ b/bigtop-deploy/juju/hadoop-spark/README.md
@@ -23,38 +23,39 @@ using a simple programming model.
Hadoop is designed to scale from a few servers to thousands of machines,
each offering local computation and storage. Rather than rely on hardware
to deliver high-availability, Hadoop can detect and handle failures at the
-application layer. This provides a highly-available service on top of a cluster
-of machines, each of which may be prone to failure.
+application layer. This provides a highly-available service on top of a
+cluster of machines, each of which may be prone to failure.
-Spark is a fast and general engine for large-scale data processing.
+Apache Spark is a fast and general engine for large-scale data processing.
+Learn more at [spark.apache.org][].
-This bundle provides a complete deployment of Hadoop and Spark components from
-[Apache Bigtop][] that performs distributed data processing at scale. Ganglia
-and rsyslog applications are also provided to monitor cluster health and syslog
-activity.
+This bundle provides a complete deployment of Hadoop and Spark components
+from [Apache Bigtop][] that performs distributed data processing at scale.
+Ganglia and rsyslog applications are also provided to monitor cluster health
+and syslog activity.
+[spark.apache.org]: http://spark.apache.org/
[Apache Bigtop]: http://bigtop.apache.org/
## Bundle Composition
-The applications that comprise this bundle are spread across 9 units as
+The applications that comprise this bundle are spread across 5 units as
follows:
- * NameNode (HDFS)
- * ResourceManager (YARN)
+ * NameNode v2.7.3
+ * ResourceManager v2.7.3
* Colocated on the NameNode unit
- * Slave (DataNode and NodeManager)
- * 3 separate units
- * Spark (Master in yarn-client mode)
- * Zookeeper
+ * Slave (DataNode and NodeManager) v2.7.3
* 3 separate units
+ * Spark (Driver in yarn-client mode) v2.1.0
* Client (Hadoop endpoint)
+ * Colocated on the Spark unit
* Plugin (Facilitates communication with the Hadoop cluster)
- * Colocated on the Spark and Client units
+ * Colocated on the Spark/Client unit
* Ganglia (Web interface for monitoring cluster metrics)
- * Colocated on the Client unit
+ * Colocated on the Spark/Client unit
* Rsyslog (Aggregate cluster syslog events in a single location)
- * Colocated on the Client unit
+ * Colocated on the Spark/Client unit
Deploying this bundle results in a fully configured Apache Bigtop
cluster on any supported cloud, which can be scaled to meet workload
@@ -63,9 +64,8 @@ demands.
# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the [getting-started][] instructions prior to deploying this
-bundle.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this bundle.
> **Note**: This bundle requires hardware resources that may exceed limits
of Free-tier or Trial accounts on some clouds. To deploy to these
@@ -77,18 +77,10 @@ Deploy this bundle from the Juju charm store with the `juju deploy` command:
juju deploy hadoop-spark
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-hadoop-spark`.
-
Alternatively, deploy a locally modified `bundle.yaml` with:
juju deploy /path/to/bundle.yaml
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-/path/to/bundle.yaml`.
-
The charms in this bundle can also be built from their source layers in the
[Bigtop charm repository][]. See the [Bigtop charm README][] for instructions
on building and deploying these charms locally.
@@ -100,7 +92,6 @@ mirror options. See [Configuring Models][] for more information.
[getting-started]: https://jujucharms.com/docs/stable/getting-started
[bundle.yaml]: https://github.com/apache/bigtop/blob/master/bigtop-deploy/juju/hadoop-spark/bundle.yaml
-[juju-quickstart]: https://launchpad.net/juju-quickstart
[Bigtop charm repository]: https://github.com/apache/bigtop/tree/master/bigtop-packages/src/charm
[Bigtop charm README]: https://github.com/apache/bigtop/blob/master/bigtop-packages/src/charm/README.md
[Configuring Models]: https://jujucharms.com/docs/stable/models-config
@@ -124,8 +115,8 @@ Once they all indicate that they are ready, perform application smoke tests
to verify that the bundle is working as expected.
## Smoke Test
-The charms for each core component (namenode, resourcemanager, slave, spark,
-and zookeeper) provide a `smoke-test` action that can be used to verify the
+The charms for each core component (namenode, resourcemanager, slave, and
+spark) provide a `smoke-test` action that can be used to verify the
application is functioning as expected. Note that the 'slave' component runs
extensive tests provided by Apache Bigtop and may take up to 30 minutes to
complete. Run the smoke-test actions as follows:
@@ -134,27 +125,17 @@ complete. Run the smoke-test actions as follows:
juju run-action resourcemanager/0 smoke-test
juju run-action slave/0 smoke-test
juju run-action spark/0 smoke-test
- juju run-action zookeeper/0 smoke-test
-
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do <application>/0 smoke-test`.
Watch the progress of the smoke test actions with:
watch -n 2 juju show-action-status
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
-
Eventually, all of the actions should settle to `status: completed`. If
any report `status: failed`, that application is not working as expected. Get
more information about a specific smoke test with:
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
-
## Utilities
Applications in this bundle include command line and web utilities that
can be used to verify information about the cluster.
@@ -165,10 +146,6 @@ of YARN NodeManager units with the following:
juju run --application namenode "su hdfs -c 'hdfs dfsadmin -report'"
juju run --application resourcemanager "su yarn -c 'yarn node -list'"
-Show the list of Zookeeper nodes with the following:
-
- juju run --unit zookeeper/0 'echo "ls /" | /usr/lib/zookeeper/bin/zkCli.sh'
-
To access the HDFS web console, find the `PUBLIC-ADDRESS` of the namenode
application and expose it:
@@ -204,7 +181,7 @@ The web interface will be available at the following URL:
# Monitoring
This bundle includes Ganglia for system-level monitoring of the namenode,
-resourcemanager, slave, spark, and zookeeper units. Metrics are sent to a
+resourcemanager, slave, and spark units. Metrics are sent to a
centralized ganglia unit for easy viewing in a browser. To view the ganglia web
interface, find the `PUBLIC-ADDRESS` of the Ganglia application and expose it:
@@ -219,7 +196,7 @@ The web interface will be available at:
# Logging
This bundle includes rsyslog to collect syslog data from the namenode,
-resourcemanager, slave, spark, and zookeeper units. These logs are sent to a
+resourcemanager, slave, and spark units. These logs are sent to a
centralized rsyslog unit for easy syslog analysis. One method of viewing this
log data is to simply cat syslog from the rsyslog unit:
@@ -278,27 +255,17 @@ run with `juju run-action`:
enqueued: 2016-02-04 14:55:14 +0000 UTC
started: 2016-02-04 14:55:27 +0000 UTC
-The `spark` charm in this bundle also provides several benchmarks to gauge
-the performance of the Spark cluster. Each benchmark is an action that can be
-run with `juju run-action`:
+The `spark` charm in this bundle provides benchmarks to gauge the performance
+of the Spark/YARN cluster. Each benchmark is an action that can be run with
+`juju run-action`:
- $ juju actions spark | grep Bench
- connectedcomponent Run the Spark Bench ConnectedComponent benchmark.
- decisiontree Run the Spark Bench DecisionTree benchmark.
- kmeans Run the Spark Bench KMeans benchmark.
- linearregression Run the Spark Bench LinearRegression benchmark.
- logisticregression Run the Spark Bench LogisticRegression benchmark.
- matrixfactorization Run the Spark Bench MatrixFactorization benchmark.
- pagerank Run the Spark Bench PageRank benchmark.
- pca Run the Spark Bench PCA benchmark.
- pregeloperation Run the Spark Bench PregelOperation benchmark.
- shortestpaths Run the Spark Bench ShortestPaths benchmark.
- sql Run the Spark Bench SQL benchmark.
- stronglyconnectedcomponent Run the Spark Bench StronglyConnectedComponent benchmark.
- svdplusplus Run the Spark Bench SVDPlusPlus benchmark.
- svm Run the Spark Bench SVM benchmark.
-
- $ juju run-action spark/0 svdplusplus
+ $ juju actions spark
+ ...
+ pagerank Calculate PageRank for a sample data set
+ sparkpi Calculate Pi
+ ...
+
+ $ juju run-action spark/0 pagerank
Action queued with id: 339cec1f-e903-4ee7-85ca-876fb0c3d28e
$ juju show-action-output 339cec1f-e903-4ee7-85ca-876fb0c3d28e
@@ -307,40 +274,41 @@ run with `juju run-action`:
composite:
direction: asc
units: secs
- value: "200.754000"
- raw: |
- SVDPlusPlus,2016-11-02-03:08:26,200.754000,85.974071,.428255,0,SVDPlusPlus-MLlibConfig,,,,,10,,,50000,4.0,1.3,
- start: 2016-11-02T03:08:26Z
- stop: 2016-11-02T03:11:47Z
- results:
- duration:
- direction: asc
- units: secs
- value: "200.754000"
- throughput:
- direction: desc
- units: MB/sec
- value: ".428255"
+ value: "83"
+ start: 2017-04-12T23:22:38Z
+ stop: 2017-04-12T23:24:01Z
+ output: '{''status'': ''completed''}'
status: completed
timing:
- completed: 2016-11-02 03:11:48 +0000 UTC
- enqueued: 2016-11-02 03:08:21 +0000 UTC
- started: 2016-11-02 03:08:26 +0000 UTC
+ completed: 2017-04-12 23:24:02 +0000 UTC
+ enqueued: 2017-04-12 23:22:36 +0000 UTC
+ started: 2017-04-12 23:22:37 +0000 UTC
# Scaling
-By default, three Hadoop slave and three zookeeper units are deployed. Scaling
-these applications is as simple as adding more units. To add one unit:
+By default, three Hadoop slave units are deployed. Scaling these is as simple
+as adding more units. To add one unit:
juju add-unit slave
- juju add-unit zookeeper
Multiple units may be added at once. For example, add four more slave units:
juju add-unit -n4 slave
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this bundle at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
+
+Ensure `Bigtop` is selected as the project. Typically, bundle issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
+
+
# Contact Information
- <bigdata@lists.ubuntu.com>
@@ -351,6 +319,6 @@ Multiple units may be added at once. For example, add four more slave units:
- [Apache Bigtop home page](http://bigtop.apache.org/)
- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-deploy/juju/hadoop-spark/bundle-dev.yaml b/bigtop-deploy/juju/hadoop-spark/bundle-dev.yaml
index a42242e5..99678f13 100644
--- a/bigtop-deploy/juju/hadoop-spark/bundle-dev.yaml
+++ b/bigtop-deploy/juju/hadoop-spark/bundle-dev.yaml
@@ -1,3 +1,8 @@
+series: xenial
+description: >
+ This is a five unit big data cluster that includes Hadoop 2.7.3 and Spark 2.1
+ from Apache Bigtop. Use it to analyse batch data with MapReduce or streaming
+ data with Spark. It will run on 5 machines in your cloud.
services:
namenode:
charm: "cs:~bigdata-dev/xenial/hadoop-namenode"
@@ -34,8 +39,8 @@ services:
gui-x: "1000"
gui-y: "400"
client:
- charm: "cs:xenial/hadoop-client-3"
- constraints: "mem=3G"
+ charm: "cs:xenial/hadoop-client-8"
+ constraints: "mem=7G root-disk=32G"
num_units: 1
annotations:
gui-x: "1250"
@@ -52,20 +57,9 @@ services:
gui-x: "1000"
gui-y: "0"
to:
- - "5"
- zookeeper:
- charm: "cs:~bigdata-dev/xenial/zookeeper"
- constraints: "mem=3G root-disk=32G"
- num_units: 3
- annotations:
- gui-x: "500"
- gui-y: "400"
- to:
- - "6"
- - "7"
- - "8"
+ - "4"
ganglia:
- charm: "cs:~bigdata-dev/xenial/ganglia-5"
+ charm: "cs:xenial/ganglia-12"
num_units: 1
annotations:
gui-x: "0"
@@ -73,7 +67,7 @@ services:
to:
- "4"
ganglia-node:
- charm: "cs:~bigdata-dev/xenial/ganglia-node-7"
+ charm: "cs:xenial/ganglia-node-7"
annotations:
gui-x: "250"
gui-y: "400"
@@ -90,44 +84,37 @@ services:
annotations:
gui-x: "750"
gui-y: "400"
-series: xenial
relations:
- [resourcemanager, namenode]
- [namenode, slave]
- [resourcemanager, slave]
- [plugin, namenode]
- [plugin, resourcemanager]
- - [client, plugin]
- [spark, plugin]
- - [spark, zookeeper]
+ - [client, plugin]
- ["ganglia-node:juju-info", "namenode:juju-info"]
- ["ganglia-node:juju-info", "resourcemanager:juju-info"]
- ["ganglia-node:juju-info", "slave:juju-info"]
- ["ganglia-node:juju-info", "spark:juju-info"]
- - ["ganglia-node:juju-info", "zookeeper:juju-info"]
- ["ganglia:node", "ganglia-node:node"]
- ["rsyslog-forwarder-ha:juju-info", "namenode:juju-info"]
- ["rsyslog-forwarder-ha:juju-info", "resourcemanager:juju-info"]
- ["rsyslog-forwarder-ha:juju-info", "slave:juju-info"]
- ["rsyslog-forwarder-ha:juju-info", "spark:juju-info"]
- - ["rsyslog-forwarder-ha:juju-info", "zookeeper:juju-info"]
- ["rsyslog:aggregator", "rsyslog-forwarder-ha:syslog"]
machines:
"0":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"1":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"2":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"3":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"4":
series: "xenial"
- "5":
- series: "xenial"
- "6":
- series: "xenial"
- "7":
- series: "xenial"
- "8":
- series: "xenial"
+ constraints: "mem=7G root-disk=32G"
diff --git a/bigtop-deploy/juju/hadoop-spark/bundle-local.yaml b/bigtop-deploy/juju/hadoop-spark/bundle-local.yaml
index bffc4592..297779a5 100644
--- a/bigtop-deploy/juju/hadoop-spark/bundle-local.yaml
+++ b/bigtop-deploy/juju/hadoop-spark/bundle-local.yaml
@@ -1,3 +1,8 @@
+series: xenial
+description: >
+ This is a five unit big data cluster that includes Hadoop 2.7.3 and Spark 2.1
+ from Apache Bigtop. Use it to analyse batch data with MapReduce or streaming
+ data with Spark. It will run on 5 machines in your cloud.
services:
namenode:
charm: "/home/ubuntu/charms/xenial/hadoop-namenode"
@@ -34,8 +39,8 @@ services:
gui-x: "1000"
gui-y: "400"
client:
- charm: "cs:xenial/hadoop-client-3"
- constraints: "mem=3G"
+ charm: "cs:xenial/hadoop-client-8"
+ constraints: "mem=7G root-disk=32G"
num_units: 1
annotations:
gui-x: "1250"
@@ -52,20 +57,9 @@ services:
gui-x: "1000"
gui-y: "0"
to:
- - "5"
- zookeeper:
- charm: "/home/ubuntu/charms/xenial/zookeeper"
- constraints: "mem=3G root-disk=32G"
- num_units: 3
- annotations:
- gui-x: "500"
- gui-y: "400"
- to:
- - "6"
- - "7"
- - "8"
+ - "4"
ganglia:
- charm: "cs:~bigdata-dev/xenial/ganglia-5"
+ charm: "cs:xenial/ganglia-12"
num_units: 1
annotations:
gui-x: "0"
@@ -73,7 +67,7 @@ services:
to:
- "4"
ganglia-node:
- charm: "cs:~bigdata-dev/xenial/ganglia-node-7"
+ charm: "cs:xenial/ganglia-node-7"
annotations:
gui-x: "250"
gui-y: "400"
@@ -90,44 +84,37 @@ services:
annotations:
gui-x: "750"
gui-y: "400"
-series: xenial
relations:
- [resourcemanager, namenode]
- [namenode, slave]
- [resourcemanager, slave]
- [plugin, namenode]
- [plugin, resourcemanager]
- - [client, plugin]
- [spark, plugin]
- - [spark, zookeeper]
+ - [client, plugin]
- ["ganglia-node:juju-info", "namenode:juju-info"]
- ["ganglia-node:juju-info", "resourcemanager:juju-info"]
- ["ganglia-node:juju-info", "slave:juju-info"]
- ["ganglia-node:juju-info", "spark:juju-info"]
- - ["ganglia-node:juju-info", "zookeeper:juju-info"]
- ["ganglia:node", "ganglia-node:node"]
- ["rsyslog-forwarder-ha:juju-info", "namenode:juju-info"]
- ["rsyslog-forwarder-ha:juju-info", "resourcemanager:juju-info"]
- ["rsyslog-forwarder-ha:juju-info", "slave:juju-info"]
- ["rsyslog-forwarder-ha:juju-info", "spark:juju-info"]
- - ["rsyslog-forwarder-ha:juju-info", "zookeeper:juju-info"]
- ["rsyslog:aggregator", "rsyslog-forwarder-ha:syslog"]
machines:
"0":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"1":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"2":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"3":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"4":
series: "xenial"
- "5":
- series: "xenial"
- "6":
- series: "xenial"
- "7":
- series: "xenial"
- "8":
- series: "xenial"
+ constraints: "mem=7G root-disk=32G"
diff --git a/bigtop-deploy/juju/hadoop-spark/bundle.yaml b/bigtop-deploy/juju/hadoop-spark/bundle.yaml
index cfbdd8b6..d26b6aef 100644
--- a/bigtop-deploy/juju/hadoop-spark/bundle.yaml
+++ b/bigtop-deploy/juju/hadoop-spark/bundle.yaml
@@ -1,6 +1,11 @@
+series: xenial
+description: >
+ This is a five unit big data cluster that includes Hadoop 2.7.3 and Spark 2.1
+ from Apache Bigtop. Use it to analyse batch data with MapReduce or streaming
+ data with Spark. It will run on 5 machines in your cloud.
services:
namenode:
- charm: "cs:xenial/hadoop-namenode-12"
+ charm: "cs:xenial/hadoop-namenode-24"
constraints: "mem=7G root-disk=32G"
num_units: 1
annotations:
@@ -9,7 +14,7 @@ services:
to:
- "0"
resourcemanager:
- charm: "cs:xenial/hadoop-resourcemanager-13"
+ charm: "cs:xenial/hadoop-resourcemanager-26"
constraints: "mem=7G root-disk=32G"
num_units: 1
annotations:
@@ -18,7 +23,7 @@ services:
to:
- "0"
slave:
- charm: "cs:xenial/hadoop-slave-12"
+ charm: "cs:xenial/hadoop-slave-25"
constraints: "mem=7G root-disk=32G"
num_units: 3
annotations:
@@ -29,13 +34,13 @@ services:
- "2"
- "3"
plugin:
- charm: "cs:xenial/hadoop-plugin-12"
+ charm: "cs:xenial/hadoop-plugin-24"
annotations:
gui-x: "1000"
gui-y: "400"
client:
- charm: "cs:xenial/hadoop-client-3"
- constraints: "mem=3G"
+ charm: "cs:xenial/hadoop-client-8"
+ constraints: "mem=7G root-disk=32G"
num_units: 1
annotations:
gui-x: "1250"
@@ -43,7 +48,7 @@ services:
to:
- "4"
spark:
- charm: "cs:xenial/spark-24"
+ charm: "cs:xenial/spark-49"
constraints: "mem=7G root-disk=32G"
num_units: 1
options:
@@ -52,20 +57,9 @@ services:
gui-x: "1000"
gui-y: "0"
to:
- - "5"
- zookeeper:
- charm: "cs:xenial/zookeeper-16"
- constraints: "mem=3G root-disk=32G"
- num_units: 3
- annotations:
- gui-x: "500"
- gui-y: "400"
- to:
- - "6"
- - "7"
- - "8"
+ - "4"
ganglia:
- charm: "cs:~bigdata-dev/xenial/ganglia-5"
+ charm: "cs:xenial/ganglia-12"
num_units: 1
annotations:
gui-x: "0"
@@ -73,7 +67,7 @@ services:
to:
- "4"
ganglia-node:
- charm: "cs:~bigdata-dev/xenial/ganglia-node-7"
+ charm: "cs:xenial/ganglia-node-7"
annotations:
gui-x: "250"
gui-y: "400"
@@ -90,44 +84,37 @@ services:
annotations:
gui-x: "750"
gui-y: "400"
-series: xenial
relations:
- [resourcemanager, namenode]
- [namenode, slave]
- [resourcemanager, slave]
- [plugin, namenode]
- [plugin, resourcemanager]
- - [client, plugin]
- [spark, plugin]
- - [spark, zookeeper]
+ - [client, plugin]
- ["ganglia-node:juju-info", "namenode:juju-info"]
- ["ganglia-node:juju-info", "resourcemanager:juju-info"]
- ["ganglia-node:juju-info", "slave:juju-info"]
- ["ganglia-node:juju-info", "spark:juju-info"]
- - ["ganglia-node:juju-info", "zookeeper:juju-info"]
- ["ganglia:node", "ganglia-node:node"]
- ["rsyslog-forwarder-ha:juju-info", "namenode:juju-info"]
- ["rsyslog-forwarder-ha:juju-info", "resourcemanager:juju-info"]
- ["rsyslog-forwarder-ha:juju-info", "slave:juju-info"]
- ["rsyslog-forwarder-ha:juju-info", "spark:juju-info"]
- - ["rsyslog-forwarder-ha:juju-info", "zookeeper:juju-info"]
- ["rsyslog:aggregator", "rsyslog-forwarder-ha:syslog"]
machines:
"0":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"1":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"2":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"3":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"4":
series: "xenial"
- "5":
- series: "xenial"
- "6":
- series: "xenial"
- "7":
- series: "xenial"
- "8":
- series: "xenial"
+ constraints: "mem=7G root-disk=32G"
diff --git a/bigtop-deploy/juju/hadoop-spark/tests/01-bundle.py b/bigtop-deploy/juju/hadoop-spark/tests/01-bundle.py
index 1dc41475..1e9794fd 100755
--- a/bigtop-deploy/juju/hadoop-spark/tests/01-bundle.py
+++ b/bigtop-deploy/juju/hadoop-spark/tests/01-bundle.py
@@ -27,8 +27,6 @@ class TestBundle(unittest.TestCase):
@classmethod
def setUpClass(cls):
- # classmethod inheritance doesn't work quite right with
- # setUpClass / tearDownClass, so subclasses have to manually call this
cls.d = amulet.Deployment(series='xenial')
with open(cls.bundle_file) as f:
bun = f.read()
@@ -55,7 +53,6 @@ class TestBundle(unittest.TestCase):
'resourcemanager': re.compile('ready'),
'slave': re.compile('ready'),
'spark': re.compile('ready'),
- 'zookeeper': re.compile('ready'),
}, timeout=3600)
cls.hdfs = cls.d.sentry['namenode'][0]
cls.yarn = cls.d.sentry['resourcemanager'][0]
@@ -88,7 +85,9 @@ class TestBundle(unittest.TestCase):
assert 'DataNode' not in yarn, "DataNode should not be running on resourcemanager"
assert 'DataNode' not in hdfs, "DataNode should not be running on namenode"
- assert 'Master' in spark, "Spark Master not started"
+ assert 'HistoryServer' in spark, "Spark HistoryServer not started"
+ assert 'Master' not in spark, "Spark Master should not be running in yarn mode"
+ assert 'Worker' not in spark, "Spark Worker should not be running in yarn mode"
def test_hdfs(self):
"""
diff --git a/bigtop-deploy/juju/hadoop-spark/tests/tests.yaml b/bigtop-deploy/juju/hadoop-spark/tests/tests.yaml
index a3b7803f..cb745df7 100644
--- a/bigtop-deploy/juju/hadoop-spark/tests/tests.yaml
+++ b/bigtop-deploy/juju/hadoop-spark/tests/tests.yaml
@@ -1,13 +1,19 @@
reset: false
-bundle_deploy: false
+deployment_timeout: 3600
sources:
- 'ppa:juju/stable'
packages:
- amulet
- python3-yaml
-# exclude tests that are unrelated to bigtop.
+# exclude tests that are unrelated to bigtop. the exclusion of spark might
+# look weird here, but for this bundle, we only care that spark is good in
+# yarn mode (covered by this bundle when we invoke the spark smoke-test). the
+# typical spark tests will test spark once in standalone and twice more in
+# various HA modes. that takes forever, so leave those heavy tests for the
+# spark-processing bundle. let's go fast on this one.
excludes:
- ganglia
- ganglia-node
- rsyslog
- rsyslog-forwarder-ha
+ - spark
diff --git a/bigtop-deploy/juju/spark-processing/README.md b/bigtop-deploy/juju/spark-processing/README.md
index c39fa2c8..a499a384 100644
--- a/bigtop-deploy/juju/spark-processing/README.md
+++ b/bigtop-deploy/juju/spark-processing/README.md
@@ -16,12 +16,14 @@
-->
# Overview
-This bundle provides a complete deployment of
-[Apache Spark][] in standalone HA mode as provided
-by [Apache Bigtop][]. Ganglia and rsyslog
+Apache Spark is a fast and general engine for large-scale data processing.
+Learn more at [spark.apache.org][].
+
+This bundle provides a complete deployment of Spark (in standalone HA mode)
+and Apache Zookeeper components from [Apache Bigtop][]. Ganglia and rsyslog
applications are included to monitor cluster health and syslog activity.
-[Apache Spark]: http://spark/apache.org/
+[spark.apache.org]: http://spark.apache.org/
[Apache Bigtop]: http://bigtop.apache.org/
## Bundle Composition
@@ -29,9 +31,9 @@ applications are included to monitor cluster health and syslog activity.
The applications that comprise this bundle are spread across 6 units as
follows:
- * Spark (Master and Worker)
+ * Spark (Master and Worker) v2.1.0
* 2 separate units
- * Zookeeper
+ * Zookeeper v3.4.6
* 3 separate units
* Ganglia (Web interface for monitoring cluster metrics)
* Rsyslog (Aggregate cluster syslog events in a single location)
@@ -44,9 +46,8 @@ demands.
# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the [getting-started][] instructions prior to deploying this
-bundle.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this bundle.
> **Note**: This bundle requires hardware resources that may exceed limits
of Free-tier or Trial accounts on some clouds. To deploy to these
@@ -58,18 +59,10 @@ Deploy this bundle from the Juju charm store with the `juju deploy` command:
juju deploy spark-processing
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-spark-processing`.
-
Alternatively, deploy a locally modified `bundle.yaml` with:
juju deploy /path/to/bundle.yaml
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-/path/to/bundle.yaml`.
-
The charms in this bundle can also be built from their source layers in the
[Bigtop charm repository][]. See the [Bigtop charm README][] for instructions
on building and deploying these charms locally.
@@ -81,7 +74,6 @@ mirror options. See [Configuring Models][] for more information.
[getting-started]: https://jujucharms.com/docs/stable/getting-started
[bundle.yaml]: https://github.com/apache/bigtop/blob/master/bigtop-deploy/juju/spark-processing/bundle.yaml
-[juju-quickstart]: https://launchpad.net/juju-quickstart
[Bigtop charm repository]: https://github.com/apache/bigtop/tree/master/bigtop-packages/src/charm
[Bigtop charm README]: https://github.com/apache/bigtop/blob/master/bigtop-packages/src/charm/README.md
[Configuring Models]: https://jujucharms.com/docs/stable/models-config
@@ -112,25 +104,16 @@ actions as follows:
juju run-action spark/0 smoke-test
juju run-action zookeeper/0 smoke-test
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do <application>/0 smoke-test`.
-
Watch the progress of the smoke test actions with:
watch -n 2 juju show-action-status
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
-
Eventually, all of the actions should settle to `status: completed`. If
any report `status: failed`, that application is not working as expected. Get
more information about the smoke-test action
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
-
## Utilities
Applications in this bundle include Zookeeper command line and Spark web
utilities that can be used to verify information about the cluster.
@@ -181,27 +164,17 @@ the [rsyslog README](https://jujucharms.com/rsyslog/) for more information.
# Benchmarking
-The `spark` charm in this bundle provides several benchmarks to gauge
-the performance of the Spark cluster. Each benchmark is an action that can be
-run with `juju run-action`:
-
- $ juju actions spark | grep Bench
- connectedcomponent Run the Spark Bench ConnectedComponent benchmark.
- decisiontree Run the Spark Bench DecisionTree benchmark.
- kmeans Run the Spark Bench KMeans benchmark.
- linearregression Run the Spark Bench LinearRegression benchmark.
- logisticregression Run the Spark Bench LogisticRegression benchmark.
- matrixfactorization Run the Spark Bench MatrixFactorization benchmark.
- pagerank Run the Spark Bench PageRank benchmark.
- pca Run the Spark Bench PCA benchmark.
- pregeloperation Run the Spark Bench PregelOperation benchmark.
- shortestpaths Run the Spark Bench ShortestPaths benchmark.
- sql Run the Spark Bench SQL benchmark.
- stronglyconnectedcomponent Run the Spark Bench StronglyConnectedComponent benchmark.
- svdplusplus Run the Spark Bench SVDPlusPlus benchmark.
- svm Run the Spark Bench SVM benchmark.
-
- $ juju run-action spark/0 svdplusplus
+The `spark` charm in this bundle provides benchmarks to gauge the performance
+of the Spark cluster. Each benchmark is an action that can be run with
+`juju run-action`:
+
+ $ juju actions spark
+ ...
+ pagerank Calculate PageRank for a sample data set
+ sparkpi Calculate Pi
+ ...
+
+ $ juju run-action spark/0 pagerank
Action queued with id: 339cec1f-e903-4ee7-85ca-876fb0c3d28e
$ juju show-action-output 339cec1f-e903-4ee7-85ca-876fb0c3d28e
@@ -210,25 +183,15 @@ run with `juju run-action`:
composite:
direction: asc
units: secs
- value: "200.754000"
- raw: |
- SVDPlusPlus,2016-11-02-03:08:26,200.754000,85.974071,.428255,0,SVDPlusPlus-MLlibConfig,,,,,10,,,50000,4.0,1.3,
- start: 2016-11-02T03:08:26Z
- stop: 2016-11-02T03:11:47Z
- results:
- duration:
- direction: asc
- units: secs
- value: "200.754000"
- throughput:
- direction: desc
- units: x/sec
- value: ".428255"
+ value: "83"
+ start: 2017-04-12T23:22:38Z
+ stop: 2017-04-12T23:24:01Z
+ output: '{''status'': ''completed''}'
status: completed
timing:
- completed: 2016-11-02 03:11:48 +0000 UTC
- enqueued: 2016-11-02 03:08:21 +0000 UTC
- started: 2016-11-02 03:08:26 +0000 UTC
+ completed: 2017-04-12 23:24:02 +0000 UTC
+ enqueued: 2017-04-12 23:22:36 +0000 UTC
+ started: 2017-04-12 23:22:37 +0000 UTC
# Scaling
@@ -244,6 +207,18 @@ Multiple units may be added at once. For example, add four more spark units:
juju add-unit -n4 spark
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this bundle at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
+
+Ensure `Bigtop` is selected as the project. Typically, bundle issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
+
+
# Contact Information
- <bigdata@lists.ubuntu.com>
@@ -254,6 +229,6 @@ Multiple units may be added at once. For example, add four more spark units:
- [Apache Bigtop home page](http://bigtop.apache.org/)
- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-deploy/juju/spark-processing/bundle-dev.yaml b/bigtop-deploy/juju/spark-processing/bundle-dev.yaml
index af762140..4ace0daf 100644
--- a/bigtop-deploy/juju/spark-processing/bundle-dev.yaml
+++ b/bigtop-deploy/juju/spark-processing/bundle-dev.yaml
@@ -21,7 +21,7 @@ services:
- "3"
- "4"
ganglia:
- charm: "cs:~bigdata-dev/xenial/ganglia-5"
+ charm: "cs:xenial/ganglia-12"
num_units: 1
annotations:
gui-x: "0"
@@ -29,7 +29,7 @@ services:
to:
- "5"
ganglia-node:
- charm: "cs:~bigdata-dev/xenial/ganglia-node-7"
+ charm: "cs:xenial/ganglia-node-7"
annotations:
gui-x: "250"
gui-y: "400"
@@ -58,13 +58,19 @@ relations:
machines:
"0":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"1":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"2":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"3":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"4":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"5":
series: "xenial"
+ constraints: "mem=3G"
diff --git a/bigtop-deploy/juju/spark-processing/bundle-local.yaml b/bigtop-deploy/juju/spark-processing/bundle-local.yaml
index 63cdc6f5..95a28f0e 100644
--- a/bigtop-deploy/juju/spark-processing/bundle-local.yaml
+++ b/bigtop-deploy/juju/spark-processing/bundle-local.yaml
@@ -21,7 +21,7 @@ services:
- "3"
- "4"
ganglia:
- charm: "cs:~bigdata-dev/xenial/ganglia-5"
+ charm: "cs:xenial/ganglia-12"
num_units: 1
annotations:
gui-x: "0"
@@ -29,7 +29,7 @@ services:
to:
- "5"
ganglia-node:
- charm: "cs:~bigdata-dev/xenial/ganglia-node-7"
+ charm: "cs:xenial/ganglia-node-7"
annotations:
gui-x: "250"
gui-y: "400"
@@ -58,13 +58,19 @@ relations:
machines:
"0":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"1":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"2":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"3":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"4":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"5":
series: "xenial"
+ constraints: "mem=3G"
diff --git a/bigtop-deploy/juju/spark-processing/bundle.yaml b/bigtop-deploy/juju/spark-processing/bundle.yaml
index 70ef4cf1..c2ba92ae 100644
--- a/bigtop-deploy/juju/spark-processing/bundle.yaml
+++ b/bigtop-deploy/juju/spark-processing/bundle.yaml
@@ -1,8 +1,11 @@
services:
spark:
- charm: "cs:xenial/spark-24"
+ charm: "cs:xenial/spark-49"
constraints: "mem=7G root-disk=32G"
num_units: 2
+ options:
+ driver_memory: "3g"
+ executor_memory: "3g"
annotations:
gui-x: "500"
gui-y: "0"
@@ -10,7 +13,7 @@ services:
- "0"
- "1"
zookeeper:
- charm: "cs:xenial/zookeeper-16"
+ charm: "cs:xenial/zookeeper-30"
constraints: "mem=3G root-disk=32G"
num_units: 3
annotations:
@@ -21,7 +24,7 @@ services:
- "3"
- "4"
ganglia:
- charm: "cs:~bigdata-dev/xenial/ganglia-5"
+ charm: "cs:xenial/ganglia-12"
num_units: 1
annotations:
gui-x: "0"
@@ -29,7 +32,7 @@ services:
to:
- "5"
ganglia-node:
- charm: "cs:~bigdata-dev/xenial/ganglia-node-7"
+ charm: "cs:xenial/ganglia-node-7"
annotations:
gui-x: "250"
gui-y: "400"
@@ -58,13 +61,19 @@ relations:
machines:
"0":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"1":
series: "xenial"
+ constraints: "mem=7G root-disk=32G"
"2":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"3":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"4":
series: "xenial"
+ constraints: "mem=3G root-disk=32G"
"5":
series: "xenial"
+ constraints: "mem=3G"
diff --git a/bigtop-deploy/juju/spark-processing/tests/tests.yaml b/bigtop-deploy/juju/spark-processing/tests/tests.yaml
index 8a28f2bd..b9517421 100644
--- a/bigtop-deploy/juju/spark-processing/tests/tests.yaml
+++ b/bigtop-deploy/juju/spark-processing/tests/tests.yaml
@@ -1,19 +1,13 @@
reset: false
-bundle_deploy: false
+deployment_timeout: 3600
sources:
- 'ppa:juju/stable'
packages:
- amulet
- python3-yaml
-# exclude tests that are unrelated to bigtop. the exclusion of spark might
-# look weird here, but for this bundle, we only care that spark is good in
-# HA mode (covered by this bundle when we invoke the spark smoke-test). the
-# typical spark tests will test spark once in standalone and twice more in
-# various HA modes. that takes forever, so leave those heavy tests for the
-# hadoop-spark bundle. let's go fast on this one.
+# exclude tests that are unrelated to bigtop.
excludes:
- ganglia
- ganglia-node
- rsyslog
- rsyslog-forwarder-ha
- - spark
diff --git a/bigtop-deploy/puppet/README.md b/bigtop-deploy/puppet/README.md
index a2f7fb1e..ddb79a50 100644
--- a/bigtop-deploy/puppet/README.md
+++ b/bigtop-deploy/puppet/README.md
@@ -136,7 +136,6 @@ hadoop_cluster_node::cluster_components:
- spark
- yarn
- zookeeper
-bigtop::jdk_package_name: "openjdk-7-jre-headless"
bigtop::bigtop_repo_uri: "http://bigtop-repos.s3.amazonaws.com/releases/1.2.0/ubuntu/16.04/x86_64"
```
diff --git a/bigtop-deploy/puppet/hieradata/bigtop/cluster.yaml b/bigtop-deploy/puppet/hieradata/bigtop/cluster.yaml
index d116763d..6ff39cc9 100644
--- a/bigtop-deploy/puppet/hieradata/bigtop/cluster.yaml
+++ b/bigtop-deploy/puppet/hieradata/bigtop/cluster.yaml
@@ -55,9 +55,8 @@
#bigtop::bigtop_repo_uri: "http://mirror.example.com/path/to/mirror/"
# Use a pre-installed java environment. The default value of 'false' will cause
-# the configured 'bigtop::jdk_package_name' package to be installed. Setting
-# this to 'true' will ignore the configured 'bigtop::jdk_package_name' but
-# requires a compatible java environment be avaialble prior to Bigtop
+# the default jdk by bigtop to be installed.
+# this to 'true' requires a compatible java environment be avaialble prior to Bigtop
# installation.
#bigtop::jdk_preinstalled: false
diff --git a/bigtop-deploy/puppet/hieradata/site.yaml b/bigtop-deploy/puppet/hieradata/site.yaml
index f18aa9c7..d1e74a98 100644
--- a/bigtop-deploy/puppet/hieradata/site.yaml
+++ b/bigtop-deploy/puppet/hieradata/site.yaml
@@ -13,11 +13,13 @@ hadoop::hadoop_storage_dirs:
#hadoop_cluster_node::cluster_components:
# - alluxio
+# - ambari
# - apex
# - crunch
# - flink
# - flume
# - giraph
+# - gpdb
# - ignite_hadoop
# - hbase
# - hcat
@@ -31,16 +33,18 @@ hadoop::hadoop_storage_dirs:
# - qfs
# - solrcloud
# - spark
+# - spark-standalone
# - sqoop
# - sqoop2
# - tez
# - yarn
-# - zookeeper
# - ycsb
-# - gpdb
-# - ambari
+# - zookeeper
#bigtop::roles_enabled: false
-#bigtop::jdk_package_name: "openjdk-7-jre-headless"
-#bigtop::bigtop_repo_uri: "http://mirror.example.com/path/to/mirror/"
+## You can specify one (or more) repositories. It is convenient if
+## you provide hotfix repo separately from the stable release, etc.
+#bigtop::bigtop_repo_uri:
+# - "http://mirror1.example.com/path/to/mirror/"
+# - "http://mirror2.example.com/path/to/mirror/"
diff --git a/bigtop-deploy/puppet/manifests/bigtop_repo.pp b/bigtop-deploy/puppet/manifests/bigtop_repo.pp
new file mode 100644
index 00000000..ed22f819
--- /dev/null
+++ b/bigtop-deploy/puppet/manifests/bigtop_repo.pp
@@ -0,0 +1,70 @@
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+class bigtop_repo {
+ case $::operatingsystem {
+ /(OracleLinux|Amazon|CentOS|Fedora|RedHat)/: {
+ $default_repo = "http://bigtop-repos.s3.amazonaws.com/releases/1.2.0/centos/7/x86_64"
+ $baseurls_array = any2array(hiera("bigtop::bigtop_repo_uri", $default_repo))
+ each ($baseurls_array) |$count, $baseurl| {
+ yumrepo { "Bigtop_$count":
+ baseurl => $baseurl,
+ descr => "Bigtop packages",
+ enabled => 1,
+ gpgcheck => 0,
+ }
+ Yumrepo<||> -> Package<||>
+ }
+ }
+
+ /(Ubuntu|Debian)/: {
+ include stdlib
+ include apt
+
+ $lower_os = downcase($operatingsystem)
+ # We use code name such as trusty for Ubuntu instead of release version in bigtop's binary convenience repos
+ if ($operatingsystem == "Ubuntu") { $release = $lsbdistcodename } else { $release = $operatingsystemmajrelease }
+ $default_repo = "http://bigtop-repos.s3.amazonaws.com/releases/1.2.0/${lower_os}/${release}/x86_64"
+ $baseurls_array = any2array(hiera("bigtop::bigtop_repo_uri", $default_repo))
+
+ # I couldn't enforce the sequence -> anymore because of this
+ # https://twitter.com/c0sin/status/875869783979196416
+ apt::conf { "disable_keys":
+ content => "APT::Get::AllowUnauthenticated 1;",
+ ensure => present
+ }
+ each ($baseurls_array) |$count, $baseurl| {
+ notify {"Baseurl: $baseurl" :}
+ apt::source { "Bigtop_$count":
+ location => $baseurl,
+ release => "bigtop",
+ repos => "contrib",
+ # BIGTOP-2796. Give Bigtop repo higher priority to solve zookeeper package conflict probem on Ubuntu
+ pin => "900",
+ ensure => present,
+ }
+ }
+ # It seems that calling update explicitely isn't needed because as far I can see
+ # it is getting called automatically. Perhaps this was needed for older versions?
+ exec {'bigtop-apt-update':
+ command => '/usr/bin/apt-get update'
+ }
+ Apt::Source<||> -> Exec['bigtop-apt-update'] -> Package<||>
+ }
+ default: {
+ notify{"WARNING: running on a neither yum nor apt platform -- make sure Bigtop repo is setup": }
+ }
+ }
+}
diff --git a/bigtop-deploy/puppet/manifests/cluster.pp b/bigtop-deploy/puppet/manifests/cluster.pp
index 83bb7b24..7579606c 100644
--- a/bigtop-deploy/puppet/manifests/cluster.pp
+++ b/bigtop-deploy/puppet/manifests/cluster.pp
@@ -69,6 +69,11 @@ $roles_map = {
worker => ["solr-server"],
},
spark => {
+ worker => ["spark-on-yarn"],
+ client => ["spark-client"],
+ library => ["spark-yarn-slave"],
+ },
+ spark-standalone => {
master => ["spark-master"],
worker => ["spark-worker"],
},
@@ -223,7 +228,7 @@ class node_with_roles ($roles = hiera("bigtop::roles")) inherits hadoop_cluster_
"ambari",
]
- deploy_module { $modules:
+ node_with_roles::deploy_module { $modules:
roles => $roles,
}
}
@@ -278,4 +283,6 @@ class node_with_components inherits hadoop_cluster_node {
class { 'node_with_roles':
roles => $roles,
}
+
+ notice("Roles to deploy: ${roles}")
}
diff --git a/bigtop-deploy/puppet/manifests/jdk.pp b/bigtop-deploy/puppet/manifests/jdk.pp
new file mode 100644
index 00000000..152e8a41
--- /dev/null
+++ b/bigtop-deploy/puppet/manifests/jdk.pp
@@ -0,0 +1,72 @@
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+class jdk {
+ case $::operatingsystem {
+ /Debian/: {
+ require apt
+ unless $operatingsystemmajrelease > "8" {
+ # we pin openjdk-8-* and ca-certificates-java to backports
+ require apt::backports
+
+ Exec['bigtop-apt-update'] ->
+ apt::pin { 'backports_jdk':
+ packages => 'openjdk-8-*',
+ priority => 500,
+ release => 'jessie-backports',
+ } ->
+ apt::pin { 'backports_ca':
+ packages => 'ca-certificates-java',
+ priority => 500,
+ release => 'jessie-backports',
+ } ->
+ exec {'own_update':
+ command => '/usr/bin/apt-get update'
+ } -> Package['jdk']
+ }
+ package { 'jdk':
+ name => 'openjdk-8-jdk',
+ ensure => present,
+ }
+
+ }
+ /Ubuntu/: {
+ include apt
+
+ package { 'jdk':
+ name => 'openjdk-8-jdk',
+ ensure => present,
+ }
+ }
+ /(CentOS|Amazon|Fedora)/: {
+ package { 'jdk':
+ name => 'java-1.8.0-openjdk-devel',
+ ensure => present
+ }
+ if ($::operatingsystem == "Fedora") {
+ file { '/usr/lib/jvm/java-1.8.0-openjdk/jre/lib/security/cacerts':
+ ensure => 'link',
+ target => '/etc/pki/java/cacerts'
+ }
+ }
+ }
+ /OpenSuSE/: {
+ package { 'jdk':
+ name => 'java-1_8_0-openjdk-devel',
+ ensure => present
+ }
+ }
+ }
+}
diff --git a/bigtop-deploy/puppet/manifests/site.pp b/bigtop-deploy/puppet/manifests/site.pp
index f35a4e0f..cd6e8d5a 100644
--- a/bigtop-deploy/puppet/manifests/site.pp
+++ b/bigtop-deploy/puppet/manifests/site.pp
@@ -13,84 +13,18 @@
# See the License for the specific language governing permissions and
# limitations under the License.
-# Prepare default repo by detecting the environment automatically
-case $operatingsystem {
- # Use CentOS 7 repo for other CentOS compatible OSs
- /(OracleLinux|Amazon|RedHat)/: {
- $default_repo = "http://bigtop-repos.s3.amazonaws.com/releases/1.0.0/centos/7/x86_64"
- }
- # Detect env to pick up default repo for other Bigtop supported OSs
- default: {
- $lower_os = downcase($operatingsystem)
- # We use code name such as trusty for Ubuntu instead of release version in bigtop's binary convenience repos
- if ($operatingsystem == "Ubuntu") { $release = $lsbdistcodename } else { $release = $operatingsystemmajrelease }
- $default_repo = "http://bigtop-repos.s3.amazonaws.com/releases/1.0.0/${lower_os}/${release}/x86_64"
- }
-}
-
$jdk_preinstalled = hiera("bigtop::jdk_preinstalled", false)
-$jdk_package_name = hiera("bigtop::jdk_package_name", "jdk")
+if ( ! $jdk_preinstalled ) {
+ require jdk
+ Class['jdk'] -> Service<||>
+}
$provision_repo = hiera("bigtop::provision_repo", true)
-
-stage {"pre": before => Stage["main"]}
-
if ($provision_repo) {
- case $::operatingsystem {
- /(OracleLinux|Amazon|CentOS|Fedora|RedHat)/: {
- yumrepo { "Bigtop":
- baseurl => hiera("bigtop::bigtop_repo_uri", $default_repo),
- descr => "Bigtop packages",
- enabled => 1,
- gpgcheck => 0,
- }
- Yumrepo<||> -> Package<||>
- }
- /(Ubuntu|Debian)/: {
- include apt
- apt::conf { "disable_keys":
- content => "APT::Get::AllowUnauthenticated 1;",
- ensure => present
- }
- apt::source { "Bigtop":
- location => hiera("bigtop::bigtop_repo_uri", $default_repo),
- release => "bigtop",
- repos => "contrib",
- ensure => present,
- }
- Apt::Source<||> -> Exec['apt_update'] -> Package<||>
- }
- default: {
- notify{"WARNING: running on a neither yum nor apt platform -- make sure Bigtop repo is setup": }
- }
- }
-}
-
-case $::operatingsystem {
- /Debian/: {
- require apt
- class { 'apt::backports':
- pin => 500,
- }
- Class['apt::backports'] -> Package <||>
-
- package { "jdk":
- name => $jdk_package_name,
- ensure => present,
- }
- }
- default: {
- package { "jdk":
- name => $jdk_package_name,
- ensure => "installed",
- alias => "jdk",
- noop => $jdk_preinstalled,
- }
- }
+ require bigtop_repo
}
node default {
-
$roles_enabled = hiera("bigtop::roles_enabled", false)
if (!is_bool($roles_enabled)) {
diff --git a/bigtop-deploy/puppet/modules/flink/manifests/init.pp b/bigtop-deploy/puppet/modules/flink/manifests/init.pp
index 221d62dd..e31d1828 100644
--- a/bigtop-deploy/puppet/modules/flink/manifests/init.pp
+++ b/bigtop-deploy/puppet/modules/flink/manifests/init.pp
@@ -37,23 +37,29 @@ class flink {
class jobmanager {
include flink::common
+ package { "flink-jobmanager":
+ ensure => latest,
+ }
+
service { "flink-jobmanager":
ensure => running,
- require => Package["flink"],
+ require => Package["flink-jobmanager"],
subscribe => File["/etc/flink/conf/flink-conf.yaml"],
hasrestart => true,
hasstatus => true
-
}
-
}
class taskmanager {
include flink::common
+ package { "flink-taskmanager":
+ ensure => latest,
+ }
+
service { "flink-taskmanager":
ensure => running,
- require => Package["flink"],
+ require => Package["flink-taskmanager"],
subscribe => File["/etc/flink/conf/flink-conf.yaml"],
hasrestart => true,
hasstatus => true,
diff --git a/bigtop-deploy/puppet/modules/ignite_hadoop/templates/default-config.xml b/bigtop-deploy/puppet/modules/ignite_hadoop/templates/default-config.xml
index bfaee60e..9d8fc1e0 100644
--- a/bigtop-deploy/puppet/modules/ignite_hadoop/templates/default-config.xml
+++ b/bigtop-deploy/puppet/modules/ignite_hadoop/templates/default-config.xml
@@ -117,20 +117,23 @@
<property name="host" value="0.0.0.0" />
<property name="port" value="10500" />
</bean>
- </property>
-
- <!-- Sample secondary file system configuration.
- 'uri' - the URI of the secondary file system.
- 'cfgPath' - optional configuration path of the secondary file system,
- e.g. /opt/foo/core-site.xml. Typically left to be null.
- 'userName' - optional user name to access the secondary file system on behalf of. Use it
- if Hadoop client and the Ignite node are running on behalf of different users.
- -->
+ </property>
<property name="secondaryFileSystem">
<bean class="org.apache.ignite.hadoop.fs.IgniteHadoopIgfsSecondaryFileSystem">
- <constructor-arg name="uri" value='hdfs://<%= @hadoop_head_node %>:<%= @hadoop_namenode_port %>'/>
- <constructor-arg name="cfgPath"><null/></constructor-arg>
- <constructor-arg name="userName" value="ignite"/>
+ <property name="fileSystemFactory">
+ <bean class="org.apache.ignite.hadoop.fs.CachingHadoopFileSystemFactory">
+ <!-- ATTN: The trailing slash in the url is very important work around for a bug
+ in the Ignite's URL parsing logic. It might get fixed in Ignite 2.1, though
+ See https://is.gd/8c2LQY for more info -->
+ <property name="uri" value='hdfs://<%= @hadoop_head_node %>:<%= @hadoop_namenode_port %>/'/>
+ <property name="configPaths">
+ <list>
+ <value>/etc/hadoop/conf/core-site.xml</value>
+ </list>
+ </property>
+ </bean>
+ </property>
+ <property name="defaultUserName" value="ignite"/>
</bean>
</property>
</bean>
diff --git a/bigtop-deploy/puppet/modules/kerberos/manifests/init.pp b/bigtop-deploy/puppet/modules/kerberos/manifests/init.pp
index 946f4258..c6480f81 100644
--- a/bigtop-deploy/puppet/modules/kerberos/manifests/init.pp
+++ b/bigtop-deploy/puppet/modules/kerberos/manifests/init.pp
@@ -121,20 +121,23 @@ class kerberos {
class admin_server inherits kerberos::kdc {
- $se_hack = "setsebool -P kadmind_disable_trans 1 ; setsebool -P krb5kdc_disable_trans 1"
package { "$package_name_admin":
ensure => installed,
require => Package["$package_name_kdc"],
- }
-
+ }
+
+ exec { '/usr/bin/setsebool -P kadmind_disable_trans 1':
+ onlyif => '/usr/bin/test -f /usr/bin/setsebook'
+ } ->
+ exec { '/usr/bin/setsebool -P krb5kdc_disable_trans 1':
+ onlyif => '/usr/bin/test -f /usr/bin/setsebook'
+ } ->
service { "$service_name_admin":
ensure => running,
require => [Package["$package_name_admin"], Service["$service_name_kdc"]],
subscribe => [File["${kdc_etc_path}/kadm5.acl"], File["${kdc_etc_path}/kdc.conf"]],
hasrestart => true,
- restart => "${se_hack} ; service ${service_name_admin} restart",
- start => "${se_hack} ; service ${service_name_admin} start",
}
}
}
diff --git a/bigtop-deploy/puppet/modules/spark/manifests/init.pp b/bigtop-deploy/puppet/modules/spark/manifests/init.pp
index 1b2ff6bc..6fe23dc1 100644
--- a/bigtop-deploy/puppet/modules/spark/manifests/init.pp
+++ b/bigtop-deploy/puppet/modules/spark/manifests/init.pp
@@ -135,7 +135,7 @@ class spark {
}
class common(
- $master_url = 'yarn',
+ $master_url = undef,
$master_host = $fqdn,
$zookeeper_connection_string = undef,
$master_port = 7077,
@@ -146,16 +146,18 @@ class spark {
$use_yarn_shuffle_service = false,
$event_log_dir = "hdfs:///var/log/spark/apps",
$history_log_dir = "hdfs:///var/log/spark/apps",
+ $extra_lib_dirs = "/usr/lib/hadoop/lib/native",
+ $driver_mem = "1g",
+ $executor_mem = "1g",
) {
- package { 'spark-core':
- ensure => latest,
- }
### This is an ungodly hack to deal with the consequence of adding
### unconditional hive-support into Spark
### The addition is tracked by BIGTOP-2154
### The real fix will come in BIGTOP-2268
- package { 'spark-datanucleus':
+ include spark::datanucleus
+
+ package { 'spark-core':
ensure => latest,
}
diff --git a/bigtop-deploy/puppet/modules/spark/templates/spark-defaults.conf b/bigtop-deploy/puppet/modules/spark/templates/spark-defaults.conf
index 5978becc..2ef4a041 100644
--- a/bigtop-deploy/puppet/modules/spark/templates/spark-defaults.conf
+++ b/bigtop-deploy/puppet/modules/spark/templates/spark-defaults.conf
@@ -13,7 +13,15 @@
# See the License for the specific language governing permissions and
# limitations under the License.
+<% if @master_url -%>
spark.master <%= @master_url %>
+<% else -%>
+<% if (scope['deploy::roles'] & ['spark-master', 'spark-worker']) != [] -%>
+spark.master spark://<%= @master_host %>:<%= @master_port %>
+<% else -%>
+spark.master yarn
+<% end -%>
+<% end -%>
spark.eventLog.enabled true
spark.eventLog.dir <%= @event_log_dir %>
spark.history.fs.logDirectory <%= @history_log_dir %>
@@ -22,4 +30,9 @@ spark.yarn.historyServer.address <%= @master_host %>:<%= @history_ui_port %>
<% end -%>
spark.history.ui.port <%= @history_ui_port %>
spark.shuffle.service.enabled <%= @use_yarn_shuffle_service %>
-spark.driver.extraJavaOptions -Djava.library.path=/usr/lib/hadoop/lib/native
+<% if @extra_lib_dirs -%>
+spark.driver.extraLibraryPath <%= @extra_lib_dirs %>
+spark.executor.extraLibraryPath <%= @extra_lib_dirs %>
+<% end -%>
+spark.driver.memory <%= @driver_mem %>
+spark.executor.memory <%= @executor_mem %>
diff --git a/bigtop-deploy/puppet/modules/spark/templates/spark-env.sh b/bigtop-deploy/puppet/modules/spark/templates/spark-env.sh
index 0aabc658..2f3e406e 100755
--- a/bigtop-deploy/puppet/modules/spark/templates/spark-env.sh
+++ b/bigtop-deploy/puppet/modules/spark/templates/spark-env.sh
@@ -24,7 +24,15 @@ export HIVE_CONF_DIR=${HIVE_CONF_DIR:-/etc/hive/conf}
export STANDALONE_SPARK_MASTER_HOST=<%= @master_host %>
export SPARK_MASTER_PORT=<%= @master_port %>
export SPARK_MASTER_IP=$STANDALONE_SPARK_MASTER_HOST
+<% if @master_url -%>
export SPARK_MASTER_URL=<%= @master_url %>
+<% else -%>
+<% if (scope['deploy::roles'] & ['spark-master', 'spark-worker']) != [] -%>
+export SPARK_MASTER_URL=spark://<%= @master_host %>:<%= @master_port %>
+<% else -%>
+export SPARK_MASTER_URL=yarn
+<% end -%>
+<% end -%>
export SPARK_MASTER_WEBUI_PORT=<%= @master_ui_port %>
export SPARK_WORKER_DIR=${SPARK_WORKER_DIR:-/var/run/spark/work}
diff --git a/bigtop-deploy/puppet/modules/zeppelin/manifests/init.pp b/bigtop-deploy/puppet/modules/zeppelin/manifests/init.pp
index 9c231bc8..979ec82e 100644
--- a/bigtop-deploy/puppet/modules/zeppelin/manifests/init.pp
+++ b/bigtop-deploy/puppet/modules/zeppelin/manifests/init.pp
@@ -30,6 +30,7 @@ class zeppelin {
$hiveserver2_password = '') {
package { 'zeppelin':
ensure => latest,
+ require => Package["jdk"],
}
file { '/etc/zeppelin/conf/zeppelin-env.sh':
diff --git a/bigtop-packages/src/charm/README.md b/bigtop-packages/src/charm/README.md
index 04213ad8..cdc50e44 100644
--- a/bigtop-packages/src/charm/README.md
+++ b/bigtop-packages/src/charm/README.md
@@ -28,9 +28,10 @@ Bigtop components. Built charms are published to the [Juju charm store][]
and can be deployed directly from there, either individually or with
[bundles][]. They can also be built from these layers and deployed locally.
-For the remainder of this guide, a working Juju installation is assumed to be
-present. If Juju is not yet set up, please follow the [getting-started][]
-instructions prior to deploying locally built charms and bundles.
+For the remainder of this guide, a working Juju 2.0 or greater installation is
+assumed to be present. If Juju is not yet set up, please follow the
+[getting-started][] instructions prior to deploying locally built charms and
+bundles.
[Juju charm store]: https://jujucharms.com/
[bundles]: https://jujucharms.com/hadoop-processing
@@ -48,11 +49,12 @@ For example:
mkdir $JUJU_REPOSITORY
cd bigtop-packages/src/charms/hadoop/layer-hadoop-namenode
- charm build
+ charm build --series xenial --report
-This will build the NameNode charm, pulling in the appropriate base and
-interface layers from [interfaces.juju.solutions][]. You can get local copies
-of those layers as well by using `charm pull-source`:
+This will build the NameNode charm in the
+$JUJU_REPOSITORY/xenial/hadoop-namenode directory, pulling in the appropriate
+base and interface layers from [interfaces.juju.solutions][]. You can get
+local copies of those layers as well by using `charm pull-source`:
export LAYER_PATH=$HOME/layers
export INTERFACE_PATH=$HOME/interfaces
@@ -65,17 +67,10 @@ You can deploy the locally built charms individually, for example:
juju deploy $JUJU_REPOSITORY/xenial/hadoop-namenode
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is: `juju deploy local:xenial/hadoop-namenode`.
-
You can also deploy the local version of a bundle:
juju deploy ./bigtop-deploy/juju/hadoop-processing/bundle-local.yaml
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-./bigtop-deploy/juju/hadoop-processing/bundle-local.yaml`.
-
[charm-tools]: https://jujucharms.com/docs/stable/tools-charm-tools
[Getting Started]: https://jujucharms.com/docs/stable/developer-getting-started
[interfaces.juju.solutions]: http://interfaces.juju.solutions/
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/README.md b/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/README.md
index e5cbf635..b92ab41c 100644
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/README.md
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/README.md
@@ -20,27 +20,22 @@ The Apache Hadoop software library is a framework that allows for the
distributed processing of large data sets across clusters of computers
using a simple programming model.
-This charm deploys the NameNode component of the [Apache Bigtop][] platform
-to provide HDFS master resources.
+This charm deploys version 2.7.3 of the NameNode component from
+[Apache Bigtop][].
[Apache Bigtop]: http://bigtop.apache.org/
# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the [getting-started][] instructions prior to deploying this
-charm.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this charm.
This charm is intended to be deployed via one of the [apache bigtop bundles][].
For example:
juju deploy hadoop-processing
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-hadoop-processing`.
-
This will deploy an Apache Bigtop cluster with this charm acting as the
NameNode. More information about this deployment can be found in the
[bundle readme](https://jujucharms.com/hadoop-processing/).
@@ -52,7 +47,6 @@ mirror options. See [Configuring Models][] for more information.
[getting-started]: https://jujucharms.com/docs/stable/getting-started
[apache bigtop bundles]: https://jujucharms.com/u/bigdata-charmers/#bundles
-[juju-quickstart]: https://launchpad.net/juju-quickstart
[Configuring Models]: https://jujucharms.com/docs/stable/models-config
@@ -79,25 +73,16 @@ application is functioning as expected. Run the action as follows:
juju run-action namenode/0 smoke-test
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do namenode/0 smoke-test`.
-
Watch the progress of the smoke test actions with:
watch -n 2 juju show-action-status
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
-
Eventually, the action should settle to `status: completed`. If it
reports `status: failed`, the application is not working as expected. Get
more information about a specific smoke test with:
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
-
## Utilities
This charm includes Hadoop command line and web utilities that can be used
to verify information about the cluster.
@@ -117,6 +102,18 @@ The web interface will be available at the following URL:
http://NAMENODE_PUBLIC_IP:50070
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this charm at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
+
+Ensure `Bigtop` is selected as the project. Typically, charm issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
+
+
# Contact Information
- <bigdata@lists.ubuntu.com>
@@ -127,6 +124,6 @@ The web interface will be available at the following URL:
- [Apache Bigtop home page](http://bigtop.apache.org/)
- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/layer.yaml b/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/layer.yaml
index 2709e8d4..16b5e431 100644
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/layer.yaml
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/layer.yaml
@@ -22,7 +22,6 @@ options:
ports:
namenode:
port: 8020
- exposed_on: 'namenode'
nn_webapp_http:
port: 50070
exposed_on: 'namenode'
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/metadata.yaml b/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/metadata.yaml
index a358a6d7..2a1806fc 100644
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/metadata.yaml
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/metadata.yaml
@@ -1,11 +1,12 @@
name: hadoop-namenode
-summary: HDFS master (NameNode) from Apache Bigtop
+summary: HDFS NameNode from Apache Bigtop
maintainer: Juju Big Data <bigdata@lists.ubuntu.com>
description: >
Hadoop is a software platform that lets one easily write and
run applications that process vast amounts of data.
- This charm provides the HDFS master node (NameNode).
+ This charm provides version 2.7.3 of the HDFS NameNode application from
+ Apache Bigtop.
tags: []
provides:
namenode:
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/metrics.yaml b/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/metrics.yaml
index f091b674..cb7d2462 100644
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/metrics.yaml
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-namenode/metrics.yaml
@@ -2,12 +2,12 @@ metrics:
namenodes:
type: gauge
description: number of namenodes in the cluster
- command: hdfs getconf -namenodes 2>/dev/null | wc -l
+ command: "charms.reactive is_state apache-bigtop-namenode.ready && hdfs getconf -namenodes 2>/dev/null | wc -l"
offlinedatanodes:
type: gauge
description: number of dead datanodes in the cluster (must be run as hdfs)
- command: su hdfs -c 'hdfs dfsadmin -report -dead 2>/dev/null | grep -i datanodes | grep -o [0-9] || echo 0'
+ command: "charms.reactive is_state apache-bigtop-namenode.ready && su hdfs -c 'hdfs dfsadmin -report -dead 2>/dev/null | grep -i datanodes | grep -o [0-9] || echo 0'"
onlinedatanodes:
type: gauge
description: number of live datanodes in the cluster (must be run as hdfs)
- command: su hdfs -c 'hdfs dfsadmin -report -live 2>/dev/null | grep -i datanodes | grep -o [0-9] || echo 0'
+ command: "charms.reactive is_state apache-bigtop-namenode.ready && su hdfs -c 'hdfs dfsadmin -report -live 2>/dev/null | grep -i datanodes | grep -o [0-9] || echo 0'"
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-plugin/README.md b/bigtop-packages/src/charm/hadoop/layer-hadoop-plugin/README.md
index f9e44838..8c9c0322 100644
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-plugin/README.md
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-plugin/README.md
@@ -28,19 +28,14 @@ This charm facilitates communication between Hadoop components of an
# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the [getting-started][] instructions prior to deploying this
-charm.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this charm.
This charm is intended to be deployed via one of the [apache bigtop bundles][].
For example:
juju deploy hadoop-processing
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-hadoop-processing`.
-
This will deploy an Apache Bigtop cluster with a client unit preconfigured to
work with the cluster. More information about this deployment can be found in the
[bundle readme](https://jujucharms.com/hadoop-processing/).
@@ -52,7 +47,6 @@ mirror options. See [Configuring Models][] for more information.
[getting-started]: https://jujucharms.com/docs/stable/getting-started
[apache bigtop bundles]: https://jujucharms.com/u/bigdata-charmers/#bundles
-[juju-quickstart]: https://launchpad.net/juju-quickstart
[Configuring Models]: https://jujucharms.com/docs/stable/models-config
@@ -79,25 +73,16 @@ application is functioning as expected. Run the action as follows:
juju run-action plugin/0 smoke-test
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do plugin/0 smoke-test`.
-
Watch the progress of the smoke test actions with:
watch -n 2 juju show-action-status
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
-
Eventually, the action should settle to `status: completed`. If it
reports `status: failed`, the application is not working as expected. Get
more information about a specific smoke test with:
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
-
## Utilities
This charm includes Hadoop command line utilities that can be used
to verify information about the cluster.
@@ -107,6 +92,18 @@ Show the dfsadmin report on the command line with the following:
juju run --application plugin "su hdfs -c 'hdfs dfsadmin -report'"
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this charm at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
+
+Ensure `Bigtop` is selected as the project. Typically, charm issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
+
+
# Contact Information
- <bigdata@lists.ubuntu.com>
@@ -117,6 +114,6 @@ Show the dfsadmin report on the command line with the following:
- [Apache Bigtop home page](http://bigtop.apache.org/)
- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/README.md b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/README.md
index 829ea3a7..bd82d008 100644
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/README.md
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/README.md
@@ -20,27 +20,22 @@ The Apache Hadoop software library is a framework that allows for the
distributed processing of large data sets across clusters of computers
using a simple programming model.
-This charm deploys the ResourceManager component of the [Apache Bigtop][]
-platform to provide YARN master resources.
+This charm deploys version 2.7.3 of the ResourceManager component from
+[Apache Bigtop][].
[Apache Bigtop]: http://bigtop.apache.org/
# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the [getting-started][] instructions prior to deploying this
-charm.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this charm.
This charm is intended to be deployed via one of the [apache bigtop bundles][].
For example:
juju deploy hadoop-processing
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-hadoop-processing`.
-
This will deploy an Apache Bigtop cluster with this charm acting as the
ResourceManager. More information about this deployment can be found in the
[bundle readme](https://jujucharms.com/hadoop-processing/).
@@ -52,7 +47,6 @@ mirror options. See [Configuring Models][] for more information.
[getting-started]: https://jujucharms.com/docs/stable/getting-started
[apache bigtop bundles]: https://jujucharms.com/u/bigdata-charmers/#bundles
-[juju-quickstart]: https://launchpad.net/juju-quickstart
[Configuring Models]: https://jujucharms.com/docs/stable/models-config
@@ -81,25 +75,16 @@ smoke tests provided by Apache Bigtop and may take up to
juju run-action resourcemanager/0 smoke-test
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do resourcemanager/0 smoke-test`.
-
Watch the progress of the smoke test actions with:
watch -n 2 juju show-action-status
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
-
Eventually, the action should settle to `status: completed`. If it
reports `status: failed`, the application is not working as expected. Get
more information about a specific smoke test with:
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
-
## Utilities
This charm includes Hadoop command line and web utilities that can be used
to verify information about the cluster.
@@ -168,6 +153,18 @@ cluster. Each benchmark is an action that can be run with `juju run-action`:
started: 2016-02-04 14:55:27 +0000 UTC
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this charm at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
+
+Ensure `Bigtop` is selected as the project. Typically, charm issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
+
+
# Contact Information
- <bigdata@lists.ubuntu.com>
@@ -178,6 +175,6 @@ cluster. Each benchmark is an action that can be run with `juju run-action`:
- [Apache Bigtop home page](http://bigtop.apache.org/)
- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/mrbench b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/mrbench
index d177a2d8..2b97413e 100755
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/mrbench
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/mrbench
@@ -71,6 +71,7 @@ benchmark-finish
cat ${RESULT_LOG} | $CHARM_DIR/actions/parseBenchmark.py
DURATION=`expr $STOP - $START`
benchmark-composite "${DURATION}" 'secs' 'asc'
+action-set outcome="success"
# clean out benchmark dir
benchmark_cleanup
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/nnbench b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/nnbench
index 13d76189..64bb2301 100755
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/nnbench
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/nnbench
@@ -75,6 +75,7 @@ benchmark-finish
cat ${RESULT_LOG} | $CHARM_DIR/actions/parseBenchmark.py
DURATION=`expr $STOP - $START`
benchmark-composite "${DURATION}" 'secs' 'asc'
+action-set outcome="success"
# clean out benchmark dir
benchmark_cleanup
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/parseBenchmark.py b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/parseBenchmark.py
index 4abdea00..2232aa56 100755
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/parseBenchmark.py
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/parseBenchmark.py
@@ -37,7 +37,8 @@ def parse_benchmark_output():
m = regex.match(line)
if m:
results[m.group(1)] = m.group(2)
- hookenv.action_set({"results.raw": json.dumps(results)})
+ hookenv.action_set({"meta.raw": json.dumps(results)})
+
if __name__ == "__main__":
parse_benchmark_output()
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/smoke-test b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/smoke-test
index 4218f7e3..34f160ba 100755
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/smoke-test
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/smoke-test
@@ -23,12 +23,12 @@ from charms.layer.apache_bigtop_base import Bigtop # noqa: E402
from charms.reactive import is_state # noqa: E402
-def fail(msg, output=None):
- if output:
- hookenv.action_set({'output': output})
+def fail(msg):
+ hookenv.action_set({'outcome': 'failure'})
hookenv.action_fail(msg)
sys.exit()
+
if not is_state('apache-bigtop-resourcemanager.ready'):
fail('Charm is not yet ready to run the Bigtop smoke test(s)')
@@ -43,6 +43,6 @@ smoke_env = {
bigtop = Bigtop()
result = bigtop.run_smoke_tests(smoke_components, smoke_env)
if result == 'success':
- hookenv.action_set({'outcome': result})
+ hookenv.action_set({'outcome': 'success'})
else:
- fail('{} smoke tests failed'.format(smoke_components), result)
+ fail('{} smoke tests failed with: {}'.format(smoke_components, result))
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/teragen b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/teragen
index d08468c3..95a65e29 100755
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/teragen
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/teragen
@@ -57,6 +57,7 @@ benchmark-finish
cat ${RESULT_LOG} | $CHARM_DIR/actions/parseBenchmark.py
DURATION=`expr $STOP - $START`
benchmark-composite "${DURATION}" 'secs' 'asc'
+action-set outcome="success"
# clean out benchmark dir
benchmark_cleanup
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/terasort b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/terasort
index 5e3e5921..2611318a 100755
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/terasort
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/terasort
@@ -78,6 +78,7 @@ benchmark-finish
cat ${RESULT_LOG} | $CHARM_DIR/actions/parseBenchmark.py
DURATION=`expr $STOP - $START`
benchmark-composite "${DURATION}" 'secs' 'asc'
+action-set outcome="success"
# clean out benchmark dir
benchmark_cleanup
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/testdfsio b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/testdfsio
index 558c9f43..a53ccac7 100755
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/testdfsio
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/actions/testdfsio
@@ -76,6 +76,7 @@ benchmark-finish
cat ${RESULT_LOG} | $CHARM_DIR/actions/parseBenchmark.py
DURATION=`expr $STOP - $START`
benchmark-composite "${DURATION}" 'secs' 'asc'
+action-set outcome="success"
# clean out benchmark dir
benchmark_cleanup
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/metadata.yaml b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/metadata.yaml
index 695d5bfa..84e42555 100644
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/metadata.yaml
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/metadata.yaml
@@ -1,11 +1,12 @@
name: hadoop-resourcemanager
-summary: YARN master (ResourceManager) from Apache Bigtop
+summary: YARN ResourceManager from Apache Bigtop
maintainer: Juju Big Data <bigdata@lists.ubuntu.com>
description: >
Hadoop is a software platform that lets one easily write and
run applications that process vast amounts of data.
- This charm provides the YARN master node (ResourceManager).
+ This charm provides version 2.7.3 of the YARN ResourceManager application from
+ Apache Bigtop.
tags: []
provides:
resourcemanager:
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/metrics.yaml b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/metrics.yaml
index 137e07e1..08fbea05 100644
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/metrics.yaml
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-resourcemanager/metrics.yaml
@@ -2,4 +2,4 @@ metrics:
nodemanagers:
type: gauge
description: number of running node managers in the cluster
- command: yarn node -list -all 2>/dev/null | grep RUNNING | wc -l
+ command: "charms.reactive is_state apache-bigtop-resourcemanager.ready && yarn node -list -all 2>/dev/null | grep RUNNING | wc -l"
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-slave/README.md b/bigtop-packages/src/charm/hadoop/layer-hadoop-slave/README.md
index ee93239c..41635dc5 100644
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-slave/README.md
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-slave/README.md
@@ -20,28 +20,22 @@ The Apache Hadoop software library is a framework that allows for the
distributed processing of large data sets across clusters of computers
using a simple programming model.
-This charm deploys a combined slave node running the NodeManager
-and DataNode components of the [Apache Bigtop][] platform
-to provide YARN compute and HDFS storage resources.
+This charm deploys a combined slave node running version 2.7.3 of both the
+NodeManager and DataNode components from [Apache Bigtop][].
[Apache Bigtop]: http://bigtop.apache.org/
# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the [getting-started][] instructions prior to deploying this
-charm.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this charm.
This charm is intended to be deployed via one of the [apache bigtop bundles][].
For example:
juju deploy hadoop-processing
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-hadoop-processing`.
-
This will deploy an Apache Bigtop cluster with 3 units of this charm acting as
the combined DataNode/NodeManager application. More information about this
deployment can be found in the [bundle readme](https://jujucharms.com/hadoop-processing/).
@@ -53,7 +47,6 @@ mirror options. See [Configuring Models][] for more information.
[getting-started]: https://jujucharms.com/docs/stable/getting-started
[apache bigtop bundles]: https://jujucharms.com/u/bigdata-charmers/#bundles
-[juju-quickstart]: https://launchpad.net/juju-quickstart
[Configuring Models]: https://jujucharms.com/docs/stable/models-config
@@ -82,25 +75,16 @@ and 'mapreduce' smoke tests provided by Apache Bigtop and may take up to
juju run-action slave/0 smoke-test
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do slave/0 smoke-test`.
-
Watch the progress of the smoke test actions with:
watch -n 2 juju show-action-status
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
-
Eventually, the action should settle to `status: completed`. If it
reports `status: failed`, the application is not working as expected. Get
more information about a specific smoke test with:
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
-
# Scaling
@@ -114,6 +98,18 @@ Multiple units may be added at once. For example, add four more slave units:
juju add-unit -n4 slave
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this charm at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
+
+Ensure `Bigtop` is selected as the project. Typically, charm issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
+
+
# Contact Information
- <bigdata@lists.ubuntu.com>
@@ -124,6 +120,6 @@ Multiple units may be added at once. For example, add four more slave units:
- [Apache Bigtop home page](http://bigtop.apache.org/)
- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-slave/actions/smoke-test b/bigtop-packages/src/charm/hadoop/layer-hadoop-slave/actions/smoke-test
index 68e646d4..f1bb34d4 100755
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-slave/actions/smoke-test
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-slave/actions/smoke-test
@@ -23,12 +23,12 @@ from charms.layer.apache_bigtop_base import Bigtop # noqa: E402
from charms.reactive import is_state # noqa: E402
-def fail(msg, output=None):
- if output:
- hookenv.action_set({'output': output})
+def fail(msg):
+ hookenv.action_set({'outcome': 'failure'})
hookenv.action_fail(msg)
sys.exit()
+
if not is_state('apache-bigtop-datanode.started'):
fail('Charm is not yet ready to run the Bigtop smoke test(s)')
@@ -44,6 +44,6 @@ smoke_env = {
bigtop = Bigtop()
result = bigtop.run_smoke_tests(smoke_components, smoke_env)
if result == 'success':
- hookenv.action_set({'outcome': result})
+ hookenv.action_set({'outcome': 'success'})
else:
- fail('{} smoke tests failed'.format(smoke_components), result)
+ fail('{} smoke tests failed with: {}'.format(smoke_components, result))
diff --git a/bigtop-packages/src/charm/hadoop/layer-hadoop-slave/metadata.yaml b/bigtop-packages/src/charm/hadoop/layer-hadoop-slave/metadata.yaml
index 9e4601e1..0b56f32a 100644
--- a/bigtop-packages/src/charm/hadoop/layer-hadoop-slave/metadata.yaml
+++ b/bigtop-packages/src/charm/hadoop/layer-hadoop-slave/metadata.yaml
@@ -5,5 +5,5 @@ description: >
Hadoop is a software platform that lets one easily write and
run applications that process vast amounts of data.
- This charm provides both the storage node (DataNode) for HDFS and the
- compute node (NodeManager) for Yarn.
+ This charm provides version 2.7.3 of both the HDFS DataNode and the
+ YARN NodeManager from Apache Bigtop.
diff --git a/bigtop-packages/src/charm/hbase/layer-hbase/README.md b/bigtop-packages/src/charm/hbase/layer-hbase/README.md
index d5b714a4..fab19b33 100644
--- a/bigtop-packages/src/charm/hbase/layer-hbase/README.md
+++ b/bigtop-packages/src/charm/hbase/layer-hbase/README.md
@@ -21,61 +21,34 @@ store.
Use HBase when you need random, realtime read/write access to your Big Data.
This project's goal is the hosting of very large tables -- billions of rows X
-millions of columns -- atop clusters of commodity hardware.
-
-HBase is an open-source, distributed, versioned, column-oriented store modeled
-after Google's Bigtable: A Distributed Storage System for Structured Data by
-Chang et al. Just as Bigtable leverages the distributed data storage provided
-by the Google File System, HBase provides Bigtable-like capabilities on top of
-Hadoop and HDFS.
-
-HBase provides:
-
-- Linear and modular scalability.
-- Strictly consistent reads and writes.
-- Automatic and configurable sharding of tables
-- Automatic failover support between RegionServers.
-- Convenient base classes for backing Hadoop MapReduce jobs with HBase tables.
-- Easy to use Java API for client access.
-- Block cache and Bloom Filters for real-time queries.
-- Query predicate push down via server side Filters
-- Thrift gateway and a REST-ful Web service that supports XML, Protobuf,
- and binary data encoding options
-- Extensible jruby-based (JIRB) shell
-- Support for exporting metrics via the Hadoop metrics subsystem to files
- or Ganglia; or via JMX.
-
-See [the homepage](http://hbase.apache.org) for more information.
-
-This charm deploys the hbase master and regionserver components of the
-[Apache Bigtop][] platform.
+millions of columns -- atop clusters of commodity hardware. Learn more at
+[hbase.apache.org][].
+This charm deploys version 1.1.9 of the HBase master, regionserver, and thrift
+components from [Apache Bigtop][].
+
+[hbase.apache.org]: http://hbase.apache.org/
[Apache Bigtop]: http://bigtop.apache.org/
# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the [getting-started][] instructions prior to deploying this
-charm.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this charm.
-An HBase deployment consists of HBase masters and HBase RegionServers.
+An HBase deployment consists of HBase Masters and HBase RegionServers.
In a distributed HBase environment, one master and one regionserver are
-deployed on each unit. HBase makes sure that only one master is active and
-the rest are in standby mode in case the active one fails.
+deployed on each unit. HBase ensures that only one master is active with
+the rest in standby mode in case the active master fails.
Because HBase requires HDFS, this charm is recommended to be deployed as part
of the `hadoop-hbase` bundle:
juju deploy hadoop-hbase
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-hadoop-processing`.
-
-This will deploy an Apache Bigtop Hadoop cluster with 3 HBase units. More
-information about this deployment can be found in the
-[bundle readme](https://jujucharms.com/hadoop-hbase/).
+This will deploy an Apache Bigtop Hadoop cluster with 3 HBase units colocated
+on 3 Hadoop DataNodes. More information about this deployment can be found in
+the [bundle readme](https://jujucharms.com/hadoop-hbase/).
This charm also supports the Thrift client API for HBase. Thrift is both
cross-platform and more lightweight than REST for many operations.
@@ -86,7 +59,6 @@ in this environment, configure a Juju model with appropriate proxy and/or
mirror options. See [Configuring Models][] for more information.
[getting-started]: https://jujucharms.com/docs/stable/getting-started
-[juju-quickstart]: https://launchpad.net/juju-quickstart
[Configuring Models]: https://jujucharms.com/docs/stable/models-config
@@ -113,52 +85,46 @@ application is functioning as expected. Run the action as follows:
juju run-action hbase/0 smoke-test
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do hbase/0 smoke-test`.
-
Watch the progress of the smoke test actions with:
watch -n 2 juju show-action-status
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
-
Eventually, the action should settle to `status: completed`. If it
reports `status: failed`, the application is not working as expected. Get
more information about a specific smoke test with:
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
-
-## HBase web UI
-HBase provides a web console that can be used to verify information about
-the cluster. To access it, find the `PUBLIC-ADDRESS` of any hbase unit and
-expose the application:
+## HBase web interfaces
+The HBase Master service provides a web console that can be used to verify
+information about the cluster. To access it, find the `PUBLIC-ADDRESS` of any
+hbase unit and expose the application:
juju status hbase
juju expose hbase
-The web interface will be available at the following URL:
+The HBase Master web interface will be available at the following URL:
+
+ http://HBASE_PUBLIC_IP:16010
+
+The HBase RegionServer and Thrift services also provide web interfaces that
+are accessible at the following URLs:
- http://HBASE_PUBLIC_IP:60010
+ http://HBASE_PUBLIC_IP:16030
+ http://HBASE_PUBLIC_IP:9095
# Using
-Once the deployment has been verified, there are a number of actions available
-in this charm.
-> **Note**: Actions described below assume Juju 2.0 or greater. If using an
-earlier version of Juju, the action syntax is:
-`juju action do hbase/0 <action_name> <action_args>; juju action fetch <id>`.
+## Actions
+Once HBase is ready, there are a number of actions available in this charm.
-Run a performance test:
+Run a performance test (as described in the **Benchmarking** section):
juju run-action hbase/0 perf-test
juju show-action-output <id> # <-- id from above command
-Run a smoke test (as described in the above **Verifying** section):
+Run a smoke test (as described in the **Verifying** section):
juju run-action hbase/0 smoke-test
juju show-action-output <id> # <-- id from above command
@@ -179,14 +145,78 @@ Start/Stop the HBase RegionServer and Thrift services on a unit:
juju run-action hbase/0 [start|stop]-hbase-regionserver
juju show-action-output <id> # <-- id from above command
+## HBase Shell
+
+HBase includes a shell that can be used to interact with the cluster. Access it
+from any hbase unit (e.g. `hbase/0`) as follows:
+
+ $ juju ssh hbase/0
+ $ hbase shell
+ HBase Shell; enter 'help<RETURN>' for list of supported commands.
+ Type "exit<RETURN>" to leave the HBase Shell
+ Version 1.1.3, rUnknown, Wed Mar 29 07:39:44 UTC 2017
+
+ hbase(main):002:0> exit
+
+# Configuring
+
+Charm configuration can be changed at runtime with `juju config`. This charm
+supports the following config parameters.
+
+## Heap
+The default heap size for the the HBase master JVM is 1024MB. Set a different
+value (in MB) with the following:
+
+ juju config hbase heap=4096
+
+
+# Benchmarking
+
+This charm provides a `perf-test` action to gauge the performance of the HBase
+cluster:
+
+ $ juju run-action hbase/0 perf-test
+ Action queued with id: 339cec1f-e903-4ee7-85ca-876fb0c3d28e
+
+ $ juju show-action-output 339cec1f-e903-4ee7-85ca-876fb0c3d28e
+ results:
+ meta:
+ composite:
+ direction: asc
+ units: secs
+ value: "90"
+ raw: /opt/hbase-perf-results/1495562300.log
+ start: 2017-05-23T17:58:20Z
+ stop: 2017-05-23T17:59:50Z
+ outcome: success
+ status: completed
+ timing:
+ completed: 2017-05-23 17:59:51 +0000 UTC
+ enqueued: 2017-05-23 17:58:16 +0000 UTC
+ started: 2017-05-23 17:58:20 +0000 UTC
+
# Limitations
-Restarting an HBase deployment is potentially disruptive. Be aware that the
-following events will cause a restart:
+Restarting an HBase cluster is potentially disruptive. Be aware that the
+following events will cause a restart of all HBase services:
+
+- Adding or removing HBase units
+- Adding or removing Zookeeper units
+- Changing charm configuration with `juju config`
+- Upgrading this charm
+
+
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this charm at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
-- Zookeeper units joining or departing the quorum.
-- Upgrading the hbase charm.
+Ensure `Bigtop` is selected as the project. Typically, charm issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
# Contact Information
@@ -196,10 +226,10 @@ following events will cause a restart:
# Resources
-- [Apache HBase home page](https://hbase.apache.org/)
-- [Apache HBase issue tracker](https://issues.apache.org/jira/browse/HBASE)
+- [Apache HBase home page](http://hbase.apache.org/)
- [Apache Bigtop home page](http://bigtop.apache.org/)
+- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-packages/src/charm/hbase/layer-hbase/actions/perf-test b/bigtop-packages/src/charm/hbase/layer-hbase/actions/perf-test
index 2209d37e..215e0dcc 100755
--- a/bigtop-packages/src/charm/hbase/layer-hbase/actions/perf-test
+++ b/bigtop-packages/src/charm/hbase/layer-hbase/actions/perf-test
@@ -42,4 +42,5 @@ benchmark-finish
DURATION=`expr $STOP - $START`
benchmark-composite "${DURATION}" 'secs' 'asc'
-benchmark-raw ${RESULT_LOG}
+action-set meta.raw=${RESULT_LOG}
+action-set outcome="success"
diff --git a/bigtop-packages/src/charm/hbase/layer-hbase/actions/smoke-test b/bigtop-packages/src/charm/hbase/layer-hbase/actions/smoke-test
index bc6f45b6..652b7063 100755
--- a/bigtop-packages/src/charm/hbase/layer-hbase/actions/smoke-test
+++ b/bigtop-packages/src/charm/hbase/layer-hbase/actions/smoke-test
@@ -44,6 +44,6 @@ echo "HBase shell return code was: " $status
if [ $status -eq 0 ]; then
action-set outcome="success"
else
- action-set outcome="failed with return code ${status}"
- action-fail "smoke-test failed"
+ action-set outcome="failure"
+ action-fail "smoke-test failed with return code ${status}"
fi
diff --git a/bigtop-packages/src/charm/hbase/layer-hbase/config.yaml b/bigtop-packages/src/charm/hbase/layer-hbase/config.yaml
new file mode 100644
index 00000000..f04d9fd0
--- /dev/null
+++ b/bigtop-packages/src/charm/hbase/layer-hbase/config.yaml
@@ -0,0 +1,6 @@
+options:
+ heap:
+ type: int
+ default: 1024
+ description: |
+ The maximum heap size (in MB) used by the HBase master JVM.
diff --git a/bigtop-packages/src/charm/hbase/layer-hbase/icon.svg b/bigtop-packages/src/charm/hbase/layer-hbase/icon.svg
index 4da73521..c86bd67e 100644
--- a/bigtop-packages/src/charm/hbase/layer-hbase/icon.svg
+++ b/bigtop-packages/src/charm/hbase/layer-hbase/icon.svg
@@ -1,278 +1,23 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
-<!-- Created with Inkscape (http://www.inkscape.org/) -->
-
-<svg
- xmlns:dc="http://purl.org/dc/elements/1.1/"
- xmlns:cc="http://creativecommons.org/ns#"
- xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
- xmlns:svg="http://www.w3.org/2000/svg"
- xmlns="http://www.w3.org/2000/svg"
- xmlns:xlink="http://www.w3.org/1999/xlink"
- xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
- xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
- width="96"
- height="96"
- id="svg6517"
- version="1.1"
- inkscape:version="0.48.4 r9939"
- sodipodi:docname="icon.svg">
- <defs
- id="defs6519">
- <linearGradient
- id="Background">
- <stop
- id="stop4178"
- offset="0"
- style="stop-color:#b8b8b8;stop-opacity:1" />
- <stop
- id="stop4180"
- offset="1"
- style="stop-color:#c9c9c9;stop-opacity:1" />
- </linearGradient>
- <filter
- style="color-interpolation-filters:sRGB;"
- inkscape:label="Inner Shadow"
- id="filter1121">
- <feFlood
- flood-opacity="0.59999999999999998"
- flood-color="rgb(0,0,0)"
- result="flood"
- id="feFlood1123" />
- <feComposite
- in="flood"
- in2="SourceGraphic"
- operator="out"
- result="composite1"
- id="feComposite1125" />
- <feGaussianBlur
- in="composite1"
- stdDeviation="1"
- result="blur"
- id="feGaussianBlur1127" />
- <feOffset
- dx="0"
- dy="2"
- result="offset"
- id="feOffset1129" />
- <feComposite
- in="offset"
- in2="SourceGraphic"
- operator="atop"
- result="composite2"
- id="feComposite1131" />
- </filter>
- <filter
- style="color-interpolation-filters:sRGB;"
- inkscape:label="Drop Shadow"
- id="filter950">
- <feFlood
- flood-opacity="0.25"
- flood-color="rgb(0,0,0)"
- result="flood"
- id="feFlood952" />
- <feComposite
- in="flood"
- in2="SourceGraphic"
- operator="in"
- result="composite1"
- id="feComposite954" />
- <feGaussianBlur
- in="composite1"
- stdDeviation="1"
- result="blur"
- id="feGaussianBlur956" />
- <feOffset
- dx="0"
- dy="1"
- result="offset"
- id="feOffset958" />
- <feComposite
- in="SourceGraphic"
- in2="offset"
- operator="over"
- result="composite2"
- id="feComposite960" />
- </filter>
- <clipPath
- clipPathUnits="userSpaceOnUse"
- id="clipPath873">
- <g
- transform="matrix(0,-0.66666667,0.66604479,0,-258.25992,677.00001)"
- id="g875"
- inkscape:label="Layer 1"
- style="fill:#ff00ff;fill-opacity:1;stroke:none;display:inline">
- <path
- style="fill:#ff00ff;fill-opacity:1;stroke:none;display:inline"
- d="m 46.702703,898.22775 50.594594,0 C 138.16216,898.22775 144,904.06497 144,944.92583 l 0,50.73846 c 0,40.86071 -5.83784,46.69791 -46.702703,46.69791 l -50.594594,0 C 5.8378378,1042.3622 0,1036.525 0,995.66429 L 0,944.92583 C 0,904.06497 5.8378378,898.22775 46.702703,898.22775 Z"
- id="path877"
- inkscape:connector-curvature="0"
- sodipodi:nodetypes="sssssssss" />
- </g>
- </clipPath>
- <filter
- inkscape:collect="always"
- id="filter891"
- inkscape:label="Badge Shadow">
- <feGaussianBlur
- inkscape:collect="always"
- stdDeviation="0.71999962"
- id="feGaussianBlur893" />
- </filter>
- </defs>
- <sodipodi:namedview
- id="base"
- pagecolor="#ffffff"
- bordercolor="#666666"
- borderopacity="1.0"
- inkscape:pageopacity="0.0"
- inkscape:pageshadow="2"
- inkscape:zoom="4.0745362"
- inkscape:cx="-19.035615"
- inkscape:cy="49.018169"
- inkscape:document-units="px"
- inkscape:current-layer="layer1"
- showgrid="true"
- fit-margin-top="0"
- fit-margin-left="0"
- fit-margin-right="0"
- fit-margin-bottom="0"
- inkscape:window-width="1920"
- inkscape:window-height="1056"
- inkscape:window-x="0"
- inkscape:window-y="24"
- inkscape:window-maximized="1"
- showborder="true"
- showguides="true"
- inkscape:guide-bbox="true"
- inkscape:showpageshadow="false"
- inkscape:snap-global="false">
- <inkscape:grid
- type="xygrid"
- id="grid821" />
- <sodipodi:guide
- orientation="1,0"
- position="16,48"
- id="guide823" />
- <sodipodi:guide
- orientation="0,1"
- position="64,80"
- id="guide825" />
- <sodipodi:guide
- orientation="1,0"
- position="80,40"
- id="guide827" />
- <sodipodi:guide
- orientation="0,1"
- position="64,16"
- id="guide829" />
- </sodipodi:namedview>
- <metadata
- id="metadata6522">
- <rdf:RDF>
- <cc:Work
- rdf:about="">
- <dc:format>image/svg+xml</dc:format>
- <dc:type
- rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
- <dc:title />
- </cc:Work>
- </rdf:RDF>
- </metadata>
- <g
- inkscape:label="BACKGROUND"
- inkscape:groupmode="layer"
- id="layer1"
- transform="translate(268,-635.29076)"
- style="display:inline">
- <path
- style="fill:#e6e3e2;fill-opacity:1;stroke:none;display:inline;filter:url(#filter1121)"
- d="m -268,700.15563 0,-33.72973 c 0,-27.24324 3.88785,-31.13513 31.10302,-31.13513 l 33.79408,0 c 27.21507,0 31.1029,3.89189 31.1029,31.13513 l 0,33.72973 c 0,27.24325 -3.88783,31.13514 -31.1029,31.13514 l -33.79408,0 C -264.11215,731.29077 -268,727.39888 -268,700.15563 Z"
- id="path6455"
- inkscape:connector-curvature="0"
- sodipodi:nodetypes="sssssssss" />
- </g>
- <g
- inkscape:groupmode="layer"
- id="layer3"
- inkscape:label="PLACE YOUR PICTOGRAM HERE"
- style="display:inline">
- <image
- y="43.003983"
- x="16.397383"
- id="image3795"
- xlink:href=" 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 "
- height="15.675"
- width="63.412498" />
- </g>
- <g
- inkscape:groupmode="layer"
- id="layer2"
- inkscape:label="BADGE"
- style="display:none"
- sodipodi:insensitive="true">
- <g
- style="display:inline"
- transform="translate(-340.00001,-581)"
- id="g4394"
- clip-path="none">
- <g
- id="g855">
- <g
- inkscape:groupmode="maskhelper"
- id="g870"
- clip-path="url(#clipPath873)"
- style="opacity:0.6;filter:url(#filter891)">
- <path
- transform="matrix(1.4999992,0,0,1.4999992,-29.999795,-237.54282)"
- d="m 264,552.36218 c 0,6.62742 -5.37258,12 -12,12 -6.62742,0 -12,-5.37258 -12,-12 0,-6.62741 5.37258,-12 12,-12 6.62742,0 12,5.37259 12,12 z"
- sodipodi:ry="12"
- sodipodi:rx="12"
- sodipodi:cy="552.36218"
- sodipodi:cx="252"
- id="path844"
- style="color:#000000;fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- sodipodi:type="arc" />
- </g>
- <g
- id="g862">
- <path
- sodipodi:type="arc"
- style="color:#000000;fill:#f5f5f5;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- id="path4398"
- sodipodi:cx="252"
- sodipodi:cy="552.36218"
- sodipodi:rx="12"
- sodipodi:ry="12"
- d="m 264,552.36218 c 0,6.62742 -5.37258,12 -12,12 -6.62742,0 -12,-5.37258 -12,-12 0,-6.62741 5.37258,-12 12,-12 6.62742,0 12,5.37259 12,12 z"
- transform="matrix(1.4999992,0,0,1.4999992,-29.999795,-238.54282)" />
- <path
- transform="matrix(1.25,0,0,1.25,33,-100.45273)"
- d="m 264,552.36218 c 0,6.62742 -5.37258,12 -12,12 -6.62742,0 -12,-5.37258 -12,-12 0,-6.62741 5.37258,-12 12,-12 6.62742,0 12,5.37259 12,12 z"
- sodipodi:ry="12"
- sodipodi:rx="12"
- sodipodi:cy="552.36218"
- sodipodi:cx="252"
- id="path4400"
- style="color:#000000;fill:#dd4814;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- sodipodi:type="arc" />
- <path
- sodipodi:type="star"
- style="color:#000000;fill:#f5f5f5;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- id="path4459"
- sodipodi:sides="5"
- sodipodi:cx="666.19574"
- sodipodi:cy="589.50385"
- sodipodi:r1="7.2431178"
- sodipodi:r2="4.3458705"
- sodipodi:arg1="1.0471976"
- sodipodi:arg2="1.6755161"
- inkscape:flatsided="false"
- inkscape:rounded="0.1"
- inkscape:randomized="0"
- d="m 669.8173,595.77657 c -0.39132,0.22593 -3.62645,-1.90343 -4.07583,-1.95066 -0.44938,-0.0472 -4.05653,1.36297 -4.39232,1.06062 -0.3358,-0.30235 0.68963,-4.03715 0.59569,-4.47913 -0.0939,-0.44198 -2.5498,-3.43681 -2.36602,-3.8496 0.18379,-0.41279 4.05267,-0.59166 4.44398,-0.81759 0.39132,-0.22593 2.48067,-3.48704 2.93005,-3.4398 0.44938,0.0472 1.81505,3.67147 2.15084,3.97382 0.3358,0.30236 4.08294,1.2817 4.17689,1.72369 0.0939,0.44198 -2.9309,2.86076 -3.11469,3.27355 -0.18379,0.41279 0.0427,4.27917 -0.34859,4.5051 z"
- transform="matrix(1.511423,-0.16366377,0.16366377,1.511423,-755.37346,-191.93651)" />
- </g>
- </g>
+<svg xmlns="http://www.w3.org/2000/svg" height="100px" width="100px" version="1.1" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 100 100"><!-- Generator: Sketch 43.2 (39069) - http://www.bohemiancoding.com/sketch -->
+ <title>hbase</title>
+ <desc>Created with Sketch.</desc>
+ <defs>
+ <circle id="path-1" cy="50" cx="50" r="50"/>
+ </defs>
+ <g id="Page-1" fill-rule="evenodd" fill="none">
+ <g id="hbase">
+ <g id="orca">
+ <mask id="mask-2" fill="white">
+ <use xlink:href="#path-1"/>
+ </mask>
+ <use id="Oval-Copy" xlink:href="#path-1" transform="translate(50 50) rotate(180) translate(-50 -50)" fill="#FFFFFF"/>
+ <g id="Orca" fill="#000" mask="url(#mask-2)" fill-rule="nonzero">
+ <g id="Shape" transform="translate(15 23)">
+ <path d="m40.531 32.873c1.61 0-0.49 5.624-7.367 8.355s-11.9 0.975-12.973 0.732c-1.072-0.243-0.519-1.35 0.878-2.049 3.123-1.555 3.853-6.829 8.291-6.973 4.438-0.143 9.562-0.065 11.171-0.065m21.895-4.475c0.211 0.32 7.469 0.968 7.43 9.392 0 0.908-0.505 1.678-0.967 0.459s-1.536-1.096-2.268-1.683c-0.732-0.586-0.732-0.706-3.463-0.561-2.731 0.146-2.557-1.683-2.829-1.951-0.218 0.585-0.097 2.415-1.73 2.078-1.634-0.338-1.293 1.072-1.829 0.536-0.535-0.535-0.585 0.609-1.072 0.464s-1.146 0.487-1.119 1.024-0.463 1.22-0.877 0.553c-3.283-5.274 3.706-6.941 3.219-9.624 1.118 0.846 2.876 2.672 3.73 3.765 0.479 0.624 0.844 0.175 0.593-0.159-3.953-5.198-9.056-7.582-13.697-7.561-5.812 0.025-10.642 5.135-12.967 6.976-0.689 0.545-2.859 0.121-5.525 0.339-4.937 0.402-5.225 5.245-8.68 7.204-1.804 1.023-1.697 2.373-0.845 2.731s2.819 0.755 3.645 0.867c-4.341 4.975-10.548 6.982-12.327 8.206-2.1939 1.512-4.1916 3.503-6.9245 3.516-1.6589 0-1.8539-1.072-1.8539-1.072-0.4794-0.104-1.5198-1.26-1.3568-2.3s-0.98289-3.65-0.39796-7.42c0.78306-5.041 3.7877-11.331 6.129-15.232 2.3573-3.929 7.8312-10.889 8.3392-11.558 1.582-2.091-2.877-14.338 2.958-17.087 0.83-0.3895 1.186-0.01553 1.186 0.52146 0 0.53694 0.655 11.165 5.413 10.779 2.194-0.179 12.453-2.4057 21.428 1.235 7.386 2.997 13.392 10.548 16.663 15.574m-44.889 7.277c-3.764 0.132-6.118 3.495-6.145 6.047-0.032 3.056 2.21 0.716 4.551-0.748s1.886-3.869 2.113-4.032 1.012-1.322-0.519-1.267m-5.81 8.583c-0.452 0.368-0.673 0.844-0.495 1.065 0.177 0.22 0.69 0.102 1.142-0.264 0.453-0.366 0.675-0.844 0.496-1.064-0.179-0.221-0.691-0.103-1.143 0.263m9.672-0.289c-1.438-0.129-2.627-0.673-3.602-1.234s-1.648 1.838-3.676 3.804c-2.178 2.113-5.1618 2.853-6.5666 4.902-1.1699 1.706-2.7521 2.114-3.6247 2.478-0.3772 0.16-0.2205 0.299-0.0575 0.32 1.1427 0.171 3.1148-0.742 5.3906-2.535 2.6022-2.049 9.4392-4.618 12.138-7.74m24.931-20.709c-1.328 0-0.754-0.844-0.226-1.008 2.654-0.825 6.371 0.032 8.858 1.56-1.17-2-5.705-5.115-12.24-3.609-6.535 1.505-7.315 8.291-10.436 11.412h1.652c1.825-1.903 4.847-4.685 7.555-6.007 2.237-1.093 5.979-2.137 11.826-0.138-1.633-2.096-4.863-2.216-6.998-2.21m21.459 12.72c0.358 0.553 0.703 0.16 0.439-0.593-0.305-0.869-1.199-4.13-5.479-5.462-3.675-1.146-3.055-0.472-2.373 0.569 0.357 0.541 1.664 1.724 1.758 2.529 0.088 0.739-0.769 0.977-1.355 0.654-0.841-0.463-2.004-2.284-3.308-3.294-0.274 1.426-3.9 4.315-3.719 5.792 0.121 1.001 0.84 0.537 1.011 0.134 0.16-0.369 0.571-0.812 1.062-0.799 1.535 0.024 3.407-0.222 3.835-1.293 0.46-1.134 0.98-0.402 1.146 0 0.48 1.146 1.862 0.774 3.983 0.735 2.284-0.041 2.64 0.491 2.992 1.033m-65.206-0.561c0.6185-1.691 2.5363-5.626 4.1936-7.868-1.106 0.098-1.6222-2.889-2.5843-2.015-2.5107 2.276-3.0237 7.006-1.6093 9.885"/>
+ </g>
</g>
+ </g>
</g>
+ </g>
</svg>
diff --git a/bigtop-packages/src/charm/hbase/layer-hbase/layer.yaml b/bigtop-packages/src/charm/hbase/layer-hbase/layer.yaml
index a35e252a..26c63e12 100644
--- a/bigtop-packages/src/charm/hbase/layer-hbase/layer.yaml
+++ b/bigtop-packages/src/charm/hbase/layer-hbase/layer.yaml
@@ -2,10 +2,11 @@ repo: https://github.com/apache/bigtop/tree/master/bigtop-packages/src/charm/hba
includes:
- 'layer:apache-bigtop-base'
- 'layer:hadoop-client'
- - 'interface:zookeeper'
+ - 'layer:leadership'
- 'interface:benchmark'
- 'interface:hbase'
- 'interface:hbase-quorum'
+ - 'interface:zookeeper'
options:
apache-bigtop-base:
ports:
@@ -14,21 +15,21 @@ options:
# resourcemanager). Communication among units within the cluster does
# not need ports to be explicitly opened.
hbase-master:
- port: 60000
- exposed_on: 'hbase'
+ port: 16000
hbase-master-web:
- port: 60010
+ port: 16010
exposed_on: 'hbase'
hbase-region:
- port: 60020
- exposed_on: 'hbase'
+ port: 16020
hbase-region-web:
- port: 60030
+ port: 16030
exposed_on: 'hbase'
hbase-thrift:
port: 9090
+ hbase-thrift-web:
+ port: 9095
exposed_on: 'hbase'
# Not yet on bigtop
#hbase-rest:
- # port: 8080
+ # port: 8085
# exposed_on: 'hbase'
diff --git a/bigtop-packages/src/charm/hbase/layer-hbase/lib/charms/layer/bigtop_hbase.py b/bigtop-packages/src/charm/hbase/layer-hbase/lib/charms/layer/bigtop_hbase.py
index cd7c14cb..40fe78a4 100755
--- a/bigtop-packages/src/charm/hbase/layer-hbase/lib/charms/layer/bigtop_hbase.py
+++ b/bigtop-packages/src/charm/hbase/layer-hbase/lib/charms/layer/bigtop_hbase.py
@@ -13,52 +13,93 @@
# See the License for the specific language governing permissions and
# limitations under the License.
-from charmhelpers.core import hookenv, host
-from jujubigdata import utils
-from charms.layer.apache_bigtop_base import Bigtop
+from charmhelpers.core import hookenv, host, unitdata
from charms import layer
+from charms.layer.apache_bigtop_base import Bigtop
+from jujubigdata import utils
+from path import Path
class HBase(object):
- """
- This class manages HBase.
- """
+ '''This class manages HBase.'''
def __init__(self):
self.dist_config = utils.DistConfig(
data=layer.options('apache-bigtop-base'))
def configure(self, hosts, zk_units):
- zks = []
- for unit in zk_units:
- ip = utils.resolve_private_address(unit['host'])
- zks.append(ip)
- zks.sort()
- zk_connect = ",".join(zks)
-
+ zk_connect = self.get_zk_connect(zk_units)
roles = ['hbase-server', 'hbase-master', 'hbase-client']
-
override = {
+ 'bigtop::hbase_thrift_port': self.dist_config.port('hbase-thrift'),
+ 'hadoop_hbase::client::thrift': True,
+ 'hadoop_hbase::common_config::heap_size': hookenv.config()['heap'],
'hadoop_hbase::common_config::zookeeper_quorum': zk_connect,
- 'hadoop_hbase::deploy::auxiliary': False
+ 'hadoop_hbase::deploy::auxiliary': False,
}
bigtop = Bigtop()
bigtop.render_site_yaml(hosts, roles, override)
bigtop.trigger_puppet()
+ def get_zk_connect(self, zk_units):
+ zks = []
+ for unit in zk_units:
+ ip = utils.resolve_private_address(unit['host'])
+ zks.append(ip)
+ zks.sort()
+ return ",".join(zks)
+
+ def update_regionservers(self, addrs, remove=False):
+ '''
+ Each HBase unit in the cluster runs a RegionServer process. Ensure
+ all unit IP addresses are listed in the regionservers file.
+
+ @param: addrs List of IP addresses
+ @param: remove Bool to add (False) or remove (True) unit IPs
+ '''
+ unit_kv = unitdata.kv()
+ kv_ips = unit_kv.get('regionservers', default=[])
+
+ # add/remove IPs from our list
+ if remove:
+ kv_ips = [ip for ip in kv_ips if ip not in addrs]
+ else:
+ kv_ips.extend(addrs)
+
+ # write regionservers file using a sorted, unique set of addrs
+ new_kv = sorted(set(kv_ips))
+ rs_file = Path('/etc/hbase/conf/regionservers')
+ rs_file.write_lines(
+ [
+ '# DO NOT EDIT',
+ '# This file is automatically managed by Juju',
+ ] + [ip for ip in new_kv],
+ append=False
+ )
+
+ # save the new kv IPs
+ unit_kv.set('regionservers', new_kv)
+ unit_kv.flush(True)
+
def restart(self):
self.stop()
self.start()
def start(self):
+ # order is important; master must start first.
+ hookenv.log('Starting HBase services')
host.service_start('hbase-master')
host.service_start('hbase-regionserver')
host.service_start('hbase-thrift')
+ hookenv.log('HBase services have been started')
def stop(self):
- host.service_stop('hbase-master')
- host.service_stop('hbase-regionserver')
+ # order is important; master must stop last.
+ hookenv.log('Stopping HBase services')
host.service_stop('hbase-thrift')
+ host.service_stop('hbase-regionserver')
+ host.service_stop('hbase-master')
+ hookenv.log('HBase services have been stopped')
def open_ports(self):
for port in self.dist_config.exposed_ports('hbase'):
diff --git a/bigtop-packages/src/charm/hbase/layer-hbase/metadata.yaml b/bigtop-packages/src/charm/hbase/layer-hbase/metadata.yaml
index 821f3fa8..49fef470 100644
--- a/bigtop-packages/src/charm/hbase/layer-hbase/metadata.yaml
+++ b/bigtop-packages/src/charm/hbase/layer-hbase/metadata.yaml
@@ -1,9 +1,9 @@
name: hbase
-summary: Apache Bitop HBase
+summary: HBase from Apache Bigtop
maintainer: Juju Big Data <bigdata@lists.ubuntu.com>
description: >
- HBase is the Hadoop database. This charm provides HBase from the
- Apache Bigtop project.
+ HBase is the Hadoop database. This charm provides version 1.1.9 of the
+ HBase application from Apache Bigtop.
tags: []
requires:
zookeeper:
diff --git a/bigtop-packages/src/charm/hbase/layer-hbase/reactive/hbase.py b/bigtop-packages/src/charm/hbase/layer-hbase/reactive/hbase.py
index 26751b59..212a16be 100644
--- a/bigtop-packages/src/charm/hbase/layer-hbase/reactive/hbase.py
+++ b/bigtop-packages/src/charm/hbase/layer-hbase/reactive/hbase.py
@@ -13,11 +13,20 @@
# See the License for the specific language governing permissions and
# limitations under the License.
-from charms.reactive import when, when_not_all, is_state, set_state, remove_state
-from charms.layer.bigtop_hbase import HBase
from charmhelpers.core import hookenv
-from charms.reactive.helpers import data_changed
from charms.layer.apache_bigtop_base import get_layer_opts, get_package_version
+from charms.layer.bigtop_hbase import HBase
+from charms.reactive import (
+ RelationBase,
+ is_state,
+ remove_state,
+ set_state,
+ when,
+ when_any,
+ when_not,
+ when_not_all
+)
+from charms.reactive.helpers import any_file_changed, data_changed
@when('bigtop.available')
@@ -39,37 +48,78 @@ def report_status():
elif not zk_ready:
hookenv.status_set('waiting',
'waiting for zookeeper to become ready')
- elif hbase_installed:
+ elif not hbase_installed:
+ hookenv.status_set('waiting',
+ 'waiting to install hbase')
+ else:
hookenv.status_set('active',
'ready')
-@when('bigtop.available', 'zookeeper.ready', 'hadoop.hdfs.ready')
-def install_hbase(zk, hdfs):
+@when('bigtop.available', 'hadoop.hdfs.ready', 'zookeeper.ready')
+def install_hbase(hdfs, zk):
+ '''
+ Anytime our dependencies are available, check to see if we have a valid
+ reason to (re)install. These include:
+ - initial install
+ - config change
+ - Zookeeper unit has joined/departed
+ '''
zks = zk.zookeepers()
- if (is_state('hbase.installed') and
- (not data_changed('zks', zks))):
- return
+ deployment_matrix = {
+ 'zookeepers': zks,
+ }
+
+ # Handle nuances when installing versus re-installing
+ if not is_state('hbase.installed'):
+ prefix = "installing"
- msg = "configuring hbase" if is_state('hbase.installed') else "installing hbase"
- hookenv.status_set('maintenance', msg)
+ # On initial install, prime our kv with the current deployment matrix.
+ # Subsequent calls will use this to determine if a reinstall is needed.
+ data_changed('deployment_matrix', deployment_matrix)
+ else:
+ prefix = "configuring"
+ # We do not need to reinstall when peers come and go; that is covered
+ # by other handlers below.
+ if is_state('hbpeer.departed') or is_state('hbpeer.joined'):
+ return
+
+ # Return if neither config nor our matrix has changed
+ if not (is_state('config.changed') or
+ data_changed('deployment_matrix', deployment_matrix)):
+ return
+
+ hookenv.status_set('maintenance', '{} hbase'.format(prefix))
+ hookenv.log("{} hbase with: {}".format(prefix, deployment_matrix))
hbase = HBase()
hosts = {}
- nns = hdfs.namenodes()
- hosts['namenode'] = nns[0]
+ hosts['namenode'] = hdfs.namenodes()[0]
hbase.configure(hosts, zks)
- hbase.open_ports()
- set_state('hbase.installed')
- report_status()
+
+ # Ensure our IP is in the regionservers list; restart if the rs conf
+ # file has changed.
+ hbase.update_regionservers([hookenv.unit_private_ip()])
+ if any_file_changed(['/etc/hbase/conf/regionservers']):
+ hbase.restart()
+
# set app version string for juju status output
hbase_version = get_package_version('hbase-master') or 'unknown'
hookenv.application_version_set(hbase_version)
+ hbase.open_ports()
+ report_status()
+ set_state('hbase.installed')
+
@when('hbase.installed')
@when_not_all('hadoop.hdfs.ready', 'zookeeper.ready')
def stop_hbase():
+ '''
+ HBase depends on HDFS and Zookeeper. If we are installed and either of
+ these dependencies go away, shut down HBase services and remove our
+ installed state.
+ '''
hbase = HBase()
hbase.close_ports()
hbase.stop()
@@ -77,10 +127,94 @@ def stop_hbase():
report_status()
-@when('hbase.installed', 'hbclient.joined')
-def serve_client(client):
+@when('hbase.installed')
+@when_any('hbpeer.departed', 'hbpeer.joined')
+def handle_peers():
+ '''
+ We use HBase peers to keep track of the RegionServer IP addresses in a
+ cluster. Use get_nodes() from the appropriate peer relation to retrieve
+ a list of peer tuples, e.g.:
+ [('hbase/0', '172.31.5.161'), ('hbase/2', '172.31.5.11')]
+
+ Depending on the state, this handler will add or remove peer IP addresses
+ from the regionservers config file.
+ '''
+ if is_state('hbpeer.departed'):
+ hbpeer = RelationBase.from_state('hbpeer.departed')
+ is_departing = True
+ message = 'removing hbase peer(s)'
+ else:
+ hbpeer = RelationBase.from_state('hbpeer.joined')
+ is_departing = False
+ message = 'adding hbase peer(s)'
+
+ # Make sure we have a valid relation object
+ if hbpeer:
+ nodes = hbpeer.get_nodes()
+ else:
+ hookenv.log('Ignoring unknown HBase peer state')
+ return
+
+ hookenv.status_set('maintenance', message)
+ hbase = HBase()
+ ip_addrs = [node[1] for node in nodes]
+ hookenv.log('{}: {}'.format(message, ip_addrs))
+ hbase.update_regionservers(ip_addrs, remove=is_departing)
+
+ # NB: the rs conf file will always change when handling peer updates, but
+ # we still include this condition to keep the files_changed kv current.
+ if any_file_changed(['/etc/hbase/conf/regionservers']):
+ hbase.restart()
+
+ # Dismiss appropriate state now that we've handled the peer
+ if is_departing:
+ hbpeer.dismiss_departed()
+ else:
+ hbpeer.dismiss_joined()
+ report_status()
+
+
+@when('hbase.installed', 'leadership.is_leader')
+@when('zookeeper.ready', 'hbclient.joined')
+def serve_client(zk, client):
+ '''
+ We may have multiple HBase peers, but we only need to send 1 set of
+ connection data. Leverage Juju leadership to only send the leader
+ info (even if it's not the actual HBase master).
+
+ Zookeeper will ensure that any HBase peer routes requests to the
+ appropriate master.
+ '''
+ hbase = HBase()
+
+ # Get hbase config and zk info
config = get_layer_opts()
+ host = hookenv.unit_private_ip()
master_port = config.port('hbase-master')
regionserver_port = config.port('hbase-region')
thrift_port = config.port('hbase-thrift')
- client.send_port(master_port, regionserver_port, thrift_port)
+ zk_connect = hbase.get_zk_connect(zk.zookeepers())
+
+ # Send data to our connected client
+ client.send_connection(master_port=master_port,
+ regionserver_port=regionserver_port,
+ thrift_port=thrift_port,
+ host=host,
+ zk_connect=zk_connect)
+
+ hookenv.log('Serving HBase client with master {}:{}, regionserver '
+ 'port {}, thrift port {}, and zk connect {}'.format(
+ host, master_port,
+ regionserver_port,
+ thrift_port,
+ zk_connect))
+
+
+@when('leadership.is_leader', 'hbclient.joined')
+@when_not('hbase.installed')
+def stop_serving_client(client):
+ '''
+ If HDFS or ZK goes away, the 'installed' state will be removed. If we have
+ connected clients, inform them that hbase is no longer ready.
+ '''
+ client.clear_hbase_started()
diff --git a/bigtop-packages/src/charm/hbase/layer-hbase/tests/01-basic-deployment.py b/bigtop-packages/src/charm/hbase/layer-hbase/tests/01-basic-deployment.py
index 3bfc5f28..4873d10c 100755
--- a/bigtop-packages/src/charm/hbase/layer-hbase/tests/01-basic-deployment.py
+++ b/bigtop-packages/src/charm/hbase/layer-hbase/tests/01-basic-deployment.py
@@ -27,7 +27,7 @@ class TestDeploy(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.d = amulet.Deployment(series='xenial')
- cls.d.add('hbase', 'cs:xenial/hbase')
+ cls.d.add('hbase')
cls.d.setup(timeout=1800)
cls.d.sentry.wait_for_messages({'hbase': re.compile('ready')}, timeout=1800)
diff --git a/bigtop-packages/src/charm/hbase/layer-hbase/tests/02-smoke-test.py b/bigtop-packages/src/charm/hbase/layer-hbase/tests/02-smoke-test.py
index 5382542f..b1683154 100755
--- a/bigtop-packages/src/charm/hbase/layer-hbase/tests/02-smoke-test.py
+++ b/bigtop-packages/src/charm/hbase/layer-hbase/tests/02-smoke-test.py
@@ -27,11 +27,11 @@ class TestDeploy(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.d = amulet.Deployment(series='xenial')
- cls.d.add('hbase', 'cs:xenial/hbase')
- cls.d.add('namenode', 'cs:xenial/hadoop-namenode')
- cls.d.add('plugin', 'cs:xenial/hadoop-plugin')
- cls.d.add('slave', 'cs:xenial/hadoop-slave')
- cls.d.add('zookeeper', 'cs:xenial/zookeeper')
+ cls.d.add('hbase')
+ cls.d.add('namenode', charm='hadoop-namenode')
+ cls.d.add('plugin', charm='hadoop-plugin')
+ cls.d.add('slave', charm='hadoop-slave')
+ cls.d.add('zookeeper')
cls.d.relate('hbase:hadoop', 'plugin:hadoop-plugin')
cls.d.relate('hbase:zookeeper', 'zookeeper:zookeeper')
diff --git a/bigtop-packages/src/charm/hive/layer-hive/README.md b/bigtop-packages/src/charm/hive/layer-hive/README.md
new file mode 100644
index 00000000..ae2ddd8e
--- /dev/null
+++ b/bigtop-packages/src/charm/hive/layer-hive/README.md
@@ -0,0 +1,237 @@
+<!--
+ Licensed to the Apache Software Foundation (ASF) under one or more
+ contributor license agreements. See the NOTICE file distributed with
+ this work for additional information regarding copyright ownership.
+ The ASF licenses this file to You under the Apache License, Version 2.0
+ (the "License"); you may not use this file except in compliance with
+ the License. You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+-->
+# Overview
+
+Apache Hive is a data warehouse infrastructure built on top of Hadoop that
+supports data summarization, query, and analysis. Hive provides an SQL-like
+language called HiveQL that transparently converts queries to MapReduce for
+execution on large datasets stored in Hadoop's HDFS. Learn more at
+[hive.apache.org][].
+
+This charm deploys version 1.2.1 of the Hive component from [Apache Bigtop][].
+
+[hive.apache.org]: http://hive.apache.org/
+[Apache Bigtop]: http://bigtop.apache.org/
+
+
+# Deploying
+
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this charm.
+
+This charm is intended to be deployed via one of the [bigtop hadoop bundles][].
+For example:
+
+ juju deploy hadoop-processing
+
+This will deploy an Apache Bigtop Hadoop cluster. More information about this
+deployment can be found in the [bundle readme](https://jujucharms.com/hadoop-processing/).
+
+Now add Hive and relate it to the cluster via the hadoop-plugin:
+
+ juju deploy hive
+ juju add-relation hive plugin
+
+## Metastore
+This charm will start the Hive Metastore service using a local Apache Derby
+metastore database by default. This is suitable for unit or smoke testing Hive,
+but this configuration should not be used in production. Deploying an external
+database for the Hive metastore is recommended:
+
+ juju deploy mariadb
+ juju add-relation hive mariadb
+
+## HBase Integration
+This charm supports interacting with HBase using Hive. Enable this by relating
+Hive to a deployment that includes HBase. For example:
+
+ juju deploy hadoop-hbase
+ juju add-relation hive hbase
+
+See the [hadoop-hbase][] bundle for more information about this HBase
+deployment.
+
+> **Note:** Applications that are duplicated in multiple bundles will be
+reused. This means when deploying both `hadoop-processing` and `hadoop-hbase`,
+Juju will reuse (and not duplicate) common applications like the NameNode,
+ResourceManager, Slaves, etc.
+
+## Network-Restricted Environments
+Charms can be deployed in environments with limited network access. To deploy
+in this environment, configure a Juju model with appropriate proxy and/or
+mirror options. See [Configuring Models][] for more information.
+
+[getting-started]: https://jujucharms.com/docs/stable/getting-started
+[bigtop hadoop bundles]: https://jujucharms.com/u/bigdata-charmers/#bundles
+[Configuring Models]: https://jujucharms.com/docs/stable/models-config
+[hadoop-hbase]: https://jujucharms.com/hadoop-hbase/
+
+
+# Verifying
+
+## Status
+Apache Bigtop charms provide extended status reporting to indicate when they
+are ready:
+
+ juju status
+
+This is particularly useful when combined with `watch` to track the on-going
+progress of the deployment:
+
+ watch -n 2 juju status
+
+The message column will provide information about a given unit's state.
+This charm is ready for use once the status message indicates that it is
+ready.
+
+## Smoke Test
+This charm provides a `smoke-test` action that can be used to verify the
+application is functioning as expected. Run the action as follows:
+
+ juju run-action hive/0 smoke-test
+
+Watch the progress of the smoke test actions with:
+
+ watch -n 2 juju show-action-status
+
+Eventually, the action should settle to `status: completed`. If it
+reports `status: failed`, the application is not working as expected. Get
+more information about a specific smoke test with:
+
+ juju show-action-output <action-id>
+
+
+# Using
+
+This charm provides a variety of actions and interfaces that can be used
+to interact with Hive.
+
+## Actions
+Run a smoke test (as described in the **Verifying** section):
+
+ juju run-action hive/0 smoke-test
+ juju show-action-output <id> # <-- id from above command
+
+Restart all Hive services on a unit:
+
+ juju run-action hive/0 restart
+ juju show-action-output <id> # <-- id from above command
+
+## Command Line Interface
+
+ $ juju ssh hive/0
+ $ hive
+ ...
+ hive> create table foo(col1 int, col2 string);
+ OK
+ Time taken: 0.381 seconds
+ hive> show tables;
+ OK
+ foo
+ hivesmoke
+ Time taken: 0.202 seconds, Fetched: 2 row(s)
+ hive> exit;
+
+### HBase
+As mentioned in the **Deploying** section, this charm supports integration
+with HBase. When HBase is deployed and related to Hive, use the Hive CLI to
+interact with HBase:
+
+ $ juju ssh hive/0
+ $ hive
+ ...
+ hive> CREATE TABLE myhivetable(key STRING, mycol STRING)
+ STORED BY 'org.apache.hadoop.hive.hbase.HBaseStorageHandler'
+ WITH SERDEPROPERTIES ('hbase.columns.mapping' = ':key,cf:mycol')
+ TBLPROPERTIES ('hbase.table.name' = 'myhbasetable');
+ OK
+ Time taken: 2.497 seconds
+ hive> DESCRIBE myhivetable;
+ OK
+ key string from deserializer
+ mycol string from deserializer
+ Time taken: 0.174 seconds, Fetched: 2 row(s)
+
+## Thrift Interface
+The HiveServer2 service provides a thrift server that can be used by Hive
+clients. To access this interface from external clients (i.e. applications
+that are not part of the Juju deployment), find the `Public address` of the
+hive unit and expose the application:
+
+ juju status hive
+ juju expose hive
+
+External clients will be able to access Hive using:
+
+ thrift://HIVE_PUBLIC_IP:10000
+
+
+# Configuring
+
+Charm configuration can be changed at runtime with `juju config`. This charm
+supports the following config parameters.
+
+## Heap
+The default heap size for the the Hive shell JVM is 1024MB. Set a different
+value (in MB) with the following:
+
+ juju config hbase heap=4096
+
+
+# Limitations
+
+## Restarting Hive
+Restarting Hive is potentially disruptive when queries are running. Be aware
+that the following events will cause a restart of all Hive services:
+
+- Adding or removing an HBase relation
+- Changing charm configuration with `juju config`
+- Upgrading this charm
+
+## Hive Web Interface
+The Hive Web Interface (HWI) has been removed upstream ([HIVE-15622][]). This
+charm does not provide HWI. Use the command line or thrift interfaces for
+interacting with Hive.
+
+[HIVE-15622]: https://issues.apache.org/jira/browse/HIVE-15622
+
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this charm at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
+
+Ensure `Bigtop` is selected as the project. Typically, charm issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
+
+
+# Contact Information
+
+- <bigdata@lists.ubuntu.com>
+
+
+# Resources
+
+- [Apache Hive home page](http://hive.apache.org/)
+- [Apache Bigtop home page](http://bigtop.apache.org/)
+- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
+- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
+- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
diff --git a/bigtop-packages/src/charm/hive/layer-hive/actions.yaml b/bigtop-packages/src/charm/hive/layer-hive/actions.yaml
new file mode 100644
index 00000000..7870f30b
--- /dev/null
+++ b/bigtop-packages/src/charm/hive/layer-hive/actions.yaml
@@ -0,0 +1,4 @@
+restart:
+ description: Retart Hive Metastore and HiveServer2.
+smoke-test:
+ description: Verify that Hive is working.
diff --git a/bigtop-packages/src/charm/hive/layer-hive/actions/restart b/bigtop-packages/src/charm/hive/layer-hive/actions/restart
new file mode 100755
index 00000000..904614fe
--- /dev/null
+++ b/bigtop-packages/src/charm/hive/layer-hive/actions/restart
@@ -0,0 +1,36 @@
+#!/usr/bin/env python3
+
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+import sys
+sys.path.append('lib')
+
+from charmhelpers.core import hookenv # noqa: E402
+from charms.layer.bigtop_hive import Hive # noqa: E402
+from charms.reactive import is_state # noqa: E402
+
+
+def fail(msg):
+ hookenv.action_set({'outcome': 'failure'})
+ hookenv.action_fail(msg)
+ sys.exit()
+
+
+if not is_state('hive.installed'):
+ fail('Hive is not yet ready')
+
+hive = Hive()
+hive.restart()
diff --git a/bigtop-packages/src/charm/hive/layer-hive/actions/smoke-test b/bigtop-packages/src/charm/hive/layer-hive/actions/smoke-test
new file mode 100755
index 00000000..d6ac2444
--- /dev/null
+++ b/bigtop-packages/src/charm/hive/layer-hive/actions/smoke-test
@@ -0,0 +1,49 @@
+#!/usr/bin/env python3
+
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+import sys
+sys.path.append('lib')
+
+from charmhelpers.core import hookenv # noqa: E402
+from charms.layer.apache_bigtop_base import Bigtop # noqa: E402
+from charms.reactive import is_state # noqa: E402
+
+
+def fail(msg):
+ hookenv.action_set({'outcome': 'failure'})
+ hookenv.action_fail(msg)
+ sys.exit()
+
+
+if not is_state('hive.installed'):
+ fail('Charm is not yet ready to run the Bigtop smoke test(s)')
+
+# Bigtop smoke test components
+smoke_components = ['hive']
+
+# Env required by test components
+smoke_env = {
+ 'HIVE_HOME': '/usr/lib/hive',
+ 'HIVE_CONF_DIR': '/etc/hive/conf',
+}
+
+bigtop = Bigtop()
+result = bigtop.run_smoke_tests(smoke_components, smoke_env)
+if result == 'success':
+ hookenv.action_set({'outcome': 'success'})
+else:
+ fail('{} smoke tests failed with: {}'.format(smoke_components, result))
diff --git a/bigtop-packages/src/charm/hive/layer-hive/config.yaml b/bigtop-packages/src/charm/hive/layer-hive/config.yaml
new file mode 100644
index 00000000..90ce3375
--- /dev/null
+++ b/bigtop-packages/src/charm/hive/layer-hive/config.yaml
@@ -0,0 +1,6 @@
+options:
+ heap:
+ type: int
+ default: 1024
+ description: |
+ The maximum heap size (in MB) used by the Hive shell JVM.
diff --git a/bigtop-packages/src/charm/hive/layer-hive/copyright b/bigtop-packages/src/charm/hive/layer-hive/copyright
new file mode 100644
index 00000000..e900b97c
--- /dev/null
+++ b/bigtop-packages/src/charm/hive/layer-hive/copyright
@@ -0,0 +1,16 @@
+Format: http://dep.debian.net/deps/dep5/
+
+Files: *
+Copyright: Copyright 2015, Canonical Ltd., All Rights Reserved.
+License: Apache License 2.0
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+ .
+ http://www.apache.org/licenses/LICENSE-2.0
+ .
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
diff --git a/bigtop-packages/src/charm/hive/layer-hive/icon.svg b/bigtop-packages/src/charm/hive/layer-hive/icon.svg
new file mode 100644
index 00000000..12771d3d
--- /dev/null
+++ b/bigtop-packages/src/charm/hive/layer-hive/icon.svg
@@ -0,0 +1,75 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!DOCTYPE svg PUBLIC '-//W3C//DTD SVG 1.1//EN' 'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd'>
+<svg xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" xml:space="preserve" height="100%" width="100%" version="1.1" clip-rule="evenodd" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 100 100">
+ <g transform="translate(-2059.4 -1166.5)">
+ <g transform="translate(2109.4 1216.5)">
+ <g transform="translate(-50 -50)">
+ <clipPath id="_clip1">
+ <rect y="0" x="0" height="100" width="100"/>
+ </clipPath>
+ <g clip-path="url(#_clip1)">
+ <g id="hive">
+ <g id="Oval.-Copy" transform="matrix(-1 -7.6571e-16 7.6571e-16 -1 100 100)">
+ <circle cy="50" cx="50" r="50" fill="#e5e2e1"/>
+ </g>
+ <g transform="matrix(.066971 0 0 .066971 46.514 47.563)">
+ <g transform="translate(-500 -450)">
+ <clipPath id="_clip2">
+ <rect y="0" x="0" height="900" width="1e3"/>
+ </clipPath>
+ <g clip-path="url(#_clip2)">
+ <g stroke="#fdee21" stroke-width="5.13px" transform="translate(-.53268 66.8)">
+ <path d="m597.33 637.79v192.85h47.35v-88.63l9.76 0.18v88.45h47.88v-192.85h-47.88v71.55h-9.76v-71.55h-47.35z"/>
+ <path d="m761.25 637.79h-46.12v192.85h46.12v-192.85z"/>
+ <path d="m768.8 637.79l36.43 192.85h54.98l36.43-192.85h-48.95l-12.07 82.52c-1 3.16-4.4 3.16-5 0l-12.06-82.52h-49.76z"/>
+ <path d="m997.97 637.79h-91.54v192.85h91.54v-50.57l-50.9-0.43v-21.68h24.25v-50.21h-24.25v-19.39h50.9v-50.57z"/>
+ </g>
+ <g transform="translate(-.53268 66.8)">
+ <path d="m503.66 52.952c-7.71-21.115-272.92-124.22-276.31-112.9-48.7 12.695-68.52 68.826-102.02 104.38l-74.393-4.261c-32.771 42.142-49.967 85.199-38.258 129.95 42.002 56.91 90.761 105.33 121.15 176.81 2.4 33.69 145.82 3.53 176.56-3.13-41.99 30.05-78.56 76.65-62.85 210.84 14.35 63.01 24.16 133.36 151.4 204.64 16.75 9.38 51.41 20.2 72.84 28.09 20.5 9.4 44.46 13.27 112.07-7.41 39.13-16.86 81.37-27.02 119.65-43.84l-46.02 2.16c-63.36 1.37-112.29 6.1-127.38-11.6l-58.32-100.68 34-66.04c47.06 4.82 62.68 42.98 104.15 57.51l48.89-36.21c141.99 83.82 198.48-53.12 214.67-159.77-1.73-43.39-93.95 13.61-88.36-6.68 2.16-46.64-35.86-107.67-60.42-155.22l28.43-110.01c12.9-11.49-59.72-133.86-119.02-149.12-52.03-13.391-130.46 52.492-130.46 52.492z" fill="#fdee21"/>
+ </g>
+ <g transform="translate(-.53268 66.8)" fill="#c8c037">
+ <path d="m736.92 286.75c0.51 11.82 0.45 26.19 1.59 35.15-0.19 6.84-5.32 7.09-9.56 8.52l27.63 10.12c5.49 9.23 9.9 18.46 14.35 27.69 5.16 22.71 1.31 23.36-2.13 25.03-10.02 0.11-20.02 0.13-29.36-1.86 4.18 2.21 5.1 3.82 5.55 6.64 0.81 5.22-2.54 12.33-8.07 19.19 8.17 4.53 23.07 8.97 34.14 13.18l12.62-28.09c-5.72-41.27-23.04-79.31-46.76-115.57z"/>
+ <path d="m788.49 425.18c15.32 6.39 36.49 4.52 65.85-10.61 4.36-3.11 8.43-1.25 0.62 3.85-38.5 34.55-56.93 17.27-66.47 6.76z"/>
+ <path d="m857.28 410.04c4.55 8.72 1.79 15.8 0.27 23.17-4.76 37.45-16.43 67.05-39.33 97.99-74.47 119.74-149.66 44.82-209.62-3.94l-24.79 62.13c-1.32 5.45-6.79 9.69 31.93 26.74l39.46-27.87c150.46 114.48 257.08-160.24 202.08-178.22z"/>
+ <path d="m626.75 517.04c-10.15 0.72-40.36 11-41.71 16.95l13.91-20.72 27.8 3.77z"/>
+ <path d="m607.01 390.07c1.86 0 10.79 2.4 9.83 1.86-1.37-0.76-0.15 12.52 2.66 19.44l-10.9 23.7c20.87-24.06 53.86-22.46 84.49-25.56l-14.61-9.05c2.54-8.47-0.45-15.17-1.86-22.37l-69.61 11.98z"/>
+ <path d="m658.28 318.71c-22.39 6.86-43.82 18.07-58.2 41.98 10.97-39.4 13.21-37.9 16.75-39.85 15.35-6.86 27.93-2.59 41.45-2.13z"/>
+ </g>
+ <g transform="translate(-.53268 66.8)" fill="#fcf6a0">
+ <path d="m538.73 780.45c-27.07 29.87-87.47-2.26-137.63-18.64-127.46-81.05-152.36-157.35-154.09-232.2-6.55-107.22 26.37-169.52 68.01-184.27-27.56 53.13-40.41 148.5-27.63 219.42 10.32 39.46 10.53 106 76.55 141.62 32.32 18.2 23.57 32.37 45.43 49.41 23.95 18.68 90.75 36.44 129.36 24.66z"/>
+ <path d="m579.17 284.94c-45.83-64.99-110.29-89.39-182.98-92.05 14.57-4.75 29.14-7.23 43.7-14.25 3.57-3.75 2.41-10.34 1.07-17.04-69.97-18.27-114.13-40.85-170.03-61.782l150.91 36.212c101.91 3.87 93.16 29.03 157.34 148.91h-0.01z"/>
+ <path d="m628.24 253.6c-33.87-48.35-66.72-107.03-111.31-144.35-107.64-48.584-214.12-84.666-338.91-117.5l39.83-51.216c132.42 30.227 256.8 80.808 368.21 164.19 18.85 47.66 31.42 95.39 42.17 148.87l0.01 0.01z"/>
+ <path d="m696.52 168.16s-18.99-42.6-28.23-58.87c-21.45-23.762-32.29-68.05-76.22-88.918 13.9 3.752 23.4-0.718 51.76 24.992l44.67 84.736 8.02 38.06z"/>
+ <path d="m720.14 241.96c4.38-36.91 12.7-96.11 3.15-119.5-26.55-35.624-53.29-72.446-80.04-106.63-4.43-4.123-7.62-9.719-11.11-14.084 37.61 9.744 76.86 35.894 129.79 139.13l-41.79 101.08z"/>
+ </g>
+ <g transform="translate(-.53268 66.8)">
+ <path d="m562.02 246.32c-14.98-11.79-28.33-53.49-51.03-62.16-21.01-1.76-28.71-8.37-56.34-2.74 10.02-5.02 19.48-11.44 30.13-14.88 7.22-1.71 13.98 0.18 20.87 1.13 1.7-0.8 2.81-1.8 2.39-3.31-27.81-17.19-84.86-17.44-123.38-27.25 44.7 1.5 94.16-0.98 127.76 9.79 27.01 23.98 35.78 69.12 49.6 99.42z"/>
+ <path d="m643.93 45.227c6.2 0.563 39.57 53.353 41.14 62.133 2.78 19.21 9.62 40.73 11.46 60.82-5.49-19.27-11.48-38.53-18.97-57.8-2.19-5.31-7.73-17.305-23.11-34.272-7.16-11.959-8.71-21.359-10.52-30.88v-0.001z"/>
+ <path d="m757.02 332.75h-14.28l15.78 4.14-1.5-4.14z"/>
+ <path d="m659.6 318.49c-14.36-1.77-29.09-2-43.45 1.16-5.85 7.86-6.25 15.85-8.81 23.24 17.45-19.23 24.38-20.41 52.26-24.4z"/>
+ <path d="m855.42 417.77c-7.99 6.38-8.79 12.38-32.41 19.57-17.23 4.08-26.96-2.83-35.07-12.11 12.29 3.52 14.26 12.81 47.22 2.39l20.26-9.85z"/>
+ <path d="m783.82 421.76c-5.75 15.81-11.95 31.79-18.2 46.6-14.88 17.45-8.54 7.51-30.82 34.62 7.13-11 16.4-21.57 21.26-33.02 3.4-7.54 7.65-15.55 9.53-22.25-5.91-2.95-18-3.18-19.64-2.12-19.81 11.68-23.38 24.05-35.06 36.08 8.46-13.53 15.69-28.29 25.51-40.47 1.11-1.58 8.38-1.89 12.84-2.82-6.94-1.19-19.78-3.68-20.82-3.57-12.92 3.1-20.16 14.36-29.75 21.83 6.99-10.1 13.43-20.61 22.31-29.29 0.88-1.02 24.89 1.08 37.33 6.05l0.25 4.95 7.06 2.85 5.31-13.32 12.89-6.12z"/>
+ <path d="m627.07 517.09c-3.19-1.09-31.35-4.71-31.35-3.86-10.81 7.69-12.45 15.06-12.22 21.43 17.99-17.69 17.32-17.74 43.57-17.57z"/>
+ <path d="m605.68 389.81s20.32-2.96 19.93-1.07c-1.48 7.06 2.48 24.24 2.92 21.84l-11.43 9.32c23.93-12.03 49.12-9.61 74.66-11.45 0 0-21.51-5.94-20.19-6.12 4.8-0.68-1.28-22.43-2.92-22.91 4.09-1.38 8.08-2.42 12.22-3.46-30.76-8.04-48.54-3.3-75.19 13.85z"/>
+ <path d="m781.56 404.98l-4.52 2.26c-0.64-13.23-14.85-12.26-26.83-12.38l-9.83-2.4c2.99 2.77 12.23 2.55 8.5 8.53-3.14 1.67-4.58 8.87-6.38 14.91l-5.31 0.26c9.39 3.67 18.1 6.89 28.43 11.19l6.11 0.93 14.61-7.86-4.78-15.44z"/>
+ </g>
+ <g transform="translate(-.53268 66.8)" fill="#fff">
+ <path d="m646.86 396.06c-2.29-4.52-13.79-3.88-16.28-0.96-2.01 2.38-0.12 17.65 2.46 15.07 3.74-3.28 8.62-4.66 14.48-4.39 0.74-2.82 0.48-5.86-0.66-9.72z"/>
+ <path d="m757.21 418.8c1.08-0.79 3.37-8.44 2.63-10.73-1.51-5.41-12.21-4.27-12.21-4.27-2.61 1.54-4.9 9.96-3.95 12.74 0.46 2.35 11.81 3.1 13.53 2.26z"/>
+ </g>
+ <g transform="translate(-.53268 66.8)">
+ <path d="m299.64 682.84l6.76 0.66c40.07 19.68 106.05 48.85 201.57 33.17l14.99 23.59c-42.07 20.44-87.31 15.73-129.71 17.17l-93.61-74.59z"/>
+ <path d="m242.11 527.3l20.07 84.27c53.74 33.59 145.54 72.07 222.06 68.96l-16.91-38.8c-159.73-33.92-173.24-76.8-225.22-114.44v0.01z"/>
+ <path d="m292.06 354.69c9.81 65.3 22.91 114.81 79.69 156.28 34.8 25.03 69.35 49.95 111.37 70.52 0 0-3.68 19.17-6.76 18.83-125.05-13.89-216.6-117.58-227.69-164.94 10.74-36.33 26.15-59.02 43.39-80.69z"/>
+ <path d="m352.17 317.69c16.66 72.38 56.4 145.68 95.89 212.18 14.48 18.37 18.26 26.47 40.58 37.66 30.16 9.55 51.48 7.11 73.38 5.67-6-11.1-11.33-22.7-18.22-33.14-49.02-38.76-26.37-74.06-13.35-96.4-27.25-6.89-63.37-21.53-68.34-40.78-8-62.27-3.94-82.02 4.07-114.01-36.91 7.78-74.31 15.49-114.01 28.82z"/>
+ <path stroke-width=".11px" d="m216.77-66.742c-12.13 7.925-23.82 19.256-36.39 32.135-20.84 21.575-34.7 42.621-55.92 58.224-4.24 3.659-16.15 9.551-31.117 10.425-7.052 0.352-11.646 1.519-24.604-0.108-11.428-6.188-22.285-2.164-32.881 10.51-11.619 16.709-26.334 48.437-32.453 68.406-12.611 50.94 19.541 92.91 50.374 125.25 27.429 26.8 43.243 43.55 54.501 68.11 8.53 15.93 14.85 37.8 21.69 53.13 2.46 4.86 1.95 4.84 8.59 6.3 14.33 3.06 34.21 3.08 51.91 4.6 7.66 0.11 18.18-0.17 28.14-1.21 13.73-2.59 29.87-5.13 43.39-9.81 13.21-3.26 24.98-7.76 35.59-11.91-1.36 4.65-11.47 9.12-15.26 15-35.97 51.49-45.83 97.31-39.57 169.6 3.55 32.05 10.9 58.61 22 89 5.08 13.91 15.88 35.93 26.23 50.57 30.79 43.5 99.67 99.37 195.56 120.88 16.73 2.28 35.72 1.06 53.57-3.69 47.33-14.35 143.78-48.28 143.78-48.28s-85.62 7.09-124.83 3.21c-9.07-1.42-19.08-1.9-25.4-8.09-1.06-1.37-4.91-9.13-2.43-9.2 3.4-0.1 13.15-4.14 28.2-5.48-32.13-3.46-31.68-3.42-34.02-9.27-3.65-9.09-9.23-21.5-14.98-32.37 14.12 1.19 45.38 2.95 55.99-8 0 0-18.5 2.13-34.85 0.22-5.5-0.65-14.89-4-17.71-5.03-7.34-2.86-13.38-3.75-14.79-5.61-2.54-6.49-4.27-8.67-7.35-17.36-4.16-11.5-4.49-24.34-5.29-36.08 10.7 13.18 24.32 24.27 42.36 29.94 0.23-0.49 23.4 10.07 40.23 4.64l3.49-1.13c0 0.32-11.15 0.98-15.24-1.04-34.22-14.55-39.37-27.28-44.9-33.6l-14.77-22.13c4.49-8.97 7.03-9.31 12.99-9.39 18.01 2 25.84 3.54 36.8 0.9 7.41 15.24 9.41 30.57 26.27 41.66 56.16 16.67 68.37-4.95 81.97-24.06 40.41 29.66 106.2 38.81 151.89 0.52 58.09-67.22 76.48-173.17 71.33-179.22-7.26-12.31-16.78-25-24.95-23.25-29.13 7.95-39.87 22.73-68.73 19.36 3.43-0.19 9.21-0.29 9.26-0.61 2.22-24.44-0.18-36.27-1.25-38.3-8.76-19.32-20.27-39.65-28.28-54.88-2.07-3.16-8.14-27.17-18.31-36.65-4.36-3.72-15.04-13.55-15.04-13.55l-0.9 10.44s4.17 0.63 5.76 7.1c6.02 24.52 36.69 82.49 38.94 85.26 10.86 17.55 1.1 39.4 9.36 51.67 0.8 1.55 16.86-0.14 29.31 0.63 20.47-4.41 19.61-13.43 37.29-14.79 11.92-0.91 13.11 21.46 12.96 23.2-2.22 24.7-9.74 53.43-21.24 79.66-23.91 46.07-50.69 87.44-88.67 93.21-46.33 8.1-70.4-12.16-95.51-25.05l-9.61 8.19c-32.64 32.5-71.39 29.62-87.24-12.85-7.89-16.47-18.17-26.57-26.97-40.7l-46.69 33.63c-3.89 7.97-8.67 20.54-14.47 34.58-4.04 9.76-7.42 26.52-7.2 40.45-5.99 10.2 20.73 51.55 37.61 76.7 4.98 7.42 14.28 20.38 14.59 21.19 3.34 8.68 10.68 16.35 11.12 17.28 31.34 40.88-39.53 31.46-54.16 28.99-28.88-4.6-57.13-16.66-83.68-32.79-1.54-0.93-3.07-1.88-4.6-2.85-31.55-19.86-60.58-45.28-85.26-70.42-14.72-16.67-28.74-50.83-39.09-75.04-15.51-58.23-37.77-159.15 22.53-235.63 3.83-4.38 7.95-11.65 11.46-13.09 17.92-12.12 37.38-20.38 58.3-24.97l-2.11-13.56c-10.45 2.37-45.63 15.24-55.58 20.63-22.62 6.55-41.39 13.4-70.22 20.62-9.37 1.15-18.59 1.17-27.58-0.05-20.74-2.82-56.09-0.3-58.35-2.4-14.04-19.58-17.89-54.68-30.7-73.46l-0.15-0.18-0.17-0.18c-7.46-10.04-16.172-18.23-24.747-26.75-30.708-30.51-56.991-60.01-64.348-91.27-1.85-9.23-6.614-18.79-4.082-46.1l0.047-0.13 0.044-0.14c7.388-25.51 19.407-46.307 39.806-67.15 21.228 0.342 42.24 0.809 58.61 3.935 7.51 1.256 23.12 3.296 39.25 9.304 40.82 15.207 94.76 40.211 94.76 40.211-40.49-22.238-85.76-51.117-114.35-56.945-4.25-0.602-6.87-2.543-8.13-5.93 43-25.264 50.86-55.009 79.14-81.686 12.93-5.626 17.97-8.498 28.95-9.692 101.57 16.06 165.51 56.515 216.09 83.566 20.53 11.164 39.19 19.606 57.02 29.773 15.62 5.139 62.77 40.734 76.57 59.924 14.01 29.6 24.25 61.56 33.58 92.41 6.69 31.38 12.57 44.1 12.57 44.1s-5.69-26.24-4.74-30.95c5.89 2.2 19.84 6.55 25.62 5.88 0 0-25.82-13.35-29.2-25.14-10.86-37.85-21.75-96.77-24.68-99.84-8.28-10.412-42.78-36.817-63.95-49.031-8-4.62-12.33-7.486-12.67-9.518 6.76-6.83 15.11-15.865 22.6-21.606 7.18-5.503 13.71-11.709 23.71-15.423 43.97-19.8 69.11 7.618 75.07 2.066 0 0-9.46-10.841-5.26-9.056 4.3 2.33 18.33 5.078 19.86 6.509 16.03 12.534 57.92 58.344 83.17 106.68 6.06 11.84 8.53 19.64 5.71 33.89-2.82 14.27-5 22.12-8.08 31.65-2.77 6.37-18.49 49.99-18.43 55.85-3.17 23.93 10.26 53.89 10.26 53.89 0.13-8.13-0.5-12.46 0.24-18.28l0.9-10.39s-0.57-2.77-0.47-3.86c0.68-7.19 2.45-13.23 2.97-17.35 5.04-31.25 13.82-53.75 23.77-81.18 2.96-6.92 6.83-10.77 6.63-16.04 0.16-9.35-8.2-21.9-14.25-34.16-6.1-12.39-13.39-26.206-22.96-40.764-21.82-31.376-40.42-55.925-74.48-71.289-9.53-4.182-47.03-8.271-59.98-5.841-15.71 3.273-29.22 6.5-39.99 13.398-16.95 10.854-30.27 27.659-45.89 37.561-34.56-17.282-51.24-30.216-54.35-31.999-20.54-11.006-45.2-23.778-71.73-35.89-12.72-11.862-91.71-40.233-164.04-45.892l-0.01-0.006zm442.08 644.59c-21.3-16.65-39.23-33.79-51.05-51.44-3.86 20.76-17.86 35.54-28.69 50.08-2.15 3.41-3.71 8.06 6.9 22.88 2.86 3.95 13.21 4.62 20.2 4.26-7.11-5.37-17.92-11.05-19.66-15.98 12.5 8.51 24.07 10.96 34.53 9.59 2.4-0.27 5.36-2.8 7.66-6.71 4.66-10.02 8.32-12.43 12-15.13l8.51 10.66 9.6-8.21z" stroke="#000"/>
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+ </g>
+</svg>
diff --git a/bigtop-packages/src/charm/hive/layer-hive/layer.yaml b/bigtop-packages/src/charm/hive/layer-hive/layer.yaml
new file mode 100644
index 00000000..5be7ac9f
--- /dev/null
+++ b/bigtop-packages/src/charm/hive/layer-hive/layer.yaml
@@ -0,0 +1,31 @@
+repo: https://github.com/apache/bigtop/tree/master/bigtop-packages/src/charm/hive/layer-hive
+includes:
+ - 'layer:apache-bigtop-base'
+ - 'layer:hadoop-client'
+ - 'interface:hbase'
+ - 'interface:hive'
+ - 'interface:mysql'
+options:
+ basic:
+ packages:
+ - 'libmysql-java'
+ - 'mysql-client'
+ apache-bigtop-base:
+ groups:
+ - 'hadoop'
+ - 'hive'
+ users:
+ ubuntu:
+ groups: ['hadoop', 'hive']
+ dirs:
+ hive:
+ path: '/usr/lib/hive'
+ hive_conf:
+ path: '/etc/hive/conf'
+ ports:
+ hive-thrift:
+ port: 10000
+ exposed_on: 'hive'
+ hive-thrift-web:
+ port: 10001
+ exposed_on: 'hive'
diff --git a/bigtop-packages/src/charm/hive/layer-hive/lib/charms/layer/bigtop_hive.py b/bigtop-packages/src/charm/hive/layer-hive/lib/charms/layer/bigtop_hive.py
new file mode 100755
index 00000000..c7d9cc6f
--- /dev/null
+++ b/bigtop-packages/src/charm/hive/layer-hive/lib/charms/layer/bigtop_hive.py
@@ -0,0 +1,138 @@
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+from charmhelpers.core import hookenv, host, unitdata
+from charms import layer
+from charms.layer.apache_bigtop_base import Bigtop
+from jujubigdata import utils
+
+
+class Hive(object):
+ '''This class manages Hive.'''
+ def __init__(self):
+ self.dist_config = utils.DistConfig(
+ data=layer.options('apache-bigtop-base'))
+
+ def install(self, hbase=None):
+ '''
+ Trigger the Bigtop puppet recipe that handles the Hive service.
+ '''
+ # Dirs are handled by the bigtop deb. No need to call out to
+ # dist_config to do that. We do want 'ubuntu' in the hive group though.
+ self.dist_config.add_users()
+
+ # Prep config
+ roles = ['hive-client', 'hive-metastore', 'hive-server2']
+ metastore = "thrift://{}:9083".format(hookenv.unit_private_ip())
+ if hbase:
+ roles.append('hive-hbase')
+ hb_connect = "{}:{}".format(hbase['host'], hbase['master_port'])
+ zk_connect = hbase['zk_connect']
+ else:
+ hb_connect = ""
+ zk_connect = ""
+
+ override = {
+ 'hadoop_hive::common_config::hbase_master': hb_connect,
+ 'hadoop_hive::common_config::hbase_zookeeper_quorum': zk_connect,
+ 'hadoop_hive::common_config::metastore_uris': metastore,
+ 'hadoop_hive::common_config::server2_thrift_port':
+ self.dist_config.port('hive-thrift'),
+ 'hadoop_hive::common_config::server2_thrift_http_port':
+ self.dist_config.port('hive-thrift-web'),
+ }
+ bigtop = Bigtop()
+ bigtop.render_site_yaml(roles=roles, overrides=override)
+ bigtop.trigger_puppet()
+
+ # Bigtop doesn't create a hive-env.sh, but we need it for heap config
+ hive_env = self.dist_config.path('hive_conf') / 'hive-env.sh'
+ if not hive_env.exists():
+ (self.dist_config.path('hive_conf') / 'hive-env.sh.template').copy(hive_env)
+
+ def configure_hive(self):
+ '''
+ Called during config-changed events
+ '''
+ config = hookenv.config()
+ hive_env = self.dist_config.path('hive_conf') / 'hive-env.sh'
+ utils.re_edit_in_place(hive_env, {
+ r'.*export HADOOP_HEAPSIZE *=.*': 'export HADOOP_HEAPSIZE=%s' % config['heap'],
+ })
+
+ def configure_remote_db(self, mysql):
+ hive_site = self.dist_config.path('hive_conf') / 'hive-site.xml'
+ jdbc_url = "jdbc:mysql://{}:{}/{}?createDatabaseIfNotExist=true".format(
+ mysql.host(), mysql.port(), mysql.database()
+ )
+ with utils.xmlpropmap_edit_in_place(hive_site) as props:
+ props['javax.jdo.option.ConnectionURL'] = jdbc_url
+ props['javax.jdo.option.ConnectionUserName'] = mysql.user()
+ props['javax.jdo.option.ConnectionPassword'] = mysql.password()
+ props['javax.jdo.option.ConnectionDriverName'] = "com.mysql.jdbc.Driver"
+
+ hive_env = self.dist_config.path('hive_conf') / 'hive-env.sh'
+ utils.re_edit_in_place(hive_env, {
+ r'.*export HIVE_AUX_JARS_PATH *=.*': 'export HIVE_AUX_JARS_PATH=/usr/share/java/mysql-connector-java.jar',
+ })
+
+ # Now that we have db connection info, init our schema (only once)
+ remote_db = hookenv.remote_service_name()
+ if not unitdata.kv().get('hive.schema.initialized.%s' % remote_db):
+ tool_path = "{}/bin/schematool".format(self.dist_config.path('hive'))
+ utils.run_as('ubuntu', tool_path, '-initSchema', '-dbType', 'mysql')
+ unitdata.kv().set('hive.schema.initialized.%s' % remote_db, True)
+ unitdata.kv().flush(True)
+
+ def configure_local_db(self):
+ local_url = 'jdbc:derby:;databaseName=/var/lib/hive/metastore/metastore_db;create=true'
+ local_driver = 'org.apache.derby.jdbc.EmbeddedDriver'
+ hive_site = self.dist_config.path('hive_conf') / 'hive-site.xml'
+ with utils.xmlpropmap_edit_in_place(hive_site) as props:
+ props['javax.jdo.option.ConnectionURL'] = local_url
+ props['javax.jdo.option.ConnectionUserName'] = 'APP'
+ props['javax.jdo.option.ConnectionPassword'] = 'mine'
+ props['javax.jdo.option.ConnectionDriverName'] = local_driver
+
+ hive_env = self.dist_config.path('hive_conf') / 'hive-env.sh'
+ utils.re_edit_in_place(hive_env, {
+ r'.*export HIVE_AUX_JARS_PATH *=.*': '# export HIVE_AUX_JARS_PATH=',
+ })
+
+ def restart(self):
+ self.stop()
+ self.start()
+
+ def start(self):
+ # order is important; metastore must start first.
+ hookenv.log('Starting Hive services')
+ host.service_start('hive-metastore')
+ host.service_start('hive-server2')
+ hookenv.log('Hive services have been started')
+
+ def stop(self):
+ # order is important; metastore must stop last.
+ hookenv.log('Stopping Hive services')
+ host.service_stop('hive-server2')
+ host.service_stop('hive-metastore')
+ hookenv.log('Hive services have been stopped')
+
+ def open_ports(self):
+ for port in self.dist_config.exposed_ports('hive'):
+ hookenv.open_port(port)
+
+ def close_ports(self):
+ for port in self.dist_config.exposed_ports('hive'):
+ hookenv.close_port(port)
diff --git a/bigtop-packages/src/charm/hive/layer-hive/metadata.yaml b/bigtop-packages/src/charm/hive/layer-hive/metadata.yaml
new file mode 100644
index 00000000..998dd72c
--- /dev/null
+++ b/bigtop-packages/src/charm/hive/layer-hive/metadata.yaml
@@ -0,0 +1,19 @@
+name: hive
+summary: Hive from Apache Bigtop
+maintainer: Juju Big Data <bigdata@lists.ubuntu.com>
+description: >
+ Apache Hive is a data warehouse infrastructure built on top of Hadoop that
+ supports data summarization, query, and analysis. Hive provides an SQL-like
+ language called HiveQL that transparently converts queries to MapReduce for
+ execution on large datasets stored in Hadoop's HDFS.
+
+ This charm provides version 1.2.1 of the Hive application from Apache Bigtop.
+tags: []
+provides:
+ client:
+ interface: hive
+requires:
+ database:
+ interface: mysql
+ hbase:
+ interface: hbase
diff --git a/bigtop-packages/src/charm/hive/layer-hive/reactive/hive.py b/bigtop-packages/src/charm/hive/layer-hive/reactive/hive.py
new file mode 100644
index 00000000..0deebd47
--- /dev/null
+++ b/bigtop-packages/src/charm/hive/layer-hive/reactive/hive.py
@@ -0,0 +1,184 @@
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+from charmhelpers.core import hookenv
+from charms.layer.apache_bigtop_base import get_layer_opts, get_package_version
+from charms.layer.bigtop_hive import Hive
+from charms.reactive import (
+ RelationBase,
+ is_state,
+ remove_state,
+ set_state,
+ when,
+ when_not,
+)
+from charms.reactive.helpers import data_changed
+
+
+@when('bigtop.available')
+def report_status():
+ hadoop_joined = is_state('hadoop.joined')
+ hadoop_ready = is_state('hadoop.ready')
+ hbase_joined = is_state('hbase.joined')
+ hbase_ready = is_state('hbase.ready')
+ database_joined = is_state('database.connected')
+ database_ready = is_state('database.available')
+ hive_installed = is_state('hive.installed')
+ if not hadoop_joined:
+ hookenv.status_set('blocked',
+ 'waiting for relation to hadoop plugin')
+ elif not hadoop_ready:
+ hookenv.status_set('waiting',
+ 'waiting for hadoop to become ready')
+ elif database_joined and not database_ready:
+ hookenv.status_set('waiting',
+ 'waiting for database to become ready')
+ elif hbase_joined and not hbase_ready:
+ hookenv.status_set('waiting',
+ 'waiting for hbase to become ready')
+ elif hive_installed and not database_ready:
+ hookenv.status_set('active',
+ 'ready (local metastore)')
+ elif hive_installed and database_ready:
+ hookenv.status_set('active',
+ 'ready (remote metastore)')
+
+
+@when('bigtop.available', 'hadoop.ready')
+def install_hive(hadoop):
+ '''
+ Anytime our dependencies are available, check to see if we have a valid
+ reason to (re)install. These include:
+ - initial install
+ - HBase has joined/departed
+ '''
+ # Hive cannot handle - in the metastore db name and
+ # mysql uses the service name to name the db
+ if "-" in hookenv.service_name():
+ hookenv.status_set('blocked', "application name may not contain '-'; "
+ "redeploy with a different name")
+ return
+
+ # Get hbase connection dict if it's available
+ if is_state('hbase.ready'):
+ hbase = RelationBase.from_state('hbase.ready')
+ hbserver = hbase.hbase_servers()[0]
+ else:
+ hbserver = None
+
+ # Use this to determine if we need to reinstall
+ deployment_matrix = {
+ 'hbase': hbserver,
+ }
+
+ # Handle nuances when installing versus re-installing
+ if not is_state('hive.installed'):
+ prefix = "installing"
+
+ # On initial install, prime our kv with the current deployment matrix.
+ # Subsequent calls will use this to determine if a reinstall is needed.
+ data_changed('deployment_matrix', deployment_matrix)
+ else:
+ prefix = "configuring"
+
+ # Return if our matrix has not changed
+ if not data_changed('deployment_matrix', deployment_matrix):
+ return
+
+ hookenv.status_set('maintenance', '{} hive'.format(prefix))
+ hookenv.log("{} hive with: {}".format(prefix, deployment_matrix))
+ hive = Hive()
+ hive.install(hbase=hbserver)
+ hive.restart()
+ hive.open_ports()
+ set_state('hive.installed')
+ report_status()
+
+ # set app version string for juju status output
+ hive_version = get_package_version('hive') or 'unknown'
+ hookenv.application_version_set(hive_version)
+
+
+@when('hive.installed', 'config.changed.heap')
+def config_changed():
+ hookenv.status_set('maintenance', 'configuring with new options')
+ hive = Hive()
+ hive.configure_hive()
+ hive.restart()
+ report_status()
+
+
+@when('hive.installed', 'database.available')
+@when_not('hive.db.configured')
+def configure_with_remote_db(db):
+ hookenv.status_set('maintenance', 'configuring external database')
+ hive = Hive()
+ hive.configure_remote_db(db)
+ hive.restart()
+ set_state('hive.db.configured')
+ report_status()
+
+
+@when('hive.installed', 'hive.db.configured')
+@when_not('database.available')
+def configure_with_local_db():
+ '''
+ Reconfigure Hive using a local metastore db.
+
+ The initial installation will configure Hive with a local metastore_db.
+ Once an external db becomes available, we reconfigure Hive to use it. If
+ that external db goes away, we'll use this method to set Hive back into
+ local mode.
+ '''
+ hookenv.status_set('maintenance', 'configuring local database')
+ hive = Hive()
+ hive.configure_local_db()
+ hive.restart()
+ remove_state('hive.db.configured')
+ report_status()
+
+
+@when('hive.installed')
+@when_not('hadoop.ready')
+def stop_hive():
+ '''
+ Hive depends on Hadoop. If we are installed and hadoop goes away, shut down
+ services and remove our installed state.
+ '''
+ hive = Hive()
+ hive.close_ports()
+ hive.stop()
+ remove_state('hive.installed')
+ report_status()
+
+
+@when('hive.installed', 'client.joined')
+def serve_client(client):
+ '''
+ Inform clients when hive is ready to serve.
+ '''
+ port = get_layer_opts().port('hive-thrift')
+ client.send_port(port)
+ client.set_ready()
+
+
+@when('client.joined')
+@when_not('hive.installed')
+def stop_serving_client(client):
+ '''
+ Inform connected clients that Hive is no longer ready. This can happen
+ if Hadoop goes away (the 'installed' state will be removed).
+ '''
+ client.clear_ready()
diff --git a/docker/bigtop-deploy/ubuntu-14.04/Dockerfile b/bigtop-packages/src/charm/hive/layer-hive/tests/01-basic-deployment.py
index 0b04e95b..04a614db 100644..100755
--- a/docker/bigtop-deploy/ubuntu-14.04/Dockerfile
+++ b/bigtop-packages/src/charm/hive/layer-hive/tests/01-basic-deployment.py
@@ -1,3 +1,5 @@
+#!/usr/bin/env python3
+
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
@@ -13,19 +15,25 @@
# See the License for the specific language governing permissions and
# limitations under the License.
-FROM bigtop/puppet:ubuntu-14.04
+import amulet
+import re
+import unittest
+
+
+class TestDeploy(unittest.TestCase):
+ """
+ Trivial deployment test for Apache Bigtop Hive.
+ """
+ @classmethod
+ def setUpClass(cls):
+ cls.d = amulet.Deployment(series='xenial')
+ cls.d.add('hive')
-# enable ssh
-RUN apt-get update && \
- apt-get install -y openssh-server vim && \
- mkdir -p /var/run/sshd && \
- # requiretty off
- sed -i.bak 's/requiretty/!requiretty/' /etc/sudoers && \
- # setup vagrant account
- mkdir -p /root/.ssh && \
- chmod 0700 /root/.ssh && \
- wget http://github.com/mitchellh/vagrant/raw/master/keys/vagrant.pub --no-check-certificate -O /root/.ssh/authorized_keys && \
- chmod 0600 /root/.ssh/authorized_keys
+ cls.d.setup(timeout=1800)
+ cls.d.sentry.wait_for_messages({'hive': re.compile('ready|waiting')},
+ timeout=1800)
+ cls.unit = cls.d.sentry['hive'][0]
-CMD /sbin/init
+if __name__ == '__main__':
+ unittest.main()
diff --git a/bigtop-packages/src/charm/hive/layer-hive/tests/02-smoke-test.py b/bigtop-packages/src/charm/hive/layer-hive/tests/02-smoke-test.py
new file mode 100755
index 00000000..86930328
--- /dev/null
+++ b/bigtop-packages/src/charm/hive/layer-hive/tests/02-smoke-test.py
@@ -0,0 +1,60 @@
+#!/usr/bin/env python3
+
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+import amulet
+import re
+import unittest
+
+
+class TestDeploy(unittest.TestCase):
+ """
+ Hadoop/Hive deployment and smoke test for the Apache Bigtop Hive service.
+ """
+ @classmethod
+ def setUpClass(cls):
+ cls.d = amulet.Deployment(series='xenial')
+ cls.d.add('hive')
+ cls.d.add('namenode', 'hadoop-namenode')
+ cls.d.add('plugin', 'hadoop-plugin')
+ cls.d.add('resourcemanager', 'hadoop-resourcemanager')
+ cls.d.add('slave', 'hadoop-slave')
+
+ cls.d.relate('hive:hadoop', 'plugin:hadoop-plugin')
+ cls.d.relate('plugin:namenode', 'namenode:namenode')
+ cls.d.relate('plugin:resourcemanager', 'resourcemanager:resourcemanager')
+ cls.d.relate('resourcemanager:namenode', 'namenode:namenode')
+ cls.d.relate('slave:namenode', 'namenode:datanode')
+ cls.d.relate('slave:resourcemanager', 'resourcemanager:nodemanager')
+
+ cls.d.setup(timeout=3600)
+ cls.d.sentry.wait_for_messages({'hive': re.compile('ready')},
+ timeout=3600)
+ cls.hive = cls.d.sentry['hive'][0]
+
+ def test_hive(self):
+ """
+ Validate Hive by running the smoke-test action.
+ """
+ uuid = self.hive.run_action('smoke-test')
+ result = self.d.action_fetch(uuid, full_output=True)
+ # action status=completed on success
+ if (result['status'] != "completed"):
+ self.fail('Hive smoke-test failed: %s' % result)
+
+
+if __name__ == '__main__':
+ unittest.main()
diff --git a/bigtop-packages/src/charm/hive/layer-hive/tests/tests.yaml b/bigtop-packages/src/charm/hive/layer-hive/tests/tests.yaml
new file mode 100644
index 00000000..3b6ce3e5
--- /dev/null
+++ b/bigtop-packages/src/charm/hive/layer-hive/tests/tests.yaml
@@ -0,0 +1,3 @@
+reset: false
+packages:
+ - amulet
diff --git a/bigtop-packages/src/charm/kafka/layer-kafka/README.md b/bigtop-packages/src/charm/kafka/layer-kafka/README.md
index 93fca06c..9d7f6059 100644
--- a/bigtop-packages/src/charm/kafka/layer-kafka/README.md
+++ b/bigtop-packages/src/charm/kafka/layer-kafka/README.md
@@ -21,7 +21,8 @@ Software Foundation written in Scala. The project aims to provide a unified,
high-throughput, low-latency platform for handling real-time data feeds. Learn
more at [kafka.apache.org][].
-This charm deploys the Kafka component of the [Apache Bigtop][] platform.
+This charm deploys version 0.10.1 of the Kafka component from
+[Apache Bigtop][].
[kafka.apache.org]: http://kafka.apache.org/
[Apache Bigtop]: http://bigtop.apache.org/
@@ -29,9 +30,8 @@ This charm deploys the Kafka component of the [Apache Bigtop][] platform.
# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the [getting-started][] instructions prior to deploying this
-charm.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this charm.
Kafka requires the Zookeeper distributed coordination service. Deploy and
relate them as follows:
@@ -52,9 +52,6 @@ mirror options. See [Configuring Models][] for more information.
# Using
Once deployed, there are a number of actions available in this charm.
-> **Note**: Actions described below assume Juju 2.0 or greater. If using an
-earlier version of Juju, the action syntax is:
-`juju action do kafka/0 <action_name> <action_args>; juju action fetch <id>`.
List the zookeeper servers that our kafka brokers
are connected to. The following will list `<ip>:<port>` information for each
@@ -110,25 +107,16 @@ topics. Run the action as follows:
juju run-action slave/0 smoke-test
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do kafka/0 smoke-test`.
-
Watch the progress of the smoke test actions with:
watch -n 2 juju show-action-status
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
-
Eventually, the action should settle to `status: completed`. If it
reports `status: failed`, the application is not working as expected. Get
more information about a specific smoke test with:
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
-
# Scaling
@@ -143,9 +131,6 @@ ready units, create a replicated topic as follows:
juju run-action kafka/0 create-topic topic=my-replicated-topic \
partitions=1 replication=2
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do kafka/0 create-topic <args>`.
-
Query the description of the recently created topic:
juju run --unit kafka/0 'kafka-topics.sh --describe \
@@ -191,9 +176,6 @@ network interface name or a CIDR range specifying a subnet. For example:
juju config kafka network_interface=eth0
juju config kafka network_interface=10.0.2.0/24
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju set-config kafka network_interface=eth0`.
-
Each kafka machine in the cluster will lookup the IP address of that
network interface, or find the first network interface with an IP
address in the specified subnet, and bind kafka to that address.
@@ -205,16 +187,24 @@ run "juju resolved" on each unit:
juju config kafka network_interface=eth0
juju resolved kafka/0
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju set-config kafka network_interface=eth0;
-juju resolved -r kafka/0`.
-
To go back to listening on any network interface on the
machine, simply pass ``0.0.0.0`` to ``network_interface``.
juju config kafka network_interface=0.0.0.0
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this charm at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
+
+Ensure `Bigtop` is selected as the project. Typically, charm issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
+
+
# Contact Information
- <bigdata@lists.ubuntu.com>
@@ -222,10 +212,10 @@ machine, simply pass ``0.0.0.0`` to ``network_interface``.
# Resources
+- [Apache Kafka home page](http://kafka.apache.org/)
- [Apache Bigtop home page](http://bigtop.apache.org/)
+- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Apache Kafka home page](http://kafka.apache.org/)
-- [Apache Kafka issue tracker](https://issues.apache.org/jira/browse/KAFKA)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-packages/src/charm/kafka/layer-kafka/actions/create-topic b/bigtop-packages/src/charm/kafka/layer-kafka/actions/create-topic
index b402fe89..159eac71 100755
--- a/bigtop-packages/src/charm/kafka/layer-kafka/actions/create-topic
+++ b/bigtop-packages/src/charm/kafka/layer-kafka/actions/create-topic
@@ -43,8 +43,9 @@ if host.service_available('kafka-server') and host.service_running('kafka-server
'--replication-factor', topic_replication,
capture_output=True)
except subprocess.CalledProcessError as e:
- kafkautils.fail('Kafka command failed', e.output)
+ kafkautils.fail('Kafka command failed: {}'.format(e.output))
else:
- hookenv.action_set({'output': output})
+ hookenv.action_set({'raw': output})
+ hookenv.action_set({'outcome': 'success'})
else:
- kafkautils.fail('Kafka service is not running', 'Please start kafka-server')
+ kafkautils.fail('kafka-server service is not running')
diff --git a/bigtop-packages/src/charm/kafka/layer-kafka/actions/kafkautils.py b/bigtop-packages/src/charm/kafka/layer-kafka/actions/kafkautils.py
index 52e52990..89250272 100644
--- a/bigtop-packages/src/charm/kafka/layer-kafka/actions/kafkautils.py
+++ b/bigtop-packages/src/charm/kafka/layer-kafka/actions/kafkautils.py
@@ -19,8 +19,8 @@ import sys
from charmhelpers.core import hookenv
-def fail(msg, output='<No output>'):
- hookenv.action_set({'output': output})
+def fail(msg):
+ hookenv.action_set({'outcome': 'failure'})
hookenv.action_fail(msg)
sys.exit()
diff --git a/bigtop-packages/src/charm/kafka/layer-kafka/actions/list-topics b/bigtop-packages/src/charm/kafka/layer-kafka/actions/list-topics
index 0ef3a3f0..0241586f 100755
--- a/bigtop-packages/src/charm/kafka/layer-kafka/actions/list-topics
+++ b/bigtop-packages/src/charm/kafka/layer-kafka/actions/list-topics
@@ -35,8 +35,9 @@ if host.service_available('kafka-server') and host.service_running('kafka-server
'--zookeeper', zookeepers, '--list',
capture_output=True)
except subprocess.CalledProcessError as e:
- kafkautils.fail('Kafka command failed', e.output)
+ kafkautils.fail('Kafka command failed: {}'.format(e.output))
else:
- hookenv.action_set({'output': output})
+ hookenv.action_set({'raw': output})
+ hookenv.action_set({'outcome': 'success'})
else:
- kafkautils.fail('Kafka service is not running')
+ kafkautils.fail('kafka-server service is not running')
diff --git a/bigtop-packages/src/charm/kafka/layer-kafka/actions/list-zks b/bigtop-packages/src/charm/kafka/layer-kafka/actions/list-zks
index 517d60c0..be9541a9 100755
--- a/bigtop-packages/src/charm/kafka/layer-kafka/actions/list-zks
+++ b/bigtop-packages/src/charm/kafka/layer-kafka/actions/list-zks
@@ -22,15 +22,16 @@ from charms.reactive import is_state
if not is_state('kafka.started'):
- kafkautils.fail('Kafka service not yet ready', 'Please deploy kafka and required relations')
+ kafkautils.fail('Kafka service not yet ready')
# List zookeepers if kafka is running
if host.service_available('kafka-server') and host.service_running('kafka-server'):
zookeepers = kafkautils.get_zookeepers()
if zookeepers:
- hookenv.action_set({'output': zookeepers})
+ hookenv.action_set({'raw': zookeepers})
+ hookenv.action_set({'outcome': 'success'})
else:
- kafkautils.fail('No zookeeper.connect string found', 'Please relate kafka to zookeeper')
+ kafkautils.fail('No zookeeper.connect string found')
else:
- kafkautils.fail('Kafka service is not running', 'Please start kafka-server')
+ kafkautils.fail('kafka-server service is not running')
diff --git a/bigtop-packages/src/charm/kafka/layer-kafka/actions/read-topic b/bigtop-packages/src/charm/kafka/layer-kafka/actions/read-topic
index 8b7a27d6..a1053e7c 100755
--- a/bigtop-packages/src/charm/kafka/layer-kafka/actions/read-topic
+++ b/bigtop-packages/src/charm/kafka/layer-kafka/actions/read-topic
@@ -47,8 +47,9 @@ if host.service_available('kafka-server') and host.service_running('kafka-server
'--no-wait-at-logend',
capture_output=True)
except subprocess.CalledProcessError as e:
- kafkautils.fail('Kafka command failed', e.output)
+ kafkautils.fail('Kafka command failed: {}'.format(e.output))
else:
- hookenv.action_set({'output': output})
+ hookenv.action_set({'raw': output})
+ hookenv.action_set({'outcome': 'success'})
else:
- kafkautils.fail('Kafka service is not running')
+ kafkautils.fail('kafka-server service is not running')
diff --git a/bigtop-packages/src/charm/kafka/layer-kafka/actions/smoke-test b/bigtop-packages/src/charm/kafka/layer-kafka/actions/smoke-test
index 5c1435a1..a6cd3b6f 100755
--- a/bigtop-packages/src/charm/kafka/layer-kafka/actions/smoke-test
+++ b/bigtop-packages/src/charm/kafka/layer-kafka/actions/smoke-test
@@ -21,6 +21,7 @@ import subprocess
from charmhelpers.core import hookenv, host
from charms.reactive import is_state
from jujubigdata.utils import run_as
+from time import time
if not is_state('kafka.started'):
@@ -28,7 +29,7 @@ if not is_state('kafka.started'):
# Define smoke test params
-topic_name = "smoketest"
+topic_name = "smoketest_{}".format(int(time()))
topic_partitions = 1
topic_replication = 1
@@ -48,7 +49,7 @@ if host.service_available('kafka-server') and host.service_running('kafka-server
'--replication-factor', topic_replication,
capture_output=True)
except subprocess.CalledProcessError as e:
- kafkautils.fail('Kafka command failed', e.output)
+ kafkautils.fail('Kafka command failed: {}'.format(e.output))
# List topics
try:
@@ -56,9 +57,9 @@ if host.service_available('kafka-server') and host.service_running('kafka-server
'--zookeeper', zookeepers, '--list',
capture_output=True)
except subprocess.CalledProcessError as e:
- kafkautils.fail('Kafka command failed', e.output)
+ kafkautils.fail('Kafka command failed: {}'.format(e.output))
# If we haven't failed yet, we passed
hookenv.action_set({'outcome': 'success'})
else:
- kafkautils.fail('Kafka service is not running')
+ kafkautils.fail('kafka-server service is not running')
diff --git a/bigtop-packages/src/charm/kafka/layer-kafka/actions/write-topic b/bigtop-packages/src/charm/kafka/layer-kafka/actions/write-topic
index 6a56265d..813c541d 100755
--- a/bigtop-packages/src/charm/kafka/layer-kafka/actions/write-topic
+++ b/bigtop-packages/src/charm/kafka/layer-kafka/actions/write-topic
@@ -46,8 +46,9 @@ if host.service_available('kafka-server') and host.service_running('kafka-server
capture_output=True,
input=bytes(data, 'UTF-8'))
except subprocess.CalledProcessError as e:
- kafkautils.fail('Kafka command failed', e.output)
+ kafkautils.fail('Kafka command failed: {}'.format(e.output))
else:
- hookenv.action_set({'output': output})
+ hookenv.action_set({'raw': output})
+ hookenv.action_set({'outcome': 'success'})
else:
- kafkautils.fail('Kafka service is not running')
+ kafkautils.fail('kafka-server service is not running')
diff --git a/bigtop-packages/src/charm/kafka/layer-kafka/icon.svg b/bigtop-packages/src/charm/kafka/layer-kafka/icon.svg
index 1564f994..de5ab1be 100644
--- a/bigtop-packages/src/charm/kafka/layer-kafka/icon.svg
+++ b/bigtop-packages/src/charm/kafka/layer-kafka/icon.svg
@@ -1,90 +1,21 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
-<svg
- xmlns:dc="http://purl.org/dc/elements/1.1/"
- xmlns:cc="http://creativecommons.org/ns#"
- xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
- xmlns:svg="http://www.w3.org/2000/svg"
- xmlns="http://www.w3.org/2000/svg"
- xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
- xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
- width="75pt"
- height="117pt"
- viewBox="0 0 75 117"
- version="1.1"
- id="svg3201"
- inkscape:version="0.48.4 r9939"
- sodipodi:docname="icon.svg">
- <metadata
- id="metadata3221">
- <rdf:RDF>
- <cc:Work
- rdf:about="">
- <dc:format>image/svg+xml</dc:format>
- <dc:type
- rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
- </cc:Work>
- </rdf:RDF>
- </metadata>
- <defs
- id="defs3219" />
- <sodipodi:namedview
- pagecolor="#ffffff"
- bordercolor="#666666"
- borderopacity="1"
- objecttolerance="10"
- gridtolerance="10"
- guidetolerance="10"
- inkscape:pageopacity="0"
- inkscape:pageshadow="2"
- inkscape:window-width="1236"
- inkscape:window-height="847"
- id="namedview3217"
- showgrid="false"
- inkscape:zoom="4.5641627"
- inkscape:cx="35.369926"
- inkscape:cy="80.60281"
- inkscape:window-x="397"
- inkscape:window-y="78"
- inkscape:window-maximized="0"
- inkscape:current-layer="layer1" />
- <path
- d="m 0,0.04322 76.8,0 0,76.8 -76.8,0 0,-76.8 z"
- id="path3203"
- style="opacity:0;fill:#fffffe;fill-opacity:0.94977172"
- inkscape:connector-curvature="0" />
- <path
- d="M 13.76256,3.6403482 C 20.992,-0.05524154 33.024,1.9665021 36.42368,7.4934765 40.37632,12.889169 34.816,19.735528 25.77408,20.917066 c 0,1.732924 0.01024,3.459282 0,5.185642 4.6592,0.708923 8.87808,2.258051 12.05248,4.56205 2.21184,-0.892717 4.526079,-1.700102 6.72768,-2.605948 -0.59392,-3.209847 -0.59392,-6.833231 3.10272,-9.340718 5.77536,-4.719589 18.51392,-4.476718 23.72608,0.531692 4.751359,4.076308 3.266559,10.450051 -3.21536,13.403898 -6.03136,3.012923 -15.28832,2.271179 -20.41856,-1.266872 -2.16064,0.833641 -4.43392,1.549128 -6.52288,2.454975 -0.307201,1.122461 0.45056,2.251486 0.6144,3.373948 0.70656,1.956103 -0.78848,3.859693 -0.68608,5.809231 2.11968,0.951795 4.47488,1.68041 6.79936,2.415589 6.36928,-4.653948 19.445759,-3.918768 24.10496,1.575386 5.12,5.087179 0.62464,12.668717 -8.52992,14.211281 -6.85056,1.273436 -14.7968,-0.794256 -17.84832,-4.988717 -1.81248,-2.23836 -1.69984,-4.857437 -0.8704,-7.259898 -2.29376,-0.951795 -4.67968,-1.805128 -6.97344,-2.756923 -3.16416,2.284307 -7.34208,3.885949 -12.01152,4.516102 -0.06144,1.746051 -0.04096,3.498667 -0.0512,5.251283 4.78208,0.728615 8.98048,2.921025 10.81344,5.868307 2.75456,4.299487 0.07168,9.872411 -6.51264,12.025436 -6.2464,2.422154 -15.06304,1.234052 -19.33312,-2.546872 -4.89472,-3.846564 -3.84,-10.095589 2.17088,-13.213539 1.91488,-1.102768 4.41344,-1.634461 6.78912,-2.19241 0.03072,-1.68041 0.04096,-3.367384 0.07168,-5.047794 C 14.98112,50.009169 10.21952,48.597887 7.26016,45.919734 1.44384,41.180451 2.2528,33.671118 9.20576,29.581682 c 2.78528,-1.93641 6.77888,-2.776616 10.567679,-3.577436 -0.03072,-1.68041 -0.04096,-3.360821 -0.07168,-5.034667 C 15.59552,20.181887 11.60192,18.678708 9.5641599,16.164655 5.82656,12.081784 7.69024,6.3644508 13.76256,3.6403482 z"
- id="path3205"
- inkscape:connector-curvature="0"
- style="fill:#201f1f" />
- <path
- d="M 18.95424,7.4869124 C 23.58272,5.3338867 30.53568,8.2614765 29.85984,11.799528 29.48096,14.924041 23.5008,17.182092 19.2,15.462297 14.42816,13.926297 14.27456,9.1410662 18.95424,7.4869124 z"
- id="path3207"
- inkscape:connector-curvature="0"
- style="fill:#fffffe" />
- <path
- d="m 55.76704,20.844861 c 4.51584,-1.673846 10.91584,0.761436 10.56768,4.135384 0.235519,3.649642 -7.33184,5.96677 -11.64288,3.557744 -4.106241,-1.897025 -3.38944,-6.255589 1.0752,-7.693128 z"
- id="path3209"
- inkscape:connector-curvature="0"
- style="fill:#fffffe" />
- <path
- d="m 18.78016,32.305784 c 7.311359,-2.303999 16.35328,2.829129 13.8752,7.75877 -1.44384,4.555487 -11.17184,6.721641 -16.5376,3.472409 -6.05184,-2.894768 -4.352,-9.570461 2.6624,-11.231179 z"
- id="path3211"
- inkscape:connector-curvature="0"
- style="fill:#fffffe" />
- <path
- d="m 54.69184,48.348451 c 4.66944,-2.619077 12.759039,0.347897 11.601919,4.253538 -0.409599,3.629949 -8.345599,5.218462 -12.103679,2.651898 -3.2256,-1.772308 -2.8672,-5.303795 0.50176,-6.905436 z"
- id="path3213"
- inkscape:connector-curvature="0"
- style="fill:#fffffe" />
- <path
- d="m 20.67456,61.030297 c 5.10976,-1.13559 10.78272,2.566565 8.82688,5.809231 -1.269761,3.190153 -8.48896,4.483282 -11.84768,1.857641 -4.06528,-2.19241 -2.03776,-6.872615 3.0208,-7.666872 z"
- id="path3215"
- inkscape:connector-curvature="0"
- style="fill:#fffffe" />
- <g
- inkscape:groupmode="layer"
- id="layer1"
- inkscape:label="Alpha"
- style="opacity:1" />
+<svg xmlns="http://www.w3.org/2000/svg" height="100px" width="100px" version="1.1" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 100 100"><!-- Generator: Sketch 43.2 (39069) - http://www.bohemiancoding.com/sketch -->
+ <title>kafka</title>
+ <desc>Created with Sketch.</desc>
+ <g id="Page-1" fill-rule="evenodd" fill="none">
+ <g id="kafka">
+ <path id="path4784" fill-rule="nonzero" fill="#fff" d="m50 1.1369e-13c-27.614-1.69e-15 -50 22.386-50 50-3.3818e-15 27.614 22.386 50 50 50 13.261 0 25.979-5.268 35.355-14.645 9.377-9.376 14.645-22.094 14.645-35.355 0-27.614-22.386-50-50-50z"/>
+ <g id="kafta" fill="#000" transform="translate(27 13)">
+ <path id="Combined-Shape" d="m13.333 20c-5.5225 0-9.9997-4.477-9.9997-10 0-5.5228 4.4772-10 9.9997-10 5.523 0 10 4.4772 10 10 0 5.523-4.477 10-10 10zm0.278-5c2.608 0 4.722-2.114 4.722-4.722 0-2.6082-2.114-4.7224-4.722-4.7224s-4.7221 2.1142-4.7221 4.7224c0 2.608 2.1141 4.722 4.7221 4.722z"/>
+ <rect id="Rectangle" y="18.889" x="11.111" height="6.6667" width="4.4444"/>
+ <rect id="Rectangle-Copy" y="49.444" x="11.111" height="6.6667" width="4.4444"/>
+ <rect id="Rectangle-Copy-2" transform="translate(26.776 29.702) rotate(60) translate(-26.776 -29.702)" height="6.6667" width="4.4444" y="26.369" x="24.553"/>
+ <rect id="Rectangle-Copy-3" transform="translate(26.22 45.258) scale(1 -1) rotate(60) translate(-26.22 -45.258)" height="6.6667" width="4.4444" y="41.925" x="23.998"/>
+ <path id="Combined-Shape-Copy-4" d="m12.778 50c-7.0572 0-12.778-5.721-12.778-12.778s5.7208-12.778 12.778-12.778c7.057 0 12.778 5.721 12.778 12.778s-5.721 12.778-12.778 12.778zm0.355-6.389c3.332 0 6.034-2.701 6.034-6.034 0-3.332-2.702-6.034-6.034-6.034-3.3327 0-6.0342 2.702-6.0342 6.034 0 3.333 2.7015 6.034 6.0342 6.034z"/>
+ <path id="Combined-Shape-Copy" d="m13.333 75c-5.5225 0-9.9997-4.477-9.9997-10s4.4772-10 9.9997-10c5.523 0 10 4.477 10 10s-4.477 10-10 10zm0.278-5c2.608 0 4.722-2.114 4.722-4.722s-2.114-4.722-4.722-4.722-4.7221 2.114-4.7221 4.722 2.1141 4.722 4.7221 4.722z"/>
+ <path id="Combined-Shape-Copy-2" d="m36.667 33.889c-5.523 0-10-4.477-10-10s4.477-10 10-10 10 4.477 10 10-4.477 10-10 10zm0.277-5c2.608 0 4.723-2.114 4.723-4.722s-2.115-4.723-4.723-4.723-4.722 2.115-4.722 4.723 2.114 4.722 4.722 4.722z"/>
+ <path id="Combined-Shape-Copy-3" d="m36.667 61.111c-5.523 0-10-4.477-10-10s4.477-10 10-10 10 4.477 10 10-4.477 10-10 10zm0.277-5c2.608 0 4.723-2.114 4.723-4.722s-2.115-4.722-4.723-4.722-4.722 2.114-4.722 4.722 2.114 4.722 4.722 4.722z"/>
+ </g>
+ </g>
+ </g>
</svg>
diff --git a/bigtop-packages/src/charm/kafka/layer-kafka/metadata.yaml b/bigtop-packages/src/charm/kafka/layer-kafka/metadata.yaml
index 5a113948..ffd64f43 100644
--- a/bigtop-packages/src/charm/kafka/layer-kafka/metadata.yaml
+++ b/bigtop-packages/src/charm/kafka/layer-kafka/metadata.yaml
@@ -1,26 +1,11 @@
name: kafka
-summary: High-performance distributed messaging system from Apache Bigtop
+summary: Kafka from Apache Bigtop
maintainer: Juju Big Data <bigdata@lists.ubuntu.com>
-description: |
- Fast
- A single Kafka broker can handle hundreds of megabytes of reads and writes per
- second from thousands of clients.
+description: >
+ Kafka is a high-performance, scalable, distributed messaging system.
- Scalable
- Kafka is designed to allow a single cluster to serve as the central data
- backbone for a large organization. It can be elastically and transparently
- expanded without downtime. Data streams are partitioned and spread over a
- cluster of machines to allow data streams larger than the capability of any
- single machine and to allow clusters of co-ordinated consumers.
-
- Durable
- Messages are persisted on disk and replicated within the cluster to prevent
- data loss. Each broker can handle terabytes of messages without performance
- impact.
-
- Distributed by Design
- Kafka has a modern cluster-centric design that offers strong durability and
- fault-tolerance guarantees.
+ This charm provides version 0.10.1 of the Kafka application from Apache
+ Bigtop.
tags: []
provides:
client:
diff --git a/bigtop-packages/src/charm/kafka/layer-kafka/tests/01-deploy.py b/bigtop-packages/src/charm/kafka/layer-kafka/tests/01-deploy.py
index f8f06791..f6d5487b 100755
--- a/bigtop-packages/src/charm/kafka/layer-kafka/tests/01-deploy.py
+++ b/bigtop-packages/src/charm/kafka/layer-kafka/tests/01-deploy.py
@@ -26,8 +26,8 @@ class TestDeploy(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.d = amulet.Deployment(series='xenial')
- cls.d.add('kafka', charm='cs:xenial/kafka')
- cls.d.add('zookeeper', charm='cs:xenial/zookeeper')
+ cls.d.add('kafka')
+ cls.d.add('zookeeper')
cls.d.relate('kafka:zookeeper', 'zookeeper:zookeeper')
diff --git a/bigtop-packages/src/charm/kafka/layer-kafka/tests/02-smoke-test.py b/bigtop-packages/src/charm/kafka/layer-kafka/tests/02-smoke-test.py
index c688c699..65c86edd 100755
--- a/bigtop-packages/src/charm/kafka/layer-kafka/tests/02-smoke-test.py
+++ b/bigtop-packages/src/charm/kafka/layer-kafka/tests/02-smoke-test.py
@@ -26,8 +26,8 @@ class TestDeploy(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.d = amulet.Deployment(series='xenial')
- cls.d.add('kafka', charm='cs:xenial/kafka')
- cls.d.add('zookeeper', charm='cs:xenial/zookeeper')
+ cls.d.add('kafka')
+ cls.d.add('zookeeper')
cls.d.relate('kafka:zookeeper', 'zookeeper:zookeeper')
diff --git a/bigtop-packages/src/charm/kafka/layer-kafka/tests/10-config-changed.py b/bigtop-packages/src/charm/kafka/layer-kafka/tests/10-config-changed.py
index a27f7833..d5f3723c 100755
--- a/bigtop-packages/src/charm/kafka/layer-kafka/tests/10-config-changed.py
+++ b/bigtop-packages/src/charm/kafka/layer-kafka/tests/10-config-changed.py
@@ -29,10 +29,10 @@ class TestConfigChanged(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.d = amulet.Deployment(series='xenial')
- cls.d.add('kafka-test', charm='cs:xenial/kafka')
- cls.d.add('zk-test', charm='cs:xenial/zookeeper')
+ cls.d.add('kafka-test', charm='kafka')
+ cls.d.add('kafka-test-zk', charm='zookeeper')
- cls.d.relate('kafka-test:zookeeper', 'zk-test:zookeeper')
+ cls.d.relate('kafka-test:zookeeper', 'kafka-test-zk:zookeeper')
cls.d.setup(timeout=1800)
cls.d.sentry.wait_for_messages({'kafka-test': 'ready'}, timeout=1800)
@@ -42,10 +42,10 @@ class TestConfigChanged(unittest.TestCase):
def tearDownClass(cls):
# NB: seems to be a remove_service issue with amulet. However, the
# unit does still get removed. Pass OSError for now:
- # OSError: juju command failed ['remove-application', 'zk-test']:
- # ERROR allocation for service ...zk-test... owned by ... not found
+ # OSError: juju command failed ['remove-application', ...]:
+ # ERROR allocation for service ... owned by ... not found
try:
- cls.d.remove_service('zk-test', 'kafka-test')
+ cls.d.remove_service('kafka-test', 'kafka-test-zk')
except OSError as e:
print("IGNORE: Amulet remove_service failed: {}".format(e))
pass
diff --git a/bigtop-packages/src/charm/mahout/layer-mahout/README.md b/bigtop-packages/src/charm/mahout/layer-mahout/README.md
index 2ecbf5ab..2b64b207 100644
--- a/bigtop-packages/src/charm/mahout/layer-mahout/README.md
+++ b/bigtop-packages/src/charm/mahout/layer-mahout/README.md
@@ -16,33 +16,27 @@
-->
# Overview
-The Apache Mahout project's goal is to build an environment for quickly creating
-scalable performant machine learning applications.
+The Apache Mahout project's goal is to build an environment for quickly
+creating scalable, performant machine learning applications. Learn more at
+[mahout.apache.org][].
-Apache Mahout software provides three major features:
- * A simple and extensible programming environment and framework for building
- scalable algorithms
- * A wide variety of premade algorithms for Scala + Apache Spark, H2O, Apache
- Flink
- * Samsara, a vector math experimentation environment with R-like syntax which
- works at scale
+This charm deploys version 0.12.2 of the Mahout component from
+[Apache Bigtop][].
+
+[mahout.apache.org]: http://mahout.apache.org/
+[Apache Bigtop]: http://bigtop.apache.org/
# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the [getting-started][] instructions prior to deploying this
-charm.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this charm.
This charm is intended to be used with one of the [apache bigtop bundles][].
For example:
juju deploy hadoop-processing
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-hadoop-processing`.
-
This will deploy an Apache Bigtop Hadoop cluster. More information about this
deployment can be found in the [bundle readme](https://jujucharms.com/hadoop-processing/).
@@ -58,7 +52,6 @@ mirror options. See [Configuring Models][] for more information.
[getting-started]: https://jujucharms.com/docs/stable/getting-started
[apache bigtop bundles]: https://jujucharms.com/u/bigdata-charmers/#bundles
-[juju-quickstart]: https://launchpad.net/juju-quickstart
[Configuring Models]: https://jujucharms.com/docs/stable/models-config
@@ -85,24 +78,27 @@ application is functioning as expected. Run the action as follows:
juju run-action mahout/0 smoke-test
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do mahout/0 smoke-test`.
-
Watch the progress of the smoke test actions with:
watch -n 2 juju show-action-status
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
-
Eventually, the action should settle to `status: completed`. If it
reports `status: failed`, the application is not working as expected. Get
more information about a specific smoke test with:
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
+
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this charm at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
+
+Ensure `Bigtop` is selected as the project. Typically, charm issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
# Contact Information
@@ -112,10 +108,10 @@ of Juju, the syntax is `juju action fetch <action-id>`.
# Resources
+- [Apache Mahout home page](http://mahout.apache.org/)
- [Apache Bigtop home page](http://bigtop.apache.org/)
+- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Apache Mahout home page](https://mahout.apache.org/)
-- [Apache Mahout issue tracker](https://issues.apache.org/jira/browse/MAHOUT)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-packages/src/charm/mahout/layer-mahout/actions/smoke-test b/bigtop-packages/src/charm/mahout/layer-mahout/actions/smoke-test
index cc98b461..f903da4a 100755
--- a/bigtop-packages/src/charm/mahout/layer-mahout/actions/smoke-test
+++ b/bigtop-packages/src/charm/mahout/layer-mahout/actions/smoke-test
@@ -62,3 +62,4 @@ hadoop jar /usr/lib/mahout/mahout-mr-*-job.jar \
-s SIMILARITY_LOGLIKELIHOOD 2>&1 | tee -a ${RESULT_LOG}
EOF
echo 'mahout smoke-test complete'
+action-set outcome="success"
diff --git a/bigtop-packages/src/charm/mahout/layer-mahout/metadata.yaml b/bigtop-packages/src/charm/mahout/layer-mahout/metadata.yaml
index 7a71d70f..bf8ee0b2 100644
--- a/bigtop-packages/src/charm/mahout/layer-mahout/metadata.yaml
+++ b/bigtop-packages/src/charm/mahout/layer-mahout/metadata.yaml
@@ -1,9 +1,12 @@
name: mahout
-summary: Create scalable and performant machine learning applications
+summary: Mahout from Apache Bigtop
maintainer: Juju Big Data <bigdata@lists.ubuntu.com>
description: >
The Apache Mahout project's goal is to build an environment for quickly
- creating scalable and performant machine learning applications.
+ creating scalable, performant machine learning applications.
+
+ This charm provides version 0.12.2 of the Mahout application from Apache
+ Bigtop.
tags: []
subordinate: true
requires:
diff --git a/bigtop-packages/src/charm/mahout/layer-mahout/tests/01-mahout-test.py b/bigtop-packages/src/charm/mahout/layer-mahout/tests/01-mahout-test.py
index 4e315d30..3dd679ed 100755
--- a/bigtop-packages/src/charm/mahout/layer-mahout/tests/01-mahout-test.py
+++ b/bigtop-packages/src/charm/mahout/layer-mahout/tests/01-mahout-test.py
@@ -26,12 +26,12 @@ class TestDeploy(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.d = amulet.Deployment(series='xenial')
- cls.d.add('mahout', 'cs:xenial/mahout')
- cls.d.add('client', 'cs:xenial/hadoop-client')
- cls.d.add('resourcemanager', 'cs:xenial/hadoop-resourcemanager')
- cls.d.add('namenode', 'cs:xenial/hadoop-namenode')
- cls.d.add('slave', 'cs:xenial/hadoop-slave')
- cls.d.add('plugin', 'cs:xenial/hadoop-plugin')
+ cls.d.add('mahout')
+ cls.d.add('client', charm='hadoop-client')
+ cls.d.add('namenode', charm='hadoop-namenode')
+ cls.d.add('resourcemanager', charm='hadoop-resourcemanager')
+ cls.d.add('slave', charm='hadoop-slave')
+ cls.d.add('plugin', charm='hadoop-plugin')
cls.d.relate('plugin:hadoop-plugin', 'client:hadoop')
cls.d.relate('plugin:namenode', 'namenode:namenode')
diff --git a/bigtop-packages/src/charm/pig/layer-pig/README.md b/bigtop-packages/src/charm/pig/layer-pig/README.md
index 23348766..f38763dc 100644
--- a/bigtop-packages/src/charm/pig/layer-pig/README.md
+++ b/bigtop-packages/src/charm/pig/layer-pig/README.md
@@ -19,35 +19,24 @@
Apache Pig is a platform for creating MapReduce programs used with Hadoop.
It consists of a high-level language (Pig Latin) for expressing data analysis
programs, coupled with infrastructure for evaluating these programs. Learn more
-at [pig.apache.org](http://pig.apache.org).
+at [pig.apache.org][].
-This charm deploys the Pig component of the Apache Bigtop platform and
-supports running Pig in two execution modes:
+This charm deploys version 0.15.0 of the Pig component from [Apache Bigtop][].
- * Local Mode: Pig runs using your local host and file system. Specify local
- mode using the -x flag: `pig -x local`
- * Mapreduce Mode: Pig runs using a Hadoop cluster and HDFS. This is the default
- mode; you can, optionally, specify it using the -x flag:
- `pig` or `pig -x mapreduce`
+[pig.apache.org]: http://pig.apache.org/
+[Apache Bigtop]: http://bigtop.apache.org/
-# Deploying / Using
+# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the
-[getting-started](https://jujucharms.com/docs/2.0/getting-started)
-instructions prior to deploying this charm.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this charm.
-This charm is intended to be used with one of the
-[apache bigtop bundles](https://jujucharms.com/u/bigdata-charmers/#bundles).
+This charm is intended to be deployed via one of the [apache bigtop bundles][].
For example:
juju deploy hadoop-processing
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart](https://launchpad.net/juju-quickstart) with the
-following syntax: `juju quickstart hadoop-processing`.
-
This will deploy an Apache Bigtop Hadoop cluster. More information about this
deployment can be found in the [bundle readme](https://jujucharms.com/hadoop-processing/).
@@ -56,21 +45,14 @@ Now add Pig and relate it to the cluster via the hadoop-plugin:
juju deploy pig
juju add-relation pig plugin
-Once deployment is complete, Apache Pig will be available to execute Pig Latin
-jobs on your data. You can run Pig in a variety of modes:
-
-## Local Mode
-Run Pig in local mode on the Pig unit with the following:
-
- juju ssh pig/0
- pig -x local
-
-## MapReduce Mode
-MapReduce mode is the default for Pig. To run in this mode, ssh to the Pig unit
-and run pig as follows:
+## Network-Restricted Environments
+Charms can be deployed in environments with limited network access. To deploy
+in this environment, configure a Juju model with appropriate proxy and/or
+mirror options. See [Configuring Models][] for more information.
- juju ssh pig/0
- pig
+[getting-started]: https://jujucharms.com/docs/stable/getting-started
+[apache bigtop bundles]: https://jujucharms.com/u/bigdata-charmers/#bundles
+[Configuring Models]: https://jujucharms.com/docs/stable/models-config
# Verifying
@@ -84,7 +66,7 @@ are ready:
This is particularly useful when combined with `watch` to track the on-going
progress of the deployment:
- watch -n 0.5 juju status
+ watch -n 2 juju status
The message column will provide information about a given unit's state.
This charm is ready for use once the status message indicates that it is
@@ -96,15 +78,9 @@ application is functioning as expected. Run the action as follows:
juju run-action pig/0 smoke-test
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do pig/0 smoke-test`.
-
Watch the progress of the smoke test actions with:
- watch -n 0.5 juju show-action-status
-
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
+ watch -n 2 juju show-action-status
Eventually, the action should settle to `status: completed`. If it
reports `status: failed`, the application is not working as expected. Get
@@ -112,17 +88,36 @@ more information about a specific smoke test with:
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
+# Using
-# Network-Restricted Environments
+Once the deployment has been verified, Apache Pig will be available to execute
+Pig Latin jobs on your data. You can run Pig in a variety of modes:
-Charms can be deployed in environments with limited network access. To deploy
-in this environment, configure a Juju model with appropriate
-proxy and/or mirror options. See
-[Configuring Models](https://jujucharms.com/docs/2.0/models-config) for more
-information.
+## Local Mode
+Run Pig in local mode on the Pig unit with the following:
+
+ juju ssh pig/0
+ pig -x local
+
+## MapReduce Mode
+MapReduce mode is the default for Pig. To run in this mode, ssh to the Pig unit
+and run pig as follows:
+
+ juju ssh pig/0
+ pig
+
+
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this charm at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
+
+Ensure `Bigtop` is selected as the project. Typically, charm issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
# Contact Information
@@ -132,9 +127,10 @@ information.
# Resources
+- [Apache Pig home page](http://pig.apache.org/)
- [Apache Bigtop home page](http://bigtop.apache.org/)
- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-packages/src/charm/pig/layer-pig/actions/smoke-test b/bigtop-packages/src/charm/pig/layer-pig/actions/smoke-test
index 378d3da4..87f128d5 100755
--- a/bigtop-packages/src/charm/pig/layer-pig/actions/smoke-test
+++ b/bigtop-packages/src/charm/pig/layer-pig/actions/smoke-test
@@ -18,16 +18,15 @@
import sys
sys.path.append('lib')
-from charmhelpers.core import hookenv
-from charms.layer.apache_bigtop_base import Bigtop
-from charms.reactive import is_state
-
-from jujubigdata.utils import run_as
-
-from path import Path
+from charmhelpers.core import hookenv # noqa: E402
+from charms.layer.apache_bigtop_base import Bigtop # noqa: E402
+from charms.reactive import is_state # noqa: E402
+from jujubigdata.utils import run_as # noqa: E402
+from path import Path # noqa: E402
def fail(msg):
+ hookenv.action_set({'outcome': 'failure'})
hookenv.action_fail(msg)
sys.exit()
@@ -63,8 +62,8 @@ else:
# The smoke tests analyze /etc/passwd. Successful runs will have an 'ubuntu'
# passwd entry in the output.
+hookenv.action_set({'raw': output})
if 'ubuntu' not in output:
- hookenv.action_set({'output': output})
fail('Unable to analyze passwd file with Pig')
else:
hookenv.action_set({'outcome': 'success'})
diff --git a/bigtop-packages/src/charm/pig/layer-pig/metadata.yaml b/bigtop-packages/src/charm/pig/layer-pig/metadata.yaml
index 2898c6a0..4aa1f661 100644
--- a/bigtop-packages/src/charm/pig/layer-pig/metadata.yaml
+++ b/bigtop-packages/src/charm/pig/layer-pig/metadata.yaml
@@ -1,9 +1,10 @@
name: pig
-summary: Create Pig Latin programs for data warehouse analysis
+summary: Pig from Apache Bigtop
maintainer: Juju Big Data <bigdata@lists.ubuntu.com>
description: |
Apache Pig is a platform for creating MapReduce programs used with Hadoop.
It consists of a high-level language (Pig Latin) for expressing data analysis
programs, coupled with infrastructure for evaluating these programs.
- Learn more at http://pig.apache.org.
+
+ This charm provides version 0.15.0 of the Pig application from Apache Bigtop.
tags: []
diff --git a/bigtop-packages/src/charm/pig/layer-pig/tests/01-deploy.py b/bigtop-packages/src/charm/pig/layer-pig/tests/01-deploy.py
index 53364c18..b7e8620f 100755
--- a/bigtop-packages/src/charm/pig/layer-pig/tests/01-deploy.py
+++ b/bigtop-packages/src/charm/pig/layer-pig/tests/01-deploy.py
@@ -27,7 +27,7 @@ class TestDeploy(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.d = amulet.Deployment(series='xenial')
- cls.d.add('pig', 'cs:xenial/pig')
+ cls.d.add('pig')
cls.d.setup(timeout=1800)
cls.d.sentry.wait_for_messages({'pig': re.compile('ready')}, timeout=1800)
diff --git a/bigtop-packages/src/charm/spark/layer-spark/README.md b/bigtop-packages/src/charm/spark/layer-spark/README.md
index 6a55c820..f7feaab7 100644
--- a/bigtop-packages/src/charm/spark/layer-spark/README.md
+++ b/bigtop-packages/src/charm/spark/layer-spark/README.md
@@ -17,36 +17,18 @@
# Overview
Apache Spark is a fast and general purpose engine for large-scale data
-processing. This charm deploys the Spark component of the [Apache Bigtop][]
-platform. Key features:
+processing. Learn more at [spark.apache.org][].
- * **Speed**
-
- Run programs up to 100x faster than Hadoop MapReduce in memory, or 10x faster
- on disk. Spark has an advanced DAG execution engine that supports cyclic data
- flow and in-memory computing.
-
- * **Ease of Use**
-
- Write applications quickly in Java, Scala or Python. Spark offers over 80
- high-level operators that make it easy to build parallel apps for use
- interactively from the Scala and Python shells.
-
- * **General Purpose Engine**
-
- Combine SQL, streaming, and complex analytics. Spark powers a stack of
- high-level tools including Shark for SQL, MLlib for machine learning, GraphX,
- and Spark Streaming. Combine these frameworks seamlessly in the same
- application.
+This charm deploys version 2.1.0 of the Spark component from [Apache Bigtop][].
+[spark.apache.org]: http://spark.apache.org/
[Apache Bigtop]: http://bigtop.apache.org/
# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the [getting-started][] instructions prior to deploying this
-charm.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this charm.
This charm supports running Spark in a variety of modes:
@@ -80,28 +62,19 @@ the unit acting as master, query Zookeeper as follows:
juju run --unit zookeeper/0 'echo "get /spark/master_status" | /usr/lib/zookeeper/bin/zkCli.sh'
-### YARN-client and YARN-cluster
+### YARN
This charm leverages our pluggable Hadoop model with the `hadoop-plugin`
-interface. This means that this charm can be related to a base Apache Hadoop
+interface. This means that this charm can be related to an Apache Hadoop
cluster to run Spark jobs there. The suggested deployment method is to use the
-[hadoop-processing][] bundle and add a relation between spark and the plugin.
+[hadoop-spark][] bundle:
-
- juju deploy hadoop-processing
- juju add-relation plugin spark
-
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-hadoop-processing`.
+ juju deploy hadoop-spark
To switch among the above execution modes, set the `spark_execution_mode`
config variable:
juju config spark spark_execution_mode=<new_mode>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju set spark spark_execution_mode=<new_mode>`.
-
See the **Configuring** section below for supported mode options.
## Network-Restricted Environments
@@ -110,8 +83,7 @@ in this environment, configure a Juju model with appropriate proxy and/or
mirror options. See [Configuring Models][] for more information.
[getting-started]: https://jujucharms.com/docs/stable/getting-started
-[hadoop-processing]: https://jujucharms.com/hadoop-processing/
-[juju-quickstart]: https://launchpad.net/juju-quickstart
+[hadoop-spark]: https://jujucharms.com/hadoop-spark/
[Configuring Models]: https://jujucharms.com/docs/stable/models-config
@@ -138,28 +110,19 @@ application is functioning as expected. Run the action as follows:
juju run-action spark/0 smoke-test
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do spark/0 smoke-test`.
-
Watch the progress of the smoke test actions with:
watch -n 2 juju show-action-status
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
-
Eventually, the action should settle to `status: completed`. If it
reports `status: failed`, the application is not working as expected. Get
more information about a specific smoke test with:
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
-
## Spark Master web UI
Spark provides a web console that can be used to verify information about
-the cluster. To access it, find the `PUBLIC-ADDRESS` of the spark application
+the cluster. To access it, find the `Public address` of the spark application
and expose it:
juju status spark
@@ -179,10 +142,33 @@ address. The job history web interface will be available at the following URL:
# Using
-Once deployment is verified, Spark batch or streaming jobs can be run in a
-variety of ways:
+## Actions
+Once Spark is ready, there are a number of actions available in this charm.
+
+Run a benchmark (as described in the **Benchmarking** section):
+
+ juju run-action spark/0 pagerank
+ juju show-action-output <id> # <-- id from above command
+
+Run a smoke test (as described in the **Verifying** section):
+
+ juju run-action spark/0 smoke-test
+ juju show-action-output <id> # <-- id from above command
+
+Start/Stop/Restart the Spark Job History service:
+
+ juju run-action spark/0 [start|stop|restart]-spark-job-history-server
+ juju show-action-output <id> # <-- id from above command
+
+Submit a Spark job:
-### Spark shell
+ juju run-action spark/0 spark-submit \
+ options='--class org.apache.spark.examples.SparkPi' \
+ job='/usr/lib/spark/examples/jars/spark-examples.jar' \
+ job-args='10'
+ juju show-action-output <id> # <-- id from above command
+
+## Spark shell
Spark shell provides a simple way to learn the API, as well as a powerful
tool to analyze data interactively. It is available in either Scala or Python
and can be run from the Spark unit as follows:
@@ -191,14 +177,14 @@ and can be run from the Spark unit as follows:
spark-shell # for interaction using scala
pyspark # for interaction using python
-### Command line
+## Command line
SSH to the Spark unit and manually run a spark-submit job, for example:
juju ssh spark/0
spark-submit --class org.apache.spark.examples.SparkPi \
- --master yarn-client /usr/lib/spark/lib/spark-examples*.jar 10
+ /usr/lib/spark/examples/jars/spark-examples.jar 10
-### Apache Zeppelin
+## Apache Zeppelin
Apache Zeppelin is a web-based notebook that enables interactive data
analytics. Make beautiful data-driven, interactive, and collaborative documents
with SQL, Scala and more. Deploy Zeppelin and relate it to Spark:
@@ -206,7 +192,7 @@ with SQL, Scala and more. Deploy Zeppelin and relate it to Spark:
juju deploy zeppelin
juju add-relation spark zeppelin
-To access the web console, find the `PUBLIC-ADDRESS` of the zeppelin
+To access the web console, find the `Public address` of the zeppelin
application and expose it:
juju status zeppelin
@@ -219,17 +205,47 @@ The web interface will be available at the following URL:
# Configuring
-## spark_bench_enabled
+Charm configuration can be changed at runtime with `juju config`. This charm
+supports the following config parameters.
+
+## driver_memory
+Amount of memory available for the Spark driver process (1g by default).
+Set a different value with:
+
+ juju config spark driver_memory=4096m
+
+## executor_memory
+Amount of memory available for each Spark executor process (1g by default).
+Set a different value with:
+
+ juju config spark executor_memory=2g
+
+> **Note**: When Spark is in YARN mode, ensure the configured executor memory
+does not exceed the NodeManager maximum (defined on each nodemanager as
+`yarn.nodemanager.resource.memory-mb` in `yarn-default.xml`).
+
+## install-cuda
+Provided by `layer-nvidia-cuda`, this option controls the installation
+of NVIDIA CUDA packages if capable GPU hardware is present. When `false` (the
+default), CUDA will not be installed or configured regardless of hardware
+support. Set this to `true` to fetch and install CUDA-related packages from
+the NVIDIA developer repository.
+
+ juju config spark install-cuda=true
+
+> **Note**: This option requires external network access to
+http://developer.download.nvidia.com/. Ensure appropriate proxies are
+configured if needed.
+## spark_bench_enabled
Install the SparkBench benchmarking suite. If `true` (the default), this charm
will download spark bench from the URL specified by `spark_bench_ppc64le`
or `spark_bench_x86_64`, depending on the unit's architecture.
## spark_execution_mode
-
Spark has four modes of execution: local, standalone, yarn-client, and
yarn-cluster. The default mode is `standalone` and can be changed by setting
-the `spark_execution_mode` config variable.
+the `spark_execution_mode` config option.
* **Local**
@@ -270,27 +286,16 @@ the `spark_execution_mode` config variable.
# Benchmarking
-This charm provides several benchmarks, including the [Spark Bench][]
-benchmarking suite (if enabled), to gauge the performance of the environment.
+This charm provides benchmarks to gauge the performance of the Spark cluster.
Each benchmark is an action that can be run with `juju run-action`:
- $ juju actions spark | grep Bench
- connectedcomponent Run the Spark Bench ConnectedComponent benchmark.
- decisiontree Run the Spark Bench DecisionTree benchmark.
- kmeans Run the Spark Bench KMeans benchmark.
- linearregression Run the Spark Bench LinearRegression benchmark.
- logisticregression Run the Spark Bench LogisticRegression benchmark.
- matrixfactorization Run the Spark Bench MatrixFactorization benchmark.
- pagerank Run the Spark Bench PageRank benchmark.
- pca Run the Spark Bench PCA benchmark.
- pregeloperation Run the Spark Bench PregelOperation benchmark.
- shortestpaths Run the Spark Bench ShortestPaths benchmark.
- sql Run the Spark Bench SQL benchmark.
- stronglyconnectedcomponent Run the Spark Bench StronglyConnectedComponent benchmark.
- svdplusplus Run the Spark Bench SVDPlusPlus benchmark.
- svm Run the Spark Bench SVM benchmark.
-
- $ juju run-action spark/0 svdplusplus
+ $ juju actions spark
+ ...
+ pagerank Calculate PageRank for a sample data set
+ sparkpi Calculate Pi
+ ...
+
+ $ juju run-action spark/0 pagerank
Action queued with id: 339cec1f-e903-4ee7-85ca-876fb0c3d28e
$ juju show-action-output 339cec1f-e903-4ee7-85ca-876fb0c3d28e
@@ -299,27 +304,27 @@ Each benchmark is an action that can be run with `juju run-action`:
composite:
direction: asc
units: secs
- value: "200.754000"
- raw: |
- SVDPlusPlus,2016-11-02-03:08:26,200.754000,85.974071,.428255,0,SVDPlusPlus-MLlibConfig,,,,,10,,,50000,4.0,1.3,
- start: 2016-11-02T03:08:26Z
- stop: 2016-11-02T03:11:47Z
- results:
- duration:
- direction: asc
- units: secs
- value: "200.754000"
- throughput:
- direction: desc
- units: x/sec
- value: ".428255"
+ value: "83"
+ start: 2017-04-12T23:22:38Z
+ stop: 2017-04-12T23:24:01Z
+ output: '{''status'': ''completed''}'
status: completed
timing:
- completed: 2016-11-02 03:11:48 +0000 UTC
- enqueued: 2016-11-02 03:08:21 +0000 UTC
- started: 2016-11-02 03:08:26 +0000 UTC
+ completed: 2017-04-12 23:24:02 +0000 UTC
+ enqueued: 2017-04-12 23:22:36 +0000 UTC
+ started: 2017-04-12 23:22:37 +0000 UTC
+
+
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this charm at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
-[Spark Bench]: https://github.com/SparkTC/spark-bench
+Ensure `Bigtop` is selected as the project. Typically, charm issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
# Contact Information
@@ -329,9 +334,10 @@ Each benchmark is an action that can be run with `juju run-action`:
# Resources
+- [Apache Spark home page](http://spark.apache.org/)
- [Apache Bigtop home page](http://bigtop.apache.org/)
- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-packages/src/charm/spark/layer-spark/actions.yaml b/bigtop-packages/src/charm/spark/layer-spark/actions.yaml
index 6564b1c2..d0be216c 100644
--- a/bigtop-packages/src/charm/spark/layer-spark/actions.yaml
+++ b/bigtop-packages/src/charm/spark/layer-spark/actions.yaml
@@ -1,5 +1,12 @@
+pagerank:
+ description: Calculate PageRank for a sample data set
+ params:
+ iterations:
+ description: Number of iterations for the SparkPageRank job
+ type: string
+ default: "1"
smoke-test:
- description: Verify that Spark is working by calculating pi.
+ description: Verify that Spark is working by calculating pi
sparkpi:
description: Calculate Pi
params:
@@ -19,8 +26,6 @@ logisticregression:
description: Run the Spark Bench LogisticRegression benchmark.
matrixfactorization:
description: Run the Spark Bench MatrixFactorization benchmark.
-pagerank:
- description: Run the Spark Bench PageRank benchmark.
pca:
description: Run the Spark Bench PCA benchmark.
pregeloperation:
@@ -41,40 +46,32 @@ start-spark-job-history-server:
description: Start the Spark job history server.
stop-spark-job-history-server:
description: Stop the Spark job history server.
-submit:
- description: Submit a job to Spark.
+spark-submit:
+ description: Submit a job to run with the 'spark-submit' utility.
required: ['job']
params:
job:
description: >
URL to a JAR or Python file. This can be any URL supported by
- spark-submit, such as a remote URL, an hdfs:// path (if
- connected to HDFS), etc.
- type: string
- class:
- description: >
- If a JAR is given, this should be the name of the class within
- the JAR to run.
+ spark-submit, such as a local path, remote URL, an hdfs:// path
+ (if connected to HDFS), etc.
type: string
job-args:
- description: Arguments for the job.
- packages:
- description: Comma-separated list of packages to include.
- type: string
- py-files:
- description: Comma-separated list of Python packages to include.
- type: string
- extra-params:
+ description: Arguments required by the job.
+ options:
description: >
- Additional params to pass to spark-submit.
- For example: "--executor-memory 1000M --supervise"
+ Options to pass to spark-submit.
+ For example, "--driver-memory 1000M --class org.foo.MyApp"
type: string
cron:
description: >
Schedule the job to be run periodically, according to the
- given cron rule. For example: "*/5 * * * *" will run the
- job every 5 minutes.
+ given cron rule. For example, "'*/5 * * * *'" will run the
+ job every 5 minutes (note the use of double and single quotes
+ is required to parse this value as a string).
type: string
+submit:
+ description: DEPRECATED, use the spark-submit action instead.
list-jobs:
description: List scheduled periodic jobs.
remove-job:
diff --git a/bigtop-packages/src/charm/spark/layer-spark/actions/list-jobs b/bigtop-packages/src/charm/spark/layer-spark/actions/list-jobs
index b6fdf182..31da9db5 100755
--- a/bigtop-packages/src/charm/spark/layer-spark/actions/list-jobs
+++ b/bigtop-packages/src/charm/spark/layer-spark/actions/list-jobs
@@ -15,10 +15,15 @@
# limitations under the License.
set -e
-for line in "$(crontab -lu ubuntu | grep '# mapreduce job: ')"; do
+for line in "$(crontab -lu ubuntu | grep '# action: ')"; do
if [[ -n "$line" ]]; then
- action_id=$(echo "$line" | sed -e 's/.* # mapreduce job: //')
- job_code=$(echo "$line" | sed -e 's/ # mapreduce job: .*//')
+ # the action uuid is after the 'action:' comment
+ action_id=$(echo "$line" | sed -e 's/.* # action: //')
+
+ # the actual job is everything before the 'action:' comment
+ job_code=$(echo "$line" | sed -e 's/ # action: .*//')
+
+ # show the people what they want
action-set job.$action_id="$job_code"
fi
done
diff --git a/bigtop-packages/src/charm/spark/layer-spark/actions/pagerank b/bigtop-packages/src/charm/spark/layer-spark/actions/pagerank
index 9e15049e..2650e74a 120000..100755
--- a/bigtop-packages/src/charm/spark/layer-spark/actions/pagerank
+++ b/bigtop-packages/src/charm/spark/layer-spark/actions/pagerank
@@ -1 +1,136 @@
-sparkbench \ No newline at end of file
+#!/usr/bin/env python3
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+import os
+import subprocess
+import sys
+
+from path import Path
+from time import time
+
+from charmhelpers.core import hookenv
+from charms.benchmark import Benchmark
+from charms.reactive import is_state
+from jujubigdata import utils
+
+
+def fail(msg):
+ hookenv.action_set({'outcome': 'failure'})
+ hookenv.action_fail(msg)
+ sys.exit()
+
+
+def main():
+ bench = Benchmark()
+
+ if not is_state('spark.started'):
+ msg = 'Spark is not started yet'
+ fail(msg)
+
+ # gather params and create dir to store results
+ num_iter = hookenv.action_get('iterations')
+ run = int(time())
+ result_dir = Path('/opt/sparkpagerank-results')
+ result_log = result_dir / '{}.log'.format(run)
+ if not result_dir.exists():
+ result_dir.mkdir()
+ result_dir.chown('ubuntu', 'ubuntu')
+ hookenv.log("values: {} {}".format(num_iter, result_log))
+
+ sample = "/home/ubuntu/SparkBench/PageRank/web-Google.txt"
+ if not os.path.isfile(sample):
+ msg = 'Could not find pagerank sample data'
+ fail('{}: {}'.format(msg, sample))
+
+ # Benchmark input data is packed into our sparkbench.tgz, which makes
+ # it available on all spark units. In yarn mode, however, the nodemanagers
+ # act as the spark workers and will not have access to this local data.
+ # In yarn mode, copy our input data to hdfs so nodemanagers can access it.
+ mode = hookenv.config()['spark_execution_mode']
+ if mode.startswith('yarn'):
+ if is_state('hadoop.hdfs.ready'):
+ try:
+ utils.run_as('ubuntu',
+ 'hdfs', 'dfs', '-put', '-f', sample, '/user/ubuntu',
+ capture_output=True)
+ except subprocess.CalledProcessError as e:
+ msg = 'Unable to copy pagerank sample data to hdfs'
+ fail('{}: {}'.format(msg, e))
+ else:
+ sample = "/user/ubuntu/web-Google.txt"
+ else:
+ msg = 'Spark is configured for yarn mode, but HDFS is not ready yet'
+ fail(msg)
+
+ # find jar location
+ spark_home = "/usr/lib/spark"
+ example_jar_name = "spark-examples.jar"
+ example_jar_path = None
+ for root, dirs, files in os.walk(spark_home):
+ if example_jar_name in files:
+ example_jar_path = os.path.join(root, example_jar_name)
+
+ if not example_jar_path:
+ msg = 'Could not find {}'.format(example_jar_name)
+ fail(msg)
+
+ print('Calculating PageRank')
+ bench.start()
+ start = int(time())
+
+ with open(result_log, 'w') as log_file:
+ arg_list = [
+ 'spark-submit',
+ '--class',
+ 'org.apache.spark.examples.SparkPageRank',
+ example_jar_path,
+ sample,
+ num_iter,
+ ]
+
+ try:
+ subprocess.check_call(arg_list, stdout=log_file,
+ stderr=subprocess.STDOUT)
+ except subprocess.CalledProcessError as e:
+ msg = 'SparkPageRank command failed: {}'.format(' '.join(arg_list))
+ fail('{}: {}'.format(msg, e))
+
+ stop = int(time())
+ bench.finish()
+
+ duration = stop - start
+ bench.set_composite_score(duration, units='secs', direction='asc')
+
+ # Tell the user how they can get the full result log
+ scp_log_msg = "juju scp {}:{} .".format(hookenv.local_unit(), result_log)
+ hookenv.action_set({'meta.fetchcmd': scp_log_msg})
+
+ with open(result_log) as log:
+ success = False
+ for line in log.readlines():
+ if 'rank' in line:
+ success = True
+ break
+
+ if not success:
+ msg = 'Spark-submit failed to calculate pagerank'
+ fail(msg)
+
+ hookenv.action_set({'outcome': 'success'})
+
+
+if __name__ == '__main__':
+ main()
diff --git a/bigtop-packages/src/charm/spark/layer-spark/actions/restart-spark-job-history-server b/bigtop-packages/src/charm/spark/layer-spark/actions/restart-spark-job-history-server
index 411c335b..331239af 100755
--- a/bigtop-packages/src/charm/spark/layer-spark/actions/restart-spark-job-history-server
+++ b/bigtop-packages/src/charm/spark/layer-spark/actions/restart-spark-job-history-server
@@ -15,22 +15,22 @@
# limitations under the License.
import sys
+from charmhelpers.core import hookenv, host
+from charms.reactive import is_state
-try:
- from charmhelpers.core import host, hookenv, unitdata
- from jujubigdata import utils
- charm_ready = True
-except ImportError:
- charm_ready = False
-if not charm_ready:
- from subprocess import call
- call(['action-fail', 'Spark service not yet ready'])
- sys.exit(1)
+def fail(msg):
+ hookenv.action_set({'outcome': 'failure'})
+ hookenv.action_fail(msg)
+ sys.exit()
+
+
+if not is_state('spark.started'):
+ msg = 'Spark is not started yet'
+ fail(msg)
if not host.service_available('spark-history'):
- from subprocess import call
- call(['action-fail', 'Spark history service not available'])
- sys.exit(1)
+ msg = 'Spark history service not available'
+ fail(msg)
host.service_restart('spark-history-server')
diff --git a/bigtop-packages/src/charm/spark/layer-spark/actions/spark-submit b/bigtop-packages/src/charm/spark/layer-spark/actions/spark-submit
new file mode 100755
index 00000000..90bd68ef
--- /dev/null
+++ b/bigtop-packages/src/charm/spark/layer-spark/actions/spark-submit
@@ -0,0 +1,44 @@
+#!/bin/bash
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+set -e
+
+if ! charms.reactive is_state 'spark.started'; then
+ action-set outcome="failure"
+ action-fail 'Spark not yet ready'
+ exit 1
+fi
+
+job="$(action-get job)"
+job_args="$(action-get job-args)"
+options="$(action-get options)"
+cron="$(action-get cron)"
+
+job_code=". /etc/environment ; spark-submit ${options} ${job} ${job_args}"
+action-set job-code="$job_code"
+
+if [[ -z "$cron" ]]; then
+ su ubuntu -c "$job_code"
+else
+ juju-log "Scheduling job with ID $JUJU_ACTION_UUID"
+ action-set action-id="$JUJU_ACTION_UUID"
+ job_line="$cron $job_code # action: $JUJU_ACTION_UUID"
+
+ # if we dont have a crontab, make an empty one
+ crontab -lu ubuntu > /dev/null || echo -n | crontab -u ubuntu -
+
+ # append our job to then end of any existing crontab
+ (crontab -lu ubuntu; echo "$job_line") | crontab -u ubuntu -
+fi
diff --git a/bigtop-packages/src/charm/spark/layer-spark/actions/sparkbench b/bigtop-packages/src/charm/spark/layer-spark/actions/sparkbench
index 906a30e9..3f626e3e 100755
--- a/bigtop-packages/src/charm/spark/layer-spark/actions/sparkbench
+++ b/bigtop-packages/src/charm/spark/layer-spark/actions/sparkbench
@@ -16,8 +16,9 @@
set -ex
if ! charms.reactive is_state 'spark.started'; then
+ action-set outcome="failure"
action-fail 'Spark not yet ready'
- exit
+ exit 1
fi
# Do not call this script directly. Call it via one of the symlinks. The
@@ -138,11 +139,14 @@ if [ -f "${SB_APPS}" ]; then
# send raw data (benchmark-raw takes a file)
echo ${DATA} > ${RESULT_LOG}
benchmark-raw ${RESULT_LOG}
+ action-set outcome="success"
else
- echo "ERROR: Invalid benchmark (${BENCHMARK})"
+ action-set outcome="failure"
+ action-fail "ERROR: Invalid benchmark (${BENCHMARK})"
exit 1
fi
else
- echo "ERROR: Could not find SparkBench application list"
+ action-set outcome="failure"
+ action-fail "ERROR: Could not find SparkBench application list"
exit 1
fi
diff --git a/bigtop-packages/src/charm/spark/layer-spark/actions/sparkpi b/bigtop-packages/src/charm/spark/layer-spark/actions/sparkpi
index 9afceaf2..93a4f107 100755
--- a/bigtop-packages/src/charm/spark/layer-spark/actions/sparkpi
+++ b/bigtop-packages/src/charm/spark/layer-spark/actions/sparkpi
@@ -14,29 +14,30 @@
# See the License for the specific language governing permissions and
# limitations under the License.
+import os
import sys
-sys.path.append('lib')
from path import Path
from time import time
import subprocess
-from charmhelpers.contrib.benchmark import Benchmark
from charmhelpers.core import hookenv
+from charms.benchmark import Benchmark
from charms.reactive import is_state
-def fail(msg, output):
- hookenv.action_set({'output': output})
+def fail(msg):
+ hookenv.action_set({'outcome': 'failure'})
hookenv.action_fail(msg)
- sys.exit(1)
+ sys.exit()
def main():
bench = Benchmark()
if not is_state('spark.started'):
- fail('Spark not yet ready', 'error')
+ msg = 'Spark is not started yet'
+ fail(msg)
num_partitions = hookenv.action_get('partitions') or ''
@@ -55,12 +56,24 @@ def main():
print('calculating pi')
+ # get the examples jar
+ spark_home = "/usr/lib/spark"
+ example_jar_name = "spark-examples.jar"
+ example_jar_path = None
+ for root, dirs, files in os.walk(spark_home):
+ if example_jar_name in files:
+ example_jar_path = os.path.join(root, example_jar_name)
+
+ if not example_jar_path:
+ msg = 'Could not find {}'.format(example_jar_name)
+ fail(msg)
+
with open(result_log, 'w') as log_file:
arg_list = [
'spark-submit',
'--class',
'org.apache.spark.examples.SparkPi',
- '/usr/lib/spark/lib/spark-examples.jar'
+ example_jar_path
]
if num_partitions:
# This is always blank. TODO: figure out what it was
@@ -73,26 +86,32 @@ def main():
except subprocess.CalledProcessError as e:
print('smoke test command failed: ')
print('{}'.format(' '.join(arg_list)))
- fail('spark-submit failed: {}'.format(e), 'error')
+ fail('spark-submit failed: {}'.format(e))
stop = int(time())
bench.finish()
duration = stop - start
- bench.set_composite_score(duration, 'secs')
- subprocess.check_call(['benchmark-raw', result_log])
+ bench.set_composite_score(duration, units='secs', direction='asc')
+
+ # Tell the user how they can get the full result log
+ scp_log_msg = "juju scp {}:{} .".format(hookenv.local_unit(), result_log)
+ hookenv.action_set({'meta.fetchcmd': scp_log_msg})
with open(result_log) as log:
success = False
for line in log.readlines():
if 'Pi is roughly 3.1' in line:
success = True
+ pi_calc = line
break
if not success:
- fail('spark-submit did not calculate pi', 'error')
+ msg = 'Spark-submit failed to calculate pi'
+ fail(msg)
- hookenv.action_set({'output': {'status': 'completed'}})
+ hookenv.action_set({'meta.raw': pi_calc})
+ hookenv.action_set({'outcome': 'success'})
if __name__ == '__main__':
diff --git a/bigtop-packages/src/charm/spark/layer-spark/actions/start-spark-job-history-server b/bigtop-packages/src/charm/spark/layer-spark/actions/start-spark-job-history-server
index 9677a383..cc218dbb 100755
--- a/bigtop-packages/src/charm/spark/layer-spark/actions/start-spark-job-history-server
+++ b/bigtop-packages/src/charm/spark/layer-spark/actions/start-spark-job-history-server
@@ -15,22 +15,22 @@
# limitations under the License.
import sys
+from charmhelpers.core import hookenv, host
+from charms.reactive import is_state
-try:
- from charmhelpers.core import host, hookenv, unitdata
- from jujubigdata import utils
- charm_ready = True
-except ImportError:
- charm_ready = False
-if not charm_ready:
- from subprocess import call
- call(['action-fail', 'Spark service not yet ready'])
- sys.exit(1)
+def fail(msg):
+ hookenv.action_set({'outcome': 'failure'})
+ hookenv.action_fail(msg)
+ sys.exit()
+
+
+if not is_state('spark.started'):
+ msg = 'Spark is not started yet'
+ fail(msg)
if not host.service_available('spark-history-server'):
- from subprocess import call
- call(['action-fail', 'Spark history service not available'])
- sys.exit(1)
+ msg = 'Spark history service not available'
+ fail(msg)
host.service_start('spark-history-server')
diff --git a/bigtop-packages/src/charm/spark/layer-spark/actions/stop-spark-job-history-server b/bigtop-packages/src/charm/spark/layer-spark/actions/stop-spark-job-history-server
index fbe41cf9..368b1e91 100755
--- a/bigtop-packages/src/charm/spark/layer-spark/actions/stop-spark-job-history-server
+++ b/bigtop-packages/src/charm/spark/layer-spark/actions/stop-spark-job-history-server
@@ -15,22 +15,22 @@
# limitations under the License.
import sys
+from charmhelpers.core import hookenv, host
+from charms.reactive import is_state
-try:
- from charmhelpers.core import host, hookenv, unitdata
- from jujubigdata import utils
- charm_ready = True
-except ImportError:
- charm_ready = False
-if not charm_ready:
- from subprocess import call
- call(['action-fail', 'Spark service not yet ready'])
- sys.exit(1)
+def fail(msg):
+ hookenv.action_set({'outcome': 'failure'})
+ hookenv.action_fail(msg)
+ sys.exit()
+
+
+if not is_state('spark.started'):
+ msg = 'Spark is not started yet'
+ fail(msg)
if not host.service_available('spark-history-server'):
- from subprocess import call
- call(['action-fail', 'Spark history service not available'])
- sys.exit(1)
+ msg = 'Spark history service not available'
+ fail(msg)
host.service_stop('spark-history-server')
diff --git a/bigtop-packages/src/charm/spark/layer-spark/actions/submit b/bigtop-packages/src/charm/spark/layer-spark/actions/submit
index a25a7af1..3604288b 100755..120000
--- a/bigtop-packages/src/charm/spark/layer-spark/actions/submit
+++ b/bigtop-packages/src/charm/spark/layer-spark/actions/submit
@@ -1,57 +1 @@
-#!/bin/bash
-# Licensed to the Apache Software Foundation (ASF) under one or more
-# contributor license agreements. See the NOTICE file distributed with
-# this work for additional information regarding copyright ownership.
-# The ASF licenses this file to You under the Apache License, Version 2.0
-# (the "License"); you may not use this file except in compliance with
-# the License. You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-set -e
-
-if ! charms.reactive is_state 'spark.started'; then
- action-fail 'Spark not yet ready'
- exit
-fi
-
-py_files="$(action-get py-files)"
-packages="$(action-get packages)"
-extra_params="$(action-get extra-params)"
-class="$(action-get class)"
-job="$(action-get job)"
-job_args="$(action-get job-args)"
-cron="$(action-get cron)"
-
-submit_args='--deploy-mode cluster'
-if [[ -n "$packages" ]]; then
- submit_args="$submit_args --packages $packages"
-fi
-if [[ -n "$py_files" ]]; then
- submit_args="$submit_args --py-files $py_files"
-fi
-if [[ -n "$extra_params" ]]; then
- submit_args="$submit_args $extra_params"
-fi
-if [[ -n "$class" ]]; then
- submit_args="$submit_args --class $class"
-fi
-submit_args="$submit_args $job"
-
-job_code=". /etc/environment ; spark-submit ${submit_args} ${job_args}"
-action-set job-code="$job_code"
-
-if [[ -z "$cron" ]]; then
- su ubuntu -c "$job_code"
-else
- juju-log "Scheduling job with ID $JUJU_ACTION_UUID"
- action-set action-id="$JUJU_ACTION_UUID"
- job_line="$cron $job_code # $JUJU_ACTION_UUID"
- crontab -lu ubuntu > /dev/null || echo -n | crontab -u ubuntu -
- (crontab -lu ubuntu; echo "$job_line") | crontab -u ubuntu -
-fi
+spark-submit \ No newline at end of file
diff --git a/bigtop-packages/src/charm/spark/layer-spark/config.yaml b/bigtop-packages/src/charm/spark/layer-spark/config.yaml
index 2a887521..b923687e 100644
--- a/bigtop-packages/src/charm/spark/layer-spark/config.yaml
+++ b/bigtop-packages/src/charm/spark/layer-spark/config.yaml
@@ -1,10 +1,18 @@
options:
- resources_mirror:
+ driver_memory:
type: string
- default: ''
+ default: '1g'
description: |
- URL used to fetch resources (e.g., Hadoop binaries) instead of the
- location specified in resources.yaml.
+ Specify gigabytes (e.g. 1g) or megabytes (e.g. 1024m). If running
+ in 'local' or 'standalone' mode, you may also specify a percentage
+ of total system memory (e.g. 50%).
+ executor_memory:
+ type: string
+ default: '1g'
+ description: |
+ Specify gigabytes (e.g. 1g) or megabytes (e.g. 1024m). If running
+ in 'local' or 'standalone' mode, you may also specify a percentage
+ of total system memory (e.g. 50%).
spark_bench_enabled:
type: boolean
default: true
@@ -16,7 +24,7 @@ options:
preserved.
spark_bench_ppc64le:
type: string
- default: 'https://s3.amazonaws.com/jujubigdata/ibm/noarch/SparkBench-2.0-20161101.tgz#sha256=2a34150dc3ad4a1469ca09c202f4db4ee995e2932b8a633d8c006d46c1f61e9f'
+ default: 'https://s3.amazonaws.com/jujubigdata/ibm/noarch/SparkBench-2.0-20170403.tgz#sha256=709caec6667dd82e42de25eb8bcd5763ca894e99e5c83c97bdfcf62cb1aa00c8'
description: |
URL (including hash) of a ppc64le tarball of SparkBench. By
default, this points to a pre-built SparkBench binary based on
@@ -24,7 +32,7 @@ options:
'spark_bench_enabled' is 'true'.
spark_bench_x86_64:
type: string
- default: 'https://s3.amazonaws.com/jujubigdata/ibm/noarch/SparkBench-2.0-20161101.tgz#sha256=2a34150dc3ad4a1469ca09c202f4db4ee995e2932b8a633d8c006d46c1f61e9f'
+ default: 'https://s3.amazonaws.com/jujubigdata/ibm/noarch/SparkBench-2.0-20170403.tgz#sha256=709caec6667dd82e42de25eb8bcd5763ca894e99e5c83c97bdfcf62cb1aa00c8'
description: |
URL (including hash) of an x86_64 tarball of SparkBench. By
default, this points to a pre-built SparkBench binary based on
diff --git a/bigtop-packages/src/charm/spark/layer-spark/icon.svg b/bigtop-packages/src/charm/spark/layer-spark/icon.svg
index a0da80db..2c457350 100644
--- a/bigtop-packages/src/charm/spark/layer-spark/icon.svg
+++ b/bigtop-packages/src/charm/spark/layer-spark/icon.svg
@@ -1,843 +1,13 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
-<!-- Created with Inkscape (http://www.inkscape.org/) -->
-
-<svg
- xmlns:dc="http://purl.org/dc/elements/1.1/"
- xmlns:cc="http://creativecommons.org/ns#"
- xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
- xmlns:svg="http://www.w3.org/2000/svg"
- xmlns="http://www.w3.org/2000/svg"
- xmlns:xlink="http://www.w3.org/1999/xlink"
- xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
- xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
- width="96"
- height="96"
- id="svg6517"
- version="1.1"
- inkscape:version="0.48.4 r9939"
- sodipodi:docname="icon.svg">
- <defs
- id="defs6519">
- <linearGradient
- inkscape:collect="always"
- xlink:href="#Background"
- id="linearGradient6461"
- gradientUnits="userSpaceOnUse"
- x1="0"
- y1="970.29498"
- x2="144"
- y2="970.29498"
- gradientTransform="matrix(0,-0.66666669,0.6660448,0,-866.25992,731.29077)" />
- <linearGradient
- id="Background">
- <stop
- id="stop4178"
- offset="0"
- style="stop-color:#b8b8b8;stop-opacity:1" />
- <stop
- id="stop4180"
- offset="1"
- style="stop-color:#c9c9c9;stop-opacity:1" />
- </linearGradient>
- <filter
- style="color-interpolation-filters:sRGB;"
- inkscape:label="Inner Shadow"
- id="filter1121">
- <feFlood
- flood-opacity="0.59999999999999998"
- flood-color="rgb(0,0,0)"
- result="flood"
- id="feFlood1123" />
- <feComposite
- in="flood"
- in2="SourceGraphic"
- operator="out"
- result="composite1"
- id="feComposite1125" />
- <feGaussianBlur
- in="composite1"
- stdDeviation="1"
- result="blur"
- id="feGaussianBlur1127" />
- <feOffset
- dx="0"
- dy="2"
- result="offset"
- id="feOffset1129" />
- <feComposite
- in="offset"
- in2="SourceGraphic"
- operator="atop"
- result="composite2"
- id="feComposite1131" />
- </filter>
- <filter
- style="color-interpolation-filters:sRGB;"
- inkscape:label="Drop Shadow"
- id="filter950">
- <feFlood
- flood-opacity="0.25"
- flood-color="rgb(0,0,0)"
- result="flood"
- id="feFlood952" />
- <feComposite
- in="flood"
- in2="SourceGraphic"
- operator="in"
- result="composite1"
- id="feComposite954" />
- <feGaussianBlur
- in="composite1"
- stdDeviation="1"
- result="blur"
- id="feGaussianBlur956" />
- <feOffset
- dx="0"
- dy="1"
- result="offset"
- id="feOffset958" />
- <feComposite
- in="SourceGraphic"
- in2="offset"
- operator="over"
- result="composite2"
- id="feComposite960" />
- </filter>
- <clipPath
- clipPathUnits="userSpaceOnUse"
- id="clipPath873">
- <g
- transform="matrix(0,-0.66666667,0.66604479,0,-258.25992,677.00001)"
- id="g875"
- inkscape:label="Layer 1"
- style="fill:#ff00ff;fill-opacity:1;stroke:none;display:inline">
- <path
- style="fill:#ff00ff;fill-opacity:1;stroke:none;display:inline"
- d="m 46.702703,898.22775 50.594594,0 C 138.16216,898.22775 144,904.06497 144,944.92583 l 0,50.73846 c 0,40.86071 -5.83784,46.69791 -46.702703,46.69791 l -50.594594,0 C 5.8378378,1042.3622 0,1036.525 0,995.66429 L 0,944.92583 C 0,904.06497 5.8378378,898.22775 46.702703,898.22775 Z"
- id="path877"
- inkscape:connector-curvature="0"
- sodipodi:nodetypes="sssssssss" />
- </g>
- </clipPath>
- <filter
- inkscape:collect="always"
- id="filter891"
- inkscape:label="Badge Shadow">
- <feGaussianBlur
- inkscape:collect="always"
- stdDeviation="0.71999962"
- id="feGaussianBlur893" />
- </filter>
- </defs>
- <sodipodi:namedview
- id="base"
- pagecolor="#ffffff"
- bordercolor="#666666"
- borderopacity="1.0"
- inkscape:pageopacity="0.0"
- inkscape:pageshadow="2"
- inkscape:zoom="4.0745362"
- inkscape:cx="18.514671"
- inkscape:cy="-0.067172296"
- inkscape:document-units="px"
- inkscape:current-layer="layer1"
- showgrid="true"
- fit-margin-top="0"
- fit-margin-left="0"
- fit-margin-right="0"
- fit-margin-bottom="0"
- inkscape:window-width="1920"
- inkscape:window-height="1056"
- inkscape:window-x="2160"
- inkscape:window-y="340"
- inkscape:window-maximized="1"
- showborder="true"
- showguides="true"
- inkscape:guide-bbox="true"
- inkscape:showpageshadow="false">
- <inkscape:grid
- type="xygrid"
- id="grid821" />
- <sodipodi:guide
- orientation="1,0"
- position="16,48"
- id="guide823" />
- <sodipodi:guide
- orientation="0,1"
- position="64,80"
- id="guide825" />
- <sodipodi:guide
- orientation="1,0"
- position="80,40"
- id="guide827" />
- <sodipodi:guide
- orientation="0,1"
- position="64,16"
- id="guide829" />
- </sodipodi:namedview>
- <metadata
- id="metadata6522">
- <rdf:RDF>
- <cc:Work
- rdf:about="">
- <dc:format>image/svg+xml</dc:format>
- <dc:type
- rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
- <dc:title></dc:title>
- </cc:Work>
- </rdf:RDF>
- </metadata>
- <g
- inkscape:label="BACKGROUND"
- inkscape:groupmode="layer"
- id="layer1"
- transform="translate(268,-635.29076)"
- style="display:inline">
- <path
- style="fill:url(#linearGradient6461);fill-opacity:1;stroke:none;display:inline;filter:url(#filter1121)"
- d="m -268,700.15563 0,-33.72973 c 0,-27.24324 3.88785,-31.13513 31.10302,-31.13513 l 33.79408,0 c 27.21507,0 31.1029,3.89189 31.1029,31.13513 l 0,33.72973 c 0,27.24325 -3.88783,31.13514 -31.1029,31.13514 l -33.79408,0 C -264.11215,731.29077 -268,727.39888 -268,700.15563 Z"
- id="path6455"
- inkscape:connector-curvature="0"
- sodipodi:nodetypes="sssssssss" />
- <image
- y="636.29077"
- x="-260.2941"
- id="image3115"
- xlink:href="
-eJzs3XeYVNX5B/Dve869M7O7sCKg9Coo2JC6uxTFroklajQxGjUmUaMmFmyJGmvsMcWoMTGJmqiJ
-SUz9RaOiRulgb4g0AQUBkbZl5t5z3t8fswuIgLuzs7Pt+3mefYTdmXPfmcU57z3lPQARERERERER
-ERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERER
-ERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERER
-ERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERER
-ERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERER
-ERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERER
-ERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERER
-ERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERER
-ERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERER
-ERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERER
-EREREREREREREREREREREREREdG2SXMHQERELcecu84assvymYeaeO3+Lo46wAAJsRvS4c5TN3bd
-c+o+F/9xTnPHSPnBBICIiLDgjmNOSS6ffQa8Hxgg7mVFk04CWDhAFc5rBNiVGVv038rOezw29Mpn
-/tvcMVPjMAEgImrHfq5a+qXLBt+SiD8+WW1RJ1EH6yN4AE4CKAQqAqNAgBhQhYesUVvyjw/O//2V
-o/rvv7y5XwPlhgkAEVE79Qf9uPSAScPuDv3Gk42xNtu5G8QSQKCwiKEQCBSAwMNCAYRw8Op9ZIqf
-iPc45KoBZz3wanO/Fmo4JgBERO3Qz1VLj5vU++5A01+JbTI0PgYAGPgdPk8hMPAQKJwESGs4A3sc
-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
-UkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJK
-KaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSiml
-lFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRS
-SimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkop
-pZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWU
-UkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJK
-KaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSiml
-lFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRS
-SimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkop
-pZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWU
-UkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJKKaWUUkoppZRSSimllFJK
-KaWUUkoppZRSSimllFJKKaWUqsn/Bw1WfWPJuUdqAAAAAElFTkSuQmCC
-"
- height="89.999992"
- width="87.294098" />
- </g>
- <g
- inkscape:groupmode="layer"
- id="layer3"
- inkscape:label="PLACE YOUR PICTOGRAM HERE"
- style="display:inline" />
- <g
- inkscape:groupmode="layer"
- id="layer2"
- inkscape:label="BADGE"
- style="display:none"
- sodipodi:insensitive="true">
- <g
- style="display:inline"
- transform="translate(-340.00001,-581)"
- id="g4394"
- clip-path="none">
- <g
- id="g855">
- <g
- inkscape:groupmode="maskhelper"
- id="g870"
- clip-path="url(#clipPath873)"
- style="opacity:0.6;filter:url(#filter891)">
- <path
- transform="matrix(1.4999992,0,0,1.4999992,-29.999795,-237.54282)"
- d="m 264,552.36218 c 0,6.62742 -5.37258,12 -12,12 -6.62742,0 -12,-5.37258 -12,-12 0,-6.62741 5.37258,-12 12,-12 6.62742,0 12,5.37259 12,12 z"
- sodipodi:ry="12"
- sodipodi:rx="12"
- sodipodi:cy="552.36218"
- sodipodi:cx="252"
- id="path844"
- style="color:#000000;fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- sodipodi:type="arc" />
- </g>
- <g
- id="g862">
- <path
- sodipodi:type="arc"
- style="color:#000000;fill:#f5f5f5;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- id="path4398"
- sodipodi:cx="252"
- sodipodi:cy="552.36218"
- sodipodi:rx="12"
- sodipodi:ry="12"
- d="m 264,552.36218 c 0,6.62742 -5.37258,12 -12,12 -6.62742,0 -12,-5.37258 -12,-12 0,-6.62741 5.37258,-12 12,-12 6.62742,0 12,5.37259 12,12 z"
- transform="matrix(1.4999992,0,0,1.4999992,-29.999795,-238.54282)" />
- <path
- transform="matrix(1.25,0,0,1.25,33,-100.45273)"
- d="m 264,552.36218 c 0,6.62742 -5.37258,12 -12,12 -6.62742,0 -12,-5.37258 -12,-12 0,-6.62741 5.37258,-12 12,-12 6.62742,0 12,5.37259 12,12 z"
- sodipodi:ry="12"
- sodipodi:rx="12"
- sodipodi:cy="552.36218"
- sodipodi:cx="252"
- id="path4400"
- style="color:#000000;fill:#dd4814;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- sodipodi:type="arc" />
- <path
- sodipodi:type="star"
- style="color:#000000;fill:#f5f5f5;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- id="path4459"
- sodipodi:sides="5"
- sodipodi:cx="666.19574"
- sodipodi:cy="589.50385"
- sodipodi:r1="7.2431178"
- sodipodi:r2="4.3458705"
- sodipodi:arg1="1.0471976"
- sodipodi:arg2="1.6755161"
- inkscape:flatsided="false"
- inkscape:rounded="0.1"
- inkscape:randomized="0"
- d="m 669.8173,595.77657 c -0.39132,0.22593 -3.62645,-1.90343 -4.07583,-1.95066 -0.44938,-0.0472 -4.05653,1.36297 -4.39232,1.06062 -0.3358,-0.30235 0.68963,-4.03715 0.59569,-4.47913 -0.0939,-0.44198 -2.5498,-3.43681 -2.36602,-3.8496 0.18379,-0.41279 4.05267,-0.59166 4.44398,-0.81759 0.39132,-0.22593 2.48067,-3.48704 2.93005,-3.4398 0.44938,0.0472 1.81505,3.67147 2.15084,3.97382 0.3358,0.30236 4.08294,1.2817 4.17689,1.72369 0.0939,0.44198 -2.9309,2.86076 -3.11469,3.27355 -0.18379,0.41279 0.0427,4.27917 -0.34859,4.5051 z"
- transform="matrix(1.511423,-0.16366377,0.16366377,1.511423,-755.37346,-191.93651)" />
- </g>
- </g>
- </g>
+<svg xmlns="http://www.w3.org/2000/svg" height="100px" width="100px" version="1.1" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 100 100"><!-- Generator: Sketch 43.2 (39069) - http://www.bohemiancoding.com/sketch -->
+ <title>spark</title>
+ <desc>Created with Sketch.</desc>
+ <g id="Page-1" fill-rule="evenodd" fill="none">
+ <g id="spark">
+ <g id="sprak">
+ <path id="path4784" fill-rule="nonzero" fill="#E77215" d="m50 1.1369e-13c-27.614-1.69e-15 -50 22.386-50 50-3.3818e-15 27.614 22.386 50 50 50 13.261 0 25.979-5.268 35.355-14.645 9.377-9.376 14.645-22.094 14.645-35.355 0-27.614-22.386-50-50-50z"/>
+ <path id="path3254" fill="#fff" d="m55.063 59.209c3.581 0.948 7.109 1.881 10.96 2.9-2.103-4.015-3.922-7.714-5.971-11.281-0.783-1.364-0.638-2.171 0.351-3.286 3.086-3.484 6.06-7.066 9.545-11.159-4.737 1.235-8.827 2.177-12.832 3.399-2.066 0.631-3.245 0.361-4.316-1.675-1.751-3.328-3.847-6.474-6.123-10.235-0.854 4.748-1.779 8.84-2.26 12.985-0.258 2.23-1.296 3.02-3.246 3.567-4.041 1.136-8.021 2.493-12.759 3.991 4.239 1.713 7.803 3.152 11.873 4.796-2.768 1.793-5.198 3.388-7.658 4.933-0.311 0.195-0.865 0.306-1.167 0.162-3.724-1.776-7.856-2.799-11.135-5.376-3.742-2.941-3.154-7.185 1.339-8.977 4.516-1.801 9.219-3.148 13.888-4.532 1.866-0.555 2.76-1.465 3.021-3.456 0.493-3.785 1.237-7.539 1.977-11.287 0.243-1.229 0.639-2.481 1.233-3.578 2.233-4.129 6.154-4.408 8.804-0.518 2.207 3.24 4.201 6.637 6.097 10.071 0.953 1.727 1.981 2.052 3.824 1.516 4.582-1.335 9.224-2.466 13.847-3.659 2.142-0.553 4.41-0.799 5.781 1.287 1.5 2.281 0.056 4.269-1.399 6.012-3.268 3.914-6.557 7.814-9.935 11.632-1.12 1.267-1.438 2.194-0.468 3.823 2.11 3.546 3.905 7.281 5.815 10.945 1.165 2.231 1.485 4.472-0.329 6.521-1.732 1.956-3.941 2.362-6.39 1.642-1.833-0.54-3.658-1.109-5.486-1.664-6.698-2.032-6.698-2.031-6.881-9.499z"/>
+ </g>
</g>
+ </g>
</svg>
diff --git a/bigtop-packages/src/charm/spark/layer-spark/layer.yaml b/bigtop-packages/src/charm/spark/layer-spark/layer.yaml
index 11fc1355..4ee763d3 100644
--- a/bigtop-packages/src/charm/spark/layer-spark/layer.yaml
+++ b/bigtop-packages/src/charm/spark/layer-spark/layer.yaml
@@ -21,12 +21,15 @@ options:
path: '/var/log/spark/apps'
ports:
# Ports that need to be exposed, overridden, or manually specified.
- # Only expose ports serving a UI or external API (i.e., namenode and
- # resourcemanager). Communication among units within the cluster does
- # not need ports to be explicitly opened.
- spark-history:
+ # Only expose ports serving a UI or external API (e.g. spark history
+ # server). IPC among units within a deployment does not typically
+ # require a port to be exposed.
+ spark-history-ui:
port: 18080
exposed_on: 'spark'
- spark-webui:
+ spark-master-ui:
port: 8080
exposed_on: 'spark'
+ spark-worker-ui:
+ port: 8081
+ exposed_on: 'spark'
diff --git a/bigtop-packages/src/charm/spark/layer-spark/lib/charms/layer/bigtop_spark.py b/bigtop-packages/src/charm/spark/layer-spark/lib/charms/layer/bigtop_spark.py
index dc2e3730..91fcbf79 100755..100644
--- a/bigtop-packages/src/charm/spark/layer-spark/lib/charms/layer/bigtop_spark.py
+++ b/bigtop-packages/src/charm/spark/layer-spark/lib/charms/layer/bigtop_spark.py
@@ -13,11 +13,11 @@
# See the License for the specific language governing permissions and
# limitations under the License.
import os
+import time
from jujubigdata import utils
from path import Path
from charms.layer.apache_bigtop_base import Bigtop
-from charms.reactive import is_state
from charms import layer
from charmhelpers.core import hookenv, host, unitdata
from charmhelpers.fetch.archiveurl import ArchiveUrlFetchHandler
@@ -36,7 +36,7 @@ class Spark(object):
mode = hookenv.config()['spark_execution_mode']
zk_units = unitdata.kv().get('zookeeper.units', [])
master = None
- if mode.startswith('local') or mode == 'yarn-cluster':
+ if mode.startswith('local') or mode.startswith('yarn'):
master = mode
elif mode == 'standalone' and not zk_units:
master = 'spark://{}:7077'.format(spark_master_host)
@@ -47,18 +47,8 @@ class Spark(object):
nodes.append('{}:7077'.format(ip))
nodes_str = ','.join(nodes)
master = 'spark://{}'.format(nodes_str)
- elif mode.startswith('yarn'):
- master = 'yarn-client'
return master
- def get_roles(self):
- roles = ['spark-worker', 'spark-client']
- zk_units = unitdata.kv().get('zookeeper.units', [])
- if is_state('leadership.is_leader') or zk_units:
- roles.append('spark-master')
- roles.append('spark-history-server')
- return roles
-
def install_benchmark(self):
"""
Install and configure SparkBench.
@@ -155,10 +145,10 @@ class Spark(object):
self.dist_config.add_users()
self.dist_config.add_dirs()
self.install_demo()
- self.open_ports()
def setup_hdfs_logs(self):
- # create hdfs storage space for history server
+ # Create hdfs storage space for history server and return the name
+ # of the created directory.
dc = self.dist_config
events_dir = dc.path('spark_events')
events_dir = 'hdfs://{}'.format(events_dir)
@@ -168,49 +158,94 @@ class Spark(object):
events_dir)
return events_dir
- def configure(self, available_hosts, zk_units, peers):
+ def configure(self, available_hosts, zk_units, peers, extra_libs):
"""
This is the core logic of setting up spark.
- Two flags are needed:
-
- * Namenode exists aka HDFS is there
- * Resource manager exists aka YARN is ready
-
- both flags are infered from the available hosts.
-
:param dict available_hosts: Hosts that Spark should know about.
+ :param list zk_units: List of Zookeeper dicts with host/port info.
+ :param list peers: List of Spark peer tuples (unit name, IP).
+ :param list extra_libs: List of extra lib paths for driver/executors.
"""
- unitdata.kv().set('zookeeper.units', zk_units)
- unitdata.kv().set('sparkpeer.units', peers)
- unitdata.kv().flush(True)
-
+ # Bootstrap spark
if not unitdata.kv().get('spark.bootstrapped', False):
self.setup()
unitdata.kv().set('spark.bootstrapped', True)
+ # Set KV based on connected applications
+ unitdata.kv().set('zookeeper.units', zk_units)
+ unitdata.kv().set('sparkpeer.units', peers)
+ unitdata.kv().flush(True)
+
+ # Get our config ready
+ dc = self.dist_config
+ events_log_dir = 'file://{}'.format(dc.path('spark_events'))
+ mode = hookenv.config()['spark_execution_mode']
master_ip = utils.resolve_private_address(available_hosts['spark-master'])
+ master_url = self.get_master_url(master_ip)
+ req_driver_mem = hookenv.config()['driver_memory']
+ req_executor_mem = hookenv.config()['executor_memory']
+
+ # handle tuning options that may be set as percentages
+ driver_mem = '1g'
+ executor_mem = '1g'
+ if req_driver_mem.endswith('%'):
+ if mode == 'standalone' or mode.startswith('local'):
+ mem_mb = host.get_total_ram() / 1024 / 1024
+ req_percentage = float(req_driver_mem.strip('%')) / 100
+ driver_mem = str(int(mem_mb * req_percentage)) + 'm'
+ else:
+ hookenv.log("driver_memory percentage in non-local mode. Using 1g default.",
+ level=None)
+ else:
+ driver_mem = req_driver_mem
+
+ if req_executor_mem.endswith('%'):
+ if mode == 'standalone' or mode.startswith('local'):
+ mem_mb = host.get_total_ram() / 1024 / 1024
+ req_percentage = float(req_executor_mem.strip('%')) / 100
+ executor_mem = str(int(mem_mb * req_percentage)) + 'm'
+ else:
+ hookenv.log("executor_memory percentage in non-local mode. Using 1g default.",
+ level=None)
+ else:
+ executor_mem = req_executor_mem
+
+ # Setup hosts dict
hosts = {
'spark': master_ip,
}
-
- dc = self.dist_config
- events_log_dir = 'file://{}'.format(dc.path('spark_events'))
if 'namenode' in available_hosts:
hosts['namenode'] = available_hosts['namenode']
events_log_dir = self.setup_hdfs_logs()
-
+ else:
+ # Bigtop includes a default hadoop_head_node if we do not specify
+ # any namenode info. To ensure spark standalone doesn't get
+ # invalid hadoop config, set our NN to an empty string.
+ hosts['namenode'] = ''
if 'resourcemanager' in available_hosts:
hosts['resourcemanager'] = available_hosts['resourcemanager']
- roles = self.get_roles()
+ # Setup roles dict. We always include the history server and client.
+ # Determine other roles based on our execution mode.
+ roles = ['spark-history-server', 'spark-client']
+ if mode == 'standalone':
+ roles.append('spark-master')
+ roles.append('spark-worker')
+ elif mode.startswith('yarn'):
+ roles.append('spark-on-yarn')
+ roles.append('spark-yarn-slave')
+ # Setup overrides dict
override = {
- 'spark::common::master_url': self.get_master_url(master_ip),
+ 'spark::common::master_url': master_url,
'spark::common::event_log_dir': events_log_dir,
'spark::common::history_log_dir': events_log_dir,
+ 'spark::common::extra_lib_dirs':
+ ':'.join(extra_libs) if extra_libs else None,
+ 'spark::common::driver_mem': driver_mem,
+ 'spark::common::executor_mem': executor_mem,
}
-
if zk_units:
zks = []
for unit in zk_units:
@@ -220,18 +255,14 @@ class Spark(object):
zk_connect = ",".join(zks)
override['spark::common::zookeeper_connection_string'] = zk_connect
else:
- override['spark::common::zookeeper_connection_string'] = ""
+ override['spark::common::zookeeper_connection_string'] = None
+ # Create our site.yaml and trigger puppet
bigtop = Bigtop()
bigtop.render_site_yaml(hosts, roles, override)
bigtop.trigger_puppet()
- # There is a race condition here.
- # The work role will not start the first time we trigger puppet apply.
- # The exception in /var/logs/spark:
- # Exception in thread "main" org.apache.spark.SparkException: Invalid master URL: spark://:7077
- # The master url is not set at the time the worker start the first time.
- # TODO(kjackal): ...do the needed... (investiate,debug,submit patch)
- bigtop.trigger_puppet()
+
+ # Do this after our puppet bits in case puppet overrides needed perms
if 'namenode' not in available_hosts:
# Local event dir (not in HDFS) needs to be 777 so non-spark
# users can write job history there. It needs to be g+s so
@@ -239,22 +270,21 @@ class Spark(object):
# It needs to be +t so users cannot remove files they don't own.
dc.path('spark_events').chmod(0o3777)
- self.patch_worker_master_url(master_ip)
+ self.patch_worker_master_url(master_ip, master_url)
+ # Install SB (subsequent calls will reconfigure existing install)
# SparkBench looks for the spark master in /etc/environment
with utils.environment_edit_in_place('/etc/environment') as env:
- env['MASTER'] = self.get_master_url(master_ip)
- # Install SB (subsequent calls will reconfigure existing install)
+ env['MASTER'] = master_url
self.install_benchmark()
- def patch_worker_master_url(self, master_ip):
+ def patch_worker_master_url(self, master_ip, master_url):
'''
Patch the worker startup script to use the full master url istead of contracting it.
The master url is placed in the spark-env.sh so that the startup script will use it.
In HA mode the master_ip is set to be the local_ip instead of the one the leader
elects. This requires a restart of the master service.
'''
- master_url = self.get_master_url(master_ip)
zk_units = unitdata.kv().get('zookeeper.units', [])
if master_url.startswith('spark://'):
if zk_units:
@@ -268,8 +298,6 @@ class Spark(object):
self.inplace_change('/etc/init.d/spark-worker',
'spark://$SPARK_MASTER_IP:$SPARK_MASTER_PORT',
'$SPARK_MASTER_URL')
- host.service_restart('spark-master')
- host.service_restart('spark-worker')
def inplace_change(self, filename, old_string, new_string):
# Safely read the input filename using 'with'
@@ -294,32 +322,50 @@ class Spark(object):
Path(demo_target).chown('ubuntu', 'hadoop')
def start(self):
- if unitdata.kv().get('spark.uprading', False):
- return
-
- # stop services (if they're running) to pick up any config change
- self.stop()
- # always start the history server, start master/worker if we're standalone
+ '''
+ Always start the Spark History Server. Start other services as
+ required by our execution mode. Open related ports as appropriate.
+ '''
host.service_start('spark-history-server')
+ hookenv.open_port(self.dist_config.port('spark-history-ui'))
+
+ # Spark master/worker is only started in standalone mode
if hookenv.config()['spark_execution_mode'] == 'standalone':
- host.service_start('spark-master')
- host.service_start('spark-worker')
+ if host.service_start('spark-master'):
+ hookenv.log("Spark Master started")
+ hookenv.open_port(self.dist_config.port('spark-master-ui'))
+ # If the master started and we have peers, wait 2m for recovery
+ # before starting the worker. This ensures the worker binds
+ # to the correct master.
+ if unitdata.kv().get('sparkpeer.units'):
+ hookenv.status_set('maintenance',
+ 'waiting for spark master recovery')
+ hookenv.log("Waiting 2m to ensure spark master is ALIVE")
+ time.sleep(120)
+ else:
+ hookenv.log("Spark Master did not start; this is normal "
+ "for non-leader units in standalone mode")
+
+ # NB: Start the worker even if the master process on this unit
+ # fails to start. In non-HA mode, spark master only runs on the
+ # leader. On non-leader units, we still want a worker bound to
+ # the leader.
+ if host.service_start('spark-worker'):
+ hookenv.log("Spark Worker started")
+ hookenv.open_port(self.dist_config.port('spark-worker-ui'))
+ else:
+ hookenv.log("Spark Worker did not start")
def stop(self):
- if not unitdata.kv().get('spark.installed', False):
- return
- # Only stop services if they're running
- if utils.jps("HistoryServer"):
- host.service_stop('spark-history-server')
- if utils.jps("Master"):
- host.service_stop('spark-master')
- if utils.jps("Worker"):
- host.service_stop('spark-worker')
-
- def open_ports(self):
- for port in self.dist_config.exposed_ports('spark'):
- hookenv.open_port(port)
-
- def close_ports(self):
- for port in self.dist_config.exposed_ports('spark'):
- hookenv.close_port(port)
+ '''
+ Stop all services (and close associated ports). Stopping a service
+ that is not currently running does no harm.
+ '''
+ host.service_stop('spark-history-server')
+ hookenv.close_port(self.dist_config.port('spark-history-ui'))
+
+ # Stop the worker before the master
+ host.service_stop('spark-worker')
+ hookenv.close_port(self.dist_config.port('spark-worker-ui'))
+ host.service_stop('spark-master')
+ hookenv.close_port(self.dist_config.port('spark-master-ui'))
diff --git a/bigtop-packages/src/charm/spark/layer-spark/metadata.yaml b/bigtop-packages/src/charm/spark/layer-spark/metadata.yaml
index efec6f0e..06664290 100644
--- a/bigtop-packages/src/charm/spark/layer-spark/metadata.yaml
+++ b/bigtop-packages/src/charm/spark/layer-spark/metadata.yaml
@@ -1,11 +1,11 @@
name: spark
-summary: Apache Spark from Apache Bigtop platform
+summary: Spark from Apache Bigtop
maintainer: Juju Big Data <bigdata@lists.ubuntu.com>
description: >
Apache Spark is a fast and general engine for large-scale data processing.
- Learn more at http://spark.apache.org.
-tags: ["applications"]
+ This charm provides version 2.1.0 of the Spark application from Apache Bigtop.
+tags: ["analytics"]
provides:
benchmark:
interface: benchmark
diff --git a/bigtop-packages/src/charm/spark/layer-spark/reactive/spark.py b/bigtop-packages/src/charm/spark/layer-spark/reactive/spark.py
index 99b21015..fc74fa10 100644
--- a/bigtop-packages/src/charm/spark/layer-spark/reactive/spark.py
+++ b/bigtop-packages/src/charm/spark/layer-spark/reactive/spark.py
@@ -12,6 +12,8 @@
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
+import time
+
from charms.reactive import RelationBase, when, when_not, is_state, set_state, remove_state, when_any
from charms.layer.apache_bigtop_base import get_fqdn, get_package_version
from charms.layer.bigtop_spark import Spark
@@ -21,18 +23,9 @@ from charms.reactive.helpers import data_changed
from jujubigdata import utils
-def set_deployment_mode_state(state):
- if is_state('spark.yarn.installed'):
- remove_state('spark.yarn.installed')
- if is_state('spark.standalone.installed'):
- remove_state('spark.standalone.installed')
- set_state('spark.started')
- set_state(state)
- # set app version string for juju status output
- spark_version = get_package_version('spark-core') or 'unknown'
- hookenv.application_version_set(spark_version)
-
-
+###############################################################################
+# Status methods
+###############################################################################
def report_status():
mode = hookenv.config()['spark_execution_mode']
if (not is_state('spark.yarn.installed')) and mode.startswith('yarn'):
@@ -45,71 +38,130 @@ def report_status():
elif mode == 'standalone' and is_state('leadership.is_leader'):
mode = mode + " - master"
- hookenv.status_set('active', 'ready ({})'.format(mode))
+ if is_state('spark.cuda.configured'):
+ mode = mode + " with CUDA"
+ if is_state('spark.started'):
+ hookenv.status_set('active', 'ready ({})'.format(mode))
+ else:
+ hookenv.status_set('blocked', 'unable to start spark ({})'.format(mode))
+
+
+###############################################################################
+# Utility methods
+###############################################################################
+def get_spark_peers():
+ nodes = [(hookenv.local_unit(), hookenv.unit_private_ip())]
+ sparkpeer = RelationBase.from_state('sparkpeers.joined')
+ if sparkpeer:
+ nodes.extend(sorted(sparkpeer.get_nodes()))
+ return nodes
-def install_spark(hadoop=None, zks=None):
- spark_master_host = leadership.leader_get('master-fqdn')
- if not spark_master_host:
- hookenv.status_set('waiting', 'master not elected yet')
- return False
+def install_spark_standalone(zks, peers):
+ """
+ Called in local/standalone mode after Juju has elected a leader.
+ """
hosts = {
- 'spark-master': spark_master_host,
+ 'spark-master': leadership.leader_get('master-fqdn'),
}
- if is_state('hadoop.yarn.ready'):
- rms = hadoop.resourcemanagers()
- hosts['resourcemanager'] = rms[0]
-
- if is_state('hadoop.hdfs.ready'):
- nns = hadoop.namenodes()
- hosts['namenode'] = nns[0]
+ # If zks have changed and we are not handling a departed spark peer,
+ # give the ensemble time to settle. Otherwise we might try to start
+ # spark master with data from the wrong zk leader. Doing so will cause
+ # spark-master to shutdown:
+ # https://issues.apache.org/jira/browse/SPARK-15544
+ if (zks and data_changed('zks', zks) and not is_state('sparkpeers.departed')):
+ hookenv.status_set('maintenance',
+ 'waiting for zookeeper ensemble to settle')
+ hookenv.log("Waiting 2m to ensure zk ensemble has settled: {}".format(zks))
+ time.sleep(120)
+
+ # Let spark know if we have cuda libs installed.
+ # NB: spark packages prereq hadoop (boo), so even in standalone mode, we'll
+ # have hadoop libs installed. May as well include them in our lib path.
+ extra_libs = ["/usr/lib/hadoop/lib/native"]
+ if is_state('cuda.installed'):
+ extra_libs.append("/usr/local/cuda/lib64")
spark = Spark()
- spark.configure(hosts, zks, get_spark_peers())
- return True
+ spark.configure(hosts, zk_units=zks, peers=peers, extra_libs=extra_libs)
+ set_deployment_mode_state('spark.standalone.installed')
-@when('config.changed', 'spark.started')
-def reconfigure_spark():
- config = hookenv.config()
- mode = config['spark_execution_mode']
- hookenv.status_set('maintenance',
- 'changing default execution mode to {}'.format(mode))
-
+def install_spark_yarn():
+ """
+ Called in 'yarn-*' mode after Juju has elected a leader. The
+ 'hadoop.yarn.ready' state must be set.
+ """
+ hosts = {
+ 'spark-master': leadership.leader_get('master-fqdn'),
+ }
hadoop = (RelationBase.from_state('hadoop.yarn.ready') or
RelationBase.from_state('hadoop.hdfs.ready'))
+ rms = hadoop.resourcemanagers()
+ hosts['resourcemanager'] = rms[0]
- zks = None
- if is_state('zookeeper.ready'):
- zk = RelationBase.from_state('zookeeper.ready')
- zks = zk.zookeepers()
+ # Probably don't need to check this since yarn.ready implies hdfs.ready
+ # for us, but it doesn't hurt.
+ if is_state('hadoop.hdfs.ready'):
+ nns = hadoop.namenodes()
+ hosts['namenode'] = nns[0]
- if install_spark(hadoop, zks):
- report_status()
+ # Always include native hadoop libs in yarn mode; add cuda libs if present.
+ extra_libs = ["/usr/lib/hadoop/lib/native"]
+ if is_state('cuda.installed'):
+ extra_libs.append("/usr/local/cuda/lib64")
+
+ spark = Spark()
+ spark.configure(hosts, zk_units=None, peers=None, extra_libs=extra_libs)
+ set_deployment_mode_state('spark.yarn.installed')
+
+
+def set_deployment_mode_state(state):
+ if is_state('spark.yarn.installed'):
+ remove_state('spark.standalone.installed')
+ if is_state('spark.standalone.installed'):
+ remove_state('spark.yarn.installed')
+ set_state(state)
+ # set app version string for juju status output
+ spark_version = get_package_version('spark-core') or 'unknown'
+ hookenv.application_version_set(spark_version)
-# This is a triky call. We want to fire when the leader changes, yarn and hdfs become ready or
-# depart. In the future this should fire when Cassandra or any other storage
-# becomes ready or departs. Since hdfs and yarn do not have a departed state we make sure
-# we fire this method always ('spark.started'). We then build a deployment-matrix
-# and if anything has changed we re-install.
-# 'hadoop.yarn.ready', 'hadoop.hdfs.ready' can be ommited but I like them here for clarity
-@when_any('hadoop.yarn.ready',
- 'hadoop.hdfs.ready', 'master.elected', 'sparkpeers.joined', 'zookeeper.ready')
+###############################################################################
+# Reactive methods
+###############################################################################
+@when_any('config.changed', 'master.elected',
+ 'hadoop.hdfs.ready', 'hadoop.yarn.ready',
+ 'sparkpeers.joined', 'sparkpeers.departed',
+ 'zookeeper.ready')
@when('bigtop.available', 'master.elected')
def reinstall_spark():
+ """
+ This is tricky. We want to fire on config or leadership changes, or when
+ hadoop, sparkpeers, or zookeepers come and go. In the future this should
+ fire when Cassandra or any other storage comes or goes. We always fire
+ this method (or rather, when bigtop is ready and juju has elected a
+ master). We then build a deployment-matrix and (re)install as things
+ change.
+ """
spark_master_host = leadership.leader_get('master-fqdn')
- peers = []
- zks = []
- if is_state('zookeeper.ready'):
- # if ZK is availuable we are in HA. We do not want reconfigurations if a leader fails
- # HA takes care of this
+ if not spark_master_host:
+ hookenv.status_set('maintenance', 'juju leader not elected yet')
+ return
+
+ mode = hookenv.config()['spark_execution_mode']
+ peers = None
+ zks = None
+
+ # If mode is standalone and ZK is ready, we are in HA. Do not consider
+ # the master_host from juju leadership in our matrix. ZK handles this.
+ if (mode == 'standalone' and is_state('zookeeper.ready')):
spark_master_host = ''
zk = RelationBase.from_state('zookeeper.ready')
zks = zk.zookeepers()
- # We need reconfigure Spark when in HA and peers change ignore otherwise
+ # peers are only used to set our MASTER_URL in standalone HA mode
peers = get_spark_peers()
deployment_matrix = {
@@ -120,34 +172,40 @@ def reinstall_spark():
'peers': peers,
}
- if not data_changed('deployment_matrix', deployment_matrix):
+ # If neither config nor our matrix is changing, there is nothing to do.
+ if not (is_state('config.changed') or
+ data_changed('deployment_matrix', deployment_matrix)):
+ report_status()
return
- hookenv.status_set('maintenance', 'configuring spark')
- hadoop = (RelationBase.from_state('hadoop.yarn.ready') or
- RelationBase.from_state('hadoop.hdfs.ready'))
- if install_spark(hadoop, zks):
- if is_state('hadoop.yarn.ready'):
- set_deployment_mode_state('spark.yarn.installed')
- else:
- set_deployment_mode_state('spark.standalone.installed')
-
+ # (Re)install based on our execution mode
+ hookenv.status_set('maintenance', 'configuring spark in {} mode'.format(mode))
+ hookenv.log("Configuring spark with deployment matrix: {}".format(deployment_matrix))
+
+ if mode.startswith('yarn') and is_state('hadoop.yarn.ready'):
+ install_spark_yarn()
+ elif mode.startswith('local') or mode == 'standalone':
+ install_spark_standalone(zks, peers)
+ else:
+ # Something's wrong (probably requested yarn without yarn.ready).
+ remove_state('spark.started')
report_status()
+ return
+ # restart services to pick up possible config changes
+ spark = Spark()
+ spark.stop()
+ spark.start()
-def get_spark_peers():
- nodes = [(hookenv.local_unit(), hookenv.unit_private_ip())]
- sparkpeer = RelationBase.from_state('sparkpeers.joined')
- if sparkpeer:
- nodes.extend(sorted(sparkpeer.get_nodes()))
- return nodes
+ set_state('spark.started')
+ report_status()
-@when('leadership.is_leader', 'bigtop.available')
+@when('bigtop.available', 'leadership.is_leader')
def send_fqdn():
spark_master_host = get_fqdn()
leadership.leader_set({'master-fqdn': spark_master_host})
- hookenv.log("Setting leader to {}".format(spark_master_host))
+ hookenv.log("Setting juju leader to {}".format(spark_master_host))
@when('leadership.changed.master-fqdn')
@@ -155,6 +213,47 @@ def leader_elected():
set_state("master.elected")
+@when('spark.started', 'cuda.installed')
+@when_not('spark.cuda.configured')
+def configure_cuda():
+ """
+ Ensure cuda bits are configured.
+
+ We can't be sure that the config.changed handler in the nvidia-cuda
+ layer will fire before the handler in this layer. We might call
+ reinstall_spark on config-changed before the cuda.installed state is set,
+ thereby missing the cuda lib path configuration. Deal with this by
+ excplicitly calling reinstall_spark after we *know* cuda.installed is set.
+ This may result in 2 calls to reinstall_spark when cuda-related config
+ changes, but it ensures our spark lib config is accurate.
+ """
+ hookenv.log("Configuring spark with CUDA library paths")
+ reinstall_spark()
+ set_state('spark.cuda.configured')
+ report_status()
+
+
+@when('spark.started', 'spark.cuda.configured')
+@when_not('cuda.installed')
+def unconfigure_cuda():
+ """
+ Ensure cuda bits are unconfigured.
+
+ Similar to the configure_cuda method, we can't be sure that the
+ config.changed handler in the nvidia-cuda layer will fire before the
+ handler in this layer. We might call reinstall_spark on config-changed
+ before the cuda.installed state is removed, thereby configuring spark with
+ a cuda lib path when the user wanted cuda config removed. Deal with this by
+ excplicitly calling reinstall_spark after we *know* cuda.installed is gone.
+ This may result in 2 calls to reinstall_spark when cuda-related config
+ changes, but it ensures our spark lib config is accurate.
+ """
+ hookenv.log("Removing CUDA library paths from spark configuration")
+ reinstall_spark()
+ remove_state('spark.cuda.configured')
+ report_status()
+
+
@when('spark.started', 'client.joined')
def client_present(client):
if is_state('leadership.is_leader'):
diff --git a/bigtop-packages/src/charm/spark/layer-spark/scripts/sparkpi.sh b/bigtop-packages/src/charm/spark/layer-spark/scripts/sparkpi.sh
index 3a345496..d003bbe8 100755
--- a/bigtop-packages/src/charm/spark/layer-spark/scripts/sparkpi.sh
+++ b/bigtop-packages/src/charm/spark/layer-spark/scripts/sparkpi.sh
@@ -15,6 +15,9 @@
# limitations under the License.
set -eu
+JAR_PATH=`find /usr/lib/spark -name spark-examples.jar`
+CMD="spark-submit --class org.apache.spark.examples.SparkPi ${JAR_PATH} 10"
+
echo "Running SparkPi"
-spark-submit --class org.apache.spark.examples.SparkPi /usr/lib/spark/lib/spark-examples-*.jar 10
-echo ""
+echo "Command: ${CMD}"
+${CMD} 2>&1 | grep "Pi is"
diff --git a/bigtop-packages/src/charm/spark/layer-spark/tests/01-basic-deployment.py b/bigtop-packages/src/charm/spark/layer-spark/tests/01-basic-deployment.py
index f387c7bd..d6bcde00 100755
--- a/bigtop-packages/src/charm/spark/layer-spark/tests/01-basic-deployment.py
+++ b/bigtop-packages/src/charm/spark/layer-spark/tests/01-basic-deployment.py
@@ -26,7 +26,7 @@ class TestDeploy(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.d = amulet.Deployment(series='xenial')
- cls.d.add('spark', 'cs:xenial/spark')
+ cls.d.add('spark')
cls.d.setup(timeout=1800)
cls.d.sentry.wait(timeout=1800)
cls.unit = cls.d.sentry['spark'][0]
diff --git a/bigtop-packages/src/charm/spark/layer-spark/tests/02-smoke-test.py b/bigtop-packages/src/charm/spark/layer-spark/tests/02-smoke-test.py
index 4f81cc7e..8f49e5fd 100755
--- a/bigtop-packages/src/charm/spark/layer-spark/tests/02-smoke-test.py
+++ b/bigtop-packages/src/charm/spark/layer-spark/tests/02-smoke-test.py
@@ -27,7 +27,7 @@ class TestDeploy(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.d = amulet.Deployment(series='xenial')
- cls.d.add('spark', 'cs:xenial/spark')
+ cls.d.add('spark')
cls.d.setup(timeout=1800)
cls.d.sentry.wait_for_messages({'spark': re.compile('ready')}, timeout=1800)
cls.spark = cls.d.sentry['spark'][0]
diff --git a/bigtop-packages/src/charm/spark/layer-spark/tests/03-scale-standalone.py b/bigtop-packages/src/charm/spark/layer-spark/tests/03-scale-standalone.py
index 33479f3d..6b118c2e 100755
--- a/bigtop-packages/src/charm/spark/layer-spark/tests/03-scale-standalone.py
+++ b/bigtop-packages/src/charm/spark/layer-spark/tests/03-scale-standalone.py
@@ -27,7 +27,8 @@ class TestScaleStandalone(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.d = amulet.Deployment(series='xenial')
- cls.d.add('spark-test-scale', 'cs:xenial/spark', units=3)
+ cls.d.add('spark-test-scale', charm='spark',
+ units=3, constraints={'mem': '7G'})
cls.d.setup(timeout=3600)
cls.d.sentry.wait(timeout=3600)
@@ -35,8 +36,8 @@ class TestScaleStandalone(unittest.TestCase):
def tearDownClass(cls):
# NB: seems to be a remove_service issue with amulet. However, the
# unit does still get removed. Pass OSError for now:
- # OSError: juju command failed ['remove-application', 'zk-test']:
- # ERROR allocation for service ...zk-test... owned by ... not found
+ # OSError: juju command failed ['remove-application', ...]:
+ # ERROR allocation for service ... owned by ... not found
try:
cls.d.remove_service('spark-test-scale')
except OSError as e:
diff --git a/bigtop-packages/src/charm/spark/layer-spark/tests/10-test-ha.py b/bigtop-packages/src/charm/spark/layer-spark/tests/10-test-ha.py
index 99c604f9..998eaf28 100755
--- a/bigtop-packages/src/charm/spark/layer-spark/tests/10-test-ha.py
+++ b/bigtop-packages/src/charm/spark/layer-spark/tests/10-test-ha.py
@@ -28,10 +28,11 @@ class TestDeployment(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.d = amulet.Deployment(series='xenial')
- cls.d.add('spark-test-ha', 'cs:xenial/spark', units=3)
- cls.d.add('zk-test', 'cs:xenial/zookeeper')
+ cls.d.add('spark-test-ha', charm='spark',
+ units=3, constraints={'mem': '7G'})
+ cls.d.add('spark-test-zk', charm='zookeeper')
- cls.d.relate('zk-test:zookeeper', 'spark-test-ha:zookeeper')
+ cls.d.relate('spark-test-zk:zookeeper', 'spark-test-ha:zookeeper')
cls.d.expose('spark-test-ha')
cls.d.setup(timeout=3600)
@@ -41,10 +42,10 @@ class TestDeployment(unittest.TestCase):
def tearDownClass(cls):
# NB: seems to be a remove_service issue with amulet. However, the
# unit does still get removed. Pass OSError for now:
- # OSError: juju command failed ['remove-application', 'zk-test']:
- # ERROR allocation for service ...zk-test... owned by ... not found
+ # OSError: juju command failed ['remove-application', ...]:
+ # ERROR allocation for service ... owned by ... not found
try:
- cls.d.remove_service('spark-test-ha', 'zk-test')
+ cls.d.remove_service('spark-test-ha', 'spark-test-zk')
except OSError as e:
print("IGNORE: Amulet remove_service failed: {}".format(e))
pass
diff --git a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/README.md b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/README.md
index c76ad1e5..1003bfe4 100644
--- a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/README.md
+++ b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/README.md
@@ -18,52 +18,73 @@
Apache Zeppelin is a web-based notebook that enables interactive data analytics.
It allows for beautiful data-driven, interactive, and collaborative documents
-with SQL, Scala and more.
+with SQL, Scala and more. Learn more at [zeppelin.apache.org][].
-As a Multi-purpose Notebook, Apache Zeppelin is the place for interactive:
-
- * Data Ingestion
- * Data Discovery
- * Data Analytics
- * Data Visualization & Collaboration
-
-This charm deploys the Zeppelin component of the [Apache Bigtop][] platform.
+This charm deploys version 0.7.0 of the Zeppelin component from
+[Apache Bigtop][].
+[zeppelin.apache.org]: http://zeppelin.apache.org/
[Apache Bigtop]: http://bigtop.apache.org/
# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the [getting-started][] instructions prior to deploying this
-charm.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this charm.
+
+Zeppelin can be deployed by itself as a stand-alone web notebook. Deployment
+is simple:
+
+ juju deploy zeppelin
+
+To access the web interface, find the `Public address` of the `zeppelin`
+application and expose it:
-This charm is intended to be deployed via one of the [apache bigtop bundles][].
+ juju status zeppelin
+ juju expose zeppelin
+
+The web interface will be available at the following URL:
+
+ http://ZEPPELIN_PUBLIC_IP:9080
+
+This charm also supports more complex integration scenarios as described below.
+
+## Hadoop Integration
+This charm may be deployed alongside any of the [Apache Bigtop bundles][].
For example:
juju deploy hadoop-processing
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, use [juju-quickstart][] with the following syntax: `juju quickstart
-hadoop-processing`.
-
-This will deploy an Apache Bigtop Hadoop cluster. More information about this
+This will deploy a basic Bigtop Hadoop cluster. More information about this
deployment can be found in the [bundle readme](https://jujucharms.com/hadoop-processing/).
-Now add Zeppelin and relate it to the cluster via the hadoop-plugin:
+Now relate the previously deployed `zeppelin` charm to the Hadoop plugin. This
+enables communication between Zeppelin and Hadoop:
- juju deploy zeppelin
juju add-relation zeppelin plugin
-To access the web console, find the `PUBLIC-ADDRESS` of the
-zeppelin application and expose it:
+Once deployment is complete, Zeppelin notebooks will have access to the
+Hadoop Distributed File System (HDFS). Additionally, the local Spark driver
+will be reconfigured in YARN mode. Any notebooks that submit Spark jobs will
+leverage the Hadoop compute resources deployed by the `hadoop-processing`
+bundle.
- juju status zeppelin
- juju expose zeppelin
+## Spark Integration
+Zeppelin includes a local Spark driver by default. This allows notebooks to
+use a SparkContext without needing external Spark resources. This driver can
+process jobs using local machine resources or compute resources from a Hadoop
+cluster as mentioned above.
-The web interface will be available at the following URL:
+Zeppelin's Spark driver can also use external Spark cluster resources. For
+example, the following will deploy a 3-unit Spark cluster that Zeppelin will
+use when submitting jobs:
- http://ZEPPELIN_PUBLIC_IP:9080
+ juju deploy spark -n 3
+ juju relate zeppelin spark
+
+Once deployment is complete, the local Spark driver will be reconfigured to
+use the external cluster as the Spark Master. Any notebooks that submit Spark
+jobs will leverage the newly deployed `spark` units.
## Network-Restricted Environments
Charms can be deployed in environments with limited network access. To deploy
@@ -72,7 +93,6 @@ mirror options. See [Configuring Models][] for more information.
[getting-started]: https://jujucharms.com/docs/stable/getting-started
[apache bigtop bundles]: https://jujucharms.com/u/bigdata-charmers/#bundles
-[juju-quickstart]: https://launchpad.net/juju-quickstart
[Configuring Models]: https://jujucharms.com/docs/stable/models-config
@@ -99,24 +119,34 @@ application is functioning as expected. Run the action as follows:
juju run-action zeppelin/0 smoke-test
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do zeppelin/0 smoke-test`.
-
Watch the progress of the smoke test actions with:
watch -n 2 juju show-action-status
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
-
Eventually, the action should settle to `status: completed`. If it
reports `status: failed`, the application is not working as expected. Get
more information about a specific smoke test with:
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
+
+# Limitations
+
+When related to Spark, Zeppelin requires a `spark://xxx.xxx.xxx.xxx:7077`
+URL for the Spark Master. This is only available when the `spark` charm is
+in `standalone` mode -- `local` and `yarn` modes are not supported.
+
+
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this charm at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
+
+Ensure `Bigtop` is selected as the project. Typically, charm issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
# Contact Information
@@ -126,9 +156,10 @@ of Juju, the syntax is `juju action fetch <action-id>`.
# Resources
+- [Apache Zeppelin home page](http://zeppelin.apache.org/)
- [Apache Bigtop home page](http://bigtop.apache.org/)
- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/actions/restart b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/actions/restart
index bb37376f..6e822b44 100755
--- a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/actions/restart
+++ b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/actions/restart
@@ -18,12 +18,13 @@
import sys
sys.path.append('lib')
-from charmhelpers.core import hookenv
-from charms.reactive import is_state
-from charms.layer.bigtop_zeppelin import Zeppelin
+from charmhelpers.core import hookenv # noqa: E402
+from charms.reactive import is_state # noqa: E402
+from charms.layer.bigtop_zeppelin import Zeppelin # noqa: E402
def fail(msg):
+ hookenv.action_set({'outcome': 'failure'})
hookenv.action_fail(msg)
sys.exit()
diff --git a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/actions/smoke-test b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/actions/smoke-test
index 0339d465..e2e59598 100755
--- a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/actions/smoke-test
+++ b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/actions/smoke-test
@@ -16,7 +16,6 @@
# limitations under the License.
import sys
-import json
from time import sleep
from urllib.parse import urljoin
from operator import itemgetter
@@ -28,6 +27,7 @@ from charms.reactive import is_state
def fail(msg):
+ hookenv.action_set({'outcome': 'failure'})
hookenv.action_fail(msg)
sys.exit()
@@ -35,23 +35,13 @@ def fail(msg):
if not is_state('zeppelin.installed'):
fail('Zeppelin not yet ready')
-
notebook_id = '2A94M5J1Z'
zep_addr = 'localhost'
base_url = 'http://{}:9080/api/notebook/'.format(zep_addr)
-interp_url = urljoin(base_url, 'interpreter/bind/%s' % notebook_id)
job_url = urljoin(base_url, 'job/%s' % notebook_id)
para_url = urljoin(base_url, '%s/paragraph/' % notebook_id)
try:
- # bind interpreters
- resp = requests.get(interp_url, timeout=60)
- resp.raise_for_status()
- interpreters = resp.json()
- interp_ids = list(map(itemgetter('id'), interpreters['body']))
- resp = requests.put(interp_url, data=json.dumps(interp_ids), timeout=60)
- resp.raise_for_status()
-
# run notebook
resp = requests.post(job_url, timeout=60)
resp.raise_for_status()
@@ -87,7 +77,9 @@ try:
errmsg = para['result']['msg'].splitlines()[0]
else:
errmsg = 'Unable to find error message'
- hookenv.action_set('paragraph', resp.text)
+ hookenv.action_set({'paragraph': resp.text})
fail('Notebook failed: {}'.format(errmsg))
except requests.exceptions.RequestException as e:
fail('Request failed: {}: {}'.format(e.request.url, e))
+
+hookenv.action_set({'outcome': 'success'})
diff --git a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/icon.svg b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/icon.svg
index 88e23c97..4334f863 100644
--- a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/icon.svg
+++ b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/icon.svg
@@ -1,486 +1,20 @@
-<?xml version="1.0" encoding="UTF-8" standalone="no"?>
-<!-- Created with Inkscape (http://www.inkscape.org/) -->
-
-<svg
- xmlns:dc="http://purl.org/dc/elements/1.1/"
- xmlns:cc="http://creativecommons.org/ns#"
- xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
- xmlns:svg="http://www.w3.org/2000/svg"
- xmlns="http://www.w3.org/2000/svg"
- xmlns:xlink="http://www.w3.org/1999/xlink"
- xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
- xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
- width="96"
- height="96"
- id="svg6517"
- version="1.1"
- inkscape:version="0.48.4 r9939"
- sodipodi:docname="icon.svg">
- <defs
- id="defs6519">
- <linearGradient
- inkscape:collect="always"
- xlink:href="#Background"
- id="linearGradient6461"
- gradientUnits="userSpaceOnUse"
- x1="0"
- y1="970.29498"
- x2="144"
- y2="970.29498"
- gradientTransform="matrix(0,-0.66666669,0.6660448,0,-832.14561,847.86846)" />
- <linearGradient
- id="Background">
- <stop
- id="stop4178"
- offset="0"
- style="stop-color:#10b1ef;stop-opacity:1;" />
- <stop
- id="stop4180"
- offset="1"
- style="stop-color:#c9c9c9;stop-opacity:1" />
- </linearGradient>
- <filter
- style="color-interpolation-filters:sRGB;"
- inkscape:label="Inner Shadow"
- id="filter1121">
- <feFlood
- flood-opacity="0.59999999999999998"
- flood-color="rgb(0,0,0)"
- result="flood"
- id="feFlood1123" />
- <feComposite
- in="flood"
- in2="SourceGraphic"
- operator="out"
- result="composite1"
- id="feComposite1125" />
- <feGaussianBlur
- in="composite1"
- stdDeviation="1"
- result="blur"
- id="feGaussianBlur1127" />
- <feOffset
- dx="0"
- dy="2"
- result="offset"
- id="feOffset1129" />
- <feComposite
- in="offset"
- in2="SourceGraphic"
- operator="atop"
- result="composite2"
- id="feComposite1131" />
- </filter>
- <filter
- style="color-interpolation-filters:sRGB;"
- inkscape:label="Drop Shadow"
- id="filter950">
- <feFlood
- flood-opacity="0.25"
- flood-color="rgb(0,0,0)"
- result="flood"
- id="feFlood952" />
- <feComposite
- in="flood"
- in2="SourceGraphic"
- operator="in"
- result="composite1"
- id="feComposite954" />
- <feGaussianBlur
- in="composite1"
- stdDeviation="1"
- result="blur"
- id="feGaussianBlur956" />
- <feOffset
- dx="0"
- dy="1"
- result="offset"
- id="feOffset958" />
- <feComposite
- in="SourceGraphic"
- in2="offset"
- operator="over"
- result="composite2"
- id="feComposite960" />
- </filter>
- <clipPath
- clipPathUnits="userSpaceOnUse"
- id="clipPath873">
- <g
- transform="matrix(0,-0.66666667,0.66604479,0,-258.25992,677.00001)"
- id="g875"
- inkscape:label="Layer 1"
- style="fill:#ff00ff;fill-opacity:1;stroke:none;display:inline">
- <path
- style="fill:#ff00ff;fill-opacity:1;stroke:none;display:inline"
- d="m 46.702703,898.22775 50.594594,0 C 138.16216,898.22775 144,904.06497 144,944.92583 l 0,50.73846 c 0,40.86071 -5.83784,46.69791 -46.702703,46.69791 l -50.594594,0 C 5.8378378,1042.3622 0,1036.525 0,995.66429 L 0,944.92583 C 0,904.06497 5.8378378,898.22775 46.702703,898.22775 Z"
- id="path877"
- inkscape:connector-curvature="0"
- sodipodi:nodetypes="sssssssss" />
- </g>
- </clipPath>
- <filter
- inkscape:collect="always"
- id="filter891"
- inkscape:label="Badge Shadow">
- <feGaussianBlur
- inkscape:collect="always"
- stdDeviation="0.71999962"
- id="feGaussianBlur893" />
- </filter>
- <linearGradient
- inkscape:collect="always"
- xlink:href="#Background"
- id="linearGradient3134"
- x1="5.0652875"
- y1="50.451253"
- x2="90"
- y2="51"
- gradientUnits="userSpaceOnUse"
- gradientTransform="translate(-255.97409,684.13067)" />
- </defs>
- <sodipodi:namedview
- id="base"
- pagecolor="#ffffff"
- bordercolor="#666666"
- borderopacity="1.0"
- inkscape:pageopacity="0.0"
- inkscape:pageshadow="2"
- inkscape:zoom="4.0745362"
- inkscape:cx="18.514671"
- inkscape:cy="49.018169"
- inkscape:document-units="px"
- inkscape:current-layer="layer1"
- showgrid="true"
- fit-margin-top="0"
- fit-margin-left="0"
- fit-margin-right="0"
- fit-margin-bottom="0"
- inkscape:window-width="1031"
- inkscape:window-height="1896"
- inkscape:window-x="49"
- inkscape:window-y="24"
- inkscape:window-maximized="1"
- showborder="true"
- showguides="true"
- inkscape:guide-bbox="true"
- inkscape:showpageshadow="false">
- <inkscape:grid
- type="xygrid"
- id="grid821" />
- <sodipodi:guide
- orientation="1,0"
- position="16,48"
- id="guide823" />
- <sodipodi:guide
- orientation="0,1"
- position="64,80"
- id="guide825" />
- <sodipodi:guide
- orientation="1,0"
- position="80,40"
- id="guide827" />
- <sodipodi:guide
- orientation="0,1"
- position="64,16"
- id="guide829" />
- </sodipodi:namedview>
- <metadata
- id="metadata6522">
- <rdf:RDF>
- <cc:Work
- rdf:about="">
- <dc:format>image/svg+xml</dc:format>
- <dc:type
- rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
- <dc:title></dc:title>
- </cc:Work>
- </rdf:RDF>
- </metadata>
- <g
- inkscape:label="BACKGROUND"
- inkscape:groupmode="layer"
- id="layer1"
- transform="translate(268,-635.29076)"
- style="display:inline">
- <path
- style="color:#000000;fill:#a0a0a0;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1px;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- d=""
- id="path3140"
- inkscape:connector-curvature="0"
- transform="translate(-268,635.29076)" />
- <path
- style="color:#000000;fill:#a1b4bb;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:0.2454267;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- d="m -248.93557,732.01702 c -5.28927,-0.46936 -9.72782,-1.8431 -12.54221,-3.88183 -2.15434,-1.5606 -4.10069,-4.54273 -4.99322,-7.65046 -0.52933,-1.84308 -1.05542,-5.60148 -1.36264,-9.7347 -0.31315,-4.21296 -0.30401,-43.3237 0.0114,-48.89694 0.38986,-6.88808 1.24042,-11.37707 2.71107,-14.30818 2.79041,-5.56148 7.0575,-7.75361 17.14746,-8.80914 4.40117,-0.46042 51.55611,-0.46042 55.95729,0 11.55122,1.20839 16.00758,4.11773 18.27096,11.92817 0.63745,2.1997 1.36317,6.78141 1.36317,8.60612 0,0.59482 0.0847,1.13383 0.18816,1.19779 0.31305,0.19347 0.374,45.16411 0.0672,49.61159 -0.66327,9.61657 -1.91214,13.63748 -5.2599,16.93499 -2.86188,2.81893 -5.73688,3.93245 -12.36882,4.7906 -3.55249,0.45969 -5.16533,0.48373 -30.3102,0.45177 -14.60693,-0.0186 -27.60284,-0.12646 -28.87979,-0.23978 l 0,0 z"
- id="path3172"
- inkscape:connector-curvature="0" />
- <image
- y="656.29077"
- x="-263"
- id="image3188"
- xlink:href="
-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
-RK5CYII=
-"
- height="55.000042"
- width="83.820099" />
- <path
- style="fill:#a1b4bb;fill-opacity:1"
- d="m 5.0652875,74.182812 c 0,-1.644894 0.059004,-1.933067 0.3712655,-1.813242 0.2041961,0.07836 0.5079117,0.03407 0.6749235,-0.09841 0.1670118,-0.132486 0.7454259,-0.319654 1.2853647,-0.415927 0.5399388,-0.09627 1.3130329,-0.325824 1.7179869,-0.510112 0.7800115,-0.354976 4.1759739,-1.096834 5.0209009,-1.096834 0.27566,0 0.5012,-0.110442 0.5012,-0.245427 0,-0.134985 0.165663,-0.245427 0.36814,-0.245427 0.459824,0 0.477938,0.09776 -0.246454,-1.330085 -0.336896,-0.664053 -0.612539,-1.354316 -0.612539,-1.533917 0,-0.1796 -0.15015,-0.326545 -0.333667,-0.326545 -0.40361,0 -3.339856,1.471741 -3.794761,1.902057 -0.1783727,0.168731 -0.4651897,0.306784 -0.637371,0.306784 -0.1721813,0 -0.5677382,0.220884 -0.8790156,0.490853 -0.3112774,0.269969 -0.7147231,0.490853 -0.8965462,0.490853 -0.1818229,0 -0.5253754,0.193274 -0.7634499,0.429497 -0.2380744,0.236223 -0.7350635,0.565181 -1.1044202,0.731018 l -0.6715576,0.301522 0,-25.028262 0,-25.028263 28.6535675,0.03677 c 15.759463,0.02022 28.322242,0.07368 27.917288,0.118796 -2.510585,0.279686 -4.943318,0.664366 -5.153961,0.81498 -0.134984,0.09652 -0.908078,0.316283 -1.717986,0.488369 -0.809909,0.172085 -1.941942,0.52442 -2.515632,0.782966 -0.573687,0.258546 -1.374392,0.536349 -1.779343,0.617339 -0.404949,0.08099 -0.736273,0.243891 -0.736273,0.362003 0,0.118112 -0.156491,0.214748 -0.347757,0.214748 -0.432162,0 -3.519027,1.622883 -3.998097,2.101953 -0.193772,0.193773 -0.513555,0.352314 -0.710626,0.352314 -0.197072,0 -0.420271,0.161459 -0.495997,0.358798 -0.07572,0.197338 -0.328894,0.419486 -0.562599,0.49366 -0.233703,0.07418 -0.637658,0.326873 -0.897675,0.561553 -0.26002,0.234679 -0.950842,0.751454 -1.535159,1.148389 -0.584317,0.396934 -1.509114,1.142418 -2.055105,1.65663 -0.545989,0.514212 -1.071244,0.934931 -1.167233,0.934931 -0.09599,0 -0.463093,0.303716 -0.815786,0.674924 -0.352695,0.371208 -1.036856,1.006249 -1.520362,1.411203 -2.714291,2.27333 -5.42323,4.745103 -9.988905,9.11438 -4.044712,3.870725 -8.055597,8.556004 -8.055597,9.410075 0,0.137878 -0.09367,0.250688 -0.208153,0.250688 -0.114484,0 -0.402637,0.469379 -0.640339,1.043064 -0.237702,0.573685 -0.6287,1.484831 -0.868884,2.02477 -1.194238,2.684674 -1.505876,7.84213 -0.630268,10.430635 0.251135,0.742416 0.535356,1.405068 0.631601,1.47256 0.09625,0.06749 0.348306,0.46116 0.560133,0.874817 0.556959,1.087625 3.658447,4.032763 4.247547,4.033418 0.148077,1.65e-4 0.523912,0.221184 0.83519,0.491153 0.311277,0.269969 0.687112,0.491533 0.835189,0.492365 0.148077,7.36e-4 0.56227,0.154406 0.920429,0.341276 0.358159,0.186873 1.076032,0.469992 1.595274,0.629156 0.519241,0.159164 1.164959,0.394445 1.434929,0.522845 0.269969,0.1284 0.987842,0.32949 1.595273,0.446863 0.695999,0.134489 -3.320148,0.223353 -10.860132,0.240297 l -11.9645515,0.02689 0,-1.955712 z M 23.618175,44.198096 c 0.797164,-0.694149 1.712944,-1.522464 2.035067,-1.8407 0.322122,-0.318236 0.669243,-0.578611 0.771378,-0.578611 0.102136,0 0.252788,-0.174823 0.334782,-0.388496 0.181106,-0.471955 -1.37429,-2.069686 -2.003086,-2.057606 -1.159466,0.02227 -2.689852,2.471904 -2.920011,4.673949 -0.09356,0.895154 -0.05888,1.453553 0.09028,1.453553 0.133212,0 0.894428,-0.56794 1.691593,-1.262089 l 0,0 z"
- id="path3191"
- inkscape:connector-curvature="0"
- transform="translate(-268,635.29076)" />
- <path
- style="fill:#a1b4bb;fill-opacity:1"
- d="m 40.161307,75.75772 c 4.119556,-0.456634 4.092711,-0.445791 4.069198,-1.643454 l -0.01966,-1.001272 1.595274,-0.356919 c 0.8774,-0.196305 1.650747,-0.444181 1.718549,-0.550836 0.0678,-0.106655 0.5426,-0.272583 1.055106,-0.368729 0.512507,-0.09615 1.064464,-0.301541 1.226571,-0.456432 0.162108,-0.154889 0.929783,-0.478553 1.705945,-0.719248 0.776162,-0.240697 1.411203,-0.533653 1.411203,-0.651014 0,-0.117363 0.338789,-0.287797 0.752864,-0.378742 0.414075,-0.09095 0.809145,-0.312023 0.877933,-0.491283 0.141606,-0.369019 1.820455,-1.100349 2.525972,-1.100349 0.255989,0 0.50985,-0.133248 0.564136,-0.296106 0.07158,-0.214742 1.217678,-0.299041 4.170932,-0.306784 3.978475,-0.01043 4.086855,0.003 4.707569,0.584315 0.349438,0.327245 0.635343,0.741403 0.635343,0.920349 0,0.178948 0.220884,0.32536 0.490854,0.32536 0.269969,0 0.490853,-0.09027 0.490853,-0.200607 0,-0.110334 0.607431,-0.392082 1.349847,-0.626108 0.742416,-0.234025 1.349847,-0.516494 1.349847,-0.627708 0,-0.111214 0.318014,-0.26581 0.706696,-0.343547 0.388685,-0.07774 0.858064,-0.285082 1.043064,-0.460767 0.185002,-0.175685 0.771008,-0.540045 1.302236,-0.809689 0.531229,-0.269644 1.152288,-0.655924 1.380135,-0.858401 0.227847,-0.202477 0.786475,-0.644245 1.241396,-0.981707 1.085222,-0.805019 3.652688,-3.360902 3.652688,-3.63621 0,-0.118426 0.358936,-0.602475 0.797636,-1.075664 1.125913,-1.214429 1.620433,-1.893239 2.199412,-3.019067 0.277675,-0.539939 0.585634,-1.036928 0.684352,-1.104421 0.09872,-0.06749 0.430044,-0.619702 0.73628,-1.227133 0.306236,-0.607431 0.63165,-1.159641 0.72314,-1.227134 0.09149,-0.06749 0.424834,-0.785365 0.740757,-1.595273 0.315923,-0.809908 0.827,-2.04109 1.135724,-2.735959 0.308725,-0.694869 0.700519,-1.937341 0.870654,-2.76105 0.170132,-0.823709 0.39768,-1.497652 0.505658,-1.497652 0.107975,0 0.196321,7.12351 0.196321,15.830022 l 0,15.830023 -25.708447,-0.03398 C 40.77683,76.075113 37.716333,76.028732 40.161307,75.75772 z m 20.689674,-0.510714 c 1.91667,-0.08859 3.709853,-0.243895 3.984852,-0.345129 0.399176,-0.146946 0.563379,-0.561281 0.814338,-2.054827 0.172891,-1.028922 0.47181,-2.172621 0.664269,-2.541551 0.483106,-0.926078 0.450064,-1.110006 -0.321973,-1.792301 -0.644294,-0.569401 -0.821654,-0.595747 -3.90828,-0.580556 -1.910105,0.0094 -3.366499,0.123596 -3.558688,0.279034 -0.178931,0.144717 -0.794129,0.340439 -1.367107,0.434939 -0.572978,0.0945 -1.10507,0.274228 -1.182429,0.399396 -0.07736,0.12517 -0.595613,0.459684 -1.151677,0.743366 -0.556065,0.283683 -1.163725,0.668485 -1.350357,0.855118 -0.186632,0.186632 -0.607713,0.406691 -0.935736,0.48902 -0.328022,0.08233 -0.596405,0.234593 -0.596405,0.33837 0,0.103773 -0.773094,0.389195 -1.717987,0.634268 -0.944892,0.245076 -1.717986,0.519652 -1.717986,0.61017 0,0.09052 -0.690263,0.310644 -1.533917,0.489165 -1.732683,0.366641 -2.252917,0.74165 -2.02501,1.459722 0.132449,0.417311 0.385353,0.496125 1.673408,0.521507 0.834558,0.01644 3.450114,0.106552 5.812346,0.200241 2.362232,0.09369 4.438633,0.136767 4.614225,0.09573 0.175591,-0.04103 1.887443,-0.147091 3.804114,-0.235681 z"
- id="path3193"
- inkscape:connector-curvature="0"
- transform="translate(-268,635.29076)" />
- <path
- style="fill:#a1b4bb;fill-opacity:1"
- d="m 88.428559,34.988646 c -0.08999,-0.08999 -0.163618,-0.386447 -0.163618,-0.658793 0,-0.635276 -0.969876,-2.676072 -1.393673,-2.932542 -0.178373,-0.107946 -0.324314,-0.344751 -0.324314,-0.526234 0,-0.337656 -3.14023,-3.631128 -4.653855,-4.880962 -1.118614,-0.923664 -5.006105,-2.973691 -6.390347,-3.36988 -0.607431,-0.173855 -1.214862,-0.394911 -1.349847,-0.491236 -0.230232,-0.164293 -2.185515,-0.609134 -3.558687,-0.809627 -0.337462,-0.04927 3.610841,-0.104625 8.774005,-0.123008 l 9.387571,-0.03342 0,6.994662 c 0,3.847063 -0.03681,6.994661 -0.08181,6.994661 -0.045,0 -0.155438,-0.07363 -0.245427,-0.163618 z"
- id="path3195"
- inkscape:connector-curvature="0"
- transform="translate(-268,635.29076)" />
- </g>
- <g
- inkscape:groupmode="layer"
- id="layer3"
- inkscape:label="PLACE YOUR PICTOGRAM HERE"
- style="display:inline" />
- <g
- inkscape:groupmode="layer"
- id="layer2"
- inkscape:label="BADGE"
- style="display:none"
- sodipodi:insensitive="true">
- <g
- style="display:inline"
- transform="translate(-340.00001,-581)"
- id="g4394"
- clip-path="none">
- <g
- id="g855">
- <g
- inkscape:groupmode="maskhelper"
- id="g870"
- clip-path="url(#clipPath873)"
- style="opacity:0.6;filter:url(#filter891)">
- <path
- transform="matrix(1.4999992,0,0,1.4999992,-29.999795,-237.54282)"
- d="m 264,552.36218 c 0,6.62742 -5.37258,12 -12,12 -6.62742,0 -12,-5.37258 -12,-12 0,-6.62741 5.37258,-12 12,-12 6.62742,0 12,5.37259 12,12 z"
- sodipodi:ry="12"
- sodipodi:rx="12"
- sodipodi:cy="552.36218"
- sodipodi:cx="252"
- id="path844"
- style="color:#000000;fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- sodipodi:type="arc" />
+<?xml version="1.0" encoding="UTF-8"?>
+<svg width="100px" height="100px" viewBox="0 0 100 100" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
+ <!-- Generator: Sketch 43.2 (39069) - http://www.bohemiancoding.com/sketch -->
+ <title>zeppelin</title>
+ <desc>Created with Sketch.</desc>
+ <defs>
+ <circle id="path-1" cx="50" cy="50" r="50"></circle>
+ </defs>
+ <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
+ <g id="zeppelin">
+ <g id="Group">
+ <mask id="mask-2" fill="white">
+ <use xlink:href="#path-1"></use>
+ </mask>
+ <use id="Oval-Copy" fill="#A1B4BB" transform="translate(50.000000, 50.000000) rotate(-180.000000) translate(-50.000000, -50.000000) " xlink:href="#path-1"></use>
+ </g>
+ <path d="M66.2781964,29.0002328 C59.7530292,28.9749411 52.5197424,31.0139972 48.6216035,33.418427 C47.1645139,34.3171811 45.6693771,35.323441 44.1710415,36.3854683 C44.1710415,36.3854683 30.6506397,46.7960363 26.4497132,52.0352624 C25.8870637,52.7369756 25.374783,53.4934016 24.9284295,54.2902138 C24.8983473,54.347414 24.8662524,54.4051787 24.8367209,54.4628416 C24.7949778,54.5395609 24.7531,54.6174023 24.7126447,54.6948103 C24.7030638,54.7142137 24.6951868,54.7346994 24.6856716,54.7541511 C24.0219192,56.1110337 23.5160919,57.5804092 23.2668864,59.0644529 C23.2647976,59.0769339 23.2635546,59.0897239 23.2615004,59.1022153 C23.2540428,59.1543472 23.2467925,59.2063064 23.2399219,59.2586593 C23.014097,60.9795294 23.1071003,62.8157201 23.8117517,64.3727595 C24.6683501,66.2655515 26.0941809,67.6782964 28.1598165,68.8395053 C30.1518315,69.9593267 33.7971949,70.9110396 33.7971949,70.9110396 L33.7378541,70.9380127 C36.7760043,71.4768843 39.9232448,71.295922 42.9950229,70.9973535 C44.5012476,70.850953 46.008085,70.685175 47.5157149,70.4956538 C47.5167507,70.495678 47.5200824,70.4956296 47.5211009,70.4956538 C47.5313895,70.4958264 47.5640921,70.4954812 47.5750471,70.4956538 C47.4756894,69.9897143 47.3152076,69.0208923 47.5103116,68.9689762 C49.5753551,68.4194827 50.8047606,68.087963 52.4140217,67.5286125 C53.9527832,66.9937665 55.0788986,66.5064415 56.3251216,65.8185178 C56.6365215,65.6466236 56.8830375,65.3601356 57.2098393,65.2197149 C58.2416585,64.77636 59.3904969,64.6724725 60.5005578,64.5022304 C61.3874559,64.3662135 62.2845891,64.2770736 63.1816842,64.2594725 C63.7635661,64.2480618 64.3527364,64.2352942 64.9241467,64.3457864 C65.3618101,64.4304155 65.80449,64.5529934 66.1864879,64.7827507 C66.4419978,64.9364309 66.6789123,65.1444716 66.8446316,65.3923428 C66.9330447,65.5807385 67.0061612,65.779062 67.0766003,65.9749618 C70.3390751,64.7525235 73.6528757,63.2785682 76.1719304,60.8878347 C79.8980717,57.3515047 82.8585945,52.7297702 84.323202,47.8058799 C85.1188404,45.1310113 85.256991,42.1252306 84.5012245,39.4388235 C84.0339848,37.7779968 83.3136657,36.7091144 81.7068111,35.0799701 C78.4197747,31.7473376 73.6311453,29.6863353 68.9809013,29.1512822 C68.1199941,29.0522266 67.2103627,29.0038459 66.2781964,29.0002328 Z M44.1710415,36.3854683 C43.5035,36.8586257 42.8338282,37.343161 42.1696373,37.8366212 L44.1710415,36.3854683 Z M58.2456065,39.530532 C60.3595761,39.5242829 61.5309304,39.8488146 61.5309304,39.8488146 C61.5309304,39.8488146 58.0529935,40.1733878 56.120126,40.5177476 C54.5891551,40.7905048 52.1265618,41.2646617 50.2076219,41.9149543 C46.4659079,43.1829491 42.9064562,44.9558078 39.3914078,46.7593235 C36.6896662,48.1455442 34.1008611,49.7469697 31.5152618,51.3393563 C29.7480877,52.4277008 26.2986638,54.7379673 26.2986638,54.7379673 C26.2986638,54.7379673 29.2382555,50.9393862 37.0555371,46.5489333 C39.2907226,45.2935767 41.5718754,44.1159819 43.9120998,43.0694031 C45.7407829,42.2515924 47.5949459,41.4721207 49.5117159,40.8899764 C50.9679941,40.4476883 52.4707869,40.1413274 53.973067,39.8973662 C55.0676036,39.71962 56.2311533,39.6076829 57.2799694,39.5575051 C57.619632,39.5412609 57.9436113,39.5314245 58.2456065,39.530532 Z M31.4289479,43.155717 C30.7365755,43.159791 30.1428514,43.9724574 29.778194,44.5852915 C29.3109042,45.370598 29.103264,46.7182674 29.0067633,47.7950907 C30.5070651,46.5119116 32.0042475,45.3182452 33.0419394,44.5097668 C32.6410147,43.8362109 32.1387712,43.2538957 31.569208,43.1665063 C31.522217,43.1592904 31.4751069,43.1554408 31.4289479,43.155717 Z M61.6550066,46.5866957 C61.6550066,46.5866957 55.1279146,49.0635498 51.8853489,50.3575354 C48.1499876,51.8481787 44.4264099,53.3760716 40.7292737,54.9591467 C38.1430978,56.0665199 35.5717523,57.2110909 33.0149663,58.3847307 C30.6643567,59.4637291 26.0019596,61.707817 26.0019596,61.707817 C26.0019596,61.707817 29.9721984,58.4529567 37.3360574,55.2342724 C41.6334449,53.355919 44.5312037,51.7102577 49.1556709,50.2010914 C51.3150123,49.4964038 53.4461378,48.7029129 55.6292155,48.0756109 C57.6172963,47.5043405 61.6550066,46.5866957 61.6550066,46.5866957 Z M63.9207473,53.2112897 C63.9207473,53.2112897 63.0045819,54.3022477 60.9591006,55.6550528 C59.9363548,56.331457 59.0396307,57.0406175 58.0352163,57.6618516 C56.7351887,58.4659228 55.400746,59.2140177 54.0270132,59.8844352 C52.3242121,60.7154468 50.5561662,61.4100978 48.7942313,62.1070189 C47.0671017,62.7901712 45.3299562,63.4545986 43.5614494,64.0221092 C41.3794523,64.7223068 39.1762824,65.3701135 36.9368554,65.8562802 C35.3119215,66.2090435 32.0115669,66.6385001 32.0115669,66.6385001 C32.0115669,66.6385001 36.0839961,65.258898 38.1128827,64.5453874 C40.255039,63.7920429 42.2863821,63.0811424 44.5216919,62.2364898 C46.8323641,61.3633605 48.4845732,60.7271889 50.4503798,59.9329868 C52.0577471,59.2835971 53.6761661,58.6558721 55.2461975,57.9207934 C56.4469968,57.3585876 57.6124023,56.7208813 58.7796739,56.092017 C60.5093636,55.1601529 63.9207473,53.2112897 63.9207473,53.2112897 Z M68.6626187,57.4892237 C68.6626187,57.4892237 68.6079923,58.1659163 66.8877885,59.9275922 C66.1932601,60.6388639 64.9695979,61.5567503 64.1904783,62.0368888 C61.1709253,63.8977084 59.5618939,64.3727595 59.5618939,64.3727595 C59.5618939,64.3727595 62.5428835,62.4229866 63.9854827,61.3787451 C64.8349827,60.763824 65.6724504,60.1245761 66.4777974,59.4528656 C67.2298627,58.8255981 68.6626187,57.4892237 68.6626187,57.4892237 Z M22.3498009,63.9357953 C21.3355639,64.3920369 20.1134726,64.9580318 19.3126295,65.3869482 C17.827733,66.1822292 14.9059272,67.5733956 15.0023277,68.0249176 C15.1496829,68.7151062 18.4575364,67.3801405 20.1811634,67.037702 C21.2777974,66.8198302 22.3682738,66.5912001 23.4610927,66.3579799 C23.0201735,65.5869203 22.6368879,64.7750653 22.3498009,63.9357953 Z M62.7824823,65.0416925 C62.3434103,65.0445063 61.8741059,65.0702313 61.3043563,65.133401 C59.5589523,65.3269168 59.0864819,65.482969 57.6899606,65.9371995 C57.1924246,66.099026 56.8988157,66.3592297 56.5085387,66.5737647 C55.8072138,66.9592824 55.1466378,67.4245076 54.4154259,67.749792 C53.3647161,68.2172078 52.2468765,68.5168776 51.1462859,68.8502945 C50.2387726,69.1252217 50.1132411,69.1789711 48.400424,69.5893576 C48.1031157,69.6605924 48.3827297,70.1462809 48.6485766,70.5172323 C52.7121224,70.5995792 65.0028788,70.7960798 65.1669046,70.1126357 L66.0732008,66.3471906 C66.1539562,66.3183341 66.2351948,66.29022 66.3159588,66.2608767 C66.2819165,66.1314662 66.2378809,66.0019539 66.1864879,65.915621 C66.0366676,65.6639416 65.8180258,65.435536 65.5553173,65.3060289 C65.1138405,65.0883952 64.5898943,65.1228379 64.0987697,65.090244 C63.6347202,65.0594472 63.2215544,65.0388873 62.7824823,65.0416925 Z M65.005066,66.0558811 C65.4921217,66.0639774 65.8869716,66.1381193 65.8843891,66.3795583 C65.8788305,66.8992994 64.762018,66.873766 64.2498191,66.924415 C60.9462295,67.2510873 59.7876911,67.1955202 57.555095,67.2049353 C57.1261666,67.2067479 56.2711754,67.1617783 56.2711754,67.1617783 C56.2711754,67.1617783 58.4164442,66.6526107 60.3225354,66.4227153 C61.4308217,66.2890444 62.5117397,66.1508644 63.5754915,66.1152219 C63.9403906,66.1029999 64.5180103,66.0477918 65.005066,66.0558811 Z M62.474989,68.1274154 C62.8721055,68.1198198 63.2695898,68.1322317 63.6618055,68.1867562 C63.9719746,68.2298804 64.3219327,68.245467 64.5627071,68.445698 C64.6701904,68.5350795 64.7949088,68.7264997 64.7515188,68.8179268 C64.6633629,69.0036778 64.3313581,69.0125285 63.6240431,69.0606847 C62.7759535,69.1184253 61.9488918,69.1867152 61.11015,69.2117341 C59.0305453,69.2737662 54.868574,69.2009449 54.868574,69.2009449 C54.868574,69.2009449 56.1665853,68.8561898 56.8268213,68.7370075 C58.2996286,68.4711433 59.7889513,68.2780073 61.2827778,68.1867562 C61.67803,68.1626125 62.0778724,68.1350127 62.474989,68.1274154 Z" id="path3051" fill="#3071A9" fill-rule="nonzero"></path>
</g>
- <g
- id="g862">
- <path
- sodipodi:type="arc"
- style="color:#000000;fill:#f5f5f5;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- id="path4398"
- sodipodi:cx="252"
- sodipodi:cy="552.36218"
- sodipodi:rx="12"
- sodipodi:ry="12"
- d="m 264,552.36218 c 0,6.62742 -5.37258,12 -12,12 -6.62742,0 -12,-5.37258 -12,-12 0,-6.62741 5.37258,-12 12,-12 6.62742,0 12,5.37259 12,12 z"
- transform="matrix(1.4999992,0,0,1.4999992,-29.999795,-238.54282)" />
- <path
- transform="matrix(1.25,0,0,1.25,33,-100.45273)"
- d="m 264,552.36218 c 0,6.62742 -5.37258,12 -12,12 -6.62742,0 -12,-5.37258 -12,-12 0,-6.62741 5.37258,-12 12,-12 6.62742,0 12,5.37259 12,12 z"
- sodipodi:ry="12"
- sodipodi:rx="12"
- sodipodi:cy="552.36218"
- sodipodi:cx="252"
- id="path4400"
- style="color:#000000;fill:#dd4814;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- sodipodi:type="arc" />
- <path
- sodipodi:type="star"
- style="color:#000000;fill:#f5f5f5;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- id="path4459"
- sodipodi:sides="5"
- sodipodi:cx="666.19574"
- sodipodi:cy="589.50385"
- sodipodi:r1="7.2431178"
- sodipodi:r2="4.3458705"
- sodipodi:arg1="1.0471976"
- sodipodi:arg2="1.6755161"
- inkscape:flatsided="false"
- inkscape:rounded="0.1"
- inkscape:randomized="0"
- d="m 669.8173,595.77657 c -0.39132,0.22593 -3.62645,-1.90343 -4.07583,-1.95066 -0.44938,-0.0472 -4.05653,1.36297 -4.39232,1.06062 -0.3358,-0.30235 0.68963,-4.03715 0.59569,-4.47913 -0.0939,-0.44198 -2.5498,-3.43681 -2.36602,-3.8496 0.18379,-0.41279 4.05267,-0.59166 4.44398,-0.81759 0.39132,-0.22593 2.48067,-3.48704 2.93005,-3.4398 0.44938,0.0472 1.81505,3.67147 2.15084,3.97382 0.3358,0.30236 4.08294,1.2817 4.17689,1.72369 0.0939,0.44198 -2.9309,2.86076 -3.11469,3.27355 -0.18379,0.41279 0.0427,4.27917 -0.34859,4.5051 z"
- transform="matrix(1.511423,-0.16366377,0.16366377,1.511423,-755.37346,-191.93651)" />
- </g>
- </g>
</g>
- </g>
-</svg>
+</svg> \ No newline at end of file
diff --git a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/layer.yaml b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/layer.yaml
index 19626b4b..39a7ba32 100644
--- a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/layer.yaml
+++ b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/layer.yaml
@@ -26,13 +26,9 @@ options:
zeppelin_notebooks:
path: '/var/lib/zeppelin/notebook'
ports:
- # Ports that need to be exposed, overridden, or manually specified.
- # Only expose ports serving a UI or external API (i.e., namenode and
- # resourcemanager). Communication among units within the cluster does
- # not need ports to be explicitly opened.
zeppelin:
port: 9080
exposed_on: 'zeppelin'
- zeppelin_web:
+ zeppelin_websocket:
port: 9081
exposed_on: 'zeppelin'
diff --git a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/lib/charms/layer/bigtop_zeppelin.py b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/lib/charms/layer/bigtop_zeppelin.py
index b600f4b7..44512d29 100644
--- a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/lib/charms/layer/bigtop_zeppelin.py
+++ b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/lib/charms/layer/bigtop_zeppelin.py
@@ -16,16 +16,17 @@
import os
import json
import time
+import requests
import socket
-from urllib.parse import urljoin
-import requests
from path import Path
+from urllib.parse import urljoin
-from jujubigdata import utils
from charmhelpers.core import hookenv, host, unitdata
from charms import layer
from charms.layer.apache_bigtop_base import Bigtop
+from charms.reactive import is_state
+from jujubigdata import utils
class Zeppelin(object):
@@ -43,43 +44,89 @@ class Zeppelin(object):
def install(self):
'''
- Trigger the Bigtop puppet recipe that handles the Zepplin service.
+ Perform initial one-time setup, workaround upstream bugs, and
+ trigger puppet.
'''
# Dirs are handled by the bigtop deb, so no need to call out to
# dist_config to do that work. However, we want to adjust the
# groups for the `ubuntu` user for better interaction with Juju.
self.dist_config.add_users()
+
+ # Set ports based on layer.yaml options
self._add_override('zeppelin::server::server_port',
self.dist_config.port('zeppelin'))
self._add_override('zeppelin::server::web_socket_port',
- self.dist_config.port('zeppelin_web'))
+ self.dist_config.port('zeppelin_websocket'))
+
+ # Default spark to local mode on initial install. This will be
+ # reconfigured if/when hadoop or spark relations are made.
+ local_master = 'local[*]'
+ self._add_override('zeppelin::server::spark_master_url', local_master)
+
+ # The spark-client role expects hdfs by default. Since we want to
+ # keep Hadoop optional, ensure we remove hadoopy bits from our
+ # local spark config. This has no effect if/when a remote spark joins,
+ # and since there is no spark history server running, the event dirs
+ # are not important -- they just need not be 'hdfs:///blah'.
+ events_log_dir = 'file:///tmp'
+ self._add_override('spark::common::master_url', local_master)
+ self._add_override('spark::common::event_log_dir', events_log_dir)
+ self._add_override('spark::common::history_log_dir', events_log_dir)
+
+ ##########
+ # BUG: BIGTOP-2742
+ # Default zeppelin init script looks for the literal '$(hostname)'
+ # string. Symlink it so it exists before the apt install from puppet
+ # tries to start the service.
+ import subprocess
+ host = subprocess.check_output(['hostname']).decode('utf8').strip()
+ zepp_pid = '/var/run/zeppelin/zeppelin-zeppelin-{}.pid'.format(host)
+ utils.run_as('root', 'mkdir', '-p', '/var/run/zeppelin')
+ utils.run_as('root', 'ln', '-sf',
+ zepp_pid,
+ '/var/run/zeppelin/zeppelin-zeppelin-$(hostname).pid')
+ ##########
+
self.trigger_bigtop()
+ ##########
+ # BUG: BIGTOP-2742
+ # Puppet apply will call systemctl daemon-reload, which removes the
+ # symlink we just created. Now that the bits are on disk, update the
+ # init script $(hostname) that caused this mess to begin with.
+ zepp_init_script = '/etc/init.d/zeppelin'
+ utils.re_edit_in_place(zepp_init_script, {
+ r'^# pidfile.*': '# pidfile: {}'.format(zepp_pid),
+ })
+ utils.run_as('root', 'systemctl', 'daemon-reload')
+ self.restart()
+ self.wait_for_api(30)
+ ##########
+
def trigger_bigtop(self):
+ '''
+ Trigger the Bigtop puppet recipe that handles the Zeppelin service.
+ '''
bigtop = Bigtop()
overrides = unitdata.kv().getrange('zeppelin.bigtop.overrides.',
strip=True)
+
+ # The zep deb depends on spark-core, spark-python, and unfortunately,
+ # most of hadoop. Include appropriate roles here to ensure these
+ # packages are configured in the same way as our other Bigtop
+ # software deployed with puppet.
bigtop.render_site_yaml(
roles=[
+ 'spark-client',
+ 'spark-yarn-slave',
'zeppelin-server',
],
overrides=overrides,
)
+
bigtop.trigger_puppet()
self.wait_for_api(30)
- def setup_etc_env(self):
- '''
- Write some niceties to /etc/environment
- '''
- # Configure system-wide bits
- zeppelin_bin = self.dist_config.path('zeppelin') / 'bin'
- zeppelin_conf = self.dist_config.path('zeppelin_conf')
- with utils.environment_edit_in_place('/etc/environment') as env:
- if zeppelin_bin not in env['PATH']:
- env['PATH'] = ':'.join([env['PATH'], zeppelin_bin])
- env['ZEPPELIN_CONF_DIR'] = zeppelin_conf
-
def reconfigure_zeppelin(self):
'''
Configure zeppelin based on current environment
@@ -109,6 +156,12 @@ class Zeppelin(object):
utils.run_as('hdfs', 'hdfs', 'dfs', '-mkdir', '-p', '/user/zeppelin')
utils.run_as('hdfs', 'hdfs', 'dfs', '-chown', 'zeppelin', '/user/zeppelin')
+ # If spark is ready, let it handle the spark_master_url. Otherwise,
+ # zepp is in local mode; set it to yarn-client since hadoop is here.
+ if not is_state('spark.ready'):
+ self._add_override('zeppelin::server::spark_master_url', 'yarn-client')
+ self.trigger_bigtop()
+
def configure_spark(self, master_url):
'''
Configure the zeppelin spark interpreter
diff --git a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/metadata.yaml b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/metadata.yaml
index f6f4be6b..f07614d5 100644
--- a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/metadata.yaml
+++ b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/metadata.yaml
@@ -1,10 +1,13 @@
name: zeppelin
-summary: A web-based notebook that enables interactive data analytics.
+summary: Zeppelin from Apache Bigtop
maintainer: Juju Big Data <bigdata@lists.ubuntu.com>
-description: |
+description: >
Apache Zeppelin is a web-based notebook that enables interactive data
analytics. You can make beautiful data-driven, interactive, and collaborative
documents with SQL, Scala and more.
+
+ This charm provides version 0.7.0 of the Zeppelin application from Apache
+ Bigtop.
tags: ["analytics"]
provides:
client:
diff --git a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/reactive/zeppelin.py b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/reactive/zeppelin.py
index 6d37fdcc..7c9ca06e 100644
--- a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/reactive/zeppelin.py
+++ b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/reactive/zeppelin.py
@@ -27,40 +27,46 @@ from charms.reactive.helpers import data_changed
def update_status():
hadoop_joined = is_state('hadoop.joined')
hadoop_ready = is_state('hadoop.ready')
- hive_joined = is_state('hive.connected')
- hive_ready = is_state('hive.available')
+ hive_joined = is_state('hive.joined')
+ hive_ready = is_state('hive.ready')
spark_joined = is_state('spark.joined')
spark_ready = is_state('spark.ready')
+ spark_blocked = is_state('spark.master.unusable')
- waiting_apps = []
- ready_apps = []
- # Check status of the hadoop plugin
- if hadoop_joined and not hadoop_ready:
- waiting_apps.append('hadoop')
- elif hadoop_ready:
- ready_apps.append('hadoop')
-
- # Check status of Hive
- if hive_joined and not hive_ready:
- waiting_apps.append('hive')
- elif hive_ready:
- ready_apps.append('hive')
-
- # Check status of Spark
- if spark_joined and not spark_ready:
- waiting_apps.append('spark')
- elif spark_ready:
- ready_apps.append('spark')
-
- # Set appropriate status based on the apps we checked above
- if waiting_apps:
- hookenv.status_set('waiting',
- 'waiting for: {}'.format(' & '.join(waiting_apps)))
- elif ready_apps:
- hookenv.status_set('active',
- 'ready with: {}'.format(' & '.join(ready_apps)))
+ # handle blockers first; then report what's ready/waiting
+ if spark_blocked:
+ hookenv.status_set('blocked',
+ 'remote spark must be in standalone mode')
else:
- hookenv.status_set('active', 'ready')
+ waiting_apps = []
+ ready_apps = []
+ # Check status of the hadoop plugin
+ if hadoop_joined and not hadoop_ready:
+ waiting_apps.append('hadoop')
+ elif hadoop_ready:
+ ready_apps.append('hadoop')
+
+ # Check status of Hive
+ if hive_joined and not hive_ready:
+ waiting_apps.append('hive')
+ elif hive_ready:
+ ready_apps.append('hive')
+
+ # Check status of Spark
+ if spark_joined and not spark_ready:
+ waiting_apps.append('spark')
+ elif spark_ready:
+ ready_apps.append('spark')
+
+ # Set appropriate status based on the apps we checked above
+ if waiting_apps:
+ hookenv.status_set('waiting',
+ 'waiting for: {}'.format(' & '.join(waiting_apps)))
+ elif ready_apps:
+ hookenv.status_set('active',
+ 'ready with: {}'.format(' & '.join(ready_apps)))
+ else:
+ hookenv.status_set('active', 'ready')
@when('bigtop.available')
@@ -69,7 +75,6 @@ def initial_setup():
hookenv.status_set('maintenance', 'installing zeppelin')
zeppelin = Zeppelin()
zeppelin.install()
- zeppelin.setup_etc_env()
zeppelin.open_ports()
set_state('zeppelin.installed')
update_status()
@@ -78,8 +83,7 @@ def initial_setup():
hookenv.application_version_set(zeppelin_version)
-@when('zeppelin.installed')
-@when('hadoop.ready')
+@when('zeppelin.installed', 'hadoop.ready')
@when_not('zeppelin.hadoop.configured')
def configure_hadoop(hadoop):
zeppelin = Zeppelin()
@@ -88,9 +92,8 @@ def configure_hadoop(hadoop):
set_state('zeppelin.hadoop.configured')
-@when('zeppelin.installed')
+@when('zeppelin.installed', 'zeppelin.hadoop.configured')
@when_not('hadoop.ready')
-@when('zeppelin.hadoop.configured')
def unconfigure_hadoop():
zeppelin = Zeppelin()
zeppelin.remove_hadoop_notebooks()
@@ -122,24 +125,47 @@ def unconfigure_hive():
@when('zeppelin.installed', 'spark.ready')
def configure_spark(spark):
+ '''
+ Configure Zeppelin to use remote Spark resources.
+ '''
+ # NB: Use the master_url string if it already starts with spark://.
+ # Otherwise, it means the remote spark is in local or yarn mode -- that's
+ # bad because using 'local' or 'yarn' here would cause zepp's spark-submit
+ # to use the builtin spark, hence ignoring the remote spark. In this case,
+ # set a state so we can inform the user that the remote spark is unusable.
master_url = spark.get_master_url()
- if data_changed('spark.master', master_url):
- hookenv.status_set('maintenance', 'configuring spark')
- zeppelin = Zeppelin()
- zeppelin.configure_spark(master_url)
- set_state('zeppelin.spark.configured')
- update_status()
+
+ if master_url.startswith('spark'):
+ remove_state('spark.master.unusable')
+ # Only (re)configure if our master url has changed.
+ if data_changed('spark.master', master_url):
+ hookenv.status_set('maintenance', 'configuring spark')
+ zeppelin = Zeppelin()
+ zeppelin.configure_spark(master_url)
+ set_state('zeppelin.spark.configured')
+ else:
+ remove_state('zeppelin.spark.configured')
+ set_state('spark.master.unusable')
+ update_status()
@when('zeppelin.installed', 'zeppelin.spark.configured')
@when_not('spark.ready')
def unconfigure_spark():
+ '''
+ Remove remote Spark; reconfigure Zeppelin to use embedded Spark.
+ '''
hookenv.status_set('maintenance', 'removing spark relation')
zeppelin = Zeppelin()
- # Yarn / Hadoop may not actually be available, but that is the default
- # value and nothing else would reasonably work here either without Spark.
- zeppelin.configure_spark('yarn-client')
- data_changed('spark.master', 'yarn-client') # ensure updated if re-added
+
+ # Zepp includes the spark-client role, so reconfigure our built-in spark
+ # if our related spark has gone away.
+ if is_state('zeppelin.hadoop.configured'):
+ local_master = 'yarn-client'
+ else:
+ local_master = 'local[*]'
+ zeppelin.configure_spark(local_master)
+ data_changed('spark.master', local_master) # ensure updated if re-added
remove_state('zeppelin.spark.configured')
update_status()
diff --git a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/tests/01-basic-deployment.py b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/tests/01-basic-deployment.py
index f3314972..f8dcd009 100755
--- a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/tests/01-basic-deployment.py
+++ b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/tests/01-basic-deployment.py
@@ -27,7 +27,7 @@ class TestDeploy(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.d = amulet.Deployment(series='xenial')
- cls.d.add('zeppelin', 'cs:xenial/zeppelin')
+ cls.d.add('zeppelin')
cls.d.setup(timeout=1800)
cls.d.sentry.wait_for_messages({'zeppelin': re.compile('ready')}, timeout=1800)
cls.zeppelin = cls.d.sentry['zeppelin'][0]
diff --git a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/tests/02-zeppelin-smoke.py b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/tests/02-zeppelin-smoke.py
index 8623cd12..0887cbef 100755
--- a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/tests/02-zeppelin-smoke.py
+++ b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/tests/02-zeppelin-smoke.py
@@ -27,13 +27,10 @@ class TestDeploy(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.d = amulet.Deployment(series='xenial')
- cls.d.add('zeppelin', 'cs:xenial/zeppelin')
- cls.d.add('spark', 'cs:xenial/spark')
-
- cls.d.relate('zeppelin:spark', 'spark:client')
+ cls.d.add('zeppelin')
cls.d.setup(timeout=1800)
- cls.d.sentry.wait_for_messages({'zeppelin': re.compile('ready with')}, timeout=1800)
+ cls.d.sentry.wait_for_messages({'zeppelin': re.compile('ready')}, timeout=1800)
cls.zeppelin = cls.d.sentry['zeppelin'][0]
def test_zeppelin(self):
diff --git a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/tests/03-zeppelin-spark-smoke.py b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/tests/03-zeppelin-spark-smoke.py
new file mode 100755
index 00000000..daddc51b
--- /dev/null
+++ b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/tests/03-zeppelin-spark-smoke.py
@@ -0,0 +1,51 @@
+#!/usr/bin/env python3
+
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+import amulet
+import re
+import unittest
+
+
+class TestDeploy(unittest.TestCase):
+ """
+ Smoke test for Apache Bigtop Zeppelin using remote Spark resources.
+ """
+ @classmethod
+ def setUpClass(cls):
+ cls.d = amulet.Deployment(series='xenial')
+ cls.d.add('zeppelin')
+ cls.d.add('spark')
+
+ cls.d.relate('zeppelin:spark', 'spark:client')
+
+ cls.d.setup(timeout=1800)
+ cls.d.sentry.wait_for_messages({'zeppelin': re.compile('ready with')}, timeout=1800)
+ cls.zeppelin = cls.d.sentry['zeppelin'][0]
+
+ def test_zeppelin(self):
+ """
+ Validate Zeppelin by running the smoke-test action.
+ """
+ uuid = self.zeppelin.run_action('smoke-test')
+ result = self.d.action_fetch(uuid, full_output=True)
+ # action status=completed on success
+ if (result['status'] != "completed"):
+ self.fail('Zeppelin smoke-test failed: %s' % result)
+
+
+if __name__ == '__main__':
+ unittest.main()
diff --git a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/wheelhouse.txt b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/wheelhouse.txt
index d555101f..7369cb8e 100644
--- a/bigtop-packages/src/charm/zeppelin/layer-zeppelin/wheelhouse.txt
+++ b/bigtop-packages/src/charm/zeppelin/layer-zeppelin/wheelhouse.txt
@@ -1 +1 @@
-requests>=2.0.0,<3.0.0
+requests==2.14.2
diff --git a/bigtop-packages/src/charm/zookeeper/layer-zookeeper/README.md b/bigtop-packages/src/charm/zookeeper/layer-zookeeper/README.md
index 9c92d736..a3d12f18 100644
--- a/bigtop-packages/src/charm/zookeeper/layer-zookeeper/README.md
+++ b/bigtop-packages/src/charm/zookeeper/layer-zookeeper/README.md
@@ -20,18 +20,19 @@ Apache ZooKeeper is a high-performance coordination service for distributed
applications. It exposes common services such as naming, configuration
management, synchronization, and group services in a simple interface. Use it
off-the-shelf to implement consensus, group management, leader election, and
-presence protocols.
+presence protocols. Learn more at [zookeeper.apache.org][].
-This charm provides the Zookeeper component of the [Apache Bigtop][] platform.
+This charm provides version 3.4.6 of the Zookeeper component from
+[Apache Bigtop][].
+[zookeeper.apache.org]: http://zookeeper.apache.org/
[Apache Bigtop]: http://bigtop.apache.org/
# Deploying
-A working Juju installation is assumed to be present. If Juju is not yet set
-up, please follow the [getting-started][] instructions prior to deploying this
-charm.
+This charm requires Juju 2.0 or greater. If Juju is not yet set up, please
+follow the [getting-started][] instructions prior to deploying this charm.
Deploy a Zookeeper unit. With only one unit, the application will be running in
`standalone` mode:
@@ -55,9 +56,6 @@ network interface name or a CIDR range specifying a subnet. For example:
juju config zookeeper network_interface=eth0
juju config zookeeper network_interface=10.0.2.0/24
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju set-config zookeeper network_interface=eth0`.
-
Each zookeeper unit in the cluster will lookup the IP address of that
network interface, or find the first network interface with an IP
address in the specified subnet, and bind Zookeeper to that address.
@@ -69,18 +67,11 @@ run "juju resolved" on any failed units:
juju config zookeeper network_interface=eth0
juju resolved zookeeper/0
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju set-config zookeeper network_interface=eth0;
-juju resolved -r zookeeper/0`.
-
To go back to listening on all interfaces, configure zookeeper with
`network_interface=0.0.0.0`:
juju config zookeeper network_interface=0.0.0.0
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju set-config zookeeper network_interface=0.0.0.0`.
-
# Verifying
@@ -105,25 +96,16 @@ application is functioning as expected. Run the action as follows:
juju run-action zookeeper/0 smoke-test
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action do zookeeper/0 smoke-test`.
-
Watch the progress of the smoke test actions with:
watch -n 2 juju show-action-status
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action status`.
-
Eventually, the action should settle to `status: completed`. If it
reports `status: failed`, the application is not working as expected. Get
more information about a specific smoke test with:
juju show-action-output <action-id>
-> **Note**: The above assumes Juju 2.0 or greater. If using an earlier version
-of Juju, the syntax is `juju action fetch <action-id>`.
-
## Utilities
This charm includes Zookeeper command line utilities that can also be used to
verify that the application is running as expected. Check the status of the
@@ -176,6 +158,18 @@ that require Zookeeper as follows:
ZK_port = relation_get('port')
+# Issues
+
+Apache Bigtop tracks issues using JIRA (Apache account required). File an
+issue for this charm at:
+
+https://issues.apache.org/jira/secure/CreateIssue!default.jspa
+
+Ensure `Bigtop` is selected as the project. Typically, charm issues are filed
+in the `deployment` component with the latest stable release selected as the
+affected version. Any uncertain fields may be left blank.
+
+
# Contact Information
- <bigdata@lists.ubuntu.com>
@@ -183,10 +177,10 @@ that require Zookeeper as follows:
# Resources
+- [Apache Zookeeper home page](http://zookeeper.apache.org/)
- [Apache Bigtop home page](http://bigtop.apache.org/)
+- [Apache Bigtop issue tracking](http://bigtop.apache.org/issue-tracking.html)
- [Apache Bigtop mailing lists](http://bigtop.apache.org/mail-lists.html)
-- [Apache Zookeeper home page](https://zookeeper.apache.org/)
-- [Apache Zookeeper issue tracker](https://issues.apache.org/jira/browse/ZOOKEEPER)
-- [Juju Bigtop charms](https://jujucharms.com/q/apache/bigtop)
+- [Juju Big Data](https://jujucharms.com/big-data)
+- [Juju Bigtop charms](https://jujucharms.com/q/bigtop)
- [Juju mailing list](https://lists.ubuntu.com/mailman/listinfo/juju)
-- [Juju community](https://jujucharms.com/community)
diff --git a/bigtop-packages/src/charm/zookeeper/layer-zookeeper/actions/restart b/bigtop-packages/src/charm/zookeeper/layer-zookeeper/actions/restart
index 7bb51364..acbd448b 100755
--- a/bigtop-packages/src/charm/zookeeper/layer-zookeeper/actions/restart
+++ b/bigtop-packages/src/charm/zookeeper/layer-zookeeper/actions/restart
@@ -22,18 +22,15 @@ from charmhelpers.core import hookenv # noqa: E402
from charms.layer.bigtop_zookeeper import Zookeeper # noqa: E402
from charms.reactive import is_state # noqa: E402
-LOG = hookenv.log
-
-LOG("starting restart handler.")
-
def main():
if not is_state('zookeeper.started'):
+ hookenv.action_set({'outcome': 'failure'})
hookenv.action_fail('Cannot restart: Zookeeper has not yet started!')
- return
+ sys.exit()
- LOG("starting restart handler main.")
- hookenv.status_set('maintenance', 'restarting ...')
+ hookenv.log("starting restart handler main.")
+ hookenv.status_set('maintenance', 'restarting zookeeper')
zookeeper = Zookeeper()
zookeeper.install()
hookenv.status_set('active', 'ready {}'.format(zookeeper.quorum_check()))
diff --git a/bigtop-packages/src/charm/zookeeper/layer-zookeeper/actions/smoke-test b/bigtop-packages/src/charm/zookeeper/layer-zookeeper/actions/smoke-test
index 64814629..0f72ca0a 100755
--- a/bigtop-packages/src/charm/zookeeper/layer-zookeeper/actions/smoke-test
+++ b/bigtop-packages/src/charm/zookeeper/layer-zookeeper/actions/smoke-test
@@ -23,12 +23,12 @@ from charms.layer.apache_bigtop_base import Bigtop # noqa: E402
from charms.reactive import is_state # noqa: E402
-def fail(msg, output=None):
- if output:
- hookenv.action_set({'output': output})
+def fail(msg):
+ hookenv.action_set({'outcome': 'failure'})
hookenv.action_fail(msg)
sys.exit()
+
if not is_state('zookeeper.started'):
fail('Charm is not yet ready to run the Bigtop smoke test(s)')
@@ -38,6 +38,6 @@ smoke_components = ['zookeeper']
bigtop = Bigtop()
result = bigtop.run_smoke_tests(smoke_components)
if result == 'success':
- hookenv.action_set({'outcome': result})
+ hookenv.action_set({'outcome': 'success'})
else:
- fail('{} smoke tests failed'.format(smoke_components), result)
+ fail('{} smoke tests failed with: {}'.format(smoke_components, result))
diff --git a/bigtop-packages/src/charm/zookeeper/layer-zookeeper/icon.svg b/bigtop-packages/src/charm/zookeeper/layer-zookeeper/icon.svg
index 4fd8c0ca..0185a7e1 100644
--- a/bigtop-packages/src/charm/zookeeper/layer-zookeeper/icon.svg
+++ b/bigtop-packages/src/charm/zookeeper/layer-zookeeper/icon.svg
@@ -1,639 +1,38 @@
-<?xml version="1.0" encoding="UTF-8" standalone="no"?>
-<!-- Created with Inkscape (http://www.inkscape.org/) -->
-
-<svg
- xmlns:dc="http://purl.org/dc/elements/1.1/"
- xmlns:cc="http://creativecommons.org/ns#"
- xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
- xmlns:svg="http://www.w3.org/2000/svg"
- xmlns="http://www.w3.org/2000/svg"
- xmlns:xlink="http://www.w3.org/1999/xlink"
- xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
- xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
- width="96"
- height="96"
- id="svg6517"
- version="1.1"
- inkscape:version="0.91+devel r"
- sodipodi:docname="hw_zoo-keeper.svg">
- <defs
- id="defs6519">
- <linearGradient
- id="linearGradient4265"
- inkscape:collect="always">
- <stop
- id="stop4267"
- offset="0"
- style="stop-color:#ab784f;stop-opacity:1" />
- <stop
- id="stop4269"
- offset="1"
- style="stop-color:#ab784f;stop-opacity:0" />
- </linearGradient>
- <linearGradient
- id="linearGradient4259"
- inkscape:collect="always">
- <stop
- id="stop4261"
- offset="0"
- style="stop-color:#ffffff;stop-opacity:1" />
- <stop
- id="stop4263"
- offset="1"
- style="stop-color:#ffffff;stop-opacity:0" />
- </linearGradient>
- <inkscape:path-effect
- effect="envelope"
- id="path-effect4253"
- is_visible="true"
- yy="true"
- xx="true"
- bendpath1="m -215.76126,697.1481 139.143385,0"
- bendpath2="m -76.617875,697.1481 0,90.93889"
- bendpath3="m -215.76126,788.08699 139.143385,0"
- bendpath4="m -215.76126,697.1481 0,90.93889" />
- <inkscape:path-effect
- effect="bend_path"
- id="path-effect4251"
- is_visible="true"
- bendpath="m -215.76126,742.61754 139.143385,0"
- prop_scale="1.12"
- scale_y_rel="false"
- vertical="false" />
- <linearGradient
- id="Background">
- <stop
- id="stop4178"
- offset="0"
- style="stop-color:#22779e;stop-opacity:1" />
- <stop
- id="stop4180"
- offset="1"
- style="stop-color:#2991c0;stop-opacity:1" />
- </linearGradient>
- <filter
- style="color-interpolation-filters:sRGB;"
- inkscape:label="Inner Shadow"
- id="filter1121">
- <feFlood
- flood-opacity="0.59999999999999998"
- flood-color="rgb(0,0,0)"
- result="flood"
- id="feFlood1123" />
- <feComposite
- in="flood"
- in2="SourceGraphic"
- operator="out"
- result="composite1"
- id="feComposite1125" />
- <feGaussianBlur
- in="composite1"
- stdDeviation="1"
- result="blur"
- id="feGaussianBlur1127" />
- <feOffset
- dx="0"
- dy="2"
- result="offset"
- id="feOffset1129" />
- <feComposite
- in="offset"
- in2="SourceGraphic"
- operator="atop"
- result="composite2"
- id="feComposite1131" />
- </filter>
- <filter
- style="color-interpolation-filters:sRGB;"
- inkscape:label="Drop Shadow"
- id="filter950">
- <feFlood
- flood-opacity="0.25"
- flood-color="rgb(0,0,0)"
- result="flood"
- id="feFlood952" />
- <feComposite
- in="flood"
- in2="SourceGraphic"
- operator="in"
- result="composite1"
- id="feComposite954" />
- <feGaussianBlur
- in="composite1"
- stdDeviation="1"
- result="blur"
- id="feGaussianBlur956" />
- <feOffset
- dx="0"
- dy="1"
- result="offset"
- id="feOffset958" />
- <feComposite
- in="SourceGraphic"
- in2="offset"
- operator="over"
- result="composite2"
- id="feComposite960" />
- </filter>
- <clipPath
- clipPathUnits="userSpaceOnUse"
- id="clipPath873">
- <g
- transform="matrix(0,-0.66666667,0.66604479,0,-258.25992,677.00001)"
- id="g875"
- inkscape:label="Layer 1"
- style="fill:#ff00ff;fill-opacity:1;stroke:none;display:inline">
- <path
- style="fill:#ff00ff;fill-opacity:1;stroke:none;display:inline"
- d="m 46.702703,898.22775 50.594594,0 C 138.16216,898.22775 144,904.06497 144,944.92583 l 0,50.73846 c 0,40.86071 -5.83784,46.69791 -46.702703,46.69791 l -50.594594,0 C 5.8378378,1042.3622 0,1036.525 0,995.66429 L 0,944.92583 C 0,904.06497 5.8378378,898.22775 46.702703,898.22775 Z"
- id="path877"
- inkscape:connector-curvature="0"
- sodipodi:nodetypes="sssssssss" />
- </g>
- </clipPath>
- <filter
- inkscape:collect="always"
- id="filter891"
- inkscape:label="Badge Shadow">
- <feGaussianBlur
- inkscape:collect="always"
- stdDeviation="0.71999962"
- id="feGaussianBlur893" />
- </filter>
- <style
- id="style867"
- type="text/css"><![CDATA[
- .fil0 {fill:#1F1A17}
- ]]></style>
- <linearGradient
- inkscape:collect="always"
- xlink:href="#linearGradient4439"
- id="linearGradient908"
- x1="-220"
- y1="731.29077"
- x2="-220"
- y2="635.29077"
- gradientUnits="userSpaceOnUse" />
- <clipPath
- id="clipPath16">
- <path
- id="path18"
- d="m -9,-9 614,0 0,231 -614,0 0,-231 z" />
- </clipPath>
- <clipPath
- id="clipPath116">
- <path
- id="path118"
- d="m 91.7368,146.3253 -9.7039,-1.577 -8.8548,-3.8814 -7.5206,-4.7308 -7.1566,-8.7335 -4.0431,-4.282 -3.9093,-1.4409 -1.034,2.5271 1.8079,2.6096 0.4062,3.6802 1.211,-0.0488 1.3232,-1.2069 -0.3569,3.7488 -1.4667,0.9839 0.0445,1.4286 -3.4744,-1.9655 -3.1462,-3.712 -0.6559,-3.3176 1.3453,-2.6567 1.2549,-4.5133 2.5521,-1.2084 2.6847,0.1318 2.5455,1.4791 -1.698,-8.6122 1.698,-9.5825 -1.8692,-4.4246 -6.1223,-6.5965 1.0885,-3.941 2.9002,-4.5669 5.4688,-3.8486 2.9007,-0.3969 3.225,-0.1094 -2.012,-8.2601 7.3993,-3.0326 9.2188,-1.2129 3.1535,2.0619 0.2427,5.5797 3.5178,5.8224 0.2426,4.6094 8.4909,-0.6066 7.8843,0.7279 -7.8843,-4.7307 1.3343,-5.701 4.9731,-7.763 4.8521,-2.0622 3.8814,1.5769 1.577,3.1538 8.1269,6.1861 1.5769,-1.3343 12.7363,-0.485 2.5473,2.0619 0.2426,3.6391 -0.849,1.5767 -0.6066,9.8251 -4.2454,8.4909 0.7276,3.7605 2.5475,-1.3343 7.1566,-6.6716 3.5175,-0.2424 3.8815,1.5769 3.8818,2.9109 1.9406,6.3077 11.4021,-0.7277 6.914,2.6686 5.5797,5.2157 4.0028,7.5206 0.9706,8.8546 -0.8493,10.3105 -2.1832,9.2185 -2.1836,2.9112 -3.0322,0.9706 -5.3373,-5.8224 -4.8518,-1.6982 -4.2455,7.0353 -4.2454,3.8815 -2.3049,1.4556 -9.2185,7.6419 -7.3993,4.0028 -7.3993,0.6066 -8.6119,-1.4556 -7.5206,-2.7899 -5.2158,-4.2454 -4.1241,-4.9734 -4.2454,-1.2129" />
- </clipPath>
- <clipPath
- id="clipPath128">
- <path
- id="path130"
- d="m 91.7368,146.3253 -9.7039,-1.577 -8.8548,-3.8814 -7.5206,-4.7308 -7.1566,-8.7335 -4.0431,-4.282 -3.9093,-1.4409 -1.034,2.5271 1.8079,2.6096 0.4062,3.6802 1.211,-0.0488 1.3232,-1.2069 -0.3569,3.7488 -1.4667,0.9839 0.0445,1.4286 -3.4744,-1.9655 -3.1462,-3.712 -0.6559,-3.3176 1.3453,-2.6567 1.2549,-4.5133 2.5521,-1.2084 2.6847,0.1318 2.5455,1.4791 -1.698,-8.6122 1.698,-9.5825 -1.8692,-4.4246 -6.1223,-6.5965 1.0885,-3.941 2.9002,-4.5669 5.4688,-3.8486 2.9007,-0.3969 3.225,-0.1094 -2.012,-8.2601 7.3993,-3.0326 9.2188,-1.2129 3.1535,2.0619 0.2427,5.5797 3.5178,5.8224 0.2426,4.6094 8.4909,-0.6066 7.8843,0.7279 -7.8843,-4.7307 1.3343,-5.701 4.9731,-7.763 4.8521,-2.0622 3.8814,1.5769 1.577,3.1538 8.1269,6.1861 1.5769,-1.3343 12.7363,-0.485 2.5473,2.0619 0.2426,3.6391 -0.849,1.5767 -0.6066,9.8251 -4.2454,8.4909 0.7276,3.7605 2.5475,-1.3343 7.1566,-6.6716 3.5175,-0.2424 3.8815,1.5769 3.8818,2.9109 1.9406,6.3077 11.4021,-0.7277 6.914,2.6686 5.5797,5.2157 4.0028,7.5206 0.9706,8.8546 -0.8493,10.3105 -2.1832,9.2185 -2.1836,2.9112 -3.0322,0.9706 -5.3373,-5.8224 -4.8518,-1.6982 -4.2455,7.0353 -4.2454,3.8815 -2.3049,1.4556 -9.2185,7.6419 -7.3993,4.0028 -7.3993,0.6066 -8.6119,-1.4556 -7.5206,-2.7899 -5.2158,-4.2454 -4.1241,-4.9734 -4.2454,-1.2129" />
- </clipPath>
- <linearGradient
- id="linearGradient3850"
- inkscape:collect="always">
- <stop
- id="stop3852"
- offset="0"
- style="stop-color:#000000;stop-opacity:1;" />
- <stop
- id="stop3854"
- offset="1"
- style="stop-color:#000000;stop-opacity:0;" />
- </linearGradient>
- <clipPath
- clipPathUnits="userSpaceOnUse"
- id="clipPath3095">
- <path
- d="m 976.648,389.551 -842.402,0 0,839.999 842.402,0 0,-839.999"
- id="path3097"
- inkscape:connector-curvature="0" />
- </clipPath>
- <linearGradient
- id="linearGradient4439"
- inkscape:collect="always">
- <stop
- id="stop4441"
- offset="0"
- style="stop-color:#ddc1ab;stop-opacity:1" />
- <stop
- id="stop4443"
- offset="1"
- style="stop-color:#edddd1;stop-opacity:1" />
- </linearGradient>
- <clipPath
- clipPathUnits="userSpaceOnUse"
- id="clipPath3195">
- <path
- d="m 611.836,756.738 -106.34,105.207 c -8.473,8.289 -13.617,20.102 -13.598,33.379 L 598.301,790.207 c -0.031,-13.418 5.094,-25.031 13.535,-33.469"
- id="path3197"
- inkscape:connector-curvature="0" />
- </clipPath>
- <clipPath
- clipPathUnits="userSpaceOnUse"
- id="clipPath3235">
- <path
- d="m 1095.64,1501.81 c 35.46,-35.07 70.89,-70.11 106.35,-105.17 4.4,-4.38 7.11,-10.53 7.11,-17.55 l -106.37,105.21 c 0,7 -2.71,13.11 -7.09,17.51"
- id="path3237"
- inkscape:connector-curvature="0" />
- </clipPath>
- <clipPath
- id="clipPath4591"
- clipPathUnits="userSpaceOnUse">
- <path
- inkscape:connector-curvature="0"
- d="m 1106.6009,730.43734 -0.036,21.648 c -0.01,3.50825 -2.8675,6.61375 -6.4037,6.92525 l -83.6503,7.33162 c -3.5205,0.30763 -6.3812,-2.29987 -6.3671,-5.8145 l 0.036,-21.6475 20.1171,-1.76662 -0.011,4.63775 c 0,1.83937 1.4844,3.19925 3.3262,3.0395 l 49.5274,-4.33975 c 1.8425,-0.166 3.3425,-1.78125 3.3538,-3.626 l 0.01,-4.63025 20.1,-1.7575"
- style="fill:#ff00ff;fill-opacity:1;fill-rule:nonzero;stroke:none"
- id="path4593" />
- </clipPath>
- <radialGradient
- gradientUnits="userSpaceOnUse"
- gradientTransform="matrix(-1.4333926,-2.2742838,1.1731823,-0.73941125,-174.08025,98.374394)"
- r="20.40658"
- fy="93.399292"
- fx="-26.508606"
- cy="93.399292"
- cx="-26.508606"
- id="radialGradient3856"
- xlink:href="#linearGradient3850"
- inkscape:collect="always" />
- <linearGradient
- gradientTransform="translate(-318.48033,212.32022)"
- gradientUnits="userSpaceOnUse"
- y2="993.19702"
- x2="-51.879555"
- y1="593.11615"
- x1="348.20132"
- id="linearGradient3895"
- xlink:href="#linearGradient3850"
- inkscape:collect="always" />
- <clipPath
- id="clipPath3906"
- clipPathUnits="userSpaceOnUse">
- <rect
- transform="scale(1,-1)"
- style="opacity:0.8;color:#000000;fill:#ff00ff;stroke:none;stroke-width:4;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- id="rect3908"
- width="1019.1371"
- height="1019.1371"
- x="357.9816"
- y="-1725.8152" />
- </clipPath>
- <filter
- style="color-interpolation-filters:sRGB"
- inkscape:label="Inner Shadow"
- id="filter1121-7">
- <feFlood
- flood-opacity="0.59999999999999998"
- flood-color="rgb(0,0,0)"
- result="flood"
- id="feFlood1123-8" />
- <feComposite
- in="flood"
- in2="SourceGraphic"
- operator="out"
- result="composite1"
- id="feComposite1125-4" />
- <feGaussianBlur
- in="composite1"
- stdDeviation="1"
- result="blur"
- id="feGaussianBlur1127-8" />
- <feOffset
- dx="0"
- dy="2"
- result="offset"
- id="feOffset1129-7" />
- <feComposite
- in="offset"
- in2="SourceGraphic"
- operator="atop"
- result="composite2"
- id="feComposite1131-8" />
- </filter>
- <linearGradient
- inkscape:collect="always"
- xlink:href="#linearGradient4259"
- id="linearGradient4293"
- x1="61.724815"
- y1="60.486755"
- x2="105.60001"
- y2="48.000011"
- gradientUnits="userSpaceOnUse" />
- <linearGradient
- inkscape:collect="always"
- xlink:href="#linearGradient4265"
- id="linearGradient4301"
- x1="57.529388"
- y1="52.851879"
- x2="-5.595726"
- y2="70.892845"
- gradientUnits="userSpaceOnUse" />
- <linearGradient
- inkscape:collect="always"
- xlink:href="#linearGradient4265"
- id="linearGradient4307"
- gradientUnits="userSpaceOnUse"
- x1="57.529388"
- y1="52.851879"
- x2="-5.595726"
- y2="70.892845"
- gradientTransform="matrix(-0.12987249,0.9915307,-0.9915307,-0.12987249,112.98532,15.539208)" />
- <linearGradient
- inkscape:collect="always"
- xlink:href="#linearGradient4259"
- id="linearGradient4309"
- gradientUnits="userSpaceOnUse"
- x1="61.724815"
- y1="60.486755"
- x2="105.60001"
- y2="48.000011"
- gradientTransform="matrix(-0.12987249,0.9915307,-0.9915307,-0.12987249,112.98532,15.539208)" />
- <clipPath
- clipPathUnits="userSpaceOnUse"
- id="clipPath4336">
- <path
- style="display:inline;opacity:0.06300001;fill:#df382c;fill-opacity:1;stroke:none"
- d="m -1.8530274e-8,64.86487 0,-33.72973 C -1.8530274e-8,3.8919 3.8878496,1.038147e-5 31.10302,1.038147e-5 l 33.79408,0 C 92.11217,1.038147e-5 96,3.8919 96,31.13514 l 0,33.72973 c 0,27.24325 -3.88783,31.13514 -31.1029,31.13514 l -33.79408,0 C 3.8878496,96.00001 -1.8530274e-8,92.10812 -1.8530274e-8,64.86487 Z"
- id="path4338"
- inkscape:connector-curvature="0"
- sodipodi:nodetypes="sssssssss" />
- </clipPath>
- <clipPath
- clipPathUnits="userSpaceOnUse"
- id="clipPath4455">
- <path
- sodipodi:nodetypes="sssssssss"
- inkscape:connector-curvature="0"
- id="path4457"
- d="m -268,700.15563 0,-33.72973 c 0,-27.24324 3.88785,-31.13513 31.10302,-31.13513 l 33.79408,0 c 27.21507,0 31.1029,3.89189 31.1029,31.13513 l 0,33.72973 c 0,27.24325 -3.88783,31.13514 -31.1029,31.13514 l -33.79408,0 c -27.21517,0 -31.10302,-3.89189 -31.10302,-31.13514 z"
- style="display:inline;fill:#df382c;fill-opacity:1;stroke:none" />
- </clipPath>
- </defs>
- <sodipodi:namedview
- id="base"
- pagecolor="#ffffff"
- bordercolor="#666666"
- borderopacity="1.0"
- inkscape:pageopacity="0.0"
- inkscape:pageshadow="2"
- inkscape:zoom="6.3664627"
- inkscape:cx="27.87084"
- inkscape:cy="45.622606"
- inkscape:document-units="px"
- inkscape:current-layer="layer3"
- showgrid="false"
- fit-margin-top="0"
- fit-margin-left="0"
- fit-margin-right="0"
- fit-margin-bottom="0"
- inkscape:window-width="1920"
- inkscape:window-height="1029"
- inkscape:window-x="0"
- inkscape:window-y="24"
- inkscape:window-maximized="1"
- showborder="true"
- showguides="false"
- inkscape:guide-bbox="true"
- inkscape:showpageshadow="false"
- inkscape:snap-global="false"
- inkscape:snap-bbox="true"
- inkscape:bbox-paths="true"
- inkscape:bbox-nodes="true"
- inkscape:snap-bbox-edge-midpoints="true"
- inkscape:snap-bbox-midpoints="true"
- inkscape:object-paths="true"
- inkscape:snap-intersection-paths="true"
- inkscape:object-nodes="true"
- inkscape:snap-smooth-nodes="true"
- inkscape:snap-midpoints="true"
- inkscape:snap-object-midpoints="true"
- inkscape:snap-center="true">
- <inkscape:grid
- type="xygrid"
- id="grid821" />
- <sodipodi:guide
- orientation="1,0"
- position="16,48"
- id="guide823" />
- <sodipodi:guide
- orientation="0,1"
- position="64,80"
- id="guide825" />
- <sodipodi:guide
- orientation="1,0"
- position="80,40"
- id="guide827" />
- <sodipodi:guide
- orientation="0,1"
- position="64,16"
- id="guide829" />
- </sodipodi:namedview>
- <metadata
- id="metadata6522">
- <rdf:RDF>
- <cc:Work
- rdf:about="">
- <dc:format>image/svg+xml</dc:format>
- <dc:type
- rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
- <dc:title></dc:title>
- </cc:Work>
- </rdf:RDF>
- </metadata>
- <g
- inkscape:label="BACKGROUND"
- inkscape:groupmode="layer"
- id="layer1"
- transform="translate(268,-635.29076)"
- style="display:inline"
- sodipodi:insensitive="true">
- <g
- id="g4464"
- style="filter:url(#filter1121)">
- <path
- sodipodi:nodetypes="sssssssss"
- inkscape:connector-curvature="0"
- id="path6455"
- d="m -268,700.15563 0,-33.72973 c 0,-27.24324 3.88785,-31.13513 31.10302,-31.13513 l 33.79408,0 c 27.21507,0 31.1029,3.89189 31.1029,31.13513 l 0,33.72973 c 0,27.24325 -3.88783,31.13514 -31.1029,31.13514 l -33.79408,0 c -27.21517,0 -31.10302,-3.89189 -31.10302,-31.13514 z"
- style="display:inline;fill:url(#linearGradient908);fill-opacity:1;stroke:none" />
- </g>
- <path
- sodipodi:nodetypes="sssssssss"
- inkscape:connector-curvature="0"
- id="path4460"
- d="m -268,700.15563 0,-33.72973 c 0,-27.24324 3.88785,-31.13513 31.10302,-31.13513 l 33.79408,0 c 27.21507,0 31.1029,3.89189 31.1029,31.13513 l 0,33.72973 c 0,27.24325 -3.88783,31.13514 -31.1029,31.13514 l -33.79408,0 c -27.21517,0 -31.10302,-3.89189 -31.10302,-31.13514 z"
- style="display:inline;fill:none;fill-opacity:1;stroke:none;filter:url(#filter1121)" />
- </g>
- <g
- inkscape:groupmode="layer"
- id="layer4"
- inkscape:label="FOLDS"
- style="display:inline"
- sodipodi:insensitive="true">
- <g
- inkscape:groupmode="maskhelper"
- id="g4327"
- clip-path="url(#clipPath4336)">
- <g
- id="g4319">
- <g
- id="g4311"
- transform="matrix(-0.76919808,0.63901044,-0.63901044,-0.76919808,108.56506,55.223802)"
- style="opacity:0.10499998">
- <path
- style="color:#000000;display:inline;overflow:visible;visibility:visible;opacity:1;fill:url(#linearGradient4307);fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate"
- d="M 118.8011,58.528402 -28.812125,79.242985 5.8755118,-40.074102 l 96.0121782,20.991633 26.85965,50.05246 z"
- id="path4303"
- inkscape:connector-curvature="0"
- sodipodi:nodetypes="cccccc" />
- <path
- style="color:#000000;display:inline;overflow:visible;visibility:visible;opacity:1;fill:url(#linearGradient4309);fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate"
- d="M 118.8011,58.528402 -28.812125,79.242985 -8.4409816,141.41578 108.00471,151.91561 Z"
- id="path4305"
- inkscape:connector-curvature="0"
- sodipodi:nodetypes="ccccc" />
- </g>
- <g
- id="g4315"
- style="opacity:0.08200001"
- transform="matrix(0.24294261,-0.68963031,1.0086859,1.2528869,10.128532,28.560155)">
- <path
- sodipodi:nodetypes="cccccc"
- inkscape:connector-curvature="0"
- id="path4283"
- d="M 41.869796,-11.349643 81.579838,132.32315 -41.231687,113.4253 -32.887179,15.500039 13.253042,-17.632567 Z"
- style="color:#000000;display:inline;overflow:visible;visibility:visible;opacity:1;fill:url(#linearGradient4301);fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate" />
- <path
- sodipodi:nodetypes="ccccc"
- inkscape:connector-curvature="0"
- id="path4285"
- d="M 41.869796,-11.349643 81.579838,132.32315 140.58042,104.05 135.86823,-12.773118 Z"
- style="color:#000000;display:inline;overflow:visible;visibility:visible;opacity:1;fill:url(#linearGradient4293);fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate" />
- </g>
- </g>
- </g>
- </g>
- <g
- inkscape:groupmode="layer"
- id="layer3"
- inkscape:label="PLACE YOUR PICTOGRAM HERE"
- style="display:inline">
- <path
- style="color:#000000;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:medium;line-height:normal;font-family:sans-serif;text-indent:0;text-align:start;text-decoration:none;text-decoration-line:none;text-decoration-style:solid;text-decoration-color:#000000;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;baseline-shift:baseline;text-anchor:start;white-space:normal;clip-rule:nonzero;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:#000000;solid-opacity:1;fill:#c39a7a;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto;enable-background:accumulate"
- d="M 17.371094 28.669922 C 16.599038 28.669922 15.566054 28.794985 14.679688 29.570312 C 13.766682 30.36894 13.5 31.521747 13.5 32.382812 L 13.5 34.671875 C 13.5 35.527049 13.783856 36.716545 14.75 37.482422 C 15.667283 38.209564 16.626117 38.240234 17.234375 38.240234 L 22.816406 38.240234 L 14.875 46.978516 A 0.50005 0.50005 0 0 0 14.871094 46.982422 L 14.869141 46.984375 L 14.847656 47.007812 L 14.826172 47.029297 L 14.818359 47.039062 A 0.50005 0.50005 0 0 0 14.701172 47.265625 C 13.864555 48.288569 13.5 49.604301 13.5 50.416016 L 13.5 53.255859 C 13.5 54.169576 13.90884 55.262942 14.785156 55.900391 C 15.592631 56.48776 16.397758 56.525391 16.84375 56.525391 L 19.427734 56.525391 C 19.718486 56.524847 19.997357 56.437001 20.269531 56.337891 C 20.541704 56.437001 20.820576 56.524847 21.111328 56.525391 L 33.220703 56.525391 L 33.230469 56.525391 A 0.50005 0.50005 0 0 0 33.402344 56.494141 C 34.12378 56.484341 34.962109 56.329895 35.681641 55.701172 C 36.510768 54.976682 36.785156 53.947547 36.785156 53.171875 L 36.785156 52.060547 L 39.943359 55.21875 C 40.598634 55.880878 41.817199 56.525391 43.085938 56.525391 L 51.427734 56.525391 C 51.65759 56.525312 51.884682 56.488241 52.105469 56.425781 C 52.91232 56.579227 53.75153 56.381051 54.339844 55.792969 L 57.271484 52.861328 A 0.50005 0.50005 0 0 0 57.273438 52.859375 L 58.769531 51.34375 L 60.810547 53.228516 L 62.800781 55.21875 C 63.456055 55.880877 64.674623 56.525391 65.943359 56.525391 L 74.285156 56.525391 C 74.373229 56.525336 74.457796 56.496578 74.544922 56.486328 L 74.544922 56.296875 C 74.544922 55.854004 74.900879 55.498047 75.34375 55.498047 L 77.492188 55.498047 L 81.09375 51.898438 L 81.072266 51.912109 A 0.50005 0.50005 0 0 0 81.126953 51.865234 C 81.887266 51.097737 82.5 49.757009 82.5 48.560547 L 82.5 36.882812 A 0.50005 0.50005 0 0 0 82.5 36.880859 L 82.492188 35.5625 A 0.50005 0.50005 0 0 0 82.490234 35.521484 C 82.439614 34.945574 82.188686 34.394202 81.767578 33.972656 L 77.726562 29.933594 L 77.722656 29.927734 C 77.693286 29.897724 77.663652 29.868344 77.632812 29.839844 A 0.50005 0.50005 0 0 0 77.626953 29.835938 C 76.880074 29.164479 75.644158 28.669922 74.529297 28.669922 L 66.285156 28.669922 A 0.50005 0.50005 0 0 0 66.283203 28.669922 L 65.035156 28.673828 A 0.50005 0.50005 0 0 0 65.011719 28.673828 C 64.405147 28.705828 63.818351 28.959454 63.375 29.402344 A 0.50005 0.50005 0 0 0 63.373047 29.404297 L 58.884766 33.919922 L 58.164062 33.226562 L 54.869141 29.933594 L 54.865234 29.927734 C 54.835864 29.897724 54.806231 29.868344 54.775391 29.839844 A 0.50005 0.50005 0 0 0 54.769531 29.835938 C 54.022652 29.164479 52.786736 28.669922 51.671875 28.669922 L 43.427734 28.669922 A 0.50005 0.50005 0 0 0 43.423828 28.669922 L 42.101562 28.677734 A 0.50005 0.50005 0 0 0 42.060547 28.679688 C 41.486404 28.731437 40.937815 28.982542 40.517578 29.402344 L 36.785156 33.136719 L 36.785156 32.373047 C 36.785156 31.723134 36.686396 30.638195 35.828125 29.746094 C 34.967253 28.851281 33.834956 28.669922 32.972656 28.669922 L 17.371094 28.669922 z M 44.785156 38.240234 L 50.072266 38.240234 L 50.072266 46.955078 L 44.785156 46.955078 L 44.785156 38.240234 z M 67.642578 38.240234 L 72.929688 38.240234 L 72.929688 46.955078 L 67.642578 46.955078 L 67.642578 38.240234 z M 28.535156 39.382812 L 28.810547 39.382812 L 18.5 51.277344 L 18.5 50.421875 C 18.505 50.416575 18.510665 50.4116 18.515625 50.40625 A 0.50005 0.50005 0 0 0 18.517578 50.402344 L 28.535156 39.382812 z M 35.214844 39.626953 L 35.214844 47.595703 C 34.546422 47.177561 33.820937 46.955078 33.205078 46.955078 L 28.863281 46.955078 L 35.214844 39.626953 z "
- id="path4241" />
- <rect
- style="color:#000000;display:inline;overflow:visible;visibility:visible;opacity:1;fill:#c39a7a;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate"
- id="rect4282"
- width="5.4180727"
- height="1.5211427"
- x="31.306763"
- y="47.455326" />
- <path
- inkscape:connector-curvature="0"
- style="color:#000000;display:inline;overflow:visible;visibility:visible;opacity:1;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate"
- d="M 17.371094,31.170159 C 16.41517,31.170159 16,31.519759 16,32.383049 l 0,2.289063 c 0,0.843413 0.397114,1.068359 1.234375,1.068359 l 17.050781,0 0,-3.367187 c 0,-0.783097 -0.249087,-1.203125 -1.3125,-1.203125 l -15.601562,0 z m 24.914062,0 -3.960937,3.960937 c -0.46567,0.428278 -0.609375,0.86035 -0.609375,1.65625 l 0,11.525391 4.570312,0 0,-17.142578 z m 1.142578,0 0,4.570312 13.714844,0 -4.044922,-4.044922 c -0.437271,-0.393115 -0.739999,-0.52539 -1.425781,-0.52539 l -8.244141,0 z m 21.714844,0 -3.960937,3.960937 c -0.46567,0.428278 -0.609375,0.86035 -0.609375,1.65625 l 0,11.525391 4.570312,0 0,-17.142578 z m 1.142578,0 0,4.570312 13.714844,0 -4.044922,-4.044922 c -0.437271,-0.393115 -0.739999,-0.52539 -1.425781,-0.52539 l -8.244141,0 z M 27.427734,36.883049 16.667969,48.72094 C 16.008587,49.402426 16,49.71964 16,50.416252 l 0,2.839844 c 0,0.632516 0.402503,0.769531 0.84375,0.769531 l 2.583984,0 14.857422,-17.142578 -6.857422,0 z m 25.144532,0 0,17.142578 3.919922,-3.919922 c 0.519261,-0.524371 0.65039,-0.777677 0.65039,-1.544921 l 0,-11.677735 -4.570312,0 z m 22.857422,0 0,17.142578 3.919921,-3.919922 C 79.86887,49.581334 80,49.328028 80,48.560784 l 0,-11.677735 -4.570312,0 z m -50.28711,12.572266 -4.03125,4.570312 12.119141,0 c 0.745441,0.03464 1.054687,-0.303646 1.054687,-0.853515 l 0,-2.6875 c 0,-0.653569 -0.291585,-1.029297 -1.080078,-1.029297 l -8.0625,0 z m 12.572266,0 4.003906,4.003906 c 0.359189,0.363486 0.690415,0.566406 1.367188,0.566406 l 8.341796,0 0,-4.570312 -13.71289,0 z m 22.857422,0 4.003906,4.003906 c 0.359189,0.363486 0.690414,0.566406 1.367187,0.566406 l 8.341797,0 0,-4.570312 -13.71289,0 z"
- id="path4268" />
- <path
- style="font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;font-size:medium;line-height:125%;font-family:'Liberation Mono';-inkscape-font-specification:'Liberation Mono Bold';text-align:end;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:end;fill:#c39a7a;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
- d="m 13.5,53.994141 0,12.99414 2.841797,0 0,-3.998047 1.222656,-1.367187 3.111328,5.365234 3.351563,0 -4.613282,-7.417969 4.429688,-5.576171 -3.302734,0 -4.199219,5.769531 0,-5.769531 z m 11.837891,0 0,12.99414 9.71875,0 0,-2.197265 -6.876953,0 0,-3.283204 5.894531,0 0,-2.197265 -5.894531,0 0,-3.121094 6.480468,0 0,-2.195312 z m 11.828125,0 0,12.99414 9.716796,0 0,-2.197265 -6.876953,0 0,-3.283204 5.894532,0 0,-2.197265 -5.894532,0 0,-3.121094 6.482422,0 0,-2.195312 z m 11.816406,0 0,12.99414 2.841797,0 0,-4.585937 1.898437,0 c 0.854016,0 1.591991,-0.111197 2.214844,-0.335938 0.622854,-0.231162 1.136482,-0.543855 1.541016,-0.935547 0.404534,-0.39169 0.703849,-0.847072 0.896484,-1.367187 0.199057,-0.526536 0.298828,-1.081689 0.298828,-1.666016 0,-0.635696 -0.103116,-1.207571 -0.308594,-1.714844 -0.199056,-0.507272 -0.508405,-0.937851 -0.925781,-1.291015 -0.417376,-0.353165 -0.942429,-0.622381 -1.578125,-0.808594 -0.635696,-0.192635 -1.387048,-0.289062 -2.253906,-0.289062 z m 11.83789,0 0,12.99414 9.71875,0 0,-2.197265 -6.876953,0 0,-3.283204 5.894532,0 0,-2.197265 -5.894532,0 0,-3.121094 6.482422,0 0,-2.195312 z m 11.828126,0 0,12.99414 2.841796,0 0,-4.960937 1.666016,0 2.792969,4.960937 3.197265,0 -3.361328,-5.597656 c 0.391692,-0.115581 0.752599,-0.274991 1.080078,-0.480469 0.32748,-0.211898 0.610073,-0.463 0.847657,-0.751953 0.237583,-0.295374 0.423749,-0.636214 0.558593,-1.021484 0.134845,-0.385271 0.201172,-0.813896 0.201172,-1.289063 0,-1.245706 -0.420545,-2.199947 -1.261718,-2.861328 -0.841175,-0.661381 -2.109499,-0.992187 -3.804688,-0.992187 z m -20.824219,2.205078 1.464843,0 c 0.841174,0 1.469343,0.151329 1.886719,0.453125 0.423798,0.295374 0.636719,0.794232 0.636719,1.49414 0,0.680644 -0.196199,1.197618 -0.587891,1.550782 -0.391691,0.346743 -1.01178,0.519531 -1.859375,0.519531 l -1.541015,0 z m 23.666015,0.263525 1.617188,0 c 0.398112,0 0.75233,0.03345 1.060547,0.09766 0.314636,0.05779 0.577163,0.157563 0.789062,0.298828 0.211899,0.134845 0.373262,0.314321 0.482422,0.539063 0.115581,0.22474 0.173828,0.368882 0.173828,0.696362 0,0.60359 -0.192854,0.933898 -0.578125,1.254956 -0.385269,0.314638 -1.002014,0.472657 -1.849609,0.472657 l -1.695313,0 z"
- id="path4243"
- inkscape:connector-curvature="0"
- sodipodi:nodetypes="cccccccccccccccccccccccccccccccccccccccccccscscscscsccccccccccccccccccccccccssssccscscscccscccscscc" />
- <path
- style="color:#000000;display:inline;overflow:visible;visibility:visible;opacity:1;fill:#c39a7a;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate"
- d="m 14,54.026463 21.32109,0 2.573485,0 2.959509,0 33.431633,0 0,2.498928 -60.285717,0 z"
- id="rect4314"
- inkscape:connector-curvature="0"
- sodipodi:nodetypes="cccccccc" />
- <rect
- style="color:#000000;display:inline;overflow:visible;visibility:visible;opacity:1;fill:#c39a7a;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate"
- id="rect4280"
- width="1.4425607"
- height="7.0013866"
- x="13.5"
- y="51.883324" />
- <rect
- style="color:#000000;display:inline;overflow:visible;visibility:visible;opacity:1;fill:#c39a7a;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate"
- id="rect4284"
- width="0.93164003"
- height="3.311523"
- x="35.353516"
- y="52.012886" />
- </g>
- <g
- inkscape:groupmode="layer"
- id="layer2"
- inkscape:label="BADGE"
- style="display:none"
- sodipodi:insensitive="true">
- <g
- style="display:inline"
- transform="translate(-340.00001,-581)"
- id="g4394"
- clip-path="none">
- <g
- id="g855">
- <g
- inkscape:groupmode="maskhelper"
- id="g870"
- clip-path="url(#clipPath873)"
- style="opacity:0.6;filter:url(#filter891)">
- <path
- transform="matrix(1.4999992,0,0,1.4999992,-29.999795,-237.54282)"
- d="m 264,552.36218 a 12,12 0 0 1 -12,12 12,12 0 0 1 -12,-12 12,12 0 0 1 12,-12 12,12 0 0 1 12,12 z"
- sodipodi:ry="12"
- sodipodi:rx="12"
- sodipodi:cy="552.36218"
- sodipodi:cx="252"
- id="path844"
- style="color:#000000;fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- sodipodi:type="arc" />
- </g>
- <g
- id="g862">
- <path
- sodipodi:type="arc"
- style="color:#000000;fill:#f5f5f5;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- id="path4398"
- sodipodi:cx="252"
- sodipodi:cy="552.36218"
- sodipodi:rx="12"
- sodipodi:ry="12"
- d="m 264,552.36218 a 12,12 0 0 1 -12,12 12,12 0 0 1 -12,-12 12,12 0 0 1 12,-12 12,12 0 0 1 12,12 z"
- transform="matrix(1.4999992,0,0,1.4999992,-29.999795,-238.54282)" />
- <path
- transform="matrix(1.25,0,0,1.25,33,-100.45273)"
- d="m 264,552.36218 a 12,12 0 0 1 -12,12 12,12 0 0 1 -12,-12 12,12 0 0 1 12,-12 12,12 0 0 1 12,12 z"
- sodipodi:ry="12"
- sodipodi:rx="12"
- sodipodi:cy="552.36218"
- sodipodi:cx="252"
- id="path4400"
- style="color:#000000;fill:#dd4814;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:4;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- sodipodi:type="arc" />
- <path
- sodipodi:type="star"
- style="color:#000000;fill:#f5f5f5;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
- id="path4459"
- sodipodi:sides="5"
- sodipodi:cx="666.19574"
- sodipodi:cy="589.50385"
- sodipodi:r1="7.2431178"
- sodipodi:r2="4.3458705"
- sodipodi:arg1="1.0471976"
- sodipodi:arg2="1.6755161"
- inkscape:flatsided="false"
- inkscape:rounded="0.1"
- inkscape:randomized="0"
- d="m 669.8173,595.77657 c -0.39132,0.22593 -3.62645,-1.90343 -4.07583,-1.95066 -0.44938,-0.0472 -4.05653,1.36297 -4.39232,1.06062 -0.3358,-0.30235 0.68963,-4.03715 0.59569,-4.47913 -0.0939,-0.44198 -2.5498,-3.43681 -2.36602,-3.8496 0.18379,-0.41279 4.05267,-0.59166 4.44398,-0.81759 0.39132,-0.22593 2.48067,-3.48704 2.93005,-3.4398 0.44938,0.0472 1.81505,3.67147 2.15084,3.97382 0.3358,0.30236 4.08294,1.2817 4.17689,1.72369 0.0939,0.44198 -2.9309,2.86076 -3.11469,3.27355 -0.18379,0.41279 0.0427,4.27917 -0.34859,4.5051 z"
- transform="matrix(1.511423,-0.16366377,0.16366377,1.511423,-755.37346,-191.93651)" />
+<?xml version="1.0" encoding="UTF-8"?>
+<svg width="100px" height="100px" viewBox="0 0 100 100" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
+ <!-- Generator: Sketch 43.2 (39069) - http://www.bohemiancoding.com/sketch -->
+ <title>zookeeper</title>
+ <desc>Created with Sketch.</desc>
+ <defs>
+ <circle id="path-1" cx="50" cy="50" r="50"></circle>
+ <circle id="path-3" cx="50" cy="50" r="50"></circle>
+ </defs>
+ <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
+ <g id="zookeeper">
+ <g id="v1">
+ <mask id="mask-2" fill="white">
+ <use xlink:href="#path-1"></use>
+ </mask>
+ <use id="Oval-Copy" fill="#EDDDD1" transform="translate(50.000000, 50.000000) rotate(-180.000000) translate(-50.000000, -50.000000) " xlink:href="#path-1"></use>
+ <g id="lockup" mask="url(#mask-2)" fill-rule="nonzero">
+ <g transform="translate(15.000000, 31.000000)">
+ <path d="M4.3095293,0.660486479 C3.54834732,0.660486479 2.52991239,0.783788028 1.65603042,1.54819493 C0.755883662,2.33557465 0.492957746,3.47214493 0.492957746,4.32108225 L0.492957746,6.57790493 C0.492957746,7.42103423 0.772815775,8.59377676 1.72535211,9.34886676 C2.62971563,10.0657673 3.57504493,10.0960054 4.17473592,10.0960054 L9.67814676,10.0960054 L1.84859155,18.711213 C1.84730081,18.7124895 1.84601713,18.7137732 1.84474056,18.7150639 L1.84281507,18.7169894 L1.82163268,18.7400963 L1.80045127,18.7612787 L1.79274831,18.7709062 C1.73557404,18.8341239 1.69576679,18.9110851 1.67721183,18.9942782 C0.852378169,20.0028145 0.492957746,21.3000151 0.492957746,22.1002975 L0.492957746,24.9001427 C0.492957746,25.8009904 0.896039437,26.8789569 1.76001296,27.5074277 C2.55611507,28.0865239 3.34990225,28.1236249 3.78961268,28.1236249 L6.33720254,28.1236249 C6.62385944,28.1230886 6.89880268,28.0364799 7.16714324,27.9387658 C7.43548282,28.0364799 7.71042704,28.1230886 7.99708394,28.1236249 L19.9359044,28.1236249 L19.9455328,28.1236249 C20.0033878,28.1233775 20.0607477,28.1129484 20.114987,28.0928151 C20.826262,28.0831531 21.6527835,27.9308824 22.3621813,27.3110146 C23.1796304,26.5967287 23.4501538,25.5820886 23.4501538,24.8173415 L23.4501538,23.7216661 L26.5638751,26.8353873 C27.2099208,27.4881896 28.411323,28.1236249 29.6621924,28.1236249 L37.8864983,28.1236249 C38.1131169,28.123547 38.3370104,28.0869982 38.5546877,28.0254179 C39.3501746,28.1767027 40.1775648,27.9813179 40.7575927,27.4015187 L43.647942,24.5111685 C43.6485859,24.5105284 43.6492281,24.5098866 43.6498685,24.509243 L45.1248897,23.0149648 L47.137159,24.8731848 L49.0993615,26.8353873 C49.7454063,27.4881886 50.9468114,28.1236249 52.1976779,28.1236249 L60.4219848,28.1236249 C60.5088173,28.1235707 60.5921932,28.0952177 60.6780921,28.0851121 L60.6780921,27.8983275 C60.6780921,27.4616941 61.0290356,27.1107506 61.465669,27.1107506 L63.5838473,27.1107506 L67.1346831,23.5618403 L67.1135017,23.5753187 C67.1325615,23.5612299 67.1505805,23.5457849 67.1674185,23.5291039 C67.9170228,22.7724168 68.5211268,21.4505723 68.5211268,20.2709618 L68.5211268,8.75770197 C68.521128,8.75706014 68.521128,8.75641831 68.5211268,8.75577648 L68.5134248,7.45598592 C68.5133366,7.44248579 68.5126939,7.42899498 68.5114983,7.41554761 C68.4615913,6.84774901 68.2141975,6.30414282 67.7990206,5.88853408 L63.8149203,1.90636028 L63.8110693,1.90058282 C63.782113,1.87099549 63.7528963,1.8420293 63.7224907,1.8139307 C63.7205743,1.8126335 63.7186487,1.81134981 63.7167142,1.81007972 C62.9803546,1.14807789 61.7618459,0.660486479 60.6626872,0.660486479 L52.5346608,0.660486479 C52.534019,0.660485226 52.5333772,0.660485226 52.5327354,0.660486479 L51.3022665,0.664337465 C51.2945652,0.664156939 51.2868608,0.664156939 51.2791596,0.664337465 C50.6811308,0.695886761 50.1025996,0.945940563 49.665493,1.38259268 C49.6648494,1.38323273 49.6642075,1.38387457 49.6635675,1.38451817 L45.2385017,5.83654282 L44.5279485,5.15294845 L41.2794348,1.90636028 L41.2755828,1.90058282 C41.2466265,1.87099549 41.2174108,1.8420293 41.1870052,1.8139307 C41.1850885,1.8126335 41.1831626,1.8113498 41.1812277,1.81007972 C40.4448682,1.14807789 39.2263594,0.660486479 38.1272007,0.660486479 L29.9991744,0.660486479 C29.9978907,0.660481465 29.996607,0.660481465 29.9953234,0.660486479 L28.6916808,0.668188451 C28.678181,0.668276689 28.6646906,0.66891939 28.6512435,0.67011493 C28.085187,0.72113507 27.5443246,0.96870338 27.1300065,1.38259268 L23.4501538,5.06437085 L23.4501538,4.31145479 C23.4501538,3.67069549 23.3527848,2.60103732 22.5066021,1.72150113 C21.6578551,0.839291127 20.5415059,0.660486479 19.691351,0.660486479 L4.3095293,0.660486479 Z M31.3374777,10.0960054 L36.5501214,10.0960054 L36.5501214,18.6881051 L31.3374777,18.6881051 L31.3374777,10.0960054 Z M53.8729642,10.0960054 L59.0856079,10.0960054 L59.0856079,18.6881051 L53.8729642,18.6881051 L53.8729642,10.0960054 Z M15.316351,11.2224907 L15.5878632,11.2224907 L5.42253521,22.9494941 L5.42253521,22.1060739 C5.42746479,22.1008486 5.43305,22.0959437 5.43794014,22.090669 C5.43858757,22.0893882 5.43922941,22.0881045 5.43986563,22.086818 L15.316351,11.2224907 Z M21.9019589,11.4631931 L21.9019589,19.3197072 C21.2429513,18.9074545 20.5276844,18.6881051 19.9204994,18.6881051 L15.6398545,18.6881051 L21.9019589,11.4631931 Z" id="path4241" fill="#C39A7A"></path>
+ <rect id="rect4282" fill="#C39A7A" x="18.0489213" y="19.1813073" width="5.34176182" height="1.49971815"></rect>
+ <path d="M4.3095293,3.12550887 C3.36706901,3.12550887 2.95774648,3.47018493 2.95774648,4.32131592 L2.95774648,6.57813859 C2.95774648,7.40967254 3.34926732,7.63145028 4.17473592,7.63145028 L20.9853651,7.63145028 L20.9853651,4.31168845 C20.9853651,3.53962099 20.7397863,3.12550887 19.691351,3.12550887 L4.3095293,3.12550887 L4.3095293,3.12550887 Z M28.872689,3.12550887 L24.9675399,7.03065803 C24.5084286,7.45290394 24.3667476,7.87889042 24.3667476,8.66358056 L24.3667476,20.0266421 L28.872689,20.0266421 L28.872689,3.12550887 L28.872689,3.12550887 Z M29.9991744,3.12550887 L29.9991744,7.63145028 L43.5208515,7.63145028 L39.5329003,3.64349901 C39.101788,3.25592085 38.8033238,3.12550887 38.1272007,3.12550887 L29.9991744,3.12550887 L29.9991744,3.12550887 Z M51.4081755,3.12550887 L47.5030263,7.03065803 C47.0439151,7.45290394 46.9022341,7.87889042 46.9022341,8.66358056 L46.9022341,20.0266421 L51.4081755,20.0266421 L51.4081755,3.12550887 L51.4081755,3.12550887 Z M52.5346608,3.12550887 L52.5346608,7.63145028 L66.056338,7.63145028 L62.0683868,3.64349901 C61.6372745,3.25592085 61.3388103,3.12550887 60.6626872,3.12550887 L52.5346608,3.12550887 L52.5346608,3.12550887 Z M14.2245265,8.75793563 L3.61630746,20.4290958 C2.96621254,21.1009834 2.95774648,21.4137296 2.95774648,22.1005301 L2.95774648,24.9003763 C2.95774648,25.5239837 3.35458042,25.6590689 3.78961268,25.6590689 L6.33720254,25.6590689 L20.9853651,8.75793563 L14.2245265,8.75793563 Z M39.0149101,8.75793563 L39.0149101,25.6590689 L42.879622,21.794357 C43.3915694,21.2773715 43.5208515,21.0276332 43.5208515,20.2711955 L43.5208515,8.75793563 L39.0149101,8.75793563 Z M61.5503966,8.75793563 L61.5503966,25.6590689 L65.4151075,21.794357 C65.9270549,21.2773715 66.056338,21.0276332 66.056338,20.2711955 L66.056338,8.75793563 L61.5503966,8.75793563 Z M11.9715558,21.1531275 L7.99708394,25.6590689 L19.9455328,25.6590689 C20.6804746,25.693221 20.9853651,25.3596996 20.9853651,24.8175752 L20.9853651,22.1679273 C20.9853651,21.5235635 20.6978869,21.1531275 19.9204994,21.1531275 L11.9715558,21.1531275 Z M24.3667476,21.1531275 L28.3142606,25.1006404 C28.6683906,25.4590069 28.9949514,25.6590689 29.6621924,25.6590689 L37.8864983,25.6590689 L37.8864983,21.1531275 L24.3667476,21.1531275 Z M46.9022341,21.1531275 L50.849747,25.1006404 C51.203877,25.4590069 51.5304369,25.6590689 52.1976779,25.6590689 L60.4219848,25.6590689 L60.4219848,21.1531275 L46.9022341,21.1531275 Z" id="path4268" fill="#FFFFFF"></path>
+ <path d="M0.492957746,25.6280263 L0.492957746,38.4391503 L3.29472944,38.4391503 L3.29472944,34.4974138 L4.50016493,33.149483 L7.56767141,38.4391503 L10.8720293,38.4391503 L6.3237231,31.1256597 L10.6910211,25.6280263 L7.43480451,25.6280263 L3.29472944,31.3162963 L3.29472944,25.6280263 L0.492957746,25.6280263 Z M12.1641179,25.6280263 L12.1641179,38.4391503 L21.7459841,38.4391503 L21.7459841,36.2728327 L14.9658896,36.2728327 L14.9658896,33.035871 L20.777399,33.035871 L20.777399,30.8695534 L14.9658896,30.8695534 L14.9658896,27.7924185 L21.3550834,27.7924185 L21.3550834,25.6280263 L12.1641179,25.6280263 Z M23.8256496,25.6280263 L23.8256496,38.4391503 L33.4055893,38.4391503 L33.4055893,36.2728327 L26.6254948,36.2728327 L26.6254948,33.035871 L32.4370052,33.035871 L32.4370052,30.8695534 L26.6254948,30.8695534 L26.6254948,27.7924185 L33.0166151,27.7924185 L33.0166151,25.6280263 L23.8256496,25.6280263 Z M35.4756273,25.6280263 L35.4756273,38.4391503 L38.277399,38.4391503 L38.277399,33.9178039 L40.1490975,33.9178039 C40.9910851,33.9178039 41.7186661,33.8081731 42.3327465,33.5865975 C42.9468279,33.3586913 43.4532217,33.0504024 43.852058,32.6642272 C44.2508944,32.2780539 44.5459937,31.8290858 44.7359155,31.3162963 C44.9321689,30.7971763 45.0305346,30.2498424 45.0305346,29.6737454 C45.0305346,29.0470028 44.928871,28.4831824 44.726287,27.9830541 C44.5300346,27.4829268 44.2250427,27.0584123 43.8135452,26.7102224 C43.4020477,26.3620315 42.8843899,26.0966073 42.2576473,25.913017 C41.6309048,25.7230952 40.8901352,25.6280263 40.0354865,25.6280263 L35.4756273,25.6280263 Z M47.1467865,25.6280263 L47.1467865,38.4391503 L56.7286527,38.4391503 L56.7286527,36.2728327 L49.9485582,36.2728327 L49.9485582,33.035871 L55.7600686,33.035871 L55.7600686,30.8695534 L49.9485582,30.8695534 L49.9485582,27.7924185 L56.3396785,27.7924185 L56.3396785,25.6280263 L47.1467865,25.6280263 Z M58.8083192,25.6280263 L58.8083192,38.4391503 L61.6100899,38.4391503 L61.6100899,33.5480856 L63.2526408,33.5480856 L66.0062723,38.4391503 L69.1585054,38.4391503 L65.84452,32.9203345 C66.2306952,32.8063814 66.586519,32.6492166 66.9093856,32.4466327 C67.2322532,32.2377192 67.5108661,31.9901538 67.7451038,31.7052706 C67.9793406,31.4140568 68.1628845,31.0780173 68.2958293,30.6981737 C68.4287751,30.318329 68.4941679,29.895741 68.4941679,29.4272665 C68.4941679,28.1991056 68.0795461,27.2583046 67.2502206,26.6062389 C66.4208931,25.9541731 65.1704328,25.6280263 63.4991197,25.6280263 L58.8083192,25.6280263 Z M38.277399,27.8020469 L39.7216104,27.8020469 C40.5509369,27.8020469 41.1702585,27.9512445 41.5817559,28.2487899 C41.9995849,28.5400037 42.209507,29.0318355 42.209507,29.7218856 C42.209507,30.3929431 42.0160714,30.9026358 41.6298962,31.2508256 C41.243722,31.5926849 40.6323666,31.7630393 39.7967096,31.7630393 L38.277399,31.7630393 L38.277399,27.8020469 Z M61.6100899,28.0618603 L63.2045006,28.0618603 C63.5970054,28.0618603 63.9462344,28.0948392 64.2501103,28.1581448 C64.5603148,28.2151208 64.8191442,28.3134886 65.0280587,28.4527639 C65.2369732,28.5857097 65.3960635,28.7626579 65.5036861,28.9842345 C65.6176392,29.2058092 65.6750658,29.347921 65.6750658,29.6707886 C65.6750658,30.2658773 65.484928,30.5915331 65.1050834,30.9080692 C64.7252407,31.2182756 64.1171823,31.374069 63.2815252,31.374069 L61.6100899,31.374069 L61.6100899,28.0618603 Z" id="path4243" fill="#C39A7A"></path>
+ <polygon id="rect4314" fill="#C39A7A" points="0.985915493 25.6598931 22.0067085 25.6598931 24.5439472 25.6598931 27.461773 25.6598931 60.4225379 25.6598931 60.4225379 28.1236249 0.985915493 28.1236249"></polygon>
+ <rect id="rect4280" fill="#C39A7A" x="0.492957746" y="23.5469392" width="1.42224294" height="6.90277552"></rect>
+ <rect id="rect4284" fill="#C39A7A" x="22.0386777" y="23.6746763" width="1" height="3.26488183"></rect>
+ </g>
+ </g>
+ </g>
+ <g id="v2">
+ <mask id="mask-4" fill="white">
+ <use xlink:href="#path-3"></use>
+ </mask>
+ <use id="Oval-Copy" fill="#EDDDD1" transform="translate(50.000000, 50.000000) rotate(-180.000000) translate(-50.000000, -50.000000) " xlink:href="#path-3"></use>
+ <image id="zk_logo_use2" mask="url(#mask-4)" x="22" y="10" width="52.756654" height="75" xlink:href=""></image>
+ </g>
</g>
- </g>
</g>
- </g>
-</svg>
+</svg> \ No newline at end of file
diff --git a/bigtop-packages/src/charm/zookeeper/layer-zookeeper/metadata.yaml b/bigtop-packages/src/charm/zookeeper/layer-zookeeper/metadata.yaml
index d9818d79..a5637759 100644
--- a/bigtop-packages/src/charm/zookeeper/layer-zookeeper/metadata.yaml
+++ b/bigtop-packages/src/charm/zookeeper/layer-zookeeper/metadata.yaml
@@ -1,12 +1,15 @@
name: zookeeper
+summary: Zookeeper from Apache Bigtop
maintainer: Juju Big Data <bigdata@lists.ubuntu.com>
-summary: High-performance coordination service for distributed applications
-description: |
+description: >
Apache ZooKeeper is a centralized, reliable application for maintaining
configuration information, naming, synchronization, and group services. All
of these kinds of services are used in some form or another by distributed
applications. In order to install and configure Apache HBase and other Hadoop
ecosystem components, you need ZooKeeper.
+
+ This charm provides version 3.4.6 of the Zookeeper application from Apache
+ Bigtop.
tags: []
provides:
zookeeper:
diff --git a/bigtop-packages/src/charm/zookeeper/layer-zookeeper/tests/01-deploy-smoke.py b/bigtop-packages/src/charm/zookeeper/layer-zookeeper/tests/01-deploy-smoke.py
index f9a008a2..78a8656b 100755
--- a/bigtop-packages/src/charm/zookeeper/layer-zookeeper/tests/01-deploy-smoke.py
+++ b/bigtop-packages/src/charm/zookeeper/layer-zookeeper/tests/01-deploy-smoke.py
@@ -24,13 +24,10 @@ class TestDeploy(unittest.TestCase):
"""
Deployment test for Apache Zookeeper quorum
"""
-
@classmethod
def setUpClass(cls):
cls.d = amulet.Deployment(series='xenial')
-
- cls.d.add('zookeeper', charm='cs:xenial/zookeeper', units=3)
-
+ cls.d.add('zookeeper', units=3)
cls.d.setup(timeout=1800)
cls.d.sentry.wait_for_messages({'zookeeper': re.compile('ready')},
timeout=1800)
diff --git a/bigtop-packages/src/charm/zookeeper/layer-zookeeper/tests/10-bind-address.py b/bigtop-packages/src/charm/zookeeper/layer-zookeeper/tests/10-bind-address.py
index 17ef3a2a..5202faf0 100755
--- a/bigtop-packages/src/charm/zookeeper/layer-zookeeper/tests/10-bind-address.py
+++ b/bigtop-packages/src/charm/zookeeper/layer-zookeeper/tests/10-bind-address.py
@@ -31,9 +31,7 @@ class TestBindClientPort(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.d = amulet.Deployment(series='xenial')
-
- cls.d.add('zk-test', charm='cs:xenial/zookeeper')
-
+ cls.d.add('zk-test', charm='zookeeper')
cls.d.setup(timeout=TIMEOUT)
cls.d.sentry.wait_for_messages({'zk-test': re.compile('^ready')},
timeout=TIMEOUT)
diff --git a/bigtop-packages/src/common/ambari/do-component-build b/bigtop-packages/src/common/ambari/do-component-build
index f9a2d0d6..59a16348 100644
--- a/bigtop-packages/src/common/ambari/do-component-build
+++ b/bigtop-packages/src/common/ambari/do-component-build
@@ -17,7 +17,7 @@
set -ex
. `dirname $0`/bigtop.bom
-export _JAVA_OPTIONS="-Xmx2048m -XX:MaxPermSize=512m -Djava.awt.headless=true"
+export _JAVA_OPTIONS="-Xmx2048m -Djava.awt.headless=true"
mvn clean package -DskipTests -Drat.skip
(cd contrib/management-packs/odpi-ambari-mpack ; mvn clean package -DskipTests -Drat.skip)
diff --git a/bigtop-packages/src/common/ambari/patch0-AMBARI.diff b/bigtop-packages/src/common/ambari/patch0-AMBARI.diff
new file mode 100644
index 00000000..a77974c5
--- /dev/null
+++ b/bigtop-packages/src/common/ambari/patch0-AMBARI.diff
@@ -0,0 +1,25 @@
+diff --git a/contrib/management-packs/odpi-ambari-mpack/pom.xml b/contrib/management-packs/odpi-ambari-mpack/pom.xml
+index 7b97e65..49c37f3 100644
+--- a/contrib/management-packs/odpi-ambari-mpack/pom.xml
++++ b/contrib/management-packs/odpi-ambari-mpack/pom.xml
+@@ -84,6 +84,7 @@
+ <plugin>
+ <artifactId>maven-assembly-plugin</artifactId>
+ <configuration>
++ <appendAssemblyId>false</appendAssemblyId>
+ <tarLongFileMode>gnu</tarLongFileMode>
+ <descriptors>
+ <descriptor>src/main/assemblies/odpi-ambari-mpack.xml</descriptor>
+diff --git a/contrib/management-packs/odpi-ambari-mpack/src/main/assemblies/odpi-ambari-mpack.xml b/contrib/management-packs/odpi-ambari-mpack/src/main/assemblies/odpi-ambari-mpack.xml
+index 5dd3db4..f7bd433 100644
+--- a/contrib/management-packs/odpi-ambari-mpack/src/main/assemblies/odpi-ambari-mpack.xml
++++ b/contrib/management-packs/odpi-ambari-mpack/src/main/assemblies/odpi-ambari-mpack.xml
+@@ -17,7 +17,7 @@
+ limitations under the License.
+ -->
+ <assembly>
+- <id></id>
++ <id>odpi-ambari-mpack</id>
+ <formats>
+ <format>dir</format>
+ <format>tar.gz</format>
diff --git a/bigtop-packages/src/common/ambari/patch1-AMBARI-storm.diff b/bigtop-packages/src/common/ambari/patch1-AMBARI-storm.diff
new file mode 100644
index 00000000..5780885e
--- /dev/null
+++ b/bigtop-packages/src/common/ambari/patch1-AMBARI-storm.diff
@@ -0,0 +1,12 @@
+diff -ruaN apache-ambari-2.5.0-src.orig/ambari-metrics/ambari-metrics-storm-sink/pom.xml apache-ambari-2.5.0-src/ambari-metrics/ambari-metrics-storm-sink/pom.xml
+--- apache-ambari-2.5.0-src.orig/ambari-metrics/ambari-metrics-storm-sink/pom.xml 2017-03-28 02:46:34.000000000 +0200
++++ apache-ambari-2.5.0-src/ambari-metrics/ambari-metrics-storm-sink/pom.xml 2017-04-10 22:05:35.679219116 +0200
+@@ -31,7 +31,7 @@
+ <packaging>jar</packaging>
+
+ <properties>
+- <storm.version>1.1.0-SNAPSHOT</storm.version>
++ <storm.version>1.1.0</storm.version>
+ </properties>
+
+ <build>
diff --git a/bigtop-packages/src/common/ambari/patch2-AMBARI-ConcurrentHashMap.diff b/bigtop-packages/src/common/ambari/patch2-AMBARI-ConcurrentHashMap.diff
new file mode 100644
index 00000000..bf0980e7
--- /dev/null
+++ b/bigtop-packages/src/common/ambari/patch2-AMBARI-ConcurrentHashMap.diff
@@ -0,0 +1,19 @@
+diff -ruaN apache-ambari-2.5.0-src.orig/ambari-server/src/main/java/org/apache/ambari/server/state/svccomphost/ServiceComponentHostImpl.java apache-ambari-2.5.0-src/ambari-server/src/main/java/org/apache/ambari/server/state/svccomphost/ServiceComponentHostImpl.java
+--- apache-ambari-2.5.0-src.orig/ambari-server/src/main/java/org/apache/ambari/server/state/svccomphost/ServiceComponentHostImpl.java 2017-03-27 20:46:35.000000000 -0400
++++ apache-ambari-2.5.0-src/ambari-server/src/main/java/org/apache/ambari/server/state/svccomphost/ServiceComponentHostImpl.java 2017-05-21 23:48:37.676372818 -0400
+@@ -25,6 +25,7 @@
+ import java.util.Map;
+ import java.util.Map.Entry;
+ import java.util.Set;
++import java.util.concurrent.ConcurrentHashMap;
+ import java.util.concurrent.ConcurrentMap;
+ import java.util.concurrent.locks.Lock;
+ import java.util.concurrent.locks.ReadWriteLock;
+@@ -77,7 +78,6 @@
+ import org.apache.ambari.server.state.fsm.StateMachine;
+ import org.apache.ambari.server.state.fsm.StateMachineFactory;
+ import org.apache.ambari.server.state.stack.upgrade.RepositoryVersionHelper;
+-import org.jboss.netty.util.internal.ConcurrentHashMap;
+ import org.slf4j.Logger;
+ import org.slf4j.LoggerFactory;
+
diff --git a/bigtop-packages/src/common/apex/do-component-build b/bigtop-packages/src/common/apex/do-component-build
index 49a8e82b..f0905ae2 100644
--- a/bigtop-packages/src/common/apex/do-component-build
+++ b/bigtop-packages/src/common/apex/do-component-build
@@ -16,7 +16,7 @@
. `dirname $0`/bigtop.bom
-export MAVEN_OPTS="-XX:PermSize=1024m -XX:MaxPermSize=1024m"
+export MAVEN_OPTS=""
# bigtop installs maven on its own and not through the package manager
export PATH=/usr/local/maven/bin:$PATH
@@ -117,6 +117,7 @@ for i in `diff -r all-deps/ hadoop-deps/ | grep all-deps | awk '{print $4}'`; do
rm -rf all-deps/ hadoop-deps/
rm -rf deps/hadoop-common-$HADOOP_VERSION-tests.jar
+rm -rf deps/slf4j-*.jar
#Download non-ASF licenses for libraries
wget -t 3 -q -O jline-LICENSE.txt https://raw.githubusercontent.com/jline/jline2/jline-2.11/LICENSE.txt
diff --git a/bigtop-packages/src/common/apex/patch1-for-hadoop27x.diff b/bigtop-packages/src/common/apex/patch1-for-hadoop27x.diff
index 2cd6be71..3ff850a3 100644
--- a/bigtop-packages/src/common/apex/patch1-for-hadoop27x.diff
+++ b/bigtop-packages/src/common/apex/patch1-for-hadoop27x.diff
@@ -1,7 +1,7 @@
-diff -Naur orig/engine/src/main/java/com/datatorrent/stram/client/StramAppLauncher.java new/engine/src/main/java/com/datatorrent/stram/client/StramAppLauncher.java
---- orig/engine/src/main/java/com/datatorrent/stram/client/StramAppLauncher.java 2016-11-22 02:49:11.000000000 +0530
-+++ new/engine/src/main/java/com/datatorrent/stram/client/StramAppLauncher.java 2017-03-23 23:08:32.692947303 +0530
-@@ -583,7 +583,7 @@
+diff -uraN apache-apex-core-3.6.0-orig/engine/src/main/java/com/datatorrent/stram/client/StramAppLauncher.java apache-apex-core-3.6.0/engine/src/main/java/com/datatorrent/stram/client/StramAppLauncher.java
+--- apache-apex-core-3.6.0-orig/engine/src/main/java/com/datatorrent/stram/client/StramAppLauncher.java 2017-04-28 20:55:41.000000000 +0200
++++ apache-apex-core-3.6.0/engine/src/main/java/com/datatorrent/stram/client/StramAppLauncher.java 2017-05-27 23:44:35.028907503 +0200
+@@ -584,7 +584,7 @@
if (UserGroupInformation.isSecurityEnabled()) {
long hdfsTokenMaxLifeTime = conf.getLong(StramClientUtils.DT_HDFS_TOKEN_MAX_LIFE_TIME, conf.getLong(StramClientUtils.HDFS_TOKEN_MAX_LIFE_TIME, StramClientUtils.DELEGATION_TOKEN_MAX_LIFETIME_DEFAULT));
dag.setAttribute(LogicalPlan.HDFS_TOKEN_LIFE_TIME, hdfsTokenMaxLifeTime);
@@ -10,15 +10,15 @@ diff -Naur orig/engine/src/main/java/com/datatorrent/stram/client/StramAppLaunch
dag.setAttribute(LogicalPlan.RM_TOKEN_LIFE_TIME, rmTokenMaxLifeTime);
setTokenRefreshCredentials(dag, conf);
}
-diff -Naur orig/engine/src/main/java/com/datatorrent/stram/plan/logical/LogicalPlan.java new/engine/src/main/java/com/datatorrent/stram/plan/logical/LogicalPlan.java
---- orig/engine/src/main/java/com/datatorrent/stram/plan/logical/LogicalPlan.java 2016-11-22 02:48:16.000000000 +0530
-+++ new/engine/src/main/java/com/datatorrent/stram/plan/logical/LogicalPlan.java 2017-03-23 23:07:18.948865455 +0530
-@@ -156,7 +156,7 @@
+diff -uraN apache-apex-core-3.6.0-orig/engine/src/main/java/com/datatorrent/stram/plan/logical/LogicalPlan.java apache-apex-core-3.6.0/engine/src/main/java/com/datatorrent/stram/plan/logical/LogicalPlan.java
+--- apache-apex-core-3.6.0-orig/engine/src/main/java/com/datatorrent/stram/plan/logical/LogicalPlan.java 2017-04-28 20:55:41.000000000 +0200
++++ apache-apex-core-3.6.0/engine/src/main/java/com/datatorrent/stram/plan/logical/LogicalPlan.java 2017-05-27 23:44:20.360926755 +0200
+@@ -162,7 +162,7 @@
*/
public static Attribute<Boolean> FAST_PUBLISHER_SUBSCRIBER = new Attribute<>(false);
public static Attribute<Long> HDFS_TOKEN_LIFE_TIME = new Attribute<>(604800000L);
- public static Attribute<Long> RM_TOKEN_LIFE_TIME = new Attribute<>(YarnConfiguration.DELEGATION_TOKEN_MAX_LIFETIME_DEFAULT);
+ public static Attribute<Long> RM_TOKEN_LIFE_TIME = new Attribute<>(YarnConfiguration.RM_DELEGATION_TOKEN_MAX_LIFETIME_DEFAULT);
- public static Attribute<String> PRINCIPAL = new Attribute<String>(null, new StringCodec.String2String());
- public static Attribute<String> KEY_TAB_FILE = new Attribute<>((String)null, new StringCodec.String2String());
+ public static Attribute<String> PRINCIPAL = new Attribute<>(null, StringCodec.String2String.getInstance());
+ public static Attribute<String> KEY_TAB_FILE = new Attribute<>((String)null, StringCodec.String2String.getInstance());
public static Attribute<Double> TOKEN_REFRESH_ANTICIPATORY_FACTOR = new Attribute<>(0.7);
diff --git a/bigtop-packages/src/common/flume/do-component-build b/bigtop-packages/src/common/flume/do-component-build
index bbf76561..b7c3362c 100755
--- a/bigtop-packages/src/common/flume/do-component-build
+++ b/bigtop-packages/src/common/flume/do-component-build
@@ -18,7 +18,7 @@ set -ex
. `dirname $0`/bigtop.bom
-export MAVEN_OPTS="-Xmx1536m -Xms256m -XX:MaxPermSize=256m"
+export MAVEN_OPTS="-Xmx1536m -Xms256m"
sed -i -e \
's#<artifactId>asynchbase</artifactId>#<artifactId>asynchbase</artifactId>\n<exclusions>\n<exclusion>\n<groupId>org.apache.zookeeper</groupId>\n<artifactId>zookeeper</artifactId>\n</exclusion>\n</exclusions>#' flume-ng-sinks/flume-ng-hbase-sink/pom.xml
diff --git a/bigtop-packages/src/common/hadoop/init-hcfs.json b/bigtop-packages/src/common/hadoop/init-hcfs.json
index f71f3854..6225a69e 100644
--- a/bigtop-packages/src/common/hadoop/init-hcfs.json
+++ b/bigtop-packages/src/common/hadoop/init-hcfs.json
@@ -92,7 +92,8 @@
["/user/hbase","755","hbase",null],
["/apps",null,null,null],
["/apps/tez",null,null,null],
- ["/apps/tez/lib",null,null,null]
+ ["/apps/tez/lib",null,null,null],
+ ["/user/zeppelin","777","zeppelin"]
],
"user": [
["tom", "0755", null],
diff --git a/bigtop-packages/src/common/hama/do-component-build b/bigtop-packages/src/common/hama/do-component-build
index a5bfc916..78bd682d 100644
--- a/bigtop-packages/src/common/hama/do-component-build
+++ b/bigtop-packages/src/common/hama/do-component-build
@@ -17,5 +17,5 @@
set -ex
. `dirname $0`/bigtop.bom
-export MAVEN_OPTS="-XX:PermSize=1024m -XX:MaxPermSize=1024m"
+export MAVEN_OPTS=""
mvn -Phadoop2 -Dhadoop.version=$HADOOP_VERSION -Dzookeeper.version=$ZOOKEEPER_VERSION clean install -DskipTests "$@"
diff --git a/bigtop-packages/src/common/hbase/patch0-jline-jrub.diff b/bigtop-packages/src/common/hbase/patch0-jline-jrub.diff
new file mode 100644
index 00000000..d6aa4e78
--- /dev/null
+++ b/bigtop-packages/src/common/hbase/patch0-jline-jrub.diff
@@ -0,0 +1,15 @@
+--- ./hbase-shell/src/main/ruby/shell/formatter.rb.orig 2017-04-22 12:39:16.617041337 +0000
++++ ./hbase-shell/src/main/ruby/shell/formatter.rb 2017-04-22 12:40:46.642890485 +0000
+@@ -30,7 +30,11 @@
+
+ def refresh_width()
+ if $stdout.tty?
+- @max_width = Java::jline.Terminal.getTerminal().getTerminalWidth()
++ if Java::jline.Terminal.respond_to?(:getTerminal)
++ @max_width = Java::jline.Terminal.getTerminal.getTerminalWidth
++ else
++ @max_width = Java::jline.TerminalFactory.get.getWidth
++ end
+ else
+ @max_width = 0
+ end
diff --git a/bigtop-packages/src/common/hive/do-component-build b/bigtop-packages/src/common/hive/do-component-build
index 2293c55c..f8be82cf 100644
--- a/bigtop-packages/src/common/hive/do-component-build
+++ b/bigtop-packages/src/common/hive/do-component-build
@@ -31,7 +31,7 @@ HIVE_MAVEN_OPTS=" -Dhbase.version=$HBASE_VERSION \
-Dspark.version=${SPARK1_VERSION}
"
-export MAVEN_OPTS="-Xmx1500m -Xms1500m -XX:MaxPermSize=256m"
+export MAVEN_OPTS="-Xmx1500m -Xms1500m"
mvn ${HIVE_MAVEN_OPTS} clean install -Phadoop-2,dist "$@"
mkdir -p build/dist
diff --git a/bigtop-packages/src/common/ignite-hadoop/do-component-build b/bigtop-packages/src/common/ignite-hadoop/do-component-build
index 417477cc..5f0eb5d4 100644
--- a/bigtop-packages/src/common/ignite-hadoop/do-component-build
+++ b/bigtop-packages/src/common/ignite-hadoop/do-component-build
@@ -18,6 +18,6 @@ set -ex
. `dirname $0`/bigtop.bom
-export MAVEN_OPTS="-Xmx512M -XX:MaxPermSize=512M"
+export MAVEN_OPTS="-Xmx512M"
mvn clean install -DskipTests -Dhadoop.version=$HADOOP_VERSION -Dspark.version=$SPARK_VERSION -Dignite.edition=hadoop
diff --git a/bigtop-packages/src/common/ignite-hadoop/ignite-hadoop.default b/bigtop-packages/src/common/ignite-hadoop/ignite-hadoop.default
index 87626d63..a0947203 100644
--- a/bigtop-packages/src/common/ignite-hadoop/ignite-hadoop.default
+++ b/bigtop-packages/src/common/ignite-hadoop/ignite-hadoop.default
@@ -20,3 +20,5 @@ export IGNITE_PID_DIR="/var/run/ignite-hadoop"
export IGNITE_LOG_DIR="/var/log/ignite-hadoop"
export IGNITE_WORK_DIR="/var/run/ignite-hadoop/work"
export IGNITE_IDENT_STRING=ignite
+
+export HADOOP_HOME=${HADOOP_HOME:-/usr/lib/hadoop}
diff --git a/bigtop-packages/src/common/kafka/do-component-build b/bigtop-packages/src/common/kafka/do-component-build
index 31cef4a1..a67d46b3 100644
--- a/bigtop-packages/src/common/kafka/do-component-build
+++ b/bigtop-packages/src/common/kafka/do-component-build
@@ -25,7 +25,7 @@ BUILD_OPTS="-Divy.home=${HOME}/.ivy2 -Dsbt.ivy.home=${HOME}/.ivy2 -Duser.home=${
## this might be an issue at times
# http://maven.40175.n5.nabble.com/Not-finding-artifact-in-local-repo-td3727753.html
-export MAVEN_OPTS="-Xmx2g -XX:ReservedCodeCacheSize=512m -XX:PermSize=1024m -XX:MaxPermSize=1024m"
+export MAVEN_OPTS="-Xmx2g -XX:ReservedCodeCacheSize=512m"
gradle wrapper
diff --git a/bigtop-packages/src/common/oozie/do-component-build b/bigtop-packages/src/common/oozie/do-component-build
index 47fefbf5..601e5a7c 100755
--- a/bigtop-packages/src/common/oozie/do-component-build
+++ b/bigtop-packages/src/common/oozie/do-component-build
@@ -82,7 +82,7 @@ sed -i.bak "/http:\/\/repository.codehaus.org/a\\
<enabled>false</enabled>\\
</releases>" ${WORKDIR}/pom.xml
-export MAVEN_OPTS="-Xmx512m -XX:MaxPermSize=128m"
+export MAVEN_OPTS="-Xmx512m"
# Invoke Oozie build script
${WORKDIR}/bin/mkdistro.sh -DjavaVersion=${JDK_VERSION} -DskipTests -Phadoop-2 -Puber -Dhadoop.version=${HADOOP_VERSION} -Dhadoop.auth.version=${HADOOP_VERSION} -Dhive.version=${HIVE_VERSION} -Dpig.version=${PIG_VERSION} -Dsqoop.version=${SQOOP_VERSION} -Dspark.version=${SPARK_VERSION} ${EXTRA_GOALS} -Dmaven.repo.local=${HOME}/.m2/repository "$@"
MKDISTRO_RESULT=$?
diff --git a/bigtop-packages/src/common/spark/do-component-build b/bigtop-packages/src/common/spark/do-component-build
index 21dffbe0..3b79b0d3 100644
--- a/bigtop-packages/src/common/spark/do-component-build
+++ b/bigtop-packages/src/common/spark/do-component-build
@@ -28,7 +28,7 @@ BUILD_OPTS="-Divy.home=${HOME}/.ivy2 -Dsbt.ivy.home=${HOME}/.ivy2 -Duser.home=${
-Dyarn.version=$HADOOP_VERSION \
-Dprotobuf.version=2.5.0 \
-DrecompileMode=all \
- -Pyarn -Phadoop-2.6 \
+ -Pyarn -Phadoop-2.7 \
-Phive -Phive-thriftserver \
$SPARK_BUILD_OPTS"
diff --git a/bigtop-packages/src/common/spark/spark-env.sh b/bigtop-packages/src/common/spark/spark-env.sh
index 885aed13..f772ef1a 100755
--- a/bigtop-packages/src/common/spark/spark-env.sh
+++ b/bigtop-packages/src/common/spark/spark-env.sh
@@ -39,5 +39,5 @@ export SPARK_MASTER_WEBUI_PORT=18080
export SPARK_WORKER_DIR=${SPARK_WORKER_DIR:-/var/run/spark/work}
export SPARK_WORKER_PORT=7078
export SPARK_WORKER_WEBUI_PORT=18081
-
+export SPARK_MASTER_URL=spark://$STANDALONE_SPARK_MASTER_HOST:$SPARK_MASTER_PORT
export SPARK_HISTORY_OPTS="$SPARK_HISTORY_OPTS -Dspark.history.fs.logDirectory=hdfs:///var/log/spark/apps -Dspark.history.ui.port=18082"
diff --git a/bigtop-packages/src/common/spark1/do-component-build b/bigtop-packages/src/common/spark1/do-component-build
index c6078b20..7ea85d43 100644
--- a/bigtop-packages/src/common/spark1/do-component-build
+++ b/bigtop-packages/src/common/spark1/do-component-build
@@ -35,7 +35,7 @@ BUILD_OPTS="-Divy.home=${HOME}/.ivy2 -Dsbt.ivy.home=${HOME}/.ivy2 -Duser.home=${
## this might be an issue at times
# http://maven.40175.n5.nabble.com/Not-finding-artifact-in-local-repo-td3727753.html
-export MAVEN_OPTS="-Xmx2g -XX:ReservedCodeCacheSize=512m -XX:PermSize=1024m -XX:MaxPermSize=1024m"
+export MAVEN_OPTS="-Xmx2g -XX:ReservedCodeCacheSize=512m"
mvn $BUILD_OPTS -DskipTests install
diff --git a/bigtop-packages/src/common/zeppelin/do-component-build b/bigtop-packages/src/common/zeppelin/do-component-build
index 2939b2a1..05d93f33 100644
--- a/bigtop-packages/src/common/zeppelin/do-component-build
+++ b/bigtop-packages/src/common/zeppelin/do-component-build
@@ -30,36 +30,31 @@ if [ $HOSTTYPE = "powerpc64le" ] ; then
sed -i "s|<version>0.0.25</version>|<version>1.1</version>|" zeppelin-web/pom.xml
fi
-t="scala.version"
-find . -name pom.xml -exec sed -i "s#<$t>.*</$t>#<$t>${SCALA_VERSION}</$t>#" {} \;
-t="scala.binary.version"
-find . -name pom.xml -exec sed -i "s#<$t>.*</$t>#<$t>${SCALA_VERSION%.*}</$t>#" {} \;
-t="scala.macros.version"
-find . -name pom.xml -exec sed -i "s#<$t>.*</$t>#<$t>2.1.0</$t>#" {} \;
-t="spark.version"
-find . -name pom.xml -exec sed -i "s#<$t>.*</$t>#<$t>${SPARK_VERSION}</$t>#" {} \;
-t="hadoop.version"
-find . -name pom.xml -exec sed -i "s#<$t>.*</$t>#<$t>${HADOOP_VERSION}</$t>#" {} \;
-t="hbase.hbase.version"
-find . -name pom.xml -exec sed -i "s#<$t>.*</$t>#<$t>${HBASE_VERSION}</$t>#" {} \;
-t="hbase.hadoop.version"
-find . -name pom.xml -exec sed -i "s#<$t>.*</$t>#<$t>${HADOOP_VERSION}</$t>#" {} \;
-t="ignite.version"
-find . -name pom.xml -exec sed -i "s#<$t>.*</$t>#<$t>${IGNITE_HADOOP_VERSION}</$t>#" {} \;
-
-BUILD_OPTS="-Divy.home=${HOME}/.ivy2 -Dsbt.ivy.home=${HOME}/.ivy2 -Duser.home=${HOME} \
- -Drepo.maven.org=$IVY_MIRROR_PROP \
- -Dreactor.repo=file://${HOME}/.m2/repository \
+./dev/change_scala_version.sh ${SCALA_VERSION%.*}
+
+BUILD_OPTS="-Dscala.version=${SCALA_VERSION} \
+ -Dscala.binary.version=${SCALA_VERSION%.*} \
+ -Dscala.macros.version=2.1.0 \
+ -Dspark.version=${SPARK_VERSION} \
+ -Dhadoop.version=${HADOOP_VERSION} \
+ -Dhbase.hbase.version=${HBASE_VERSION} \
+ -Dhbase.hadoop.version=${HADOOP_VERSION} \
+ -Dignite.version=${IGNITE_HADOOP_VERSION} \
+ -Dflink.version=${FLINK_VERSION} \
+ -Pspark-${SPARK_VERSION%.*} \
+ -Phadoop-${HADOOP_VERSION%.*} \
-Pscala-${SCALA_VERSION%.*} \
+ -Ppyspark \
+ -Psparkr \
-Pbuild-distr"
-
+
if [ "$ZEPPELIN_RUN_TESTS" = "true" ]; then
BUILD_OPTS="$BUILD_OPTS -DskipTests=false"
else
BUILD_OPTS="$BUILD_OPTS -DskipTests"
fi
-export MAVEN_OPTS="-Xmx1500m -Xms1500m -XX:MaxPermSize=256m"
+export MAVEN_OPTS="-Xmx1500m -Xms1500m"
mvn $BUILD_OPTS clean package
diff --git a/bigtop-packages/src/deb/flink/flink.preinst b/bigtop-packages/src/deb/flink/flink.preinst
index cee0a14a..ece0ee02 100644
--- a/bigtop-packages/src/deb/flink/flink.preinst
+++ b/bigtop-packages/src/deb/flink/flink.preinst
@@ -32,11 +32,12 @@ set -e
case "$1" in
install|upgrade)
+ getent group flink >/dev/null || groupadd -r flink
if ! getent passwd flink >/dev/null; then
# Adding system user: flink .
adduser \
--system \
- --group \
+ --ingroup flink \
--home /var/lib/flink \
--gecos "Flink" \
--shell /bin/false \
diff --git a/bigtop-packages/src/deb/flume/flume.preinst b/bigtop-packages/src/deb/flume/flume.preinst
index f0fb3e55..21c0ea02 100644
--- a/bigtop-packages/src/deb/flume/flume.preinst
+++ b/bigtop-packages/src/deb/flume/flume.preinst
@@ -32,11 +32,12 @@ set -e
case "$1" in
install|upgrade)
+ getent group flume >/dev/null || groupadd -r flume
if ! getent passwd flume >/dev/null; then
# Adding system user: flume .
adduser \
--system \
- --group \
+ --ingroup flume \
--home /var/lib/flume \
--gecos "Flume User" \
--shell /bin/false \
diff --git a/bigtop-packages/src/deb/hadoop/hadoop-hdfs.preinst b/bigtop-packages/src/deb/hadoop/hadoop-hdfs.preinst
index dedd7b9b..72bdc3c2 100644
--- a/bigtop-packages/src/deb/hadoop/hadoop-hdfs.preinst
+++ b/bigtop-packages/src/deb/hadoop/hadoop-hdfs.preinst
@@ -32,11 +32,12 @@ set -e
case "$1" in
install|upgrade)
+ getent group hdfs >/dev/null || groupadd -r hdfs
if ! getent passwd hdfs >/dev/null; then
# Adding system user: hdfs.
adduser \
--system \
- --group \
+ --ingroup hdfs \
--home /var/lib/hadoop-hdfs \
--gecos "Hadoop HDFS" \
--shell /bin/bash \
diff --git a/bigtop-packages/src/deb/hadoop/hadoop-httpfs.preinst b/bigtop-packages/src/deb/hadoop/hadoop-httpfs.preinst
index 634bcc3c..98d6a8ba 100644
--- a/bigtop-packages/src/deb/hadoop/hadoop-httpfs.preinst
+++ b/bigtop-packages/src/deb/hadoop/hadoop-httpfs.preinst
@@ -32,10 +32,11 @@ set -e
case "$1" in
install|upgrade)
+ getent group httpfs >/dev/null || groupadd -r httpfs
if ! getent passwd httpfs >/dev/null; then
adduser \
--system \
- --group \
+ --ingroup httpfs \
--home /var/run/hadoop-httpfs \
--gecos "Hadoop HTTPFS" \
--shell /bin/bash \
diff --git a/bigtop-packages/src/deb/hadoop/hadoop-mapreduce.preinst b/bigtop-packages/src/deb/hadoop/hadoop-mapreduce.preinst
index b52c5fdc..84e975e5 100644
--- a/bigtop-packages/src/deb/hadoop/hadoop-mapreduce.preinst
+++ b/bigtop-packages/src/deb/hadoop/hadoop-mapreduce.preinst
@@ -32,10 +32,11 @@ set -e
case "$1" in
install|upgrade)
+ getent group mapred >/dev/null || groupadd -r mapred
if ! getent passwd mapred >/dev/null; then
adduser \
--system \
- --group \
+ --ingroup mapred \
--home /var/lib/hadoop-mapreduce \
--gecos "Hadoop MapReduce" \
--shell /bin/bash \
diff --git a/bigtop-packages/src/deb/hadoop/hadoop-yarn.preinst b/bigtop-packages/src/deb/hadoop/hadoop-yarn.preinst
index 14451362..fdf5aae9 100644
--- a/bigtop-packages/src/deb/hadoop/hadoop-yarn.preinst
+++ b/bigtop-packages/src/deb/hadoop/hadoop-yarn.preinst
@@ -32,11 +32,12 @@ set -e
case "$1" in
install|upgrade)
+ getent group yarn >/dev/null || groupadd -r yarn
if ! getent passwd yarn >/dev/null; then
# Adding system user: yarn.
adduser \
--system \
- --group \
+ --ingroup yarn \
--home /var/lib/hadoop-yarn \
--gecos "Hadoop YARN" \
--shell /bin/bash \
diff --git a/bigtop-packages/src/deb/hama/hama.preinst b/bigtop-packages/src/deb/hama/hama.preinst
index 421ee900..cc0ecd7a 100644
--- a/bigtop-packages/src/deb/hama/hama.preinst
+++ b/bigtop-packages/src/deb/hama/hama.preinst
@@ -32,11 +32,12 @@ set -e
case "$1" in
install|upgrade)
+ getent group hama >/dev/null || groupadd -r hama
if ! getent passwd hama >/dev/null; then
# Adding system user: hama.
adduser \
--system \
- --group \
+ --ingroup hama \
--home /var/lib/hama \
--gecos "Apache Hama User" \
--shell /bin/bash \
diff --git a/bigtop-packages/src/deb/hbase/hbase.preinst b/bigtop-packages/src/deb/hbase/hbase.preinst
index 3c68f764..4e4a9ea8 100644
--- a/bigtop-packages/src/deb/hbase/hbase.preinst
+++ b/bigtop-packages/src/deb/hbase/hbase.preinst
@@ -32,11 +32,12 @@ set -e
case "$1" in
install|upgrade)
+ getent group hbase >/dev/null || groupadd -r hbase
if ! getent passwd hbase >/dev/null; then
# Adding system user: hbase.
adduser \
--system \
- --group \
+ --ingroup hbase \
--home /var/run/hbase \
--gecos "HBase User" \
--shell /bin/bash \
diff --git a/bigtop-packages/src/deb/hive/hive.preinst b/bigtop-packages/src/deb/hive/hive.preinst
index f87c85bf..db807fea 100644
--- a/bigtop-packages/src/deb/hive/hive.preinst
+++ b/bigtop-packages/src/deb/hive/hive.preinst
@@ -23,11 +23,12 @@ set -e
case "$1" in
install|upgrade)
+ getent group hive >/dev/null || groupadd -r hive
if ! getent passwd hive >/dev/null; then
# Adding system user: hive.
adduser \
--system \
- --group \
+ --ingroup hive \
--home /var/lib/hive \
--gecos "Hive User" \
--shell /bin/false \
diff --git a/bigtop-packages/src/deb/hue/control b/bigtop-packages/src/deb/hue/control
index e1240d9b..ccfc640f 100644
--- a/bigtop-packages/src/deb/hue/control
+++ b/bigtop-packages/src/deb/hue/control
@@ -23,7 +23,7 @@ Homepage: http://github.com/cloudera/hue
Package: hue-common
Architecture: any
-Depends: ${shlibs:Depends}, ${misc:Depends}, ${build:SYS-PYTHON}, libsasl2-modules-gssapi-mit, libxslt1.1, make, python (>= 2.6), libgmp10, libffi
+Depends: ${shlibs:Depends}, ${misc:Depends}, ${build:SYS-PYTHON}, libsasl2-modules-gssapi-mit, libxslt1.1, make, python (>= 2.6), libgmp10, libffi6
Description: A browser-based desktop interface for Hadoop
Hue is a browser-based desktop interface for interacting with Hadoop.
It supports a file browser, job tracker interface, cluster health monitor, and more.
diff --git a/bigtop-packages/src/deb/hue/hue-common.preinst b/bigtop-packages/src/deb/hue/hue-common.preinst
index 0641767f..28242eaf 100644
--- a/bigtop-packages/src/deb/hue/hue-common.preinst
+++ b/bigtop-packages/src/deb/hue/hue-common.preinst
@@ -32,11 +32,12 @@ set -e
USER=hue
case "$1" in
install|upgrade)
+ getent group $USER >/dev/null || groupadd -r $USER
if ! getent passwd $USER >/dev/null; then
adduser \
--system \
--disabled-login \
- --group \
+ --ingroup $USER \
--home /usr/lib/hue \
--gecos "Hue daemon" \
$USER >/dev/null
diff --git a/bigtop-packages/src/deb/ignite-hadoop/ignite-hadoop.preinst b/bigtop-packages/src/deb/ignite-hadoop/ignite-hadoop.preinst
index b3b7db94..2623c283 100644
--- a/bigtop-packages/src/deb/ignite-hadoop/ignite-hadoop.preinst
+++ b/bigtop-packages/src/deb/ignite-hadoop/ignite-hadoop.preinst
@@ -32,11 +32,12 @@ set -e
case "$1" in
install|upgrade)
+ getent group ignite >/dev/null || groupadd -r ignite
if ! getent passwd ignite >/dev/null; then
# Adding system user: ignite.
adduser \
--system \
- --group \
+ --ingroup ignite \
--home /var/run/ignite-hadoop \
--gecos "Ignite User" \
--shell /bin/bash \
diff --git a/bigtop-packages/src/deb/oozie/oozie.preinst b/bigtop-packages/src/deb/oozie/oozie.preinst
index 8a74e9c5..a5f8d722 100644
--- a/bigtop-packages/src/deb/oozie/oozie.preinst
+++ b/bigtop-packages/src/deb/oozie/oozie.preinst
@@ -32,12 +32,13 @@ set -e
case "$1" in
install|upgrade)
+ getent group oozie >/dev/null || groupadd -r oozie
if ! getent passwd oozie >/dev/null; then
# Adding system user: oozie.
adduser \
--system \
--disabled-login \
- --group \
+ --ingroup oozie \
--home /var/lib/oozie \
--gecos "Oozie User" \
--shell /bin/false \
diff --git a/bigtop-packages/src/deb/phoenix/phoenix.preinst b/bigtop-packages/src/deb/phoenix/phoenix.preinst
index f3174ca5..24fe06d4 100644
--- a/bigtop-packages/src/deb/phoenix/phoenix.preinst
+++ b/bigtop-packages/src/deb/phoenix/phoenix.preinst
@@ -23,12 +23,13 @@ set -e
case "$1" in
install|upgrade)
- if ! getent passwd phenix >/dev/null; then
- # Adding system user: phenix.
+ getent group phoenix >/dev/null || groupadd -r phoenix
+ if ! getent passwd phoenix >/dev/null; then
+ # Adding system user: phoenix.
adduser \
--system \
- --group \
- --home /var/lib/phenix \
+ --ingroup phoenix \
+ --home /var/lib/phoenix \
--gecos "Phoenix User" \
--shell /bin/false \
phoenix >/dev/null
diff --git a/bigtop-packages/src/deb/solr/solr.preinst b/bigtop-packages/src/deb/solr/solr.preinst
index 1c2ad0f5..68ad4177 100644
--- a/bigtop-packages/src/deb/solr/solr.preinst
+++ b/bigtop-packages/src/deb/solr/solr.preinst
@@ -32,11 +32,12 @@ set -e
case "$1" in
install|upgrade)
+ getent group solr >/dev/null || groupadd -r solr
if ! getent passwd solr >/dev/null; then
# Adding system user: solr .
adduser \
--system \
- --group \
+ --ingroup solr \
--home /var/lib/solr \
--gecos "Solr" \
--shell /bin/false \
diff --git a/bigtop-packages/src/deb/spark/control b/bigtop-packages/src/deb/spark/control
index 4b7f2ffe..01a393de 100644
--- a/bigtop-packages/src/deb/spark/control
+++ b/bigtop-packages/src/deb/spark/control
@@ -23,7 +23,7 @@ Homepage: http://spark.apache.org/
Package: spark-core
Architecture: all
-Depends: adduser, bigtop-utils (>= 0.7), hadoop-client
+Depends: adduser, bigtop-utils (>= 0.7), hadoop-client, hadoop-yarn
Description: Lightning-Fast Cluster Computing
Spark is a MapReduce-like cluster computing framework designed to support
low-latency iterative jobs and interactive use from an interpreter. It is
diff --git a/bigtop-packages/src/deb/spark/rules b/bigtop-packages/src/deb/spark/rules
index 0bc7fc7f..d5fdb6d9 100644
--- a/bigtop-packages/src/deb/spark/rules
+++ b/bigtop-packages/src/deb/spark/rules
@@ -22,6 +22,10 @@ export DH_VERBOSE=1
# This has to be exported to make some magic below work.
export DH_OPTIONS
+lib_spark=/usr/lib/spark
+lib_hadoop_client=/usr/lib/hadoop/client
+lib_hadoop_yarn=/usr/lib/hadoop-yarn/
+
%:
dh $@
@@ -45,3 +49,20 @@ override_dh_install:
dh_install
# BIGTOP-2588 drop datanucleus jars from spark-core
rm -Rf debian/spark-core/usr/lib/spark/jars/datanucleus*
+
+ rm -f debian/tmp/${lib_spark}/jars/hadoop-*.jar
+ ln -s ${lib_hadoop_client}/hadoop-annotations.jar debian/tmp/${lib_spark}/jars/
+ ln -s ${lib_hadoop_client}/hadoop-auth.jar debian/tmp/${lib_spark}/jars/
+ ln -s ${lib_hadoop_client}/hadoop-client.jar debian/tmp/${lib_spark}/jars/
+ ln -s ${lib_hadoop_client}/hadoop-common.jar debian/tmp/${lib_spark}/jars/
+ ln -s ${lib_hadoop_client}/hadoop-hdfs.jar debian/tmp/${lib_spark}/jars/
+ ln -s ${lib_hadoop_client}/hadoop-mapreduce-client-app.jar debian/tmp/${lib_spark}/jars/
+ ln -s ${lib_hadoop_client}/hadoop-mapreduce-client-common.jar debian/tmp/${lib_spark}/jars/
+ ln -s ${lib_hadoop_client}/hadoop-mapreduce-client-core.jar debian/tmp/${lib_spark}/jars/
+ ln -s ${lib_hadoop_client}/hadoop-mapreduce-client-jobclient.jar debian/tmp/${lib_spark}/jars/
+ ln -s ${lib_hadoop_client}/hadoop-mapreduce-client-shuffle.jar debian/tmp/${lib_spark}/jars/
+ ln -s ${lib_hadoop_yarn}/hadoop-yarn-api.jar debian/tmp/${lib_spark}/jars/
+ ln -s ${lib_hadoop_yarn}/hadoop-yarn-client.jar debian/tmp/${lib_spark}/jars/
+ ln -s ${lib_hadoop_yarn}/hadoop-yarn-common.jar debian/tmp/${lib_spark}/jars/
+ ln -s ${lib_hadoop_yarn}/hadoop-yarn-server-common.jar debian/tmp/${lib_spark}/jars/
+ ln -s ${lib_hadoop_yarn}/hadoop-yarn-server-web-proxy.jar debian/tmp/${lib_spark}/jars/
diff --git a/bigtop-packages/src/deb/spark/spark-core.preinst b/bigtop-packages/src/deb/spark/spark-core.preinst
index ea83e68e..d0b716f8 100644
--- a/bigtop-packages/src/deb/spark/spark-core.preinst
+++ b/bigtop-packages/src/deb/spark/spark-core.preinst
@@ -32,11 +32,12 @@ set -e
case "$1" in
install|upgrade)
+ getent group spark >/dev/null || groupadd -r spark
if ! getent passwd spark >/dev/null; then
# Adding system user: spark .
adduser \
--system \
- --group \
+ --ingroup spark \
--home /var/lib/spark \
--gecos "Spark" \
--shell /bin/false \
diff --git a/bigtop-packages/src/deb/spark1/spark-core.preinst b/bigtop-packages/src/deb/spark1/spark-core.preinst
index ea83e68e..d0b716f8 100644
--- a/bigtop-packages/src/deb/spark1/spark-core.preinst
+++ b/bigtop-packages/src/deb/spark1/spark-core.preinst
@@ -32,11 +32,12 @@ set -e
case "$1" in
install|upgrade)
+ getent group spark >/dev/null || groupadd -r spark
if ! getent passwd spark >/dev/null; then
# Adding system user: spark .
adduser \
--system \
- --group \
+ --ingroup spark \
--home /var/lib/spark \
--gecos "Spark" \
--shell /bin/false \
diff --git a/bigtop-packages/src/deb/sqoop/sqoop.preinst b/bigtop-packages/src/deb/sqoop/sqoop.preinst
index 56d7e736..1477d5cb 100644
--- a/bigtop-packages/src/deb/sqoop/sqoop.preinst
+++ b/bigtop-packages/src/deb/sqoop/sqoop.preinst
@@ -32,11 +32,12 @@ set -e
case "$1" in
install|upgrade)
+ getent group sqoop >/dev/null || groupadd -r sqoop
if ! getent passwd sqoop >/dev/null; then
# Adding system user: sqoop .
adduser \
--system \
- --group \
+ --ingroup sqoop \
--home /var/lib/sqoop \
--gecos "Sqoop User" \
--shell /bin/false \
diff --git a/bigtop-packages/src/deb/tajo/tajo.preinst b/bigtop-packages/src/deb/tajo/tajo.preinst
index ee7a7944..63d75962 100644
--- a/bigtop-packages/src/deb/tajo/tajo.preinst
+++ b/bigtop-packages/src/deb/tajo/tajo.preinst
@@ -32,11 +32,12 @@ set -e
case "$1" in
install|upgrade)
+ getent group tajo >/dev/null || groupadd -r tajo
if ! getent passwd tajo >/dev/null; then
# Adding system user: tajo .
adduser \
--system \
- --group \
+ --ingroup tajo \
--home /var/lib/tajo \
--gecos "Tajo" \
--shell /bin/false \
diff --git a/bigtop-packages/src/deb/zeppelin/zeppelin.preinst b/bigtop-packages/src/deb/zeppelin/zeppelin.preinst
index 6434c1ac..aa19763f 100644
--- a/bigtop-packages/src/deb/zeppelin/zeppelin.preinst
+++ b/bigtop-packages/src/deb/zeppelin/zeppelin.preinst
@@ -32,11 +32,12 @@ set -e
case "$1" in
install|upgrade)
+ getent group zeppelin >/dev/null || groupadd -r zeppelin
if ! getent passwd zeppelin >/dev/null; then
# Adding system user: zeppelin .
adduser \
--system \
- --group \
+ --ingroup zeppelin \
--home /var/lib/zeppelin \
--gecos "Zeppelin" \
--shell /bin/false \
diff --git a/bigtop-packages/src/deb/zookeeper/zookeeper.preinst b/bigtop-packages/src/deb/zookeeper/zookeeper.preinst
index 3183a513..98860628 100644
--- a/bigtop-packages/src/deb/zookeeper/zookeeper.preinst
+++ b/bigtop-packages/src/deb/zookeeper/zookeeper.preinst
@@ -32,11 +32,12 @@ set -e
case "$1" in
install|upgrade)
+ getent group zookeeper >/dev/null || groupadd -r zookeeper
if ! getent passwd zookeeper >/dev/null; then
# Adding system user: zookeeper .
adduser \
--system \
- --group \
+ --ingroup zookeeper \
--home /var/lib/zookeeper \
--gecos "ZooKeeper User" \
--shell /bin/false \
diff --git a/bigtop-packages/src/rpm/ambari/SPECS/ambari.spec b/bigtop-packages/src/rpm/ambari/SPECS/ambari.spec
index b51f9a11..24334978 100644
--- a/bigtop-packages/src/rpm/ambari/SPECS/ambari.spec
+++ b/bigtop-packages/src/rpm/ambari/SPECS/ambari.spec
@@ -37,10 +37,11 @@ Group: Development
BuildArch: noarch
Buildroot: %(mktemp -ud %{_tmppath}/apache-%{ambari_name}-%{version}-%{release}-XXXXXX)
License: ASL 2.0
-Source0: apache-%{ambari_name}-%{ambari_version}-src.tar.gz
+Source0: apache-%{ambari_name}-%{ambari_base_version}-src.tar.gz
Source1: do-component-build
Source2: install_%{ambari_name}.sh
Source3: bigtop.bom
+#BIGTOP_PATCH_FILES
# FIXME
AutoProv: no
AutoReqProv: no
@@ -51,6 +52,8 @@ Ambari
%prep
%setup -n apache-%{ambari_name}-%{ambari_base_version}-src
+#BIGTOP_PATCH_COMMANDS
+
%build
bash $RPM_SOURCE_DIR/do-component-build
diff --git a/bigtop-packages/src/rpm/hbase/SPECS/hbase.spec b/bigtop-packages/src/rpm/hbase/SPECS/hbase.spec
index d59a404b..a224b3ba 100644
--- a/bigtop-packages/src/rpm/hbase/SPECS/hbase.spec
+++ b/bigtop-packages/src/rpm/hbase/SPECS/hbase.spec
@@ -91,6 +91,7 @@ Source4: init.d.tmpl
Source5: hbase.default
Source6: hbase.nofiles.conf
Source7: regionserver-init.d.tpl
+#BIGTOP_PATCH_FILES
BuildArch: noarch
Requires: coreutils, /usr/sbin/useradd, /sbin/chkconfig, /sbin/service
Requires: hadoop-client, zookeeper >= 3.3.1, bigtop-utils >= 0.7
@@ -262,6 +263,8 @@ The Apache HBase REST gateway
%prep
%setup -n %{name}-%{hbase_base_version}
+#BIGTOP_PATCH_COMMANDS
+
%build
env HBASE_VERSION=%{version} bash %{SOURCE1}
diff --git a/bigtop-packages/src/rpm/ignite-hadoop/SPECS/ignite-hadoop.spec b/bigtop-packages/src/rpm/ignite-hadoop/SPECS/ignite-hadoop.spec
index 1d621c6b..b360b0a5 100644
--- a/bigtop-packages/src/rpm/ignite-hadoop/SPECS/ignite-hadoop.spec
+++ b/bigtop-packages/src/rpm/ignite-hadoop/SPECS/ignite-hadoop.spec
@@ -22,6 +22,7 @@
%define pids_ignite %{ignite_home}/pids
%define man_dir %{_mandir}
%define ignite_username ignite
+%define service_name %{name}-service
%define vcs_tag %{ignite_hadoop_version}
%if %{?suse_version:1}0
@@ -163,8 +164,8 @@ ln -s %{_localstatedir}/log/%{name} %{buildroot}/%{logs_ignite}
%__install -d -m 0755 %{buildroot}/%{_localstatedir}/run/%{name}
ln -s %{_localstatedir}/run/%{name} %{buildroot}/%{pids_ignite}
-init_file=$RPM_BUILD_ROOT/%{initd_dir}/%{name}
-bash %{SOURCE4} ${RPM_SOURCE_DIR}/ignite.svc rpm $init_file
+init_file=$RPM_BUILD_ROOT/%{initd_dir}/%{service_name}
+bash %{SOURCE4} ${RPM_SOURCE_DIR}/ignite-hadoop.svc rpm $init_file
chmod 755 $init_file
%__install -d -m 0755 $RPM_BUILD_ROOT/usr/bin
@@ -204,17 +205,17 @@ fi
%define service_macro() \
%files %1 \
-%attr(0755,root,root)/%{initd_dir}/%{name} \
+%attr(0755,root,root)/%{initd_dir}/%{service_name} \
%post %1 \
-chkconfig --add %{name} \
+chkconfig --add %{service_name} \
\
%preun %1 \
if [ $1 = 0 ] ; then \
- service %{name} stop > /dev/null 2>&1 \
- chkconfig --del %{name} \
+ service %{service_name} stop > /dev/null 2>&1 \
+ chkconfig --del %{service_name} \
fi \
%postun %1 \
if [ $1 -ge 1 ]; then \
- service %{name} condrestart >/dev/null 2>&1 \
+ service %{service_name} condrestart >/dev/null 2>&1 \
fi
%service_macro service
diff --git a/bigtop-packages/src/rpm/spark/SPECS/spark.spec b/bigtop-packages/src/rpm/spark/SPECS/spark.spec
index d2b07a68..24961095 100644
--- a/bigtop-packages/src/rpm/spark/SPECS/spark.spec
+++ b/bigtop-packages/src/rpm/spark/SPECS/spark.spec
@@ -24,6 +24,8 @@
%define bin /usr/bin
%define man_dir /usr/share/man
%define spark_services master worker history-server thriftserver
+%define lib_hadoop_client /usr/lib/hadoop/client
+%define lib_hadoop_yarn /usr/lib/hadoop-yarn/
%if %{?suse_version:1}0
%define doc_spark %{_docdir}/spark
@@ -54,7 +56,7 @@ Source6: init.d.tmpl
Source7: spark-history-server.svc
Source8: spark-thriftserver.svc
Source9: bigtop.bom
-Requires: bigtop-utils >= 0.7, hadoop-client
+Requires: bigtop-utils >= 0.7, hadoop-client, hadoop-yarn
Requires(preun): /sbin/service
%global initd_dir %{_sysconfdir}/init.d
@@ -157,6 +159,23 @@ bash $RPM_SOURCE_DIR/install_spark.sh \
--prefix=$RPM_BUILD_ROOT \
--doc-dir=%{doc_spark}
+%__rm -f $RPM_BUILD_ROOT/%{lib_spark}/jars/hadoop-*.jar
+%__ln_s %{lib_hadoop_client}/hadoop-annotations.jar $RPM_BUILD_ROOT/%{lib_spark}/jars/
+%__ln_s %{lib_hadoop_client}/hadoop-auth.jar $RPM_BUILD_ROOT/%{lib_spark}/jars/
+%__ln_s %{lib_hadoop_client}/hadoop-client.jar $RPM_BUILD_ROOT/%{lib_spark}/jars/
+%__ln_s %{lib_hadoop_client}/hadoop-common.jar $RPM_BUILD_ROOT/%{lib_spark}/jars/
+%__ln_s %{lib_hadoop_client}/hadoop-hdfs.jar $RPM_BUILD_ROOT/%{lib_spark}/jars/
+%__ln_s %{lib_hadoop_client}/hadoop-mapreduce-client-app.jar $RPM_BUILD_ROOT/%{lib_spark}/jars/
+%__ln_s %{lib_hadoop_client}/hadoop-mapreduce-client-common.jar $RPM_BUILD_ROOT/%{lib_spark}/jars/
+%__ln_s %{lib_hadoop_client}/hadoop-mapreduce-client-core.jar $RPM_BUILD_ROOT/%{lib_spark}/jars/
+%__ln_s %{lib_hadoop_client}/hadoop-mapreduce-client-jobclient.jar $RPM_BUILD_ROOT/%{lib_spark}/jars/
+%__ln_s %{lib_hadoop_client}/hadoop-mapreduce-client-shuffle.jar $RPM_BUILD_ROOT/%{lib_spark}/jars/
+%__ln_s %{lib_hadoop_yarn}/hadoop-yarn-api.jar $RPM_BUILD_ROOT/%{lib_spark}/jars/
+%__ln_s %{lib_hadoop_yarn}/hadoop-yarn-client.jar $RPM_BUILD_ROOT/%{lib_spark}/jars/
+%__ln_s %{lib_hadoop_yarn}/hadoop-yarn-common.jar $RPM_BUILD_ROOT/%{lib_spark}/jars/
+%__ln_s %{lib_hadoop_yarn}/hadoop-yarn-server-common.jar $RPM_BUILD_ROOT/%{lib_spark}/jars/
+%__ln_s %{lib_hadoop_yarn}/hadoop-yarn-server-web-proxy.jar $RPM_BUILD_ROOT/%{lib_spark}/jars/
+
for service in %{spark_services}
do
# Install init script
diff --git a/bigtop-packages/src/rpm/ycsb/SPECS/ycsb.spec b/bigtop-packages/src/rpm/ycsb/SPECS/ycsb.spec
index b208c36d..f89bf2e5 100644
--- a/bigtop-packages/src/rpm/ycsb/SPECS/ycsb.spec
+++ b/bigtop-packages/src/rpm/ycsb/SPECS/ycsb.spec
@@ -32,7 +32,10 @@ Source0: %{ycsb_name}-%{ycsb_base_version}.tar.gz
Source1: do-component-build
Source2: install_%{ycsb_name}.sh
Source3: bigtop.bom
-Requires: python
+## This package _explicitly_ turns off the auto-discovery of required dependencies
+## to work around OSGI corner case, added to RPM lately. See BIGTOP-2421 for more info.
+Requires: coreutils, bigtop-utils >= 0.7, python
+AutoReq: no
%description
The Yahoo! Cloud Serving Benchmark (YCSB) is an open-source
diff --git a/bigtop.bom b/bigtop.bom
index 828a9bcb..feef0d90 100644
--- a/bigtop.bom
+++ b/bigtop.bom
@@ -91,13 +91,12 @@ bigtop {
dependsOn := [list of dependents]
So, below phoenix and giraph ought to be build after the hbase has been built
- To build a component without its dependencies, simply comment out
- dependencies section or run build with -Dbuildnodeps=true
+ To build a component with its dependencies, run build with -Dbuildwithdeps=true
*/
dependencies = [
zookeeper:['hadoop', 'hbase'],
hadoop:['ignite-hadoop', 'hbase', 'crunch', 'pig', 'hive', 'tez', 'sqoop', 'sqoop2',
- 'oozie', 'mahout', 'flume', 'giraph', 'solr', 'crunch', 'spark','spark1',
+ 'oozie', 'mahout', 'flume', 'giraph', 'solr', 'spark','spark1',
'phoenix', 'alluxio', 'kafka', 'ycsb', 'kite', 'hama', 'zeppelin',
'tajo', 'apex'
],
@@ -151,7 +150,7 @@ bigtop {
'hbase' {
name = 'hbase'
relNotes = 'Apache HBase'
- version { base = '1.1.3'; pkg = base; release = 1 }
+ version { base = '1.1.9'; pkg = base; release = 1 }
tarball { destination = "${name}-${version.base}.tar.gz"
source = "${name}-${version.base}-src.tar.gz" }
url { download_path = "/$name/${version.base}/"
@@ -223,7 +222,7 @@ bigtop {
'mahout' {
name = 'mahout'
relNotes = 'Apache Mahout'
- version { base = '0.12.2'; pkg = base; release = 1 }
+ version { base = '0.13.0'; pkg = base; release = 1 }
tarball { destination = "apache-$name-distribution-${version.base}-src.tar.gz"
source = destination }
url { download_path = "/$name/${version.base}/"
@@ -305,7 +304,7 @@ bigtop {
name = 'spark'
pkg = 'spark-core'
relNotes = 'Apache Spark'
- version { base = '2.1.0'; pkg = base; release = 1 }
+ version { base = '2.1.1'; pkg = base; release = 1 }
tarball { destination = "$name-${version.base}.tar.gz"
source = "$name-${version.base}.tgz" }
url { download_path = "/$name/$name-${version.base}"
@@ -428,7 +427,7 @@ bigtop {
'zeppelin' {
name = 'zeppelin'
relNotes = 'Apache Zeppelin'
- version { base = '0.7.0'; pkg = base; release = 1 }
+ version { base = '0.7.2'; pkg = base; release = 1 }
tarball { source = "$name-${version.base}.tgz"
destination = "$name-${version.base}.tar.gz" }
url { download_path = "/$name/$name-${version.base}/"
@@ -448,7 +447,7 @@ bigtop {
'apex' {
name = 'apex'
relNotes = 'Apache Apex'
- version { base = '3.5.0'; pkg = base; release = 1 }
+ version { base = '3.6.0'; pkg = base; release = 1 }
tarball { source = "apache-$name-core-${version.base}-source-release.tar.gz"
destination = "$name-${version.base}.tar.gz" }
url { download_path = "/$name/apache-$name-core-${version.base}/"
@@ -476,7 +475,7 @@ bigtop {
'ambari' {
name = 'ambari'
relNotes = 'Apache Ambari'
- version { base = '2.5.0'; pkg = base; release = 1 }
+ version { base = '2.5.0'; pkg = '2.5.0.0'; release = 1 }
tarball { destination = "apache-$name-${version.base}-src.tar.gz"
source = destination }
url { download_path = "/$name/$name-${version.base}/"
diff --git a/bigtop_toolchain/bin/puppetize.sh b/bigtop_toolchain/bin/puppetize.sh
index a9d7798e..a5ae590b 100755
--- a/bigtop_toolchain/bin/puppetize.sh
+++ b/bigtop_toolchain/bin/puppetize.sh
@@ -55,11 +55,15 @@ case ${ID}-${VERSION_ID} in
apt-get update
apt-get -y install wget
# BIGTOP-2523. in order to install puppet 3.8 we need to get it from puppet repo
- wget -O /tmp/puppetlabs-release-trusty.deb https://apt.puppetlabs.com/puppetlabs-release-trusty.deb && dpkg -i /tmp/puppetlabs-release-trusty.deb
- rm -f /tmp/puppetlabs-release-trusty.deb
+ wget -O /tmp/puppetlabs-release-jessie.deb https://apt.puppetlabs.com/puppetlabs-release-jessie.deb && dpkg -i /tmp/puppetlabs-release-jessie.deb
+ rm -f /tmp/puppetlabs-release-jessie.deb
apt-get update
apt-get -y install curl sudo unzip puppet
;;
+ debian-9*)
+ apt-get update
+ apt-get -y install wget curl sudo unzip puppet
+ ;;
opensuse-*)
zypper --gpg-auto-import-keys install -y curl sudo unzip wget puppet suse-release ca-certificates-mozilla net-tools tar
;;
diff --git a/bigtop_toolchain/manifests/gradle.pp b/bigtop_toolchain/manifests/gradle.pp
index dcddfbe9..19be947e 100644
--- a/bigtop_toolchain/manifests/gradle.pp
+++ b/bigtop_toolchain/manifests/gradle.pp
@@ -15,7 +15,7 @@
class bigtop_toolchain::gradle {
- $gradle_version = '2.12'
+ $gradle_version = '2.14.1'
$gradle = "gradle-${gradle_version}"
exec {"/usr/bin/wget http://services.gradle.org/distributions/${gradle}-bin.zip":
diff --git a/bigtop_toolchain/manifests/jdk.pp b/bigtop_toolchain/manifests/jdk.pp
index b15539d1..8c1518b2 100644
--- a/bigtop_toolchain/manifests/jdk.pp
+++ b/bigtop_toolchain/manifests/jdk.pp
@@ -17,7 +17,9 @@ class bigtop_toolchain::jdk {
case $::operatingsystem {
/Debian/: {
require apt
- require apt::backports
+ unless $os[release][major] > "8" {
+ require apt::backports
+ }
package { 'openjdk-8-jdk' :
ensure => present,
@@ -42,6 +44,12 @@ class bigtop_toolchain::jdk {
package { 'java-1.8.0-openjdk-devel' :
ensure => present
}
+ if ($::operatingsystem == "Fedora") {
+ file { '/usr/lib/jvm/java-1.8.0-openjdk/jre/lib/security/cacerts':
+ ensure => 'link',
+ target => '/etc/pki/java/cacerts'
+ }
+ }
}
/OpenSuSE/: {
package { 'java-1_8_0-openjdk-devel' :
diff --git a/bigtop_toolchain/manifests/packages.pp b/bigtop_toolchain/manifests/packages.pp
index 64bc12b4..6101e357 100644
--- a/bigtop_toolchain/manifests/packages.pp
+++ b/bigtop_toolchain/manifests/packages.pp
@@ -132,7 +132,7 @@ class bigtop_toolchain::packages {
require => [Package['libapr1']]
}
}
- Amazon: { $pkgs = [
+ /Amazon/: { $pkgs = [
"unzip",
"curl",
"wget",
@@ -157,7 +157,14 @@ class bigtop_toolchain::packages {
"bzip2-devel",
"libffi-devel"
] }
- /(Ubuntu|Debian)/: { $pkgs = [
+ /(Ubuntu|Debian)/: {
+ # Debian-9 is using mariadb instead of mysql
+ if ($operatingsystem == "Debian") and ($os[release][major] > "8") {
+ $mysql_dev="libmariadb-dev"
+ } else {
+ $mysql_dev="libmysqlclient-dev"
+ }
+ $pkgs = [
"unzip",
"curl",
"wget",
@@ -192,7 +199,7 @@ class bigtop_toolchain::packages {
"libsqlite3-dev",
"libldap2-dev",
"libsasl2-dev",
- "libmysqlclient-dev",
+ $mysql_dev,
"python-setuptools",
"libkrb5-dev",
"asciidoc",
@@ -202,8 +209,7 @@ class bigtop_toolchain::packages {
"libboost-regex-dev",
"xfslibs-dev",
"libbz2-dev",
- "libreadline6",
- "libreadline6-dev",
+ "libreadline-dev",
"zlib1g",
"libapr1",
"libapr1-dev",
diff --git a/bigtop_toolchain/manifests/puppet-modules.pp b/bigtop_toolchain/manifests/puppet-modules.pp
index 3fab254f..38ecca26 100644
--- a/bigtop_toolchain/manifests/puppet-modules.pp
+++ b/bigtop_toolchain/manifests/puppet-modules.pp
@@ -23,9 +23,14 @@ class bigtop_toolchain::puppet-modules {
case $operatingsystem{
/Ubuntu|Debian/: {
+ if versioncmp($::puppetversion, '4') < 0 {
+ $version = '--version 2.4.0'
+ } else {
+ $version = ''
+ }
exec { 'install-puppet-apt':
path => '/usr/bin:/bin',
- command => 'puppet module install puppetlabs-apt',
+ command => "puppet module install puppetlabs-apt ${version}",
creates => '/etc/puppet/modules/apt',
}
}
diff --git a/build.gradle b/build.gradle
index 8857d7c5..7cf6b142 100644
--- a/build.gradle
+++ b/build.gradle
@@ -23,7 +23,7 @@ buildscript {
}
plugins {
- id "de.undercouch.download" version "2.0.0"
+ id "de.undercouch.download" version "3.2.0"
id "org.nosphere.apache.rat" version "0.2.0"
}
@@ -226,7 +226,7 @@ task toolchain(type:Exec,
description: 'Setup dev. env via toolchain; Requires: Puppet, sudo',
group: DEVENV_GROUP) {
def command = [
- 'sudo', 'puppet', 'apply', '-d',
+ 'sudo', 'puppet', 'apply', '-d', '--parser', 'future',
"--modulepath=${projectDir.absolutePath}:/etc/puppet/modules", '-e',
'include bigtop_toolchain::installer'
]
diff --git a/buildSrc/src/main/groovy/org/apache/bigtop/NullOutputStream.groovy b/buildSrc/src/main/groovy/org/apache/bigtop/NullOutputStream.groovy
deleted file mode 100644
index 0d673bbc..00000000
--- a/buildSrc/src/main/groovy/org/apache/bigtop/NullOutputStream.groovy
+++ /dev/null
@@ -1,27 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-package org.apache.bigtop
-
-import java.io.OutputStream
-import java.io.IOException
-
-public class NullOutputStream extends OutputStream {
- @Override
- public void write(int b) throws IOException {
- }
-}
diff --git a/buildSrc/src/test/groovy/org/apache/bigtop/TestNullOutputStream.groovy b/buildSrc/src/test/groovy/org/apache/bigtop/TestNullOutputStream.groovy
deleted file mode 100644
index 1e90d5f8..00000000
--- a/buildSrc/src/test/groovy/org/apache/bigtop/TestNullOutputStream.groovy
+++ /dev/null
@@ -1,29 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-package org.apache.bigtop
-
-import org.junit.Assert
-import org.junit.Test
-
-class TestNullOutputStream {
-
- @Test
- void testDevNull () {
- new Properties().store(new NullOutputStream(), "stuff");
- }
-}
diff --git a/docker/bigtop-deploy/centos-6/Dockerfile b/docker/bigtop-deploy/centos-6/Dockerfile
deleted file mode 100644
index cb1b6bb7..00000000
--- a/docker/bigtop-deploy/centos-6/Dockerfile
+++ /dev/null
@@ -1,28 +0,0 @@
-# Licensed to the Apache Software Foundation (ASF) under one or more
-# contributor license agreements. See the NOTICE file distributed with
-# this work for additional information regarding copyright ownership.
-# The ASF licenses this file to You under the Apache License, Version 2.0
-# (the "License"); you may not use this file except in compliance with
-# the License. You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-
-FROM bigtop/puppet:centos-6
-
-# enable ssh
-RUN yum -y install openssh-server openssh-clients vim && \
- # requiretty off
- sed -i.bak 's/requiretty/!requiretty/' /etc/sudoers && \
- # setup vagrant account
- mkdir /root/.ssh && \
- chmod 0700 /root/.ssh && \
- wget http://github.com/mitchellh/vagrant/raw/master/keys/vagrant.pub --no-check-certificate -O /root/.ssh/authorized_keys && \
- chmod 0600 /root/.ssh/authorized_keys
-
-CMD /sbin/init
diff --git a/docker/bigtop-deploy/centos-6/build.sh b/docker/bigtop-deploy/centos-6/build.sh
deleted file mode 100755
index fd32dbfd..00000000
--- a/docker/bigtop-deploy/centos-6/build.sh
+++ /dev/null
@@ -1,18 +0,0 @@
-# Licensed to the Apache Software Foundation (ASF) under one or more
-# contributor license agreements. See the NOTICE file distributed with
-# this work for additional information regarding copyright ownership.
-# The ASF licenses this file to You under the Apache License, Version 2.0
-# (the "License"); you may not use this file except in compliance with
-# the License. You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-
-docker build -t bigtop/deploy:centos-6 .
-ret=$?
-exit $ret
diff --git a/docker/bigtop-deploy/centos-7/Dockerfile b/docker/bigtop-deploy/centos-7/Dockerfile
deleted file mode 100644
index 22460764..00000000
--- a/docker/bigtop-deploy/centos-7/Dockerfile
+++ /dev/null
@@ -1,28 +0,0 @@
-# Licensed to the Apache Software Foundation (ASF) under one or more
-# contributor license agreements. See the NOTICE file distributed with
-# this work for additional information regarding copyright ownership.
-# The ASF licenses this file to You under the Apache License, Version 2.0
-# (the "License"); you may not use this file except in compliance with
-# the License. You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-
-FROM bigtop/puppet:centos-7
-
-# enable ssh
-RUN yum -y install openssh-server openssh-clients deltarpm vim && \
- # requiretty off
- sed -i.bak 's/requiretty/!requiretty/' /etc/sudoers && \
- # setup vagrant account
- mkdir /root/.ssh && \
- chmod 0700 /root/.ssh && \
- wget http://github.com/mitchellh/vagrant/raw/master/keys/vagrant.pub --no-check-certificate -O /root/.ssh/authorized_keys && \
- chmod 0600 /root/.ssh/authorized_keys
-
-CMD /sbin/init
diff --git a/docker/bigtop-deploy/debian-8/Dockerfile b/docker/bigtop-deploy/debian-8/Dockerfile
deleted file mode 100644
index 74bb1f5c..00000000
--- a/docker/bigtop-deploy/debian-8/Dockerfile
+++ /dev/null
@@ -1,34 +0,0 @@
-# Licensed to the Apache Software Foundation (ASF) under one or more
-# contributor license agreements. See the NOTICE file distributed with
-# this work for additional information regarding copyright ownership.
-# The ASF licenses this file to You under the Apache License, Version 2.0
-# (the "License"); you may not use this file except in compliance with
-# the License. You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-
-FROM bigtop/puppet:debian-8
-
-# enable ssh
-RUN apt-get update && \
- apt-get install -y openssh-server vim dbus && \
- # requiretty off
- sed -i.bak 's/requiretty/!requiretty/' /etc/sudoers && \
- # setup vagrant account
- mkdir -p /root/.ssh && \
- chmod 0700 /root/.ssh && \
- wget http://github.com/mitchellh/vagrant/raw/master/keys/vagrant.pub --no-check-certificate -O /root/.ssh/authorized_keys && \
- chmod 0600 /root/.ssh/authorized_keys && \
- sed -i -e "s,^PermitRootLogin.*,PermitRootLogin without-password," \
- /etc/ssh/sshd_config
-# fix systemd
-RUN rm /lib/systemd/system/getty-static.service /lib/systemd/system/console-getty.service && \
- systemctl disable getty@tty1.service
-
-CMD /sbin/init
diff --git a/docker/bigtop-deploy/ubuntu-14.04/build.sh b/docker/bigtop-puppet/debian-9/Dockerfile
index eec1d03b..26a4095d 100755..100644
--- a/docker/bigtop-deploy/ubuntu-14.04/build.sh
+++ b/docker/bigtop-puppet/debian-9/Dockerfile
@@ -12,7 +12,9 @@
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
+FROM debian:9
+MAINTAINER dev@bigtop.apache.org
-docker build -t bigtop/deploy:ubuntu-14.04 .
-ret=$?
-exit $ret
+COPY puppetize.sh /tmp/puppetize.sh
+
+RUN bash /tmp/puppetize.sh
diff --git a/docker/bigtop-deploy/debian-8/build.sh b/docker/bigtop-puppet/debian-9/build.sh
index 72fef3c9..cdc4623b 100755
--- a/docker/bigtop-deploy/debian-8/build.sh
+++ b/docker/bigtop-puppet/debian-9/build.sh
@@ -12,7 +12,5 @@
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
-
-docker build -t bigtop/deploy:debian-8 .
-ret=$?
-exit $ret
+cp ../../../bigtop_toolchain/bin/puppetize.sh .
+docker build --pull=true -t bigtop/puppet:debian-9 .
diff --git a/docker/bigtop-deploy/centos-7/build.sh b/docker/bigtop-slaves/debian-9/Dockerfile
index 89bae88d..69229d14 100755..100644
--- a/docker/bigtop-deploy/centos-7/build.sh
+++ b/docker/bigtop-slaves/debian-9/Dockerfile
@@ -12,9 +12,12 @@
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
+FROM bigtop/puppet:debian-9
+MAINTAINER dev@bigtop.apache.org
-cp -r ../../../bigtop_toolchain .
-docker build -t bigtop/deploy:centos-7 .
-ret=$?
-rm -rf bigtop_toolchain
-exit $ret
+COPY bigtop_toolchain /usr/share/puppet/modules/bigtop_toolchain
+
+RUN apt-get clean && apt-get update && puppet apply -e "include bigtop_toolchain::installer"
+
+COPY . /tmp/bigtop
+RUN cd /tmp/bigtop && ./gradlew && cd && rm -rf /tmp/bigtop
diff --git a/docker/pseudo-cluster/config/hieradata/site.yaml b/docker/pseudo-cluster/config/hieradata/site.yaml
index 3e9ebc4d..eb338406 100644
--- a/docker/pseudo-cluster/config/hieradata/site.yaml
+++ b/docker/pseudo-cluster/config/hieradata/site.yaml
@@ -7,5 +7,4 @@ hadoop_cluster_node::cluster_components:
- yarn
- mapreduce
bigtop::bigtop_repo_uri: http://bigtop-repos.s3.amazonaws.com/releases/1.2.0/ubuntu/16.04/x86_64
-bigtop::jdk_package_name: openjdk-8-jdk
diff --git a/docker/sandbox/README.md b/docker/sandbox/README.md
index 711903cc..d7a61059 100644
--- a/docker/sandbox/README.md
+++ b/docker/sandbox/README.md
@@ -19,52 +19,56 @@ A tool to build and run big data pseudo cluster using Docker.
## How to run
-* Make sure you have Docker installed. We've tested this using [Docker for Mac](https://docs.docker.com/docker-for-mac/)
+Make sure you have Docker installed. We've tested this using [Docker for Mac](https://docs.docker.com/docker-for-mac/)
-* Currently supported OS list:
+Currently supported OS list:
* centos-6
* debian-8
- * ubuntu-14.04
+ * ubuntu-16.04
-* Running Hadoop
+### Run Hadoop HDFS
```
-docker run -ti --privileged -p 50070:50070 bigtop/sandbox:centos-6_hadoop
+docker run -d -p 50070:50070 bigtop/sandbox:centos-6_hdfs
```
-* Running Spark (Standalone mode)
+### Run Spark on YARN
```
-docker run -ti --privileged -p 8080:8080 bigtop/sandbox:debian-8_spark
+docker run -d -p 50070:50070 -p 8088:8088 -p 8080:8080 bigtop/sandbox:debian-8_hdfs_yarn_spark
```
-* Running Hadoop + HBase
+### Run Hadoop HDFS + HBase
```
-docker run -ti --privileged -p 50070:50070 -p 60010:60010 bigtop/sandbox:ubuntu-14.04_hbase
+docker run -d -p 50070:50070 -p 60010:60010 bigtop/sandbox:ubuntu-16.04_hdfs_hbase
```
## How to build
-### Examples
+### Build a Hadoop HDFS sandbox image
-* Build sandbox image that has Hadoop provisioned
+```
+./build.sh -a bigtop -o centos-6 -c hdfs
+```
+
+### Build a Hadoop HDFS, Hadoop YARN, and Spark on YARN sandbox image
```
-./build.sh -a bigtop -o debian-8 -c hadoop
+./build.sh -a bigtop -o debian-8 -c "hdfs, yarn, spark"
```
-* Build sandbox image that has Hadoop and Spark provisioned
+### Build a Hadoop HDFS and HBase sandbox image
```
-./build.sh -a bigtop -o debian-8 -c "hadoop, spark"
+./build.sh -a bigtop -o ubuntu-16.04 -c "hdfs, hbase"
```
-* Build sandbox image that has Hadoop and HBase provisioned
+### Use --dryrun to skip the build and get Dockerfile and configuration
```
-./build.sh -a bigtop -o debian-8 -c "hadoop, yarn, hbase"
+./build.sh -a bigtop -o ubuntu-16.04 -c "hdfs, hbase" --dryrun
```
### Change the repository of packages
@@ -73,10 +77,10 @@ docker run -ti --privileged -p 50070:50070 -p 60010:60010 bigtop/sandbox:ubuntu-
```
export REPO=http://ci.bigtop.apache.org:8080/job/Bigtop-trunk-repos/BUILD_ENVIRONMENTS=centos-6%2Clabel=docker-slave-06//ws/output
-./build.sh -a bigtop -o centos-6 -c "hadoop, spark, ignite"
+./build.sh -a bigtop -o centos-6 -c "hdfs, yarn, spark, ignite"
```
-### Customize your Hadoop stack
+### Customize your Big Data Stack
* Edit *site.yaml.template.centos-6_hadoop* to create your own prefered stack
@@ -89,7 +93,7 @@ vim site.yaml.template.centos-6_hadoop_ignite
```
...
-hadoop_cluster_node::cluster_components: [hadoop, yarn, ignite]
+hadoop_cluster_node::cluster_components: [hdfs, yarn, ignite]
...
```
diff --git a/docker/sandbox/build.sh b/docker/sandbox/build.sh
index 8936fd06..8910f93f 100755
--- a/docker/sandbox/build.sh
+++ b/docker/sandbox/build.sh
@@ -41,7 +41,6 @@ bigtop::hadoop_head_node: ${HEAD_NODE:-"head.node.fqdn"}
hadoop::hadoop_storage_dirs: [/data/1, /data/2]
bigtop::bigtop_repo_uri: ${REPO}
hadoop_cluster_node::cluster_components: [${COMPONENTS}]
-bigtop::jdk_package_name: ${JDK}
EOF
}
@@ -64,18 +63,9 @@ generate_tag() {
fi
}
-detect_jdk() {
- for RPM in ${RPMS[*]}; do
- [[ $OS == $RPM ]] && JDK=$RPM_JDK
- done
- for DEB in ${DEBS[*]}; do
- [[ $OS == $DEB ]] && JDK=$DEB_JDK
- done
-}
-
detect_repo() {
- OS_WITH_CODE_NAME=${OS/ubuntu-14.04/ubuntu-trusty}
- REPO=${REPO:-"http://bigtop-repos.s3.amazonaws.com/releases/${BIGTOP_VERSION}/${OS_WITH_CODE_NAME/-//}/x86_64"}
+ OS_SEP_BY_SLASH=${OS/-//}
+ REPO=${REPO:-"http://bigtop-repos.s3.amazonaws.com/releases/${BIGTOP_VERSION}/${OS_SEP_BY_SLASH}/x86_64"}
}
image_config_validator() {
@@ -103,10 +93,6 @@ deploy_config_validator() {
echo "repository unset!"
invalid=0
fi
- if [ -z "$JDK" ]; then
- echo "jdk unset!"
- invalid=0
- fi
if [ -z "$COMPONENTS" ]; then
echo "components unset!"
invalid=0
@@ -131,16 +117,20 @@ show_deploy_configs() {
echo "DEPLOY CONFIGS:"
echo "REPOSITORY $REPO"
echo "COMPONENTS $COMPONENTS"
- echo "JDK $JDK"
echo "-------------------------------------------------"
}
+log() {
+ echo -e "\n[LOG] $1\n"
+}
+
usage() {
echo "usage: $PROG args"
echo " -a, --account Specify account name for image."
echo " -c, --components Specify components to build."
echo " You need to specify a comma separated, quoted string."
echo " For example: --components \"hadoop, yarn\""
+ echo " -d, --dryrun Generate the Dockerfile and configuration and skip the build."
echo " -f, --file Specify a written site.yaml config file."
echo " -o, --operating-system Specify an OS from Bigtop supported OS list."
echo " RPM base: ${RPMS[*]}"
@@ -158,6 +148,9 @@ while [ $# -gt 0 ]; do
fi
ACCOUNT=$2
shift 2;;
+ -d|--dryrun)
+ DRYRUN=true
+ shift;;
-c|--components)
if [ $# -lt 2 ]; then
usage
@@ -194,7 +187,6 @@ image_config_validator
show_image_configs
if [ -z "$FILE" ]; then
- detect_jdk
detect_repo
deploy_config_validator
generate_config
@@ -203,7 +195,7 @@ else
if [ -f "$FILE" ]; then
cp -vfr $FILE site.yaml.template
else
- echo "$FILE not exist!"
+ log "$FILE not exist!"
exit 1
fi
fi
@@ -211,5 +203,10 @@ fi
export ACCOUNT
export TAG
generate_dockerfile
+if [ "$DRYRUN" == true ]; then
+ log "Generated Dockerfile:"
+ cat Dockerfile
+ exit 0
+fi
build
cleanup
diff --git a/docker/sandbox/sandbox-env.sh b/docker/sandbox/sandbox-env.sh
index f6caeef1..e1599d52 100644
--- a/docker/sandbox/sandbox-env.sh
+++ b/docker/sandbox/sandbox-env.sh
@@ -15,10 +15,16 @@
# See the License for the specific language governing permissions and
# limitations under the License.
-RPMS=(centos-6 centos-7 fedora-20)
-DEBS=(debian-8 ubuntu-14.04)
-
-RPM_JDK=java-1.8.0-openjdk-devel.x86_64
-DEB_JDK=openjdk-8-jdk
-
BIGTOP_VERSION=1.2.0
+# REPO="YOUR CUSTOM REPO"
+
+RPMS=( \
+ centos-6 \
+ centos-7 \
+ fedora-25 \
+ opensuse-42.1 \
+)
+DEBS=( \
+ debian-8 \
+ ubuntu-16.04 \
+)
diff --git a/docker/sandbox/site.yaml.template.centos-6_hadoop b/docker/sandbox/site.yaml.template.centos-6_hadoop
index 4fd74979..db49e484 100644
--- a/docker/sandbox/site.yaml.template.centos-6_hadoop
+++ b/docker/sandbox/site.yaml.template.centos-6_hadoop
@@ -16,5 +16,4 @@
bigtop::hadoop_head_node: "head.node.fqdn"
hadoop::hadoop_storage_dirs: [/data/1, /data/2]
bigtop::bigtop_repo_uri: http://bigtop-repos.s3.amazonaws.com/releases/1.2.0/centos/6/x86_64
-hadoop_cluster_node::cluster_components: [hdfs, yarn, mapreduce]
-bigtop::jdk_package_name: java-1.8.0-openjdk-devel.x86_64
+hadoop_cluster_node::cluster_components: [hdfs, yarn, mapred-app]
diff --git a/docker/sandbox/site.yaml.template.debian-8_hadoop b/docker/sandbox/site.yaml.template.debian-8_hadoop
index d87146b2..1bbae6c6 100644
--- a/docker/sandbox/site.yaml.template.debian-8_hadoop
+++ b/docker/sandbox/site.yaml.template.debian-8_hadoop
@@ -16,5 +16,4 @@
bigtop::hadoop_head_node: "head.node.fqdn"
hadoop::hadoop_storage_dirs: [/data/1, /data/2]
bigtop::bigtop_repo_uri: http://bigtop-repos.s3.amazonaws.com/releases/1.2.0/debian/8/x86_64
-hadoop_cluster_node::cluster_components: [hdfs, yarn, mapreduce]
-bigtop::jdk_package_name: openjdk-8-jdk
+hadoop_cluster_node::cluster_components: [hdfs, yarn, mapred-app]
diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties
index e44ba6c5..2fd41c7d 100644
--- a/gradle/wrapper/gradle-wrapper.properties
+++ b/gradle/wrapper/gradle-wrapper.properties
@@ -17,4 +17,4 @@ distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
-distributionUrl=https\://services.gradle.org/distributions/gradle-2.12-bin.zip
+distributionUrl=https\://services.gradle.org/distributions/gradle-2.14.1-bin.zip
diff --git a/packages.gradle b/packages.gradle
index 8576ab12..e93e94f0 100644
--- a/packages.gradle
+++ b/packages.gradle
@@ -89,8 +89,11 @@ def setDefaults = { comp ->
comp.version.pkg = comp.version.base
}
}
+def devNull = new OutputStream() {
+ @Override
+ public void write(int b) {}
+}
def nativePackaging = {
- def devNull = new org.apache.bigtop.NullOutputStream()
def result = exec {
commandLine "/bin/bash", "-c",
"""dpkg-query -S /bin/sh && exit 1
@@ -182,8 +185,6 @@ def genTasks = { target ->
def final GIT_USER_NAME = config.bigtop.components[target].git.user ?: config.bigtop.git.user
def final GIT_ACCESS_TOKEN = config.bigtop.components[target].git.token ?: config.bigtop.git.token
- def devNull = new org.apache.bigtop.NullOutputStream()
-
if (!DOWNLOAD_URL)
return
diff --git a/pom.xml b/pom.xml
index 3bb9ef93..5301f920 100644
--- a/pom.xml
+++ b/pom.xml
@@ -40,8 +40,7 @@
<properties>
<hadoop.version>2.7.3</hadoop.version>
- <!--An awful hack for BIGTOP-1429-->
- <hbase.version>1.1.3</hbase.version>
+ <hbase.version>1.1.9</hbase.version>
<pig.version>0.15.0</pig.version>
<pig-smoke.version>0.15.0</pig-smoke.version>
<sqoop.version>1.4.6</sqoop.version>
diff --git a/provisioner/docker/config.yaml b/provisioner/docker/config.yaml
index 776a8f1f..19fef164 120000
--- a/provisioner/docker/config.yaml
+++ b/provisioner/docker/config.yaml
@@ -1 +1 @@
-config_centos7.yaml \ No newline at end of file
+config_centos-7.yaml \ No newline at end of file
diff --git a/provisioner/docker/config/hiera.yaml b/provisioner/docker/config/hiera.yaml
deleted file mode 100644
index 8b137891..00000000
--- a/provisioner/docker/config/hiera.yaml
+++ /dev/null
@@ -1 +0,0 @@
-
diff --git a/provisioner/docker/config/hieradata/PLACEHOLDER b/provisioner/docker/config/hieradata/PLACEHOLDER
deleted file mode 100644
index e69de29b..00000000
--- a/provisioner/docker/config/hieradata/PLACEHOLDER
+++ /dev/null
diff --git a/provisioner/docker/config/hosts b/provisioner/docker/config/hosts
deleted file mode 100644
index 8b137891..00000000
--- a/provisioner/docker/config/hosts
+++ /dev/null
@@ -1 +0,0 @@
-
diff --git a/provisioner/docker/config_centos6.yaml b/provisioner/docker/config_centos-6.yaml
index 459f8a2a..7912aca6 100644
--- a/provisioner/docker/config_centos6.yaml
+++ b/provisioner/docker/config_centos-6.yaml
@@ -22,4 +22,3 @@ distro: centos
components: [hdfs, yarn, mapreduce]
enable_local_repo: false
smoke_test_components: [hdfs, yarn, mapreduce]
-jdk: "java-1.8.0-openjdk-devel.x86_64"
diff --git a/provisioner/docker/config_centos7.yaml b/provisioner/docker/config_centos-7.yaml
index 6e3c28b3..6cdd7cfc 100644
--- a/provisioner/docker/config_centos7.yaml
+++ b/provisioner/docker/config_centos-7.yaml
@@ -22,4 +22,3 @@ distro: centos
components: [hdfs, yarn, mapreduce]
enable_local_repo: false
smoke_test_components: [hdfs, yarn, mapreduce]
-jdk: "java-1.8.0-openjdk-devel.x86_64"
diff --git a/provisioner/docker/config_debian8.yaml b/provisioner/docker/config_debian-8.yaml
index 10915e50..c1a468a4 100644
--- a/provisioner/docker/config_debian8.yaml
+++ b/provisioner/docker/config_debian-8.yaml
@@ -22,4 +22,3 @@ distro: debian
components: [hdfs, yarn, mapreduce]
enable_local_repo: false
smoke_test_components: [hdfs, yarn, mapreduce]
-jdk: "openjdk-8-jdk"
diff --git a/provisioner/docker/config_ubuntu_xenial.yaml b/provisioner/docker/config_ubuntu-16.04.yaml
index 8f8cb878..54c91f77 100644
--- a/provisioner/docker/config_ubuntu_xenial.yaml
+++ b/provisioner/docker/config_ubuntu-16.04.yaml
@@ -22,4 +22,3 @@ distro: debian
components: [hdfs, yarn, mapreduce]
enable_local_repo: false
smoke_test_components: [hdfs, yarn, mapreduce]
-jdk: "openjdk-8-jdk"
diff --git a/provisioner/docker/docker-hadoop.sh b/provisioner/docker/docker-hadoop.sh
index 12488a13..2783a1fb 100755
--- a/provisioner/docker/docker-hadoop.sh
+++ b/provisioner/docker/docker-hadoop.sh
@@ -34,7 +34,7 @@ usage() {
create() {
if [ -e .provision_id ]; then
- echo "Cluster already exist! Run ./$PROG -d to destroy the cluster or delete .provision_id file and containers manually."
+ log "Cluster already exist! Run ./$PROG -d to destroy the cluster or delete .provision_id file and containers manually."
exit 1;
fi
echo "`date +'%Y%m%d_%H%M%S'`_R$RANDOM" > .provision_id
@@ -49,7 +49,7 @@ create() {
# Startup instances
docker-compose -p $PROVISION_ID scale bigtop=$1
if [ $? -ne 0 ]; then
- echo "Docker container(s) startup failed!";
+ log "Docker container(s) startup failed!";
exit 1;
fi
@@ -60,10 +60,9 @@ create() {
# Fetch configurations form specificed yaml config file
repo=$(get-yaml-config repo)
components="[`echo $(get-yaml-config components) | sed 's/ /, /g'`]"
- jdk=$(get-yaml-config jdk)
distro=$(get-yaml-config distro)
enable_local_repo=$(get-yaml-config enable_local_repo)
- generate-config "$hadoop_head_node" "$repo" "$components" "$jdk"
+ generate-config "$hadoop_head_node" "$repo" "$components"
# Start provisioning
generate-hosts
@@ -78,11 +77,11 @@ generate-hosts() {
done
wait
# This must be the last entry in the /etc/hosts
- echo "127.0.0.1 localhost" >> ./config/hosts
+ docker exec ${NODES[0]} bash -c "echo '127.0.0.1 localhost' >> ./etc/hosts"
}
generate-config() {
- echo "Bigtop Puppet configurations are shared between instances, and can be modified under config/hieradata"
+ log "Bigtop Puppet configurations are shared between instances, and can be modified under config/hieradata"
cat $BIGTOP_PUPPET_DIR/hiera.yaml >> ./config/hiera.yaml
cp -vfr $BIGTOP_PUPPET_DIR/hieradata ./config/
cat > ./config/hieradata/site.yaml << EOF
@@ -90,7 +89,6 @@ bigtop::hadoop_head_node: $1
hadoop::hadoop_storage_dirs: [/data/1, /data/2]
bigtop::bigtop_repo_uri: $2
hadoop_cluster_node::cluster_components: $3
-bigtop::jdk_package_name: $4
EOF
}
@@ -122,13 +120,12 @@ smoke-tests() {
}
destroy() {
+ docker exec ${NODES[0]} bash -c "umount /etc/hosts; rm -f /etc/hosts"
if [ -n "$PROVISION_ID" ]; then
docker-compose -p $PROVISION_ID stop
docker-compose -p $PROVISION_ID rm -f
fi
- echo > ./config/hiera.yaml
- echo > ./config/hosts
- rm -rvf ./config/hieradata/bigtop ./config/hieradata/site.yaml .provision_id
+ rm -rvf ./config .provision_id
}
bigtop-puppet() {
@@ -180,6 +177,10 @@ list() {
echo "$msg"
}
+log() {
+ echo -e "\n[LOG] $1\n"
+}
+
PROG=`basename $0`
if [ $# -eq 0 ]; then
diff --git a/provisioner/vagrant/Vagrantfile b/provisioner/vagrant/Vagrantfile
index fc6bfc19..ae099631 100755
--- a/provisioner/vagrant/Vagrantfile
+++ b/provisioner/vagrant/Vagrantfile
@@ -59,9 +59,6 @@ smoke_test_components = CONF['smoke_test_components'].join(',')
enable_local_repo = CONF['enable_local_repo']
puts "vagrant conf local repo enabled: #{enable_local_repo}"
-# JDK package name
-jdk = CONF['jdk']
-
# master node hostname
bigtop_master = "bigtop1.vagrant"
@@ -86,7 +83,6 @@ bigtop::hadoop_head_node: #{bigtop_master}
hadoop::hadoop_storage_dirs: [/data/1, /data/2]
bigtop::bigtop_repo_uri: #{repo}
hadoop_cluster_node::cluster_components: #{components}
-bigtop::jdk_package_name: #{jdk}
hadoop::common_hdfs::testonly_hdfs_sshkeys: "yes"
EOF
SCRIPT
diff --git a/provisioner/vagrant/vagrantconfig.yaml b/provisioner/vagrant/vagrantconfig.yaml
index 4fbb4e44..54604b01 100644
--- a/provisioner/vagrant/vagrantconfig.yaml
+++ b/provisioner/vagrant/vagrantconfig.yaml
@@ -23,4 +23,3 @@ components: [hdfs, yarn, mapreduce]
enable_local_repo: false
run_smoke_tests: false
smoke_test_components: [hdfs, yarn, mapreduce]
-jdk: "java-1.8.0-openjdk-devel.x86_64"