nginx负载均衡的理解与实际应用

简介:

公司有一个公网IP,有两台apache服务器,需求是想让apache服务器映射到公网上去,让公网用户可以访问到,然而如果在路由器上做映射的话就不是很好,因为路由器上的IP映射都是“私网IP:端口”<>“公网IP:对应端口”,两台私网的apache服务器的内容都不一样,但都是80端口,做映射没法做的。如果要做的话只能这样192.168.10.38:80 210.22.3.91:80

             192.168.10.40:80 210.22.3.91:81

这样的话,你就只能让客户加端口访问了,这个不太友好,这就想到了做nginx反向代理了

nginx的编译安装这里就略了,主要反向代理代码如下

编辑反向代理服务器配置文件:
vim /usr/local/nginx/conf/reverse-proxy.conf

server

{

    listen 80;

    server_name www.aaa.com;

    location / {

        proxy_redirect off;

        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_pass http://192.168.10.38:80;

    }

    access_log logs/www.aaa.com_access.log;

}

 

server

{

    listen 80;

    server_name www.ccc.com;

    location / {

        proxy_redirect off;

        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_pass http://192.168.10.40:80;

    }

    access_log logs/www.ccc.com_access.log;

}

然后重新加载nginx配置文件,使之修改生效,再把www.aaa.com和www.ccc.com域名指向公司静态IP,即申请DNS的时候直接申请两个域名再加上公司的公网IP,例如这样:210.22.3.91 www.aaa.com www.ccc.com, 这样就成功的做到了在浏览器中输入www.aaa.com的时候访问的内网服务器192.168.10.38的80端口,输入www.ccc.com访问192.168.10.40的80端口的作用。这里有一个问题,我在内网服务器中其实是有三个80端口的,两个apache一个nginx都是80端口,这三个服务器对外的时候都是一个整体,都是80端口,那么在我从公网也就是外网去访问www.aaa.com或者去访问www.ccc.com,怎么能保证一定访问的就是nginx代理服务器呢?其中nginx代理服务器的内网IP是192.168.10.37,外网IP是210.22.3.91。

spacer.gifwKiom1hfelzx1wGrAAAwcRWO834711.png-wh_50

那么先抛开这些问题不说,首先说一说原理,nginx反向代理时,客户端即外网是完全不知道内网服务器的存在的,也就是说他只是按照DNS服务器的解析,去访问www.aaa.com时,直接就去找210.22.3.91这个IP,nginx看请求是www.aaa.com,在代理配置中去找,其实是对应着内网192.168.10.38:80,于是nginx就去将这个页面的内容拿过来作为自己的东西给访问者,好像这些内容本身就是他自己的一样。对访问者而言,nginx代理服务器就是“他要的那个服务器”

根据原理我个人认为需要在其余两台apache服务器建立防火墙,即只允许nginx服务器对其80端口进行访问,而其余主机对80端口的访问一律拒绝。这样就可以解决外网主机去访问www.aaa.com或者www.ccc.com,会直接转到nginx代理服务器上。从而让nginx代理服务器发挥作用。

本文转自飞奔的小GUI博客51CTO博客,原文链接http://blog.51cto.com/9237101/1885952如需转载请自行联系原作者

ziwenzhou
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
相关文章
|
10月前
|
负载均衡 网络协议 算法
一文读懂什么是Nginx?它能否实现IM的负载均衡?
Nginx(及其衍生产品)是目前被大量使用的服务端反向代理和负载均衡方案,从某种意义上来讲,Nginx几乎是低成本、高负载Web服务端代名词。 如此深入人心的Nginx,很多人也想当然的认为,在IM或消息推送等场景下是否也能使用Nginx来解决负载均衡问题? 另外,即时通讯网的论坛和QQ群里也经常有人问起,Nginx是否能支持TCP、UDP、WebSocket的负载
296 4
|
负载均衡 算法 搜索推荐
Nginx 常用的负载均衡算法
【10月更文挑战第17天】在实际应用中,我们需要根据具体的情况来选择合适的负载均衡算法。同时,还可以结合其他的优化措施,如服务器健康检查、动态调整权重等,来进一步提高负载均衡的效果和系统的稳定性。
386 59
|
7月前
|
负载均衡 前端开发 应用服务中间件
Tomcat的负载均衡和动静分离(与nginx联动)
总的来说,负载均衡和动静分离是提高Web应用性能的两个重要手段。通过合理的配置和使用,我们可以让Web应用更好地服务于用户。
252 21
|
7月前
|
负载均衡 Java 应用服务中间件
Tomcat与Nginx的负载均衡与动静分离技巧
总的来说,Tomcat和Nginx各有各的优点,在负载均衡和动静分离这两方面它们都有很好的应用。灵活使用这两个工具能够让Web应用具有更好的扩展性和用户体验。
235 14
|
7月前
|
负载均衡 前端开发 JavaScript
LVS-DR模式、keepalived、Nginx与Tomcat合作,打造动静分离,高效负载均衡与高可用性
为了采用这样的架构,你需要对LVS-DR、Keepalived、Nginx与Tomcat有一定的理解和掌握,同时也需要投入一些时间去研究和配置,但是一旦你把它运行起来,你将会发现,这一切都是值得的。
324 11
|
缓存 负载均衡 算法
如何配置Nginx反向代理以实现负载均衡?
如何配置Nginx反向代理以实现负载均衡?
1185 152
|
9月前
|
负载均衡 算法 应用服务中间件
Nginx长连接负载均衡详细说明以及案例
本文详细介绍了Nginx长连接负载均衡的配置与原理。长连接(Keepalive)允许客户端和服务器保持连接,减少建立和关闭连接的开销。Nginx支持多种负载均衡算法,如轮询、IP哈希等。通过在Nginx配置文件中使用`upstream`模块和`keepalive`指令,可以实现长连接负载均衡,从而提高系统的性能和响应速度。示例配置展示了如何设置后端服务器组、长连接数及HTTP/1.1协议,确保连接复用,降低延迟。
587 5
|
10月前
|
存储 缓存 应用服务中间件
Nginx 响应头 Vary 的介绍与应用
`Vary` 头部字段在Web开发中扮演着重要角色,通过合理使用 `Vary`,可以优化缓存策略,提升Web应用的性能和响应速度。本文介绍了 `Vary` 头部字段的基本概念、作用、常见使用场景及其在Nginx中的配置方法。通过这些内容,希望读者能够更好地理解和应用 `Vary` 头部字段,提高Web应用的缓存效率和用户体验。
434 10
|
9月前
|
负载均衡 应用服务中间件 nginx
如何使用nginx实现负载均衡?
如何使用nginx实现负载均衡?
|
负载均衡 监控 应用服务中间件
除了 Nginx,还有以下一些常见的负载均衡工具
【10月更文挑战第17天】这些负载均衡工具各有特点和优势,在不同的应用场景中发挥着重要作用。选择合适的负载均衡工具需要综合考虑性能、功能、稳定性、成本等因素。
1968 56

热门文章

最新文章