• 欢迎访问MACD实战投资网站,推荐使用最新版谷歌Chrome浏览器访问本网站,关注公众号 丁火甲木庚金 www.macd11.com/subscriptions

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

未分类 智子论道 15年前 (2010-07-17) 2732次浏览 5个评论

周末突发奇想“能不能用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


macd11.com 和 丁火甲木庚金 公众号版权所有丨如未注明 , 均为原创丨转载请注明原文链接。
喜欢 (0)
[sp91@qq.com]
分享 (0)

您必须 登录 才能发表评论!

(5)个小伙伴在吐槽
  1. 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给加到应用的黑名单里面了。
    发现问题2010-09-14 09:54
    • 这种情况偶不清楚,本文的方法偶只测试过一次,并没有长期去部署~~
    • 不是加入黑名单,只是提示你,这个ip是经常访问的,提示你是不是把它加入黑名单.不用管即可
      DYG2011-06-10 19:48
  2. 学习了,nginx做负载确实不错!
    Sky2010-09-25 09:01