Skip to content

yusing/godoxy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

864a432 Β· Apr 3, 2025
Mar 29, 2025
Mar 27, 2025
Feb 23, 2025
Apr 2, 2025
Mar 28, 2025
Dec 10, 2024
Apr 3, 2025
Mar 27, 2025
Mar 28, 2025
Feb 24, 2025
Mar 29, 2025
Mar 27, 2025
Mar 27, 2025
Oct 6, 2024
Feb 6, 2025
Apr 3, 2025
Apr 1, 2024
Mar 28, 2025
Mar 29, 2025
Mar 27, 2025
Mar 27, 2025
Mar 28, 2025
Apr 3, 2025
Apr 3, 2025
Oct 4, 2024

Repository files navigation

GoDoxy

Quality Gate Status GitHub last commit Lines of Code Discord

A lightweight, simple, and performant reverse proxy with WebUI.

For full documentation, check out Wiki

EN | δΈ­ζ–‡

Table of content

Key Features

  • Easy to use
    • Effortless configuration
    • Simple multi-node setup with GoDoxy agents or Docker Socket Proxies
    • Error messages is clear and detailed, easy troubleshooting
  • Auto SSL with Let's Encrypt (See Supported DNS-01 Challenge Providers)
  • Auto hot-reload on container state / config file changes
  • Container aware: create routes dynamically from running docker containers
  • idlesleeper: stop and wake containers based on traffic (optional, see screenshots)
  • HTTP reserve proxy and TCP/UDP port forwarding
  • OpenID Connect integration: SSO and secure your apps easily
  • HTTP middleware and Custom error pages support
  • Web UI with App dashboard, config editor, uptime and system metrics, docker logs viewer
  • Supports linux/amd64 and linux/arm64
  • Written in Go

πŸ”ΌBack to top

Prerequisites

Setup Wildcard DNS Record(s) for machine running GoDoxy, e.g.

  • A Record: *.domain.com -> 10.0.10.1
  • AAAA Record (if you use IPv6): *.domain.com -> ::ffff:a00:a01

How does GoDoxy work

  1. List all the containers
  2. Read container name, labels and port configurations for each of them
  3. Create a route if applicable (a route is like a "Virtual Host" in NPM)
  4. Watch for container / config changes and update automatically

GoDoxy uses the label proxy.aliases as the subdomain(s), if unset it defaults to the container_name field in docker compose.

For example, with the label proxy.aliases: qbt you can access your app via qbt.domain.com.

Setup

NOTE: GoDoxy is designed to be (and only works when) running in host network mode, do not change it. To change listening ports, modify .env.

  1. Prepare a new directory for docker compose and config files.

  2. Run setup script inside the directory, or set up manually

    /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/yusing/godoxy/main/scripts/setup.sh)"
  3. Start the container docker compose up -d and wait for it to be ready

  4. You may now do some extra configuration on WebUI https://godoxy.yourdomain.com

πŸ”ΌBack to top

Screenshots

idlesleeper

idlesleeper

Metrics and Logs

Uptime Monitor Docker Logs Server Overview
Uptime Monitor Docker Logs Server Overview
System Monitor Graphs
System Monitor Graphs

πŸ”ΌBack to top

Manual Setup

  1. Make config directory then grab config.example.yml into config/config.yml

    mkdir -p config && wget https://raw.githubusercontent.com/yusing/godoxy/main/config.example.yml -O config/config.yml

  2. Grab .env.example into .env

    wget https://raw.githubusercontent.com/yusing/godoxy/main/.env.example -O .env

  3. Grab compose.example.yml into compose.yml

    wget https://raw.githubusercontent.com/yusing/godoxy/main/compose.example.yml -O compose.yml

Folder structrue

β”œβ”€β”€ certs
β”‚   β”œβ”€β”€ cert.crt
β”‚   └── priv.key
β”œβ”€β”€ compose.yml
β”œβ”€β”€ config
β”‚   β”œβ”€β”€ config.yml
β”‚   β”œβ”€β”€ middlewares
β”‚   β”‚   β”œβ”€β”€ middleware1.yml
β”‚   β”‚   β”œβ”€β”€ middleware2.yml
β”‚   β”œβ”€β”€ provider1.yml
β”‚   └── provider2.yml
β”œβ”€β”€ data
β”‚   β”œβ”€β”€ metrics # metrics data
β”‚   β”‚   β”œβ”€β”€ uptime.json
β”‚   β”‚   └── system_info.json
└── .env

Build it yourself

  1. Clone the repository git clone https://github.com/yusing/godoxy --depth=1

  2. Install / Upgrade go (>=1.22) and make if not already

  3. Clear cache if you have built this before (go < 1.22) with go clean -cache

  4. get dependencies with make get

  5. build binary with make build

πŸ”ΌBack to top