mirror of
				https://github.com/datahub-project/datahub.git
				synced 2025-10-31 18:59:23 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			58 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
| # Using as a base image because to get the needed jars for confluent utils
 | |
| FROM confluentinc/cp-base-new:6.1.4 as confluent_base
 | |
| 
 | |
| # Based on https://github.com/blacktop's alpine kafka build
 | |
| FROM python:3-alpine
 | |
| 
 | |
| ENV KAFKA_VERSION 2.8.1
 | |
| ENV SCALA_VERSION 2.13
 | |
| 
 | |
| # Set the classpath for JARs required by `cub`
 | |
| ENV CUB_CLASSPATH='"/usr/share/java/cp-base-new/*"'
 | |
| 
 | |
| # Confluent Docker Utils Version (Namely the tag or branch to grab from git to install)
 | |
| ARG PYTHON_CONFLUENT_DOCKER_UTILS_VERSION="v0.0.49"
 | |
| 
 | |
| # This can be overriden for an offline/air-gapped builds
 | |
| ARG PYTHON_CONFLUENT_DOCKER_UTILS_INSTALL_SPEC="git+https://github.com/confluentinc/confluent-docker-utils@${PYTHON_CONFLUENT_DOCKER_UTILS_VERSION}"
 | |
| 
 | |
| LABEL name="kafka" version=${KAFKA_VERSION}
 | |
| 
 | |
| RUN apk add --no-cache openjdk8-jre bash coreutils
 | |
| RUN apk add --no-cache -t .build-deps git curl ca-certificates jq gcc musl-dev libffi-dev zip
 | |
| RUN mkdir -p /opt \
 | |
|   && mirror=$(curl --stderr /dev/null https://www.apache.org/dyn/closer.cgi\?as_json\=1 | jq -r '.preferred') \
 | |
|   && curl -sSL "${mirror}kafka/${KAFKA_VERSION}/kafka_${SCALA_VERSION}-${KAFKA_VERSION}.tgz" \
 | |
|   | tar -xzf - -C /opt \
 | |
|   && mv /opt/kafka_${SCALA_VERSION}-${KAFKA_VERSION} /opt/kafka \
 | |
|   && adduser -DH -s /sbin/nologin kafka \
 | |
|   && chown -R kafka: /opt/kafka \
 | |
|   && echo "===> Installing python packages ..."  \
 | |
|   && pip install --no-cache-dir jinja2 requests \
 | |
|   && pip install --prefer-binary --prefix=/usr/local --upgrade "${PYTHON_CONFLUENT_DOCKER_UTILS_INSTALL_SPEC}" \
 | |
|   && echo "===> Applying log4j log4shell fix based on https://www.slf4j.org/log4shell.html ..." \
 | |
|   && zip -d /opt/kafka/libs/log4j-1.2.17.jar org/apache/log4j/net/JMSAppender.class \
 | |
|   && rm -rf /tmp/* \
 | |
|   && apk del --purge .build-deps
 | |
| 
 | |
| ENV PATH /sbin:/opt/kafka/bin/:$PATH
 | |
| 
 | |
| WORKDIR /opt/kafka
 | |
| 
 | |
| RUN ls -la
 | |
| COPY --from=confluent_base /usr/share/java/cp-base-new/ /usr/share/java/cp-base-new/
 | |
| 
 | |
| ENV METADATA_AUDIT_EVENT_NAME="MetadataAuditEvent_v4"
 | |
| ENV METADATA_CHANGE_EVENT_NAME="MetadataChangeEvent_v4"
 | |
| ENV FAILED_METADATA_CHANGE_EVENT_NAME="FailedMetadataChangeEvent_v4"
 | |
| ENV DATAHUB_USAGE_EVENT_NAME="DataHubUsageEvent_v1"
 | |
| ENV METADATA_CHANGE_LOG_VERSIONED_TOPIC="MetadataChangeLog_Versioned_v1"
 | |
| ENV METADATA_CHANGE_LOG_TIMESERIES_TOPIC="MetadataChangeLog_Timeseries_v1"
 | |
| ENV METADATA_CHANGE_PROPOSAL_TOPIC="MetadataChangeProposal_v1"
 | |
| ENV FAILED_METADATA_CHANGE_PROPOSAL_TOPIC="FailedMetadataChangeProposal_v1"
 | |
| ENV PLATFORM_EVENT_TOPIC_NAME="PlatformEvent_v1"
 | |
| 
 | |
| COPY ./kafka-setup.sh ./kafka-setup.sh
 | |
| 
 | |
| CMD ./kafka-setup.sh
 | 
