使用Nginx给GAE(Google App Engine)做负载均衡

2023-10-18 09:50

本文主要是介绍使用Nginx给GAE(Google App Engine)做负载均衡,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

周末突发奇想“能不能用nginx给自己的多个Google App Enine (以下简称GAE)应用作负载均衡呢?”想想蛮有意思的,动手试试看吧,不过这是我第一次用nginx做负载均衡,也是玩玩而已,我还没有那么大访问量的 应用。

关于nginx的介绍,维基百科,百度百科和官网都能找到,国内的张晏写了个很详细的用nignx 搭建Web服务器的教程:《Nginx + PHP (FastCGI)搭建胜过Apache十倍的Web服务器》,也是得益于这个教程,我才顺利的在vps上用nginx搭建好了web服务器,在此表示感谢。

负载均衡听起来貌似很复杂,很深奥的技术,等你亲自尝试一番之后会发现:其实在nginx上配置比较简单。

好了,下面就进入到我们这个系统吧,我们要架构的整个系统的结构如下:


步骤1.配置nginx代理访问GAE应用

首先,我们要配置多个代理(你有多少个GAE应用配额就可以设置多少个代理),直接通过IP访问GAE的应用是行不通的,因为Google的服务器 无法辨认是哪个应用,所以我们要使用nginx做代理,每个代理的配置方式如下:

