使用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

相关文章

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

C#中Guid类使用小结

《C#中Guid类使用小结》本文主要介绍了C#中Guid类用于生成和操作128位的唯一标识符,用于数据库主键及分布式系统,支持通过NewGuid、Parse等方法生成,感兴趣的可以了解一下... 目录前言一、什么是 Guid二、生成 Guid1. 使用 Guid.NewGuid() 方法2. 从字符串创建

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客