TranslateProject/sources/tech/20221002 How to Install HAProxy on Ubuntu 20.04 LTS -Focal Fossa-.md

239 lines
7.9 KiB
Markdown
Raw Normal View History

[#]: subject: "How to Install HAProxy on Ubuntu 20.04 LTS (Focal Fossa)"
[#]: via: "https://www.linuxtechi.com/how-to-install-haproxy-ubuntu-20-04/"
[#]: author: "Pradeep Kumar https://www.linuxtechi.com/author/pradeep/"
[#]: collector: "lkxed"
[#]: translator: " "
[#]: reviewer: " "
[#]: publisher: " "
[#]: url: " "
How to Install HAProxy on Ubuntu 20.04 LTS (Focal Fossa)
======
In this guide, we will cover how to install latest version of HAProxy on Ubuntu 20.04 LTS (Focal Fossa) step-by-step.
HAProxy is a free & open source solution for High availability and load balancing, it can also be used for proxying TCP & HTTP based applications. HAProxy can be installed and configured on Linux, Solaris & FreeBSD. HAProxy is best recommended solution for the websites which has huge traffic as it improves performance & reliability of the server by means of load balancing the servers & using its high availability capabilities.
HAProxy is used by a number of most popular websites including GitHub, Bitbucket, Stack Overflow, Reddit, Tumblr, Twitter and it is also used in the OpsWorks product from Amazon Web Services.
##### Prerequisites
* Minimal Installed Ubuntu 20.04 System
* Local User with sudo rights
* Internet connectivity
Without any further delay, lets deep dive into HAProxy installation steps.
### Step 1) Install Updates
Login to Ubuntu 20.04 system and install all the available updated using beneath apt command,
```
$ sudo apt update
$ sudo apt upgrade -y
```
Once all the updates are installed, reboot the system once.
```
$ sudo reboot
```
### Step 2) Install latest HAProxy
HAProxy package is available in the default package repositories but it is not the latest and stable version. So to install latest version, enable HAProxy PPA, run
```
$ sudo apt install software-properties-common
$ sudo add-apt-repository ppa:vbernat/haproxy-2.6 -y
```
Now, run following apt command to install haproxy
Note: At the time of writing this article, HAProxy 2.6 is available via PPA.
```
$ sudo apt update$ sudo apt install haproxy -y
```
To verify the haproxy version, run
```
$ haproxy -v'
```
![Haproxy-version-check-ubuntu][1]
Haproxy service starts automatically when we install haproxy package. To validate the haproxy service status, run following
```
$ sudo systemctl status haproxy
```
output,
![Haproxy-Service-Status-Ubuntu-20-04][2]
### Step 3) Configure HAProxy
Now we have haproxy ready. For purpose of this guide, we will configure HAProxy to load balance the requests from a mail server & a web server.
##### Load balancing a Mail server with HAProxy
For this example, we will be using two SMTP servers with the IP adresse 192.168.1.10 & 192.168.1.20 respectively.
The IP address for haproxy server is 192.168.1.100.
We will now make the changes to main HAProxy configuration file i.e. /etc/haproxy/haproxy.cfg and then make the configuration changes for load balancing the two SMTP servers,
Before making the changes, take backup of its configuration file using cp command.
```
$ sudo cp /etc/haproxy/haproxy.cfg /etc/haproxy/haproxy.cfg-org
```
Now the make the changes, add the following **frontend** & **backend** section at the end of the file.
```
$ sudo vi /etc/haproxy/haproxy.cfg
-------------------------------
frontend front_smtp
     bind *:25
    mode tcp
    default_backend back_smtp
backend back_smtp
    mode tcp
    balance roundrobin
    server smtp1 192.168.1.10:25 check
    server smtp2 192.168.1.20:25 check
```
Here most of the options have been set by default, main things to change here are **frontend** & **backend** sections.
frontend front_smtp
bind *:25
mode tcp
default_backend back_smtp
Here we have defined a name for frontend i.e. front_smtp & have asked to take all the request from port 25 with bind parameter, laslty we have mentioned the backend section with the name back_smtp where all the requests will be distributed.
backend back_smtp
mode tcp
balance roundrobin
server smtp1 192.168.1.10:25 check
server smtp2 192.168.1.20:25 check
In this section, we have established a name for backend i.e. back_smtp & mode for the transmission will be tcp load balancing method to be used is **roundrobin**. Other load balancing methods that can be used are **Weighted round robin**, **Dynamic round robin algorithm**,**Least connection algorithm**, Source. Lastly we have mentioned the server addresses for both SMTP servers.
Once the changes have been made, save the file & restart the haproxy service to implement the changes,
```
$ sudo systemctl restart haproxy
```
Our Haproxy server is now ready to work as load balancer for mail server. Now rather than using the SMTP server addresses, we need to use the server address for HAPROXY i.e. 192.168.1.100:25 for haproxy loadbalancing to work.
To check out if the load balancing for our smtp server is working we can use telnet,
Output of telnet command should be something like below:
```
$ telnet 192.168.1.100 25
Trying 192.168.1.100..
Connected to 192.168.1.100.
Escape character is ^].
220 smtp1.linuxtechi.com ESMTP Postfix
```
Now again run the telnet command,
```
$ telnet 192.168.1.100 25
Trying 192.168.1.100..
Connected to 192.168.1.100.
Escape character is ^].
220 smtp2.linuxtechi.com ESMTP Postfix
```
Notice the change in the server of the mail servers in both the outputs, which shows that the load balancing is working fine. Now lets discuss a harpoxy example for load balancing a web server.
##### Load balancing a Web server with HAProxy
Same file will be edited /etc/haproxy/haproxy.cfg. We will be using two web servers (192.168.1.10 & 192.168.1.20) on backend.  IP address for the haproxy server is 192.168.1.100.
Open the haproxy main configuration file and append following changes at the end of file
```
$ sudo vi /etc/haproxy/haproxy.cfg
------------
frontend www-http
  bind *:80
    mode http
    default_backend apache
backend apache
    mode http
    balance roundrobin
     server web1 192.168.1.10
    server web2 192.168.1.20
```
Save the file & restart the haproxy service to implement the changes,
```
$ sudo systemctl restart haproxy
```
To test out if the load balancing is working, we can place two different web pages on both server. Like for example, we can modify index.html on Webserver 1,
```
[[email protected] ~]$ sudo vi /var/www/html/index.html
This is WEB SERVER 1
```
& similarly on Web server 2, we can edit the index.html to say,
```
[[email protected] ~]$ sudo vi /var/www/html/index.html
This is WEB SERVER 2
```
Dont forget to restart the web service to implement the changes that have been made.
Now, use the haproxy IP address, 192.168.1.100 & access it using a web browser.
![Web1][3]
Every time we refresh the browser, we should the alternating web pages from both web servers.
![web2][4]
This shows that our webserver load balancing also working fine. Thats all from from this guide, I hope, you have successfully installed HAProxy on Ubuntu 20.04 LTS (Focal Fossa). Please feel free to send in your queries or suggestions using the comment box below.
--------------------------------------------------------------------------------
via: https://www.linuxtechi.com/how-to-install-haproxy-ubuntu-20-04/
作者:[Pradeep Kumar][a]
选题:[lkxed][b]
译者:[译者ID](https://github.com/译者ID)
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]: https://www.linuxtechi.com/author/pradeep/
[b]: https://github.com/lkxed
[1]: https://www.linuxtechi.com/wp-content/uploads/2017/12/Haproxy-version-check-ubuntu.png
[2]: https://www.linuxtechi.com/wp-content/uploads/2017/12/Haproxy-Service-Status-Ubuntu-20-04.png
[3]: https://www.linuxtechi.com/wp-content/uploads/2017/12/Web1.jpg
[4]: https://www.linuxtechi.com/wp-content/uploads/2017/12/web2.jpg