在CentOS上进行负载均衡可以通过多种方法实现,常见的包括使用LVS、Nginx和Haproxy等工具。以下是使用Nginx和LVS在CentOS上进行负载均衡的详细步骤:
sudo yum install epel-release -y
sudo yum install nginx -y
编辑Nginx配置文件,通常位于 /etc/nginx/nginx.conf
或 /etc/nginx/conf.d/default.conf
。
http {
upstream backend {
server backend1.example.com;
server backend2.example.com;
# 添加更多后端服务器
}
server {
listen 80;
server_name example.com;
location / {
proxy_pass http://backend;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
}
sudo systemctl start nginx
sudo systemctl enable nginx
访问服务器的IP地址和端口,查看是否能按预期进行负载均衡。
sudo yum install ipvsadm -y
# 清除iptables规则
sudo iptables -F
# 设置内核参数
echo "1" > /proc/sys/net/ipv4/ip_forward
# 添加虚拟服务器
sudo ipvsadm -A -t VIP:端口 -s rr
# 添加真实服务器
sudo ipvsadm -a -t VIP:端口 -r RSIP:端口 -g
其中,VIP
是虚拟IP地址,RSIP
是后端服务器的IP地址,端口
是服务的端口号。
sudo yum install haproxy -y
编辑Haproxy配置文件,通常位于 /etc/haproxy/haproxy.cfg
。
global
log /dev/log local0
log /dev/log local1 notice
maxconn 4096
tune.ssl.default-dh-param 2048
defaults
log global
mode http
option httplog
option dontlognull
retries 3
timeout http-request 10s
timeout queue 1m
timeout connect 10s
timeout client 1m
timeout server 1m
frontend http-in
bind *:80
default_backend servers
backend servers
balance roundrobin
server server1 192.168.0.101:80 check
server server2 192.168.0.102:80 check
sudo systemctl start haproxy
sudo systemctl enable haproxy
通过浏览器或命令行工具访问Haproxy服务器的IP地址和端口,查看是否能按预期进行负载均衡。