Easy to use reverse proxy with docker integration
Find a file
2025-02-19 00:36:44 +08:00
.github Create FUNDING.yml 2025-02-06 04:44:19 +08:00
.trunk deps upgrade 2025-02-18 16:39:25 +08:00
.vscode update readme 2025-01-31 03:33:20 +08:00
cmd simplify setup with script 2025-02-18 05:43:33 +08:00
examples n8n compose example 2024-12-11 07:21:04 +08:00
internal fix cloudflare real ip middleware resolving local addresses 2025-02-19 00:36:44 +08:00
pkg added package version api, dependencies upgrade 2024-10-06 09:23:41 +08:00
schemas autocert: add porkbun cert provider 2025-02-13 23:48:35 +08:00
screenshots fixed idlewatcher panics and incorrect behavior, update screenshot 2024-10-06 16:17:52 +08:00
scripts simplify setup with script 2025-02-18 05:43:33 +08:00
.env.example api: move prometheus handler inside api handler /v1/metrics 2025-02-01 02:09:43 +08:00
.gitignore fix npm package 2025-01-25 02:36:22 +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 compose example 2025-02-06 05:59:21 +08:00
config.example.yml adjusted and simplified default config and compose.yml 2025-02-04 07:04:05 +08:00
Dockerfile deps upgrade 2025-02-18 16:39:25 +08:00
go.mod deps upgrade 2025-02-18 16:39:25 +08:00
go.sum deps upgrade 2025-02-18 16:39:25 +08:00
LICENSE added license 2024-04-01 04:08:48 +00:00
Makefile Feat/fileserver (#60) 2025-02-06 18:23:10 +08:00
next-release.md update next release md 2025-02-13 19:30:23 +08:00
package.json autocert: add porkbun cert provider 2025-02-13 23:48:35 +08:00
providers.example.yml readme updates, docs moved to wiki 2024-10-04 11:27:11 +08:00
README.md simplify setup with script 2025-02-18 05:43:33 +08:00
README_CHT.md simplify setup with script 2025-02-18 05:43:33 +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 | 中文

Currently working on feat/godoxy-agent.
Fork this instead of default branch.

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/go-proxy/v0.9/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/go-proxy/v0.9/config.example.yml -O config/config.yml

  2. Grab .env.example into .env

    wget https://raw.githubusercontent.com/yusing/go-proxy/v0.9/.env.example -O .env

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

    wget https://raw.githubusercontent.com/yusing/go-proxy/v0.9/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

🔼Back to top

Build it yourself

  1. Clone the repository git clone https://github.com/yusing/go-proxy --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