haproxy/README.md

52 lines
1.4 KiB
Markdown
Raw Normal View History

2022-06-06 12:05:05 +05:30
# HAProxy
2022-06-05 00:50:22 +05:30
2022-06-06 12:05:05 +05:30
Build scripts for HAProxy with QUIC
2022-06-05 00:50:22 +05:30
**PROJECT STATUS: Alpha, __not exhaustively tested yet__**
## Quickstart
docker run -it \
-v /path/to/haproxy.cfg:/usr/local/etc/haproxy/haproxy.cfg:ro \
registry.gitlab.com/mangadex-pub/haproxy:2.6-bullseye
## Build it
2022-06-05 00:50:22 +05:30
2022-06-06 12:05:05 +05:30
You will need the following dependencies (Debian/Ubuntu packages given as example):
- Development tools (`build-essential`)
- curl and ssl support for it (`curl` and `ca-certificates`)
- CMake (`cmake`)
- Readline library headers (`libreadline-dev`)
- Libsystemd headers (`libsystemd-dev`)
- GNU TAR (`tar`)
Then just run `make` and the build should pass.
2022-06-06 13:37:59 +05:30
First, `deps/quictls/quictls-dist.tar.gz` should be expanded so it matches the host's
`/opt/quictls` when expanding, as it is where HAProxy will look for OpenSSL.
2022-06-06 12:05:05 +05:30
2022-06-06 13:37:59 +05:30
And finally `haproxy/haproxy-dist.tar.gz` can be expanded anywhere.
2022-06-06 12:05:05 +05:30
## Should I use this repo?
This is an:
- unofficial build of HAProxy
- which enables an experimental feature of HAProxy
- which relies on an unofficial build of OpenSSL
- which is based on an unofficial patch of OpenSSL
Generally speaking, you shouldn't.
That said, please PR improvements back if you do. We'll be using it ourselves too.
## What's in there
First, we want to statically build things where possible, which is done for:
- LUA
- PCRE2
- QuicTLS
Then we want HAProxy to not use the system's OpenSSL but rather our QuicTLS build, which
it will look for at the `/opt/quictls` prefix.