Skip to content

Commit

Permalink
feat: remove restrictions on pg17 (#283)
Browse files Browse the repository at this point in the history
Upgrades alpine for pg17 to 3.21 since 3.20 is missing some packages
like postgresql17-plpython3. Keeping old versions on 3.20 to ensure
maximum backwards compatibility.
  • Loading branch information
cevian authored Dec 11, 2024
1 parent 64d5655 commit a896f94
Show file tree
Hide file tree
Showing 2 changed files with 40 additions and 35 deletions.
41 changes: 20 additions & 21 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
ARG PG_VERSION
ARG PREV_IMAGE
ARG TS_VERSION
ARG ALPINE_VERSION
############################
# Build tools binaries in separate image
############################
Expand All @@ -27,38 +28,36 @@ RUN rm -f $(pg_config --sharedir)/extension/timescaledb*mock*.sql
# Now build image and copy in tools
############################
ARG PG_VERSION
FROM postgres:${PG_VERSION}-alpine3.20
ARG ALPINE_VERSION
FROM postgres:${PG_VERSION}-alpine${ALPINE_VERSION}
ARG OSS_ONLY

LABEL maintainer="Timescale https://www.timescale.com"


ARG PG_VERSION
RUN set -ex; \
if [ "$PG_VERSION" -lt 17 ]; then \
apk update; \
apk add --no-cache \
postgresql${PG_VERSION}-plpython3; \
fi
apk update; \
apk add --no-cache \
postgresql${PG_VERSION}-plpython3;

ARG PGVECTOR_VERSION
ARG PG_VERSION
ARG CLANG_VERSION
RUN set -ex; \
if [ "$PG_VERSION" -lt 17 ]; then \
apk update; \
apk add --no-cache --virtual .vector-deps \
postgresql${PG_VERSION}-dev \
git \
build-base \
clang15 \
llvm15-dev \
llvm15; \
git clone --branch ${PGVECTOR_VERSION} https://github.com/pgvector/pgvector.git /build/pgvector; \
cd /build/pgvector; \
make; \
make install; \
apk del .vector-deps; \
fi
apk update; \
apk add --no-cache --virtual .vector-deps \
postgresql${PG_VERSION}-dev \
git \
build-base \
clang${CLANG_VERSION} \
llvm${CLANG_VERSION}-dev \
llvm${CLANG_VERSION}; \
git clone --branch ${PGVECTOR_VERSION} https://github.com/pgvector/pgvector.git /build/pgvector; \
cd /build/pgvector; \
make; \
make install; \
apk del .vector-deps;

# install pgai only on pg16+ and not on 32 bit arm
ARG PGAI_VERSION
Expand Down
34 changes: 20 additions & 14 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,13 @@ ORG=timescaledev
PG_VER=pg16
PG_VER_NUMBER=$(shell echo $(PG_VER) | cut -c3-)
PG_MAJOR_VERSION=$(shell echo $(PG_VER_NUMBER) | cut -d. -f1)
ifeq ($(shell test $(PG_MAJOR_VERSION) -ge 17; echo $$?),0)
ALPINE_VERSION=3.21
CLANG_VERSION=19
else
ALPINE_VERSION=3.20
CLANG_VERSION=15
endif
TS_VERSION=main
PREV_TS_VERSION=$(shell wget --quiet -O - https://raw.githubusercontent.com/timescale/timescaledb/${TS_VERSION}/version.config | grep update_from_version | sed -e 's!update_from_version = !!')
PREV_TS_IMAGE="timescale/timescaledb:$(PREV_TS_VERSION)-pg$(PG_VER_NUMBER)$(PREV_EXTRA)"
Expand All @@ -23,6 +30,15 @@ TAG_OSS=-t $(TAG_VERSION)-oss $(if $(BETA),,-t $(TAG_LATEST)-oss)
PGVECTOR_VERSION=v0.7.2
PGAI_VERSION=extension-0.6.0

COMMON_BUILD_ARGS= --build-arg TS_VERSION=$(TS_VERSION) \
--build-arg PREV_IMAGE=$(PREV_IMAGE) \
--build-arg PG_VERSION=$(PG_VER_NUMBER) \
--build-arg PG_MAJOR_VERSION=$(PG_MAJOR_VERSION) \
--build-arg ALPINE_VERSION=$(ALPINE_VERSION) \
--build-arg CLANG_VERSION=$(CLANG_VERSION) \
--build-arg PGVECTOR_VERSION=$(PGVECTOR_VERSION) \
--build-arg PGAI_VERSION=$(PGAI_VERSION)

default: image

.multi_$(TS_VERSION)_$(PG_VER)_oss: Dockerfile
Expand All @@ -31,13 +47,8 @@ default: image
docker buildx create --platform $(PLATFORM) --name multibuild --use
docker buildx inspect multibuild --bootstrap
docker buildx build --platform $(PLATFORM) \
--build-arg TS_VERSION=$(TS_VERSION) \
--build-arg PG_VERSION=$(PG_VER_NUMBER) \
--build-arg PG_MAJOR_VERSION=$(PG_MAJOR_VERSION) \
--build-arg PREV_IMAGE=$(PREV_IMAGE) \
$(COMMON_BUILD_ARGS) \
--build-arg OSS_ONLY=" -DAPACHE_ONLY=1" \
--build-arg PGVECTOR_VERSION=$(PGVECTOR_VERSION) \
--build-arg PGAI_VERSION=$(PGAI_VERSION) \
$(TAG_OSS) $(PUSH_MULTI) .
touch .multi_$(TS_VERSION)_$(PG_VER)_oss
docker buildx rm multibuild
Expand All @@ -49,22 +60,17 @@ default: image
docker buildx create --platform $(PLATFORM) --name multibuild --use
docker buildx inspect multibuild --bootstrap
docker buildx build --platform $(PLATFORM) \
--build-arg TS_VERSION=$(TS_VERSION) \
--build-arg PREV_IMAGE=$(PREV_IMAGE) \
--build-arg PG_VERSION=$(PG_VER_NUMBER) \
--build-arg PG_MAJOR_VERSION=$(PG_MAJOR_VERSION) \
--build-arg PGVECTOR_VERSION=$(PGVECTOR_VERSION) \
--build-arg PGAI_VERSION=$(PGAI_VERSION) \
$(COMMON_BUILD_ARGS) \
$(TAG) $(PUSH_MULTI) .
touch .multi_$(TS_VERSION)_$(PG_VER)
docker buildx rm multibuild

.build_$(TS_VERSION)_$(PG_VER)_oss: Dockerfile
docker build --build-arg OSS_ONLY=" -DAPACHE_ONLY=1" --build-arg PG_VERSION=$(PG_VER_NUMBER) --build-arg PG_MAJOR_VERSION=$(PG_MAJOR_VERSION) --build-arg PGVECTOR_VERSION=$(PGVECTOR_VERSION) --build-arg PGAI_VERSION=$(PGAI_VERSION) $(TAG_OSS) .
docker build $(COMMON_BUILD_ARGS) --build-arg OSS_ONLY=" -DAPACHE_ONLY=1" $(TAG_OSS) .
touch .build_$(TS_VERSION)_$(PG_VER)_oss

.build_$(TS_VERSION)_$(PG_VER): Dockerfile
docker build --build-arg PG_VERSION=$(PG_VER_NUMBER) --build-arg PG_MAJOR_VERSION=$(PG_MAJOR_VERSION) --build-arg TS_VERSION=$(TS_VERSION) --build-arg PREV_IMAGE=$(PREV_IMAGE) --build-arg PGVECTOR_VERSION=$(PGVECTOR_VERSION) --build-arg PGAI_VERSION=$(PGAI_VERSION) $(TAG) .
docker build $(COMMON_BUILD_ARGS) $(TAG) .
touch .build_$(TS_VERSION)_$(PG_VER)

image: .build_$(TS_VERSION)_$(PG_VER)
Expand Down

0 comments on commit a896f94

Please sign in to comment.