Я скомпилировал версию Haproxy LTS 2.2 из исходников с помощью этой команды:
make TARGET=linux-glibc USE_PCRE=1 USE_OPENSSL=1 USE_ZLIB=1 USE_CRYPT_H=1 USE_LIBCRYPT=1
Во время компиляции ошибок не было. Это моя конфигурация Haproxy:
global
log 127.0.0.1 local2
chroot /var/lib/haproxy
pidfile /var/run/haproxy.pid
maxconn 4000
user haproxy
group haproxy
daemon
# turn on stats unix socket
stats socket /var/lib/haproxy/stats
defaults
mode http
log global
option httplog
option dontlognull
option http-server-close
option forwardfor except 127.0.0.0/8
option redispatch
retries 3
timeout http-request 10s
timeout queue 1m
timeout connect 10s
timeout client 1m
timeout server 1m
timeout http-keep-alive 10s
timeout check 10s
maxconn 3000
frontend http-in
bind 192.168.123.40:80
acl gerrit hdr(host) -i gerrit.example.local
acl jenkins hdr(host) -i jenkins.example.local
use_backend gerrit if gerrit
use_backend jenkins if jenkins
backend gerrit
server gerrit 127.0.0.1:8080
backend jenkins
server jenkins 127.0.0.1:8081
Когда я проверяю конфигурацию с помощью haproxy -c -q -V -f /etc/haproxy/haproxy.cfg
command Я получаю следующую ошибку:
[NOTICE] 226/130914 (35193) : haproxy version is 2.2.2
[NOTICE] 226/130914 (35193) : path to executable is /usr/sbin/haproxy
[ALERT] 226/130914 (35193) : parsing [/etc/haproxy/haproxy.cfg:33] : unknown keyword 'bind 192.168.123.40:80' in 'frontend' section
[ALERT] 226/130914 (35193) : Error(s) found in configuration file : /etc/haproxy/haproxy.cfg
[ALERT] 226/130914 (35193) : Fatal errors found in configuration.
Я проверил документацию, и можно использовать bind
ключевое слово в разделе внешнего интерфейса http://cbonte.github.io/haproxy-dconv/2.2/configuration.html#bind (справочник по ключевым словам, отсортированным по алфавиту)
Больше мозгов достигнуто, когда я комментирую bind
ключевое слово в разделе внешнего интерфейса. Затем ошибка говорит:
[WARNING] 226/132456 (36642) : config : frontend 'http-in' has no 'bind' directive. Please declare it as a backend if this was intended.
🤷
Похоже, вы использовали какой-то другой символ пробела, который выглядит как пробел, но на самом деле не является обычным символом пробела между bind
и 192.168.123.40:80
. Попробуйте ввести текст еще раз, но на этот раз используйте обычный пробел (U + 0020, ASCII 32).