当前位置:首页 > 免费资源 > 正文内容

用Nginx 给Google App Engine 做负载均衡

admin16年前 (2010-05-16)免费资源738
周末突发奇想“能不能用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;                                                       
  •    }                                                                                                                      
  •  }   
  • ....  
  • 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;                                                                                                 
  •     ...                                                                                                
  •   }  
  • 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;                                                       
  •     }                                                                                                                      
  •   }  
  • 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应用都用单独的数据库的话,那就不是一个系统了。迫切期待大家想出好的解决方式。 来自:http://server.jzxue.com/http-iis-apache/201005/10-3767.html

    扫描二维码推送至手机访问。

    版权声明:本文由博赚恋吧资源站发布,如需转载请注明出处。

    本文链接:https://www.432l.com/post/2492.html

    分享给朋友:

    相关文章

    QQ积分夺金转转转,红钻免费玩3次

    50积分玩1次;80积分玩2次;188积分玩5次;红钻免费玩3次。 1、本活动面向所有QQ积分用户,活动时间:即日起至2009年06月30日。 2、活动期间,红钻用户可免费领取3次夺金机会。 3、请在兑换完夺金机会后24小时内使用,逾期作废,积分不予退还。 4、活动中如您获得QQ秀购物券、QQ秀物品、QQ空间物品、积分等虚拟物品,我们将在48小时内赠送,请在注意查询; 5、获得实物奖品的...

    relianceicall(免费电话)无限拨打;注册使用图文教程

    Relianceicall是一款支持SIP协议的网络电话,也是站长最新发现的一款通话质量还不错的免费网络电话,在申请其账户后,可以利用X-lite这款SIP网络电话软件,来绑定Relianceicall账号,无需申请使用VPN即可免费拨打电话了,本站独家推出 Relianceicall 注册下载及拨打电话图文教程,经站长亲自测试可用,现发布给大家,以飨支持一流免费电话吧的广大网友。  关于reli...

    Liondrive - 支持FTP的5G免费外链硬盘

    Liondrive(狮子硬盘)是一家新推出的免费网络硬盘,注册非常简单(在首页右下角填写用户名、密码、邮箱即可)。Liondrive虽然功能不算多,但却很强大,支持FTP、Web方式上传管理文件,对于你上传的ZIP压缩文件可以直接查看ZIP压缩文件中的内容,最吸引人的是完全支持外链!你可以把Liondrive当做免费FTP空间、免费外链相册、免费MP3音乐外链空间(具有Flash播放器,你可以用i...

    FreeSMF—可绑自己域名的免费论坛申请

    FreeSMF.org提供使用者免费的Simple Machines Forum申请服务,透过注册-˃收取密码信-˃登入帐号便可以管理一个属于你自己的论坛。 FreeSMF.org提供使用者免费的Simple Machines Forum申请服务,透过注册-˃收取密码信-˃登入帐号便可以管理一个属于你自己的免费论坛。而SMF也支援中文介面,只要在注册时选择Chinese-Traditional便可...

    Filefront提供免费无限多媒体存储空间

    Filefront是来自美国的一个比较老牌的免费多媒体存储空间,其存储空间大小无限制,服务器位于加利福尼亚洲。提供图片空间、文件存储空间、视频存储空间、以及博客服务。 可上传JPG,GIF,PNG等格式的图片到图片存储空间中,图片支持外链,单张上传图片大小无限制。支持批量上传图片,一次最多可上传100张图片。可对图片进行隐私设置。还可上传任何格式的文件到文件存储空间和视频空间中,支持文...

    飞信两周年活动送话费

    飞信两周年活动送话费*  活动时间:2009年5月21日至6月26日的周一至周五(周末及法定假期除外);    * 活动期间,每天(周三除外)15点-17点保持飞信PC客户端在线,或15点30-16点30保持手机客户端在线的用户,将有机会抽取每日幸运奖,奖品为中国移动10元充值卡一张(每日100名);周三参与活动将有机会获得周三幸运奖,奖品为中国移动30元充...

    评论列表

    济南seo
    16年前 (2010-05-16)

    真精彩!
    o(∩_∩)o

    RichardJulianne31
    16年前 (2010-05-19)

    I took my first http://lowest-rate-loans.com when I was 20 and this helped my business a lot. Nevertheless, I need the short term loan as well.

    发表评论

    访客

    ◎欢迎参与讨论,请在这里发表您的看法和观点。