mirror of
https://github.com/wallabag/docker.git
synced 2026-02-28 04:37:34 +01:00
Compare commits
22 Commits
a2ed3534e1
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
| 1e28e25500 | |||
| bfb9e7dc40 | |||
| b133e9559d | |||
| b0b760a765 | |||
| 480d3833bc | |||
| 42981284a6 | |||
| 91a399d3bb | |||
| ccb4b25562 | |||
| c8b95ac15b | |||
| 25a2e3de71 | |||
| b522c24645 | |||
| 2ed6cbca1c | |||
| 9dd6c5b52b | |||
| 0e11114336 | |||
| 6379d9b90f | |||
| e1fafcc31f | |||
| 7d2f4919c6 | |||
| 096ea7f79c | |||
| 2c1ec84dc7 | |||
| 488814d187 | |||
| 3808b524fc | |||
| 923dffae55 |
2
.github/workflows/publish.yml
vendored
2
.github/workflows/publish.yml
vendored
@ -13,7 +13,7 @@ jobs:
|
|||||||
contents: read
|
contents: read
|
||||||
steps:
|
steps:
|
||||||
- name: Check out the repo
|
- name: Check out the repo
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v6
|
||||||
|
|
||||||
- name: Log in to Docker Hub
|
- name: Log in to Docker Hub
|
||||||
uses: docker/login-action@v3
|
uses: docker/login-action@v3
|
||||||
|
|||||||
5
.github/workflows/test.yml
vendored
5
.github/workflows/test.yml
vendored
@ -21,16 +21,15 @@ jobs:
|
|||||||
- "sqlite"
|
- "sqlite"
|
||||||
- "mariadb"
|
- "mariadb"
|
||||||
- "postgresql"
|
- "postgresql"
|
||||||
- "postgresql-secret"
|
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: "Checkout"
|
- name: "Checkout"
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v6
|
||||||
with:
|
with:
|
||||||
fetch-depth: 2
|
fetch-depth: 2
|
||||||
|
|
||||||
- name: Set up Python
|
- name: Set up Python
|
||||||
uses: actions/setup-python@v5
|
uses: actions/setup-python@v6
|
||||||
with:
|
with:
|
||||||
python-version: 3.11
|
python-version: 3.11
|
||||||
|
|
||||||
|
|||||||
76
Dockerfile
76
Dockerfile
@ -1,19 +1,19 @@
|
|||||||
ARG COMPOSER_VERSION=2.5.8
|
ARG COMPOSER_VERSION=2.2
|
||||||
|
|
||||||
FROM composer:$COMPOSER_VERSION as composer
|
FROM composer:$COMPOSER_VERSION AS composer
|
||||||
|
|
||||||
FROM golang:alpine as builder
|
FROM golang:alpine AS builder
|
||||||
|
|
||||||
# envsubst from gettext can not replace env vars with default values
|
# envsubst from gettext can not replace env vars with default values
|
||||||
# this package is not available for ARM32 and we have to build it from source code
|
# this package is not available for ARM32 and we have to build it from source code
|
||||||
# flag -ldflags "-s -w" produces a smaller executable
|
# flag -ldflags "-s -w" produces a smaller executable
|
||||||
RUN go install -ldflags "-s -w" -v github.com/a8m/envsubst/cmd/envsubst@v1.3.0
|
RUN go install -ldflags "-s -w" -v github.com/a8m/envsubst/cmd/envsubst@v1.4.3
|
||||||
|
|
||||||
FROM alpine:3.18
|
FROM alpine:3.22
|
||||||
|
|
||||||
COPY --from=builder /go/bin/envsubst /usr/bin/envsubst
|
COPY --from=builder /go/bin/envsubst /usr/bin/envsubst
|
||||||
|
|
||||||
ARG WALLABAG_VERSION=2.6.12
|
ARG WALLABAG_VERSION=2.6.14
|
||||||
|
|
||||||
RUN set -ex \
|
RUN set -ex \
|
||||||
&& apk add --no-cache \
|
&& apk add --no-cache \
|
||||||
@ -21,43 +21,43 @@ RUN set -ex \
|
|||||||
libwebp \
|
libwebp \
|
||||||
nginx \
|
nginx \
|
||||||
pcre \
|
pcre \
|
||||||
php81 \
|
php84 \
|
||||||
php81-bcmath \
|
php84-bcmath \
|
||||||
php81-ctype \
|
php84-ctype \
|
||||||
php81-curl \
|
php84-curl \
|
||||||
php81-dom \
|
php84-dom \
|
||||||
php81-fpm \
|
php84-fpm \
|
||||||
php81-gd \
|
php84-gd \
|
||||||
php81-gettext \
|
php84-gettext \
|
||||||
php81-iconv \
|
php84-iconv \
|
||||||
php81-json \
|
php84-json \
|
||||||
php81-mbstring \
|
php84-mbstring \
|
||||||
php81-opcache \
|
php84-opcache \
|
||||||
php81-openssl \
|
php84-openssl \
|
||||||
php81-pecl-amqp \
|
php84-pecl-amqp \
|
||||||
php81-pecl-imagick \
|
php84-pecl-imagick \
|
||||||
php81-pdo_mysql \
|
php84-pdo_mysql \
|
||||||
php81-pdo_pgsql \
|
php84-pdo_pgsql \
|
||||||
php81-pdo_sqlite \
|
php84-pdo_sqlite \
|
||||||
php81-phar \
|
php84-phar \
|
||||||
php81-session \
|
php84-session \
|
||||||
php81-simplexml \
|
php84-simplexml \
|
||||||
php81-tokenizer \
|
php84-tokenizer \
|
||||||
php81-xml \
|
php84-xml \
|
||||||
php81-zlib \
|
php84-zlib \
|
||||||
php81-sockets \
|
php84-sockets \
|
||||||
php81-xmlreader \
|
php84-xmlreader \
|
||||||
php81-tidy \
|
php84-tidy \
|
||||||
php81-intl \
|
php84-intl \
|
||||||
php81-sodium \
|
php84-sodium \
|
||||||
mariadb-client \
|
mariadb-client \
|
||||||
postgresql14-client \
|
postgresql17-client \
|
||||||
rabbitmq-c \
|
rabbitmq-c \
|
||||||
s6 \
|
s6 \
|
||||||
tar \
|
tar \
|
||||||
tzdata \
|
tzdata \
|
||||||
&& ln -sf /usr/bin/php81 /usr/bin/php \
|
&& ln -sf /usr/bin/php84 /usr/bin/php \
|
||||||
&& ln -sf /usr/sbin/php-fpm81 /usr/sbin/php-fpm \
|
&& ln -sf /usr/sbin/php-fpm84 /usr/sbin/php-fpm \
|
||||||
&& rm -rf /var/cache/apk/* \
|
&& rm -rf /var/cache/apk/* \
|
||||||
&& ln -sf /dev/stdout /var/log/nginx/access.log \
|
&& ln -sf /dev/stdout /var/log/nginx/access.log \
|
||||||
&& ln -sf /dev/stderr /var/log/nginx/error.log
|
&& ln -sf /dev/stderr /var/log/nginx/error.log
|
||||||
|
|||||||
@ -43,8 +43,6 @@ Default login is `wallabag:wallabag`.
|
|||||||
- `-e SYMFONY__ENV__SERVER_NAME=...` (defaults to "Your wallabag instance". Specifies a user-friendly name for the 2FA issuer)
|
- `-e SYMFONY__ENV__SERVER_NAME=...` (defaults to "Your wallabag instance". Specifies a user-friendly name for the 2FA issuer)
|
||||||
- `-e PHP_MEMORY_LIMIT=...` (allows you to change the PHP `memory_limit` value. defaults to 128M, and should be a number and unit, eg. 512K, 128M, 2G, or a number of bytes)
|
- `-e PHP_MEMORY_LIMIT=...` (allows you to change the PHP `memory_limit` value. defaults to 128M, and should be a number and unit, eg. 512K, 128M, 2G, or a number of bytes)
|
||||||
|
|
||||||
To set any of these environment variables from a file (for instance a Docker Secret), append `__FILE` to the name of the environment variable.
|
|
||||||
|
|
||||||
## SQLite
|
## SQLite
|
||||||
|
|
||||||
The easiest way to start wallabag is to use the SQLite backend. You can spin that up with
|
The easiest way to start wallabag is to use the SQLite backend. You can spin that up with
|
||||||
@ -144,7 +142,7 @@ services:
|
|||||||
volumes:
|
volumes:
|
||||||
- /opt/wallabag/data:/var/lib/mysql
|
- /opt/wallabag/data:/var/lib/mysql
|
||||||
healthcheck:
|
healthcheck:
|
||||||
test: ["CMD", "mysqladmin" ,"ping", "-h", "localhost"]
|
test: ["CMD", "/usr/local/bin/healthcheck.sh", "--innodb_initialized"]
|
||||||
interval: 20s
|
interval: 20s
|
||||||
timeout: 3s
|
timeout: 3s
|
||||||
redis:
|
redis:
|
||||||
|
|||||||
@ -2,16 +2,6 @@
|
|||||||
# Exit when any command fails
|
# Exit when any command fails
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
FILE_ENV_VARS="$(env | grep '__FILE=')"
|
|
||||||
for env_var in $FILE_ENV_VARS; do
|
|
||||||
var_name="$(echo $env_var | grep -o '.*__FILE=' | sed 's/__FILE=//g')"
|
|
||||||
file_path="$(echo $env_var | grep -o '__FILE=.*' | sed 's/__FILE=//g')"
|
|
||||||
file_content="$(cat $file_path)"
|
|
||||||
[[ ! $? -eq 0 ]] && exit 1 # Exit if last command failed
|
|
||||||
new_var="$(echo $var_name=$file_content)"
|
|
||||||
export $(echo $new_var | xargs)
|
|
||||||
done
|
|
||||||
|
|
||||||
COMMAND_ARG1="$1"
|
COMMAND_ARG1="$1"
|
||||||
COMMAND_ARG2="$2"
|
COMMAND_ARG2="$2"
|
||||||
|
|
||||||
@ -38,7 +28,7 @@ provisioner() {
|
|||||||
|
|
||||||
# Replace environment variables
|
# Replace environment variables
|
||||||
envsubst < /etc/wallabag/parameters.template.yml > app/config/parameters.yml
|
envsubst < /etc/wallabag/parameters.template.yml > app/config/parameters.yml
|
||||||
envsubst < /etc/wallabag/php-wallabag.template.ini > /etc/php81/conf.d/50_wallabag.ini
|
envsubst < /etc/wallabag/php-wallabag.template.ini > /etc/php84/conf.d/50_wallabag.ini
|
||||||
|
|
||||||
# Wait for external database
|
# Wait for external database
|
||||||
if [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_mysql" ] || [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_pgsql" ] ; then
|
if [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_mysql" ] || [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_pgsql" ] ; then
|
||||||
|
|||||||
@ -35,8 +35,7 @@ http {
|
|||||||
}
|
}
|
||||||
|
|
||||||
server {
|
server {
|
||||||
listen 80;
|
listen [::]:80 ipv6only=off;
|
||||||
listen [::0]:80;
|
|
||||||
server_name _;
|
server_name _;
|
||||||
root /var/www/wallabag/web;
|
root /var/www/wallabag/web;
|
||||||
|
|
||||||
|
|||||||
@ -36,11 +36,11 @@ parameters:
|
|||||||
rss_limit: 50
|
rss_limit: 50
|
||||||
|
|
||||||
# RabbitMQ processing
|
# RabbitMQ processing
|
||||||
rabbitmq_host: localhost
|
rabbitmq_host: ${SYMFONY__ENV__RABBITMQ_HOST:-localhost}
|
||||||
rabbitmq_port: 5672
|
rabbitmq_port: ${SYMFONY__ENV__RABBITMQ_PORT:-5672}
|
||||||
rabbitmq_user: guest
|
rabbitmq_user: ${SYMFONY__ENV__RABBITMQ_USER:-guest}
|
||||||
rabbitmq_password: guest
|
rabbitmq_password: ${SYMFONY__ENV__RABBITMQ_PASSWORD:-guest}
|
||||||
rabbitmq_prefetch_count: 10
|
rabbitmq_prefetch_count: ${SYMFONY__ENV__RABBITMQ_PREFETCH_COUNT:-10}
|
||||||
|
|
||||||
# Redis processing
|
# Redis processing
|
||||||
redis_scheme: ${SYMFONY__ENV__REDIS_SCHEME:-tcp}
|
redis_scheme: ${SYMFONY__ENV__REDIS_SCHEME:-tcp}
|
||||||
|
|||||||
@ -1 +0,0 @@
|
|||||||
wallapass
|
|
||||||
@ -1 +0,0 @@
|
|||||||
F00B4R
|
|
||||||
@ -1 +0,0 @@
|
|||||||
my-secret-pw
|
|
||||||
@ -1,31 +0,0 @@
|
|||||||
version: '2'
|
|
||||||
services:
|
|
||||||
wallabag:
|
|
||||||
build:
|
|
||||||
context: ../
|
|
||||||
image: wallabag:postgresql
|
|
||||||
container_name: wallabag
|
|
||||||
environment:
|
|
||||||
- POSTGRES_PASSWORD__FILE=/run/secrets/postgres_password
|
|
||||||
- POSTGRES_USER=my-super-user
|
|
||||||
- SYMFONY__ENV__SECRET__FILE=/run/secrets/env_secret
|
|
||||||
- SYMFONY__ENV__DATABASE_DRIVER=pdo_pgsql
|
|
||||||
- SYMFONY__ENV__DATABASE_HOST=db
|
|
||||||
- SYMFONY__ENV__DATABASE_PORT=5432
|
|
||||||
- SYMFONY__ENV__DATABASE_NAME=wallabag
|
|
||||||
- SYMFONY__ENV__DATABASE_USER=wallabag
|
|
||||||
- SYMFONY__ENV__DATABASE_PASSWORD__FILE=/run/secrets/db_password
|
|
||||||
ports:
|
|
||||||
- "127.0.0.1:80:80"
|
|
||||||
# Docker Secrets require Swarm Mode, so we use volumes instead to spoof the behaviour
|
|
||||||
volumes:
|
|
||||||
- ./credentials/db_password:/run/secrets/db_password
|
|
||||||
- ./credentials/postgres_password:/run/secrets/postgres_password
|
|
||||||
- ./credentials/env_secret:/run/secrets/env_secret
|
|
||||||
db:
|
|
||||||
image: postgres:10.3
|
|
||||||
environment:
|
|
||||||
- POSTGRES_PASSWORD_FILE=/run/secrets/postgres_password
|
|
||||||
- POSTGRES_USER=my-super-user
|
|
||||||
volumes:
|
|
||||||
- ./credentials/postgres_password:/run/secrets/postgres_password
|
|
||||||
Reference in New Issue
Block a user