Compare commits
No commits in common. "master" and "release-0.0.5" have entirely different histories.
master
...
release-0.
15
Dockerfile
15
Dockerfile
@ -1,19 +1,10 @@
|
|||||||
ARG BASE_IMAGE="fabiocicerchia/nginx-lua:1.25.2-alpine3.18.3"
|
ARG BASE_IMAGE="nginx"
|
||||||
|
|
||||||
FROM ${BASE_IMAGE}
|
FROM ${BASE_IMAGE}
|
||||||
|
|
||||||
# Install ping and ip
|
# Install ping and ip
|
||||||
RUN apk add --no-cache iproute2 iputils bash
|
RUN apt update && \
|
||||||
|
apt install -y iproute2 iputils-ping
|
||||||
# Default nginx proxy envs
|
|
||||||
ENV NGINX_PROXY_SOURCE_PORT=${NGINX_PROXY_SOURCE_PORT:-"Please configure NGINX_PROXY_SOURCE_PORT env!"}
|
|
||||||
ENV NGINX_PROXY_SOURCE_ADDRESS=${NGINX_PROXY_SOURCE_ADDRESS:-"Please configure NGINX_PROXY_SOURCE_ADDRESS env!"}
|
|
||||||
|
|
||||||
# Copy default nginx configuration
|
|
||||||
#COPY default.nginx.conf /etc/nginx/nginx.conf
|
|
||||||
|
|
||||||
# Remove default nginx config
|
|
||||||
RUN rm -r /etc/nginx/nginx.conf
|
|
||||||
|
|
||||||
# Copy entrypoint
|
# Copy entrypoint
|
||||||
COPY docker-entrypoint.sh /usr/local/bin/docker-entrypoint.sh
|
COPY docker-entrypoint.sh /usr/local/bin/docker-entrypoint.sh
|
||||||
|
46
README.MD
46
README.MD
@ -1,46 +0,0 @@
|
|||||||
# Nginx Routes Helper
|
|
||||||
|
|
||||||
Специальный образ NGINX, который упрощает работу с проксированием портов между разными сетками у докер контейнеров.
|
|
||||||
|
|
||||||
По-умолчанию установлены утилиты для работы с роутами.
|
|
||||||
|
|
||||||
# Пре-стартовый скрипт
|
|
||||||
|
|
||||||
При старте контейнера происходит проверка на наличие скрипта, который должен быть выполнен в самом начале.
|
|
||||||
|
|
||||||
Скрипт располагается в `/invoke_initial_script.sh`, собственно сюда его и надо монтировать.
|
|
||||||
|
|
||||||
Например, требуется добавить роуты в контейнер при его старте.
|
|
||||||
|
|
||||||
`/invoke_initial_script.sh`:
|
|
||||||
```bash
|
|
||||||
#!/usr/bin/env bash
|
|
||||||
echo "Adding routes..."
|
|
||||||
ip route add 192.168.255.0/24 via 172.20.20.2
|
|
||||||
echo "Routes added!"
|
|
||||||
```
|
|
||||||
|
|
||||||
Тут может быть совершенно что угодно, этот скрипт выполнится до старта NGINX.
|
|
||||||
|
|
||||||
# Проброс портов по-умолчанию
|
|
||||||
|
|
||||||
Если пользователь не примонтирует свой `/etc/nginx/nginx.conf`, то по-умолчанию будет использоваться
|
|
||||||
обычный `stream` прокси с порта на адрес. Слушаемый порт и целевой адрес указываются через переменные окружения:
|
|
||||||
- `NGINX_PROXY_SOURCE_PORT` - Порт (например `80`), который слушает NGINX
|
|
||||||
- `NGINX_PROXY_TARGET_ADDRESS` - Адрес и порт (например `localhost:25565`), куда будет отправляться трафик
|
|
||||||
|
|
||||||
Пример использования в `docker-compose`:
|
|
||||||
```yml
|
|
||||||
version: '3.7'
|
|
||||||
services:
|
|
||||||
test-nginx:
|
|
||||||
image: "git.tswf.io/docker-base-images/nginx-routes:latest"
|
|
||||||
ports:
|
|
||||||
- "25565:25565"
|
|
||||||
environment:
|
|
||||||
NGINX_PROXY_SOURCE_PORT: 25565
|
|
||||||
NGINX_PROXY_TARGET_ADDRESS: "another_container:9000"
|
|
||||||
another_container:
|
|
||||||
image: "blablabla"
|
|
||||||
#...
|
|
||||||
```
|
|
@ -6,24 +6,6 @@ if [ -f "/invoke_initial_script.sh" ]; then
|
|||||||
source /invoke_initial_script.sh
|
source /invoke_initial_script.sh
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Проверяем наличие файла /etc/nginx/nginx.conf
|
|
||||||
if [ ! -f "/etc/nginx/nginx.conf" ]; then
|
|
||||||
# Заполняем файл /etc/nginx/nginx.conf с использованием переменных окружения
|
|
||||||
cat > /etc/nginx/nginx.conf <<EOF
|
|
||||||
events {}
|
|
||||||
|
|
||||||
stream {
|
|
||||||
server {
|
|
||||||
listen $NGINX_PROXY_SOURCE_PORT;
|
|
||||||
proxy_pass $NGINX_PROXY_TARGET_ADDRESS;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
EOF
|
|
||||||
echo "Created default nginx conf forwarding from port '$NGINX_PROXY_SOURCE_PORT' to address '$NGINX_PROXY_TARGET_ADDRESS'"
|
|
||||||
else
|
|
||||||
echo "Skip default "
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "$1" = 'app' ]]; then
|
if [[ "$1" = 'app' ]]; then
|
||||||
exec nginx -g 'daemon off;'
|
exec nginx -g 'daemon off;'
|
||||||
else
|
else
|
||||||
|
Loading…
Reference in New Issue
Block a user