Nginx反向代理--负载均衡-搭建上游服务器

环境搭建拓扑图

在这里插入图片描述

具体实现

第一步:搭建nginx反向代理服务器
nginx安装教程传送门
编辑配置文件nginx.conf(常见位置:/etc/nginx/conf.d/default.conf或者 /usr/local/nginx/conf)配置上游服务器,一定要注意千万别丢了分号!!!!!
1、定义上游服务器

默认使用的是轮询算法:web1 we2 we1 web2
upstream 自定义名称 {
	server ip1:端口;
	server ip2:端口;
}
自行设置权重:三次请求中,1次web1 2次web2;
upstream 自定义名称 {
	server ip1:端口 weight 1;
	server ip2:端口 weight 2;
}
ip绑定
upstream 自定义名称 {
	ip_hash;
	server ip1:端口;
	server ip2:端口;
}

2、使用上游服务器

在http{}块中添加如下
location / {
	proxy_pass	http://上游服务器自定义的名称; #主要配置
	#按需配置以下配置
	proxy_set_header Host $host; #只要用户在浏览器中访问的域名绑定了 VIP VIP 下面有RS;则就用$host; host是访问URL中的域名和端口  www.xxxx.com:80
	proxy_set_header X-Real-IP $remote_addr;  #把源IP 【$remote_addr,建立HTTP连接header里面的信息】赋值给X-Real-IP;这样在代码中 $X-Real-IP来获取 源IP
	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;#在nginx 作为代理服务器时,设置的IP列表,会把经过的机器ip,代理机器ip都记录下来,用 【,】隔开;代码中用 echo $x-forwarded-for |awk -F, '{print $1}' 来作为源IP
}

举例截图:
在这里插入图片描述

第二步:搭建web1服务器,为了测试方便,简单搭建

yum install -y httpd
vim /var/www/html/index.html #编辑上具有识别性的文字等信息

第三步:搭建web2服务器和web1,可以一样,可以不同,按照自己的需要配置

yum install -y httpd
vim /var/www/html/index.html #编辑上具有识别性的文字等信息

测试结果:
默认轮询算法: web1出现一次,web2出现一次…
权重算法:因为web1的权重是1,web2 的权重是2; 因此发三次请求,两次web2,一次web1;
ip绑定:ip地址绑定以后只能访问绑定的服务器

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
***反向代理配置https双机负载均衡的问题,您可以按照以下步骤进行配置: 1. 安装nginx:首先确保已经在服务器上安装了nginx。您可以使用适用于您操作系统的包管理器进行安装,或者从nginx官方网站下载并手动安装。 2. 生成SSL证书:为了启用HTTPS,您需要为每个后端服务器生成SSL证书。您可以使用公开的CA(证书颁发机构)签名证书,或者使用自签名证书。这里以自签名证书为例,在服务器上执行以下命令: ```shell openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /path/to/private.key -out /path/to/certificate.crt ``` 这将生成一个私钥文件 `private.key` 和一个证书文件 `certificate.crt`。 3. 配置nginx:打开 nginx 的配置文件 `nginx.conf`,一般位于 `/etc/nginx/nginx.conf` 或 `/usr/local/nginx/conf/nginx.conf`。确保以下配置已添加或修改: ```nginx http { # ... upstream backend { server backend1.example.com; server backend2.example.com; } server { listen 443 ssl; server_name yourdomain.com; ssl_certificate /path/to/certificate.crt; ssl_certificate_key /path/to/private.key; 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; # 可选:添加其他的代理设置 # ... } } } ``` 在上述配置中,`backend1.example.com` 和 `backend2.example.com` 是您的后端服务器的域名或IP地址,您可以根据实际情况进行修改。 4. 重启nginx:保存并关闭 `nginx.conf` 文件。然后使用以下命令重启nginx服务: ```shell sudo service nginx restart ``` 或者 ```shell sudo systemctl restart nginx ``` 这样就完成了nginx反向代理配置https双机负载均衡。现在,当用户访问 `yourdomain.com` 时,nginx将会根据负载均衡算法将请求转发到后端服务器,并通过HTTPS进行加密传输。 请注意,上述示例中的配置仅供参考,请根据您的实际需求进行适当的修改。同时,确保您的后端服务器已经正确配置和运行,并监听适当的端口。 希望以上信息对您有所帮助!如有任何疑问,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值