From 0245b4b25908eab4f29c3436fab9a7cf6ca59527 Mon Sep 17 00:00:00 2001 From: Bryan Sullivan Date: Thu, 14 Dec 2017 21:41:31 -0800 Subject: Containerize kafka server JIRA: VES-2 Change-Id: Idc2db4b99de7d2757a7907f3170e58ae9a38f8b5 Signed-off-by: Bryan Sullivan --- build/ves-kafka/Dockerfile | 44 ++++++++++++++++++++++++++++++++++++++++++++ build/ves-kafka/start.sh | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 76 insertions(+) create mode 100644 build/ves-kafka/Dockerfile create mode 100644 build/ves-kafka/start.sh (limited to 'build/ves-kafka') diff --git a/build/ves-kafka/Dockerfile b/build/ves-kafka/Dockerfile new file mode 100644 index 0000000..c2acc8a --- /dev/null +++ b/build/ves-kafka/Dockerfile @@ -0,0 +1,44 @@ +# Copyright 2017 AT&T Intellectual Property, Inc +# +# 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. +# +# What this is: A Dockerfile for building a kafka server for use by the OPFNV +# VES framework. +# +# Status: this is a work in progress, under test. +# + +FROM ubuntu:xenial + +MAINTAINER Bryan Sullivan + +RUN apt-get update +RUN apt-get install -y apt-utils +RUN apt-get upgrade -y +RUN apt-get update +# Required for kafka +RUN apt-get install -y default-jre +RUN apt-get install -y python-pip +RUN pip install kafka-python +RUN apt-get install -y wget + +RUN mkdir /opt/ves + +RUN cd /opt/ves; \ +wget http://www-eu.apache.org/dist/kafka/0.11.0.2/kafka_2.11-0.11.0.2.tgz; \ +tar -xvzf kafka_2.11-0.11.0.2.tgz; \ +sed -i -- 's/#delete.topic.enable=true/delete.topic.enable=true/' \ + kafka_2.11-0.11.0.2/config/server.properties + +COPY start.sh /opt/ves/start.sh +ENTRYPOINT ["/bin/bash", "/opt/ves/start.sh"] diff --git a/build/ves-kafka/start.sh b/build/ves-kafka/start.sh new file mode 100644 index 0000000..ab4169b --- /dev/null +++ b/build/ves-kafka/start.sh @@ -0,0 +1,32 @@ +#!/bin/bash +# Copyright 2017 AT&T Intellectual Property, Inc +# +# 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. +# +#. What this is: Startup script for a kafka server as used by the OPNFV VES +#. framework. + +echo "$zookeeper $zookeeper_host" >>/etc/hosts +cat /etc/hosts +cd /opt/ves + +sed -i "s/localhost:2181/$zookeeper_host:2181/" \ + kafka_2.11-0.11.0.2/config/server.properties +grep 2181 kafka_2.11-0.11.0.2/config/server.properties +sed -i "s~#advertised.listeners=PLAINTEXT://your.host.name:9092~advertised.listeners=PLAINTEXT://$kafka_hostname:9092~" \ + kafka_2.11-0.11.0.2/config/server.properties +grep advertised.listeners kafka_2.11-0.11.0.2/config/server.properties + +kafka_2.11-0.11.0.2/bin/kafka-server-start.sh \ + kafka_2.11-0.11.0.2/config/server.properties + -- cgit