server
{
listen 8081;
location / {
proxy_pass http://app1.appspot.com;
proxy_set_header Host “app1.appspot.com”;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
….

上面配置中设置主机头是关键配置,它应该设置为你GAE应用的原始域名,一般是xxx.appspot.com。当你重新nginx配置后,你将可 以通过8081端口访问你的GAE应用。

步骤2.配置负载均衡

nginx负载均衡是通过添加upstream{..}配置节来实现的,我配置了一个最简单的负载均衡方式:

upstream backend
{
server 127.0.0.1:8081;

}

可以看到,上面可以配置多个server字段,因为在前面配置了多个代理,它们各自使用的端口不同。关于Server,据我所知有两种类型:

1.每个Server的ip不同,开始我给每个代理分配了一个域名,然后试图通过不同域名来区分server,失败了,这个还有待研究,有了解的朋 友请不吝赐教。

2.每个Server的端口号不同,这个就是我们上面采取的方式了。

Server除了配置地址参数外,还有其他很重要的参数,比如设置每个Server的权重,是否为备份server等等,需要知道更详细的,建议看官方wiki。大家也可以尝试多种配置,做做实验嘛~~

步骤3.配置应用的总入口

其他配置都准备就绪了,就差一个应用的入口点,也就是访问这个系统的域名,我的配置如下:

server {
listen 80;
server_name g.ooq.me;
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;
}
}

到这里所有的配置也就完了,重新加载一下nginx的配置文件,这个系统就启动了。

小结

搭建这个系统有诸多好处:

1.可以免费使用多个GAE跑一个应用。

2.一个很好的学习nginx负载均衡的配置的实验环境。

3.永远不用担心GAE被封掉,只要确保你的vps能访问。

缺点也是存在的:

1.企业级的应用暂时是不可能的了,就算有也不用这么麻烦,GAE本就是云计算应用,Google已经做了负载均衡,也就只能个人玩玩,做个博客什 么的还是很好的选择。

2.带宽的问题,我的vps是在美国,ping了一下GAE的服务器只要6-8ms,还算是比较满意的,如果你的vps是在国内的话,估计速度会成 问题。

3.数据库的共享是一个比较复杂的问题,如果每个GAE应用都用单独的数据库的话,那就不是一个系统了。迫切期待大家想出好的解决方式。

作者:lloydsheng

永久链接 : http://www.ha97.com/1747.html

本文相关评论 - 才 5 条评论
RSS for this comments | Trackback URI
( 展开所有评论 | 收起所有评论 ) 立刻发表评论 »

发现问题
2010-09-14 09:54:23
Internet Explorer 8.0 Internet Explorer 8.0 Windows XP Windows XP

Hi,GOOGLE搜到你这个博客的,我们的思路一样,我之前也是这样想的,并且配置成功了,但是有一个比较有意思的问题,GOOGLE将我的VPS的IP加到应用程序的blacklist里面了。
请看:
No blacklists are defined for this application.
You can define blacklists in dos.yaml (Python) or dos.xml (Java). Learn more about blacklists.
Top 25 visitors (last 45 minutes). IP address Number of requests
204.74.*.* 79

我将我的IP后两位用*号隐掉了,由于是采用反向代理的,流量都是从我的VPS的IP去访问GAE,于是GOOGLE将我的VPS的IP加到黑名单里面了,而且这是自动的,我想手工把黑名单删除,可GOOGLE不给我这个权限,于是得出一个结论,GOOGLE考虑过这种模式,并且有应对方案,我看除非我能将我的VPS的IP加到白名单里面,否则这种VPS给GAE应用做负载均衡的模式不可行。就算你能配置成功,但是没一会GOOGLE就将你的VPS的IP给加到应用的黑名单里面了。

这篇关于使用Nginx给GAE(Google App Engine)做负载均衡的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/231789

相关文章

Golang interface{}的具体使用

《Golanginterface{}的具体使用》interface{}是Go中可以表示任意类型的空接口,本文主要介绍了Golanginterface{}的具体使用,具有一定的参考价值,感兴趣的可以了... 目录一、什么是 interface{}?定义形China编程式:二、interface{} 有什么特别的?✅

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

Spring 缓存在项目中的使用详解

《Spring缓存在项目中的使用详解》Spring缓存机制,Cache接口为缓存的组件规范定义,包扩缓存的各种操作(添加缓存、删除缓存、修改缓存等),本文给大家介绍Spring缓存在项目中的使用... 目录1.Spring 缓存机制介绍2.Spring 缓存用到的概念Ⅰ.两个接口Ⅱ.三个注解(方法层次)Ⅲ.

PyTorch中cdist和sum函数使用示例详解

《PyTorch中cdist和sum函数使用示例详解》torch.cdist是PyTorch中用于计算**两个张量之间的成对距离(pairwisedistance)**的函数,常用于点云处理、图神经网... 目录基本语法输出示例1. 简单的 2D 欧几里得距离2. 批量形式(3D Tensor)3. 使用不

Nginx 413修改上传文件大小限制的方法详解

《Nginx413修改上传文件大小限制的方法详解》在使用Nginx作为Web服务器时,有时会遇到客户端尝试上传大文件时返回​​413RequestEntityTooLarge​​... 目录1. 理解 ​​413 Request Entity Too Large​​ 错误2. 修改 Nginx 配置2.1

C#使用MQTTnet实现服务端与客户端的通讯的示例

《C#使用MQTTnet实现服务端与客户端的通讯的示例》本文主要介绍了C#使用MQTTnet实现服务端与客户端的通讯的示例,包括协议特性、连接管理、QoS机制和安全策略,具有一定的参考价值,感兴趣的可... 目录一、MQTT 协议简介二、MQTT 协议核心特性三、MQTTNET 库的核心功能四、服务端(BR

使用@Cacheable注解Redis时Redis宕机或其他原因连不上继续调用原方法的解决方案

《使用@Cacheable注解Redis时Redis宕机或其他原因连不上继续调用原方法的解决方案》在SpringBoot应用中,我们经常使用​​@Cacheable​​注解来缓存数据,以提高应用的性能... 目录@Cacheable注解Redis时,Redis宕机或其他原因连不上,继续调用原方法的解决方案1

Web技术与Nginx网站环境部署教程

《Web技术与Nginx网站环境部署教程》:本文主要介绍Web技术与Nginx网站环境部署教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Web基础1.域名系统DNS2.Hosts文件3.DNS4.域名注册二.网页与html1.网页概述2.HTML概述3.

java中XML的使用全过程

《java中XML的使用全过程》:本文主要介绍java中XML的使用全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录什么是XML特点XML作用XML的编写语法基本语法特殊字符编写约束XML的书写格式DTD文档schema文档解析XML的方法​​DOM解析XM