Easy to use reverse proxy with docker integration
Find a file
2025-02-24 04:20:00 +08:00
.github cicd: fix workflow 2025-02-24 03:32:15 +08:00
.trunk refactor and remove unused code 2025-02-11 01:10:09 +08:00
.vscode fix access log rotation attempt 2025-02-18 21:11:20 +08:00
agent fixed http server context handling 2025-02-24 04:20:00 +08:00
cmd simplify setup with script 2025-02-18 05:39:15 +08:00
examples n8n compose example 2024-12-11 07:21:04 +08:00
internal fixed http server context handling 2025-02-24 04:20:00 +08:00
pkg implement godoxy-agent 2025-02-11 01:10:09 +08:00
schemas add agent to schema 2025-02-18 21:11:24 +08:00
screenshots update screenshots 2025-02-14 22:20:51 +08:00
scripts fix setup script 2025-02-24 00:00:05 +08:00
.env.example add example to override app base domain in dashboard 2025-02-23 00:08:24 +08:00
.gitignore simplify some code and implement metrics storage 2025-02-17 07:18:59 +08:00
.gitlab-ci.yml added package version api, dependencies upgrade 2024-10-06 09:23:41 +08:00
.gitmodules refactor file names, readme updates, removed frontend submodule as it is being built independently 2024-09-25 11:22:25 +08:00
.golangci.yml Feat/fileserver (#60) 2025-02-06 18:23:10 +08:00
bun.lock fix npm package 2025-01-25 02:36:22 +08:00
compose.example.yml update default image name 2025-02-23 06:36:20 +08:00
config.example.yml rename go-proxy to godoxy 2025-02-23 14:27:25 +08:00
Dockerfile refactor, fix metrics and upgrade go to 1.24.0 2025-02-12 11:15:45 +08:00
go.mod refactor docker api code, deps upgrade 2025-02-22 04:51:07 +08:00
go.sum refactor docker api code, deps upgrade 2025-02-22 04:51:07 +08:00
LICENSE added license 2024-04-01 04:08:48 +00:00
Makefile Fix dockerfile and makefile 2025-02-11 01:10:09 +08:00
next-release.md simplify setup process 2025-02-11 05:05:56 +08:00
package.json rename go-proxy to godoxy 2025-02-23 14:27:25 +08:00
providers.example.yml readme updates, docs moved to wiki 2024-10-04 11:27:11 +08:00
README.md rename go-proxy to godoxy 2025-02-23 14:27:25 +08:00
README_CHT.md rename go-proxy to godoxy 2025-02-23 14:27:25 +08:00
tsconfig.json fix npm package 2025-01-25 02:36:22 +08:00

GoDoxy

Quality Gate Status GitHub last commit Lines of Code

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
    • Error messages is clear and detailed, easy troubleshooting
  • Auto SSL cert management (See Supported DNS-01 Challenge Providers)
  • Auto configuration for docker containers
  • Auto hot-reload on container state / config file changes
  • idlesleeper: stop containers on idle, wake it up on traffic (optional, see screenshots)
  • HTTP(s) reserve proxy
  • OpenID Connect support
  • HTTP middleware support
  • Custom error pages support
  • TCP and UDP port forwarding
  • Web UI with App dashboard and config editor
  • Supports linux/amd64, linux/arm64
  • Written in Go

🔼Back to top

Prerequisites

Setup DNS Records point to machine which runs GoDoxy, e.g.

  • A Record: *.y.z -> 10.0.10.1
  • AAAA Record: *.y.z -> ::ffff:a00:a01

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

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

Screenshots

idlesleeper

idlesleeper

Uptime Monitor

uptime monitor

System Monitor

system monitor

🔼Back to top

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