mirror of
				https://github.com/datahub-project/datahub.git
				synced 2025-10-31 02:37:05 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			27 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
			
		
		
	
	
			27 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
| # This "container" is a workaround to pre-create search indices
 | |
| 
 | |
| # Defining environment
 | |
| ARG APP_ENV=prod
 | |
| 
 | |
| FROM alpine:3 as base
 | |
| ENV DOCKERIZE_VERSION v0.6.1
 | |
| RUN apk add --no-cache curl jq tar bash coreutils \
 | |
|     && curl -L https://github.com/jwilder/dockerize/releases/download/$DOCKERIZE_VERSION/dockerize-linux-amd64-$DOCKERIZE_VERSION.tar.gz | tar -C /usr/local/bin -xzv
 | |
| 
 | |
| FROM base AS prod-install
 | |
| 
 | |
| COPY docker/elasticsearch-setup/create-indices.sh /
 | |
| RUN chmod 755 create-indices.sh
 | |
| COPY metadata-service/restli-servlet-impl/src/main/resources/index /index
 | |
| 
 | |
| FROM base AS dev-install
 | |
| # Dummy stage for development. Use local files for setup
 | |
| # See this excellent thread https://github.com/docker/cli/issues/1134
 | |
| 
 | |
| FROM ${APP_ENV}-install AS final
 | |
| CMD if [ "$ELASTICSEARCH_USE_SSL" == "true" ]; then ELASTICSEARCH_PROTOCOL=https; else ELASTICSEARCH_PROTOCOL=http; fi \
 | |
|     && if [[ -n "$ELASTICSEARCH_USERNAME" ]]; then ELASTICSEARCH_HTTP_HEADERS="Authorization: Basic $(echo -ne "$ELASTICSEARCH_USERNAME:$ELASTICSEARCH_PASSWORD" | base64)"; else ELASTICSEARCH_HTTP_HEADERS="Accept: */*"; fi \
 | |
|     && if [[ "$SKIP_ELASTICSEARCH_CHECK" != "true" ]]; then \
 | |
|         dockerize -wait $ELASTICSEARCH_PROTOCOL://$ELASTICSEARCH_HOST:$ELASTICSEARCH_PORT -wait-http-header "${ELASTICSEARCH_HTTP_HEADERS}" -timeout 120s /create-indices.sh; \
 | |
|     else /create-indices.sh; fi
 | 
