Skip to content

Commit

Permalink
feat: Initial commit
Browse files Browse the repository at this point in the history
  • Loading branch information
gabe565 committed Apr 23, 2024
0 parents commit c685a32
Show file tree
Hide file tree
Showing 7 changed files with 174 additions and 0 deletions.
1 change: 1 addition & 0 deletions .dockerignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
**
1 change: 1 addition & 0 deletions .github/CODEOWNERS
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
* @clevyr/devops
81 changes: 81 additions & 0 deletions .github/workflows/build.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
name: Build

on: push

env:
# renovate datasource=github-releases depName=timescale/timescaledb
TIMESCALEDB_VERSION: 2.14.2

jobs:
build:
name: Build Image (pg${{ matrix.postgres_version }})
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
strategy:
matrix:
include:
- postgres_version: "16"
# renovate datasource=docker depName=ghcr.io/cloudnative-pg/postgresql
cnpg_version: 16.2-7
latest: "true"
- postgres_version: "15"
# renovate datasource=docker depName=ghcr.io/cloudnative-pg/postgresql
cnpg_version: 15.6-6
- postgres_version: "14"
# renovate datasource=docker depName=ghcr.io/cloudnative-pg/postgresql
cnpg_version: 14.11-6
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Get CloudNativePG version
id: cnpg
env:
VERSION: ${{ matrix.cnpg_version }}
run: |
{
echo "version=$VERSION"
echo "minor=$(cut -d- -f1 <<<"$VERSION")"
echo "major=$(cut -d. -f1 <<<"$VERSION")"
} >> $GITHUB_OUTPUT
- name: Docker meta
id: meta
uses: docker/metadata-action@v5
with:
images: |
ghcr.io/${{ github.repository_owner }}/cloudnativepg-timescaledb
flavor: latest=false
tags: |
type=raw,priority=1000,value=latest,enable=${{ matrix.latest || 'false' }}
type=raw,priority=999,value=${{ steps.cnpg.outputs.version }}-vectors${{ steps.vectors.outputs.version }}
type=raw,priority=998,value=${{ steps.cnpg.outputs.minor }}-vectors${{ steps.vectors.outputs.version }}
type=raw,priority=997,value=${{ steps.cnpg.outputs.major }}-vectors${{ steps.vectors.outputs.version }}
type=raw,priority=996,value=${{ steps.cnpg.outputs.version }}
type=raw,priority=995,value=${{ steps.cnpg.outputs.minor }}
type=raw,priority=994,value=${{ steps.cnpg.outputs.major }}
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Buildx
uses: docker/setup-buildx-action@v3
- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ github.token }}
- name: Build and Push
uses: docker/build-push-action@v5
with:
context: .
pull: true
push: ${{ github.ref_name == 'main' }}
platforms: linux/amd64,linux/arm64/v8
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
build-args: |
POSTGRES_VERSION=${{ matrix.postgres_version }}
CLOUDNATIVEPG_VERSION=${{ steps.cnpg.outputs.version }}
TIMESCALEDB_VERSION=${{ env.TIMESCALEDB_VERSION }}
cache-from: type=gha
cache-to: type=gha,mode=max
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
.DS_Store
.idea/
32 changes: 32 additions & 0 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
#syntax=docker/dockerfile:1.7

ARG CLOUDNATIVEPG_VERSION

FROM ghcr.io/cloudnative-pg/postgresql:$CLOUDNATIVEPG_VERSION
USER root

ARG POSTGRES_VERSION
ARG TIMESCALEDB_VERSION
RUN <<EOT
set -eux

# Install dependencies
apt-get update
apt-get install -y --no-install-recommends curl

# Add Timescale apt repo
. /etc/os-release 2>/dev/null
echo "deb https://packagecloud.io/timescale/timescaledb/debian/ $VERSION_CODENAME main" >/etc/apt/sources.list.d/timescaledb.list
curl -Lsf https://packagecloud.io/timescale/timescaledb/gpgkey | gpg --dearmor >/etc/apt/trusted.gpg.d/timescale.gpg

# Install Timescale
apt-get update
apt-get install -y --no-install-recommends "timescaledb-2-postgresql-$POSTGRES_VERSION=$TIMESCALEDB_VERSION~debian$VERSION_ID"

# Cleanup
apt-get purge -y curl
rm /etc/apt/sources.list.d/timescaledb.list /etc/apt/trusted.gpg.d/timescale.gpg
rm -rf /var/cache/apt/*
EOT

USER 26
29 changes: 29 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
# CloudNativePG Container with TimescaleDB

[![Build](https://github.com/clevyr/docker-cloudnativepg-timescaledb/actions/workflows/build.yaml/badge.svg)](https://github.com/clevyr/docker-cloudnativepg-timescaledb/actions/workflows/build.yaml)

This repo builds Docker images for [CloudNativePG](https://cloudnative-pg.io/) with the [TimescaleDB](https://timescale.com) extension installed.

Both versions are automatically updated by Renovate bot, so new releases will be available within a few hours.

## Images

Images are available at [`ghcr.io/clevyr/cloudnativepg-timescaledb`](https://github.com/clevyr/docker-cloudnativepg-timescaledb/pkgs/container/cloudnativepg-vecto-rs). There are tags available for Postgres v14, v15, and v16.

## Deployment

Set `.spec.imageName` in the `Cluster` to use one of the container images provided by this repository.

For example:
```yaml
apiVersion: postgresql.cnpg.io/v1
kind: Cluster
metadata:
name: example
spec:
instances: 3
imageName: ghcr.io/clevyr/cloudnativepg-timescaledb:16
postgresql:
shared_preload_libraries:
- timescaledb
```
28 changes: 28 additions & 0 deletions renovate.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
{
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
"extends": [
"local>gabe565/renovate-config",
":automergeAll"
],
"regexManagers": [
{
"fileMatch": ["\\.ya?ml$"],
"matchStrings": [
"# ?renovate datasource=(?<datasource>.+?) depName=(?<depName>.+)\\n.+: [\"']?(?<currentValue>.+?)[\"']?\\n"
]
},
{
"fileMatch": ["README.md"],
"matchStrings": [
"<!--renovate datasource=(?<datasource>.+?) repo=(?<depName>.+) -->\\n.*\\/Version-(?<currentValue>.+?)-"
]
}
],
"packageRules": [
{
"matchDepNames": ["ghcr.io/cloudnative-pg/postgresql"],
"matchUpdateTypes": ["major"],
"enabled": false
}
]
}

0 comments on commit c685a32

Please sign in to comment.