1) Определение и скачивание новой версии haproxy
Просмотреть все актуальные версии haproxy можно на странице:
http://www.haproxy.org/download/2.0/src/
Мы просто воспользуемся командой ниже и для удобства запишем в переменную крайнюю версию
LAST_HAPROXY=$(wget -qO- http://www.haproxy.org/download/2.0/src/ | egrep -o "haproxy-2.[0-9]+.[0-9]+" | head -1)
Скачиваем и распаковываем архив с исходниками haproxy
cd /usr/src/
wget http://www.haproxy.org/download/2.0/src/${LAST_HAPROXY}.tar.gz
tar xzvf ${LAST_HAPROXY}.tar.gz
2) Подготовка окружения и установка
Установка необходимых пакетов для сборки haproxy
yum install gcc-c++ openssl-devel pcre-static pcre-devel systemd-devel -y
Сборка и установка haproxy
cd /usr/src/${LAST_HAPROXY}
make TARGET=linux-glibc USE_PCRE=1 USE_OPENSSL=1 USE_ZLIB=1 USE_CRYPT_H=1 USE_LIBCRYPT=1 USE_SYSTEMD=1
mkdir /etc/haproxy
make install
Создание systemd службы
cat > /usr/lib/systemd/system/haproxy.service << 'EOL' [Unit] Description=HAProxy Load Balancer After=syslog.target network.target [Service] Environment="CONFIG=/etc/haproxy/haproxy.cfg" "PIDFILE=/run/haproxy.pid" ExecStartPre=/usr/local/sbin/haproxy -f $CONFIG -c -q ExecStart=/usr/local/sbin/haproxy -Ws -f $CONFIG -p $PIDFILE ExecReload=/usr/local/sbin/haproxy -f $CONFIG -c -q ExecReload=/bin/kill -USR2 $MAINPID KillMode=mixed Restart=always SuccessExitStatus=143 Type=notify [Install] WantedBy=multi-user.target EOL systemctl daemon-reload
3) Создание конфига haproxy и запуск
Создадим конфиг с tcp пробросом 80 порта на localhost
cat > /etc/haproxy/haproxy.cfg << 'EOL'
global
log /dev/log local0
log /dev/log local1 notice
daemon
defaults
log global
defaults
log global
mode http
option httplog
option dontlognull
listen AnyName
bind *:80
mode tcp
server MyServer 127.0.0.1:80
EOL
Запуск haproxy
systemctl start haproxy
Проверяем статус службы
systemctl status haproxy
Готовый скрипт целиком
LAST_HAPROXY=$(wget -qO- http://www.haproxy.org/download/2.0/src/ | egrep -o "haproxy-2.[0-9]+.[0-9]+" | head -1)
cd /usr/src/
wget http://www.haproxy.org/download/2.0/src/${LAST_HAPROXY}.tar.gz
tar xzvf ${LAST_HAPROXY}.tar.gz
yum install gcc-c++ openssl-devel pcre-static pcre-devel systemd-devel -y
cd /usr/src/${LAST_HAPROXY}
make TARGET=linux-glibc USE_PCRE=1 USE_OPENSSL=1 USE_ZLIB=1 USE_CRYPT_H=1 USE_LIBCRYPT=1 USE_SYSTEMD=1
mkdir /etc/haproxy
make install
cat > /usr/lib/systemd/system/haproxy.service << 'EOL'
[Unit]
Description=HAProxy Load Balancer
After=syslog.target network.target
[Service]
Environment="CONFIG=/etc/haproxy/haproxy.cfg" "PIDFILE=/run/haproxy.pid"
ExecStartPre=/usr/local/sbin/haproxy -f $CONFIG -c -q
ExecStart=/usr/local/sbin/haproxy -Ws -f $CONFIG -p $PIDFILE
ExecReload=/usr/local/sbin/haproxy -f $CONFIG -c -q
ExecReload=/bin/kill -USR2 $MAINPID
KillMode=mixed
Restart=always
SuccessExitStatus=143
Type=notify
[Install]
WantedBy=multi-user.target
EOL
cat > /etc/haproxy/haproxy.cfg << 'EOL'
global
log /dev/log local0
log /dev/log local1 notice
daemon
defaults
log global
option dontlognull
timeout connect 50000
timeout client 50000
timeout server 50000
listen AnyName
bind *:80
mode tcp
server MyServer 127.0.0.1:80
EOL
systemctl start haproxy
systemctl status haproxy
0 Comments