配置还是非常简单的,充分体现了nginx的强大与配置的简单^^下面是大致的服务器结构图:
应用的最前端是一台nginx服务器,所有静态的内容都由nginx来处理,而将所有php的请求都分摊到下游的若干台运行php fastcgi守护进程的服务器中,这样可以以一种廉价的方案来实现对系统负载的分摊,扩展系统的负载能力。
三台php fastcgi服务器的ip地址分别为:
172.16.236.110 , 172.16.236.111, 172.16.236.112
运行php fastcgi进程时,需要让php-cgi监听到服务器的局域网地址(分别如上所示),而不是之前一般都是监听的本地地址(127.0.0.1)。以172.16.236.110这台服务器为例:
1
|
/usr/local/php5/bin/php-cgi -b 172.16.236.110:9000
|
或许你用spawn-fcgi来启动php-fcgi,那么就是这样(供参考,其实也就是修改监听的地址和端口即可):
1
|
/usr/local/lighttpd/bin/spawn-fcgi -f /usr/local/php5/bin/php-cgi -a 172.16.236.110 -p 9000
|
又或许你是用php-fpm来管理php-fcgi,那么你需要修改php-fpm的配置:
1
|
vi /usr/local/php5/etc/php-fpm.conf
|
找到这个配置项(其中的地址可能需要根据你自己环境来调整)
1
|
<value name="listen_address">127.0.0.1:9000</value>
|
修改为:
1
|
<value name="listen_address">172.16.236.110:9000</value>
|
修改完毕后,重启你的php-fpm进程。
然后按照上面的步骤,依次修改其他php fastcgi服务器。
php方面的工作暂时就是这些,下面修改nginx。
1
|
vi /usr/local/nginx/conf/nginx.conf
|
在配置文件的http段内增加类似如下的配置:
1
2
3
4
5
|
upstream myfastcgi {
server 172.16.236.110 weight=1;
server 172.16.236.111 weight=1;
server 172.16.236.112 weight=1;
}
|
我这里三台php fastcgi服务器的权重是相同的,所以其中的weight值都是1,如果你的php fastcgi服务器需要分主次,那么可以通过调整其weight值来达到目的。比如以第一台服务器为主,其他两台为辅,则就是这样:
1
2
3
4
5
|
upstream myfastcgi {
server 172.16.236.110 weight=1;
server 172.16.236.111 weight=2;
server 172.16.236.112 weight=2;
}
|
然后找到原来nginx关于php fastcgi配置的部分,比如:
1
2
3
4
5
6
|
location ~ \.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
|
将其中的fastcgi_pass那一段改为:
1
|
fastcgi_pass myfastcgi;
|
其中的myfastcgi也就是上面刚刚配置的php fastcgi均衡器的名字了。
完了以后,重启nginx即可。
简单吧,就通过这么几个简单的配置,就可以实现一个经济高效的nginx、多php-fcgi的负载均衡解决方案了。当然了,这样的方案运用到实际项目中还需要进行一些细化的配置,主要是php方面还需要进一步配置,我会在接下来的博客中记录现在项目的一些心得。
分享到:
相关推荐
首先,创建一个名为`fastcgi_params`的文件,存放在Nginx的配置目录下,如`/usr/local/nginx/conf`(Ubuntu存放在`/etc/nginx`),该文件定义了FastCGI的基本环境变量,如请求方法、查询字符串等。 接下来,在...
- **负载均衡**:对于高流量网站,可以考虑使用Nginx作为反向代理服务器,将请求分发到多个后端服务器上,实现负载均衡。 通过以上步骤,我们可以有效地搭建起Nginx与PHP(FastCGI)的集成环境,并对其进行优化,以...
Nginx是当前最流行的Web服务器软件之一,常用于搭建Web服务器、反向代理服务器、负载均衡器等。下面是Nginx的完整配置说明,涵盖基本配置、反向代理、FastCGI等方面的知识点。 一、基本配置 在配置文件中,我们...
本文详细介绍了如何使用 Nginx 进行负载均衡、动静分离以及请求日志打印配置,并讨论了日志自动切割、压缩和删除的方法。这些技术对于提高 Web 应用程序的性能和稳定性至关重要。在实际部署中,可以根据具体的业务...
在实现负载均衡方面,Nginx支持多种调度算法,可以将客户端的请求高效地分配到多个服务器上,从而提高系统的整体性能和可用性。 Nginx的负载均衡功能主要依赖于ngx_http_upstream_module模块。该模块允许定义一组...
若需要在单个域名下进一步实现项目间的负载均衡或反向代理,可以在Nginx配置中使用`upstream`模块。例如,如果你有两个项目实例运行在不同的端口,可以这样配置: ```conf upstream project1_servers { server ...
5. **负载均衡**:使用`upstream`模块可以实现负载均衡,如轮询、权重轮询、最少连接等策略,确保服务器间的负载均衡。 6. **日志优化**:通过调整`access_log`和`error_log`的日志级别,降低日志记录的频率,减轻...
Nginx负载均衡技术(4.2.2):Nginx的负载均衡功能可以将客户端请求智能地分布到多个后端服务器,以优化资源利用率,提高可用性和响应速度。常见的负载均衡策略包括轮询、权重轮询、最少连接数等。 在深入Nginx配置...
而优化配置则需要根据实际业务需求,结合负载均衡、缓存策略、安全防护等多个层面进行精细调整,以实现最佳性能和服务质量。通过不断学习和实践,我们可以更好地掌握Nginx的运用,为我们的网站提供强大的支持。
"nts"代表"Non-thread-safe",这意味着这个版本不支持多线程,通常与ISAPI或FastCGI一起使用。 接下来,我们将按照以下步骤配置环境: 1. **下载和解压软件包**: - 解压`nginx-1.0.15.zip`,这是Nginx的安装包。...
通过配置,Nginx可以将来自客户端的请求转发给后端的多个服务器,实现负载均衡,提高系统的可用性和可靠性。此外,Nginx还可以作为SSL/TLS终止点,减轻后端服务器的压力,并提供HTTP/2支持以优化性能。 总结,Nginx...
总结来说,Nginx配置涉及多个层面,包括全局、服务器和位置级别的指令,以及高级特性如负载均衡、反向代理等。理解并熟练掌握这些配置,能够帮助我们构建高效、安全的Web服务环境。在实际应用中,根据需求灵活调整`...
当然了Apache的 mod_proxy和mod_cache结合使用也可以实现对多台app server的反向代理和负载均衡,但是在并发处理方面apache还是没有 nginx擅长。 1)环境: a. 我们本地是Windows系统,然后使用VirutalBox安装
如果有多个Magento实例,可以通过upstream模块实现负载均衡: ```nginx upstream magento_servers { server 192.168.1.101:80 weight=2; server 192.168.1.102:80; } server { location / { proxy_pass ...
- **NFS共享存储**:为了提高文件系统的一致性和访问效率,可以在集群中配置NFS作为共享存储,使得多个Nginx服务器能够共享静态资源文件。 #### 三、负载均衡方案设计 负载均衡是提高Web服务稳定性和可用性的关键...