| 
									
										
										
										
											2024-10-22 10:14:25 -05:00
										 |  |  | ARG KAFKA_DOCKER_VERSION=7.7.1
 | 
					
						
							| 
									
										
										
										
											2023-08-22 01:08:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-28 21:52:11 +01:00
										 |  |  | # Defining custom repo urls for use in enterprise environments. Re-used between stages below.
 | 
					
						
							|  |  |  | ARG ALPINE_REPO_URL=http://dl-cdn.alpinelinux.org/alpine
 | 
					
						
							|  |  |  | ARG GITHUB_REPO_URL=https://github.com
 | 
					
						
							|  |  |  | ARG MAVEN_CENTRAL_REPO_URL=https://repo1.maven.org/maven2
 | 
					
						
							|  |  |  | ARG APACHE_DOWNLOAD_URL=null | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-14 14:23:11 +05:30
										 |  |  | # Using AS a base image because to get the needed jars for confluent utils
 | 
					
						
							|  |  |  | FROM confluentinc/cp-base-new:$KAFKA_DOCKER_VERSION AS confluent_base
 | 
					
						
							| 
									
										
										
										
											2023-02-20 00:02:05 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-28 21:52:11 +01:00
										 |  |  | ARG MAVEN_CENTRAL_REPO_URL
 | 
					
						
							| 
									
										
										
										
											2023-04-11 16:17:21 -04:00
										 |  |  | ARG SNAKEYAML_VERSION="2.0"
 | 
					
						
							| 
									
										
										
										
											2023-02-20 00:02:05 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  | RUN rm /usr/share/java/cp-base-new/snakeyaml-*.jar \
 | 
					
						
							| 
									
										
										
										
											2023-11-28 21:52:11 +01:00
										 |  |  |   && wget -P /usr/share/java/cp-base-new $MAVEN_CENTRAL_REPO_URL/org/yaml/snakeyaml/$SNAKEYAML_VERSION/snakeyaml-$SNAKEYAML_VERSION.jar
 | 
					
						
							| 
									
										
										
										
											2022-01-29 01:25:57 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | # Based on https://github.com/blacktop's alpine kafka build
 | 
					
						
							| 
									
										
										
										
											2022-12-26 10:09:08 -06:00
										 |  |  | FROM python:3-alpine
 | 
					
						
							| 
									
										
										
										
											2022-01-29 01:25:57 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-28 21:52:11 +01:00
										 |  |  | ARG ALPINE_REPO_URL
 | 
					
						
							|  |  |  | ARG APACHE_DOWNLOAD_URL
 | 
					
						
							|  |  |  | ARG GITHUB_REPO_URL
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-16 21:28:48 +05:30
										 |  |  | ENV KAFKA_VERSION=3.7.2
 | 
					
						
							| 
									
										
										
										
											2024-08-14 14:23:11 +05:30
										 |  |  | ENV SCALA_VERSION=2.13
 | 
					
						
							| 
									
										
										
										
											2022-01-29 01:25:57 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | LABEL name="kafka" version=${KAFKA_VERSION}
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-28 21:52:11 +01:00
										 |  |  | # Optionally set corporate mirror for apk
 | 
					
						
							|  |  |  | RUN if [ "${ALPINE_REPO_URL}" != "http://dl-cdn.alpinelinux.org/alpine" ] ; then sed -i "s#http.*://dl-cdn.alpinelinux.org/alpine#${ALPINE_REPO_URL}#g" /etc/apk/repositories ; fi
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 18:44:28 +01:00
										 |  |  | RUN apk add --no-cache bash coreutils
 | 
					
						
							| 
									
										
										
										
											2023-12-15 13:28:33 -06:00
										 |  |  | RUN apk --no-cache add openjdk17-jre-headless --repository=${ALPINE_REPO_URL}/edge/community
 | 
					
						
							| 
									
										
										
										
											2022-09-08 18:44:28 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-29 01:25:57 +01:00
										 |  |  | RUN apk add --no-cache -t .build-deps git curl ca-certificates jq gcc musl-dev libffi-dev zip
 | 
					
						
							|  |  |  | RUN mkdir -p /opt \
 | 
					
						
							| 
									
										
										
										
											2023-11-28 21:52:11 +01:00
										 |  |  |   && if [ "${APACHE_DOWNLOAD_URL}" != "null" ] ; then mirror="${APACHE_DOWNLOAD_URL}/" ; else mirror=$(curl --stderr /dev/null https://www.apache.org/dyn/closer.cgi\?as_json\=1 | jq -r '.preferred'); fi \
 | 
					
						
							| 
									
										
										
										
											2022-01-29 01:25:57 +01:00
										 |  |  |   && 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 \
 | 
					
						
							|  |  |  |   && rm -rf /tmp/* \
 | 
					
						
							|  |  |  |   && apk del --purge .build-deps
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-14 14:23:11 +05:30
										 |  |  | ENV PATH=/sbin:/opt/kafka/bin/:$PATH
 | 
					
						
							| 
									
										
										
										
											2022-01-29 01:25:57 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | WORKDIR /opt/kafka
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | RUN ls -la
 | 
					
						
							|  |  |  | COPY --from=confluent_base /usr/share/java/cp-base-new/ /usr/share/java/cp-base-new/
 | 
					
						
							| 
									
										
										
										
											2023-02-20 00:02:05 -06:00
										 |  |  | COPY --from=confluent_base /etc/cp-base-new/log4j.properties /etc/cp-base-new/log4j.properties
 | 
					
						
							| 
									
										
										
										
											2020-06-08 13:37:14 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-15 15:02:54 -07:00
										 |  |  | ADD --chown=kafka:kafka ${GITHUB_REPO_URL}/aws/aws-msk-iam-auth/releases/download/v2.0.3/aws-msk-iam-auth-2.0.3-all.jar /usr/share/java/cp-base-new
 | 
					
						
							|  |  |  | ADD --chown=kafka:kafka ${GITHUB_REPO_URL}/aws/aws-msk-iam-auth/releases/download/v2.0.3/aws-msk-iam-auth-2.0.3-all.jar /opt/kafka/libs
 | 
					
						
							| 
									
										
										
										
											2022-11-22 16:37:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-14 19:07:50 -07:00
										 |  |  | ENV METADATA_AUDIT_EVENT_NAME="MetadataAuditEvent_v4"
 | 
					
						
							|  |  |  | ENV METADATA_CHANGE_EVENT_NAME="MetadataChangeEvent_v4"
 | 
					
						
							|  |  |  | ENV FAILED_METADATA_CHANGE_EVENT_NAME="FailedMetadataChangeEvent_v4"
 | 
					
						
							| 
									
										
										
										
											2021-05-11 15:41:42 -07:00
										 |  |  | ENV DATAHUB_USAGE_EVENT_NAME="DataHubUsageEvent_v1"
 | 
					
						
							| 
									
										
										
										
											2023-01-24 18:48:23 +00:00
										 |  |  | ENV METADATA_CHANGE_LOG_VERSIONED_TOPIC_NAME="MetadataChangeLog_Versioned_v1"
 | 
					
						
							|  |  |  | ENV METADATA_CHANGE_LOG_TIMESERIES_TOPIC_NAME="MetadataChangeLog_Timeseries_v1"
 | 
					
						
							|  |  |  | ENV METADATA_CHANGE_PROPOSAL_TOPIC_NAME="MetadataChangeProposal_v1"
 | 
					
						
							|  |  |  | ENV FAILED_METADATA_CHANGE_PROPOSAL_TOPIC_NAME="FailedMetadataChangeProposal_v1"
 | 
					
						
							| 
									
										
										
										
											2022-04-19 15:22:49 -07:00
										 |  |  | ENV PLATFORM_EVENT_TOPIC_NAME="PlatformEvent_v1"
 | 
					
						
							| 
									
										
										
										
											2023-02-03 07:09:19 -06:00
										 |  |  | ENV DATAHUB_UPGRADE_HISTORY_TOPIC_NAME="DataHubUpgradeHistory_v1"
 | 
					
						
							| 
									
										
										
										
											2023-05-01 13:18:41 -05:00
										 |  |  | ENV USE_CONFLUENT_SCHEMA_REGISTRY="TRUE"
 | 
					
						
							| 
									
										
										
										
											2021-04-13 07:58:31 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-26 10:09:08 -06:00
										 |  |  | COPY docker/kafka-setup/kafka-setup.sh ./kafka-setup.sh
 | 
					
						
							| 
									
										
										
										
											2023-01-09 12:27:00 +00:00
										 |  |  | COPY docker/kafka-setup/kafka-config.sh ./kafka-config.sh
 | 
					
						
							|  |  |  | COPY docker/kafka-setup/kafka-topic-workers.sh ./kafka-topic-workers.sh
 | 
					
						
							| 
									
										
										
										
											2023-08-22 01:08:08 -04:00
										 |  |  | COPY docker/kafka-setup/kafka-ready.sh ./kafka-ready.sh
 | 
					
						
							| 
									
										
										
										
											2024-08-15 17:20:45 -05:00
										 |  |  | COPY docker/kafka-setup/env_to_properties.py ./env_to_properties.py
 | 
					
						
							| 
									
										
										
										
											2023-01-09 12:27:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-22 01:08:08 -04:00
										 |  |  | RUN chmod +x ./kafka-setup.sh ./kafka-topic-workers.sh ./kafka-ready.sh
 | 
					
						
							| 
									
										
										
										
											2021-04-16 18:40:39 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | CMD ./kafka-setup.sh
 |