nginx负载均衡怎么访问数据库

作者&投稿:洪冠 (若有异议请与网页底部的电邮联系)
nginx负载均衡怎么访问数据库~

  nginx 是一个轻量级的、高性能的 web server 主要可以干两件事情:

  1、直接作为http server(代替apache,对PHP需要FastCGI处理器支持);
  2、作为反向代理服务器实现负载均衡

  以下我们就来举例说明如何使用 nginx 实现负载均衡。因为nginx在处理并发方面的优势,现在这个应用非常常见。当然了Apache的 mod_proxy和mod_cache结合使用也可以实现对多台app server的反向代理和负载均衡,但是在并发处理方面apache还是没有 nginx擅长。

  方法/步骤
  1
  一、环境:
  a. 我们本地是Windows系统,然后使用VirutalBox安装一个虚拟的Linux系统。
  在本地的Windows系统上分别安装nginx(侦听8080端口)和apache(侦听80端口)。在虚拟的Linux系统上安装apache(侦听80端口)。
  这样我们相当于拥有了1台nginx在前端作为反向代理服务器;后面有2台apache作为应用程序服务器(可以看作是小型的server cluster。;-) );

  b. nginx用来作为反向代理服务器,放置到两台apache之前,作为用户访问的入口;
  nginx仅仅处理静态页面,动态的页面(php请求)统统都交付给后台的两台apache来处理。
  也就是说,可以把我们网站的静态页面或者文件放置到nginx的目录下;动态的页面和数据库访问都保留到后台的apache服务器上。

  c. 如下介绍两种方法实现server cluster的负载均衡。
  我们假设前端nginx(为127.0.0.1:80)仅仅包含一个静态页面index.html;
  后台的两个apache服务器(分别为localhost:80和158.37.70.143:80),一台根目录放置phpMyAdmin文件夹和test.php(里面测试代码为print “server1“;),另一台根目录仅仅放置一个test.php(里面测试代码为 print “server2“;)。

  2
  二、针对不同请求 的负载均衡:
  a. 在最简单地构建反向代理的时候 (nginx仅仅处理静态不处理动态内容,动态内容交给后台的apache server来处理),我们具体的设置为:在nginx.conf中修改:
  复制代码 代码如下:
  location ~ \.php$ {
  proxy_pass 158.37.70.143:80 ;
  }
  这样当客户端访问localhost:8080/index.html的时候,前端的nginx会自动进行响应;
  当用户访问localhost:8080/test.php的时候(这个时候nginx目录下根本就没有该文件),但是通过上面的设置 location ~ \.php$(表示正则表达式匹配以.php结尾的文件,详情参看location是如何定义和匹配的) ,nginx服务器会自动pass给 158.37.70.143的apache服务器了。该服务器下的test.php就会被自动解析,然后将html的结果页面返回给nginx,然后 nginx进行显示(如果nginx使用memcached模块或者squid还可以支持缓存),输出结果为打印server2。
  如上是最为简单的使用nginx做为反向代理服务器的例子;
  b. 我们现在对如上例子进行扩展,使其支持如上的两台服务器。
  我们设置nginx.conf的server模块部分,将对应部分修改为:
  复制代码 代码如下:
  location ^~ /phpMyAdmin/ {
  proxy_pass 127.0.0.1:80 ;
  }
  location ~ \.php$ {
  proxy_pass 158.37.70.143:80 ;
  }
  上面第一个部分location ^~ /phpMyAdmin/,表示不使用正则表达式匹配(^~),而是直接匹配,也就是如果客户端访问的 URL是以http://localhost:8080/phpMyAdmin/ 开头的话(本地的nginx目录下根本没有phpMyAdmin目录),nginx会自动pass到127.0.0.1:80 的Apache服务器,该服务器对phpMyAdmin目录下的页面进行解析,然后将结果发送给nginx,后者显示;
  如果客户端访问URL是http://localhost/test.php 的话,则会被pass到158.37.70.143:80 的apache进行处理。
  因此综上,我们实现了针对不同请求的负载均衡。
  如果用户访问静态页面index.html,最前端的nginx直接进行响应;
  如果用户访问test.php页面的话,158.37.70.143:80 的Apache进行响应;
  如果用户访问目录phpMyAdmin下的页面的话,127.0.0.1:80 的Apache进行响应;

  3
  三、 访问同一页面 的负载均衡:
  即用户访问http://localhost:8080/test.php 这个同一页面的时候,我们实现两台服务器的负载均衡 (实际情况中,这两个服务器上的数据要求同步一致,这里我们分别定义了打印server1和server2是为了进行辨认区别)。
  a. 现在我们的情况是在windows下nginx是localhost侦听8080端口;
  两台apache,一台是127.0.0.1:80(包含test.php页面但是打印server1),另一台是虚拟机的158.37.70.143:80(包含test.php页面但是打印server2)。

  b. 因此重新配置nginx.conf为:
  首先在nginx的配置文件nginx.conf的http模块中添加,服务器集群server cluster(我们这里是两台)的定义:
  复制代码 代码如下:
  upstream myCluster {
  server 127.0.0.1:80 ;
  server 158.37.70.143:80 ;
  }
  表示这个server cluster包含2台服务器
  〉然后在server模块中定义,负载均衡:
  复制代码 代码如下:
  location ~ \.php$ {
  proxy_pass http://myCluster ; #这里的名字和上面的cluster的名字相同
  proxy_ www.gzlij.comredirect off;
  proxy_set_header Host $host;
  proxy_set_header X-Real-IP $remote_addr;
  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }
  这样的话,如果访问http://localhost:8080/test.php 页面的话,nginx目录下根本没有该文件,但是它会自动将其pass到myCluster定义的服务区机群中,分别由127.0.0.1:80;或者158.37.70.143:80;来做处理。
  上面在定义upstream的时候每个server之后没有定义权重,表示两者均衡;如果希望某个更多响应的话例如:
  复制代码 代码如下:
  upstream myCluster {
  server 127.0.0.1:80 weight=5;
  server 158.37.70.143:80 ;
  }

  4
  综上,我们使用nginx的反向代理服务器reverse proxy server的功能,将其布置到多台apache server的前端。
  nginx仅仅用来处理静态页面响应和动态请求的代理pass,后台的apache server作为app server来对前台pass过来的动态页面进行处理并返回给nginx。
  通过以上的架构,我们可以实现nginx和多台apache构成的机群cluster的负载均衡。
  两种均衡:
  1)可以在nginx中定义访问不同的内容,代理到不同的后台server; 如上例子中的访问phpMyAdmin目录代理到第一台server上;访问test.php代理到第二台server上;
  2)可以在nginx中定义访问同一页面,均衡 (当然如果服务器性能不同可以定义权重来均衡)地代理到不同的后台server上。 如上的例子访问test.php页面,会均衡地代理到server1或者server2上。
  实际应用中,server1和server2上分别保留相同的app程序和数据,需要考虑两者的数据同步。

我的负载均衡是这样实现的。
upstream abc#com {
server 1.2.3.1:80;
server 1.2.3.4:80; }
server {
listen 80;
server_name abc#com;
location / {
proxy_pass abc#com/;
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 是一个轻量级的、高性能的 web server 主要可以干两件事情:

  1、直接作为http server(代替apache,对PHP需要FastCGI处理器支持);
  2、作为反向代理服务器实现负载均衡

  以下我们就来举例说明如何使用 nginx 实现负载均衡。因为nginx在处理并发方面的优势,现在这个应用非常常见。当然了Apache的 mod_proxy和mod_cache结合使用也可以实现对多台app server的反向代理和负载均衡,但是在并发处理方面apache还是没有 nginx擅长。

  方法/步骤
  1
  一、环境:
  a. 我们本地是Windows系统,然后使用VirutalBox安装一个虚拟的Linux系统。
  在本地的Windows系统上分别安装nginx(侦听8080端口)和apache(侦听80端口)。在虚拟的Linux系统上安装apache(侦听80端口)。
  这样我们相当于拥有了1台nginx在前端作为反向代理服务器;后面有2台apache作为应用程序服务器(可以看作是小型的server cluster。;-) );

  b. nginx用来作为反向代理服务器,放置到两台apache之前,作为用户访问的入口;
  nginx仅仅处理静态页面,动态的页面(php请求)统统都交付给后台的两台apache来处理。
  也就是说,可以把我们网站的静态页面或者文件放置到nginx的目录下;动态的页面和数据库访问都保留到后台的apache服务器上。

  c. 如下介绍两种方法实现server cluster的负载均衡。
  我们假设前端nginx(为127.0.0.1:80)仅仅包含一个静态页面index.html;
  后台的两个apache服务器(分别为localhost:80和158.37.70.143:80),一台根目录放置phpMyAdmin文件夹和test.php(里面测试代码为print “server1“;),另一台根目录仅仅放置一个test.php(里面测试代码为 print “server2“;)。

  2
  二、针对不同请求 的负载均衡:
  a. 在最简单地构建反向代理的时候 (nginx仅仅处理静态不处理动态内容,动态内容交给后台的apache server来处理),我们具体的设置为:在nginx.conf中修改:
  复制代码 代码如下:
  location ~ \.php$ {
  proxy_pass 158.37.70.143:80 ;
  }
  这样当客户端访问localhost:8080/index.html的时候,前端的nginx会自动进行响应;
  当用户访问localhost:8080/test.php的时候(这个时候nginx目录下根本就没有该文件),但是通过上面的设置 location ~ \.php$(表示正则表达式匹配以.php结尾的文件,详情参看location是如何定义和匹配的) ,nginx服务器会自动pass给 158.37.70.143的apache服务器了。该服务器下的test.php就会被自动解析,然后将html的结果页面返回给nginx,然后 nginx进行显示(如果nginx使用memcached模块或者squid还可以支持缓存),输出结果为打印server2。
  如上是最为简单的使用nginx做为反向代理服务器的例子;
  b. 我们现在对如上例子进行扩展,使其支持如上的两台服务器。
  我们设置nginx.conf的server模块部分,将对应部分修改为:
  复制代码 代码如下:
  location ^~ /phpMyAdmin/ {
  proxy_pass 127.0.0.1:80 ;
  }
  location ~ \.php$ {
  proxy_pass 158.37.70.143:80 ;
  }
  上面第一个部分location ^~ /phpMyAdmin/,表示不使用正则表达式匹配(^~),而是直接匹配,也就是如果客户端访问的 URL是以http://localhost:8080/phpMyAdmin/ 开头的话(本地的nginx目录下根本没有phpMyAdmin目录),nginx会自动pass到127.0.0.1:80 的Apache服务器,该服务器对phpMyAdmin目录下的页面进行解析,然后将结果发送给nginx,后者显示;
  如果客户端访问URL是http://localhost/test.php 的话,则会被pass到158.37.70.143:80 的apache进行处理。
  因此综上,我们实现了针对不同请求的负载均衡。
  如果用户访问静态页面index.html,最前端的nginx直接进行响应;
  如果用户访问test.php页面的话,158.37.70.143:80 的Apache进行响应;
  如果用户访问目录phpMyAdmin下的页面的话,127.0.0.1:80 的Apache进行响应;

  3
  三、 访问同一页面 的负载均衡:
  即用户访问http://localhost:8080/test.php 这个同一页面的时候,我们实现两台服务器的负载均衡 (实际情况中,这两个服务器上的数据要求同步一致,这里我们分别定义了打印server1和server2是为了进行辨认区别)。
  a. 现在我们的情况是在windows下nginx是localhost侦听8080端口;
  两台apache,一台是127.0.0.1:80(包含test.php页面但是打印server1),另一台是虚拟机的158.37.70.143:80(包含test.php页面但是打印server2)。

  b. 因此重新配置nginx.conf为:
  首先在nginx的配置文件nginx.conf的http模块中添加,服务器集群server cluster(我们这里是两台)的定义:
  复制代码 代码如下:
  upstream myCluster {
  server 127.0.0.1:80 ;
  server 158.37.70.143:80 ;
  }
  表示这个server cluster包含2台服务器
  〉然后在server模块中定义,负载均衡:
  复制代码 代码如下:
  location ~ \.php$ {
  proxy_pass http://myCluster ; #这里的名字和上面的cluster的名字相同
  proxy_ www.gzlij.comredirect off;
  proxy_set_header Host $host;
  proxy_set_header X-Real-IP $remote_addr;
  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }
  这样的话,如果访问http://localhost:8080/test.php 页面的话,nginx目录下根本没有该文件,但是它会自动将其pass到myCluster定义的服务区机群中,分别由127.0.0.1:80;或者158.37.70.143:80;来做处理。
  上面在定义upstream的时候每个server之后没有定义权重,表示两者均衡;如果希望某个更多响应的话例如:
  复制代码 代码如下:
  upstream myCluster {
  server 127.0.0.1:80 weight=5;
  server 158.37.70.143:80 ;
  }

  4
  综上,我们使用nginx的反向代理服务器reverse proxy server的功能,将其布置到多台apache server的前端。
  nginx仅仅用来处理静态页面响应和动态请求的代理pass,后台的apache server作为app server来对前台pass过来的动态页面进行处理并返回给nginx。
  通过以上的架构,我们可以实现nginx和多台apache构成的机群cluster的负载均衡。
  两种均衡:
  1)可以在nginx中定义访问不同的内容,代理到不同的后台server; 如上例子中的访问phpMyAdmin目录代理到第一台server上;访问test.php代理到第二台server上;
  2)可以在nginx中定义访问同一页面,均衡 (当然如果服务器性能不同可以定义权重来均衡)地代理到不同的后台server上。 如上的例子访问test.php页面,会均衡地代理到server1或者server2上。
  实际应用中,server1和server2上分别保留相同的app程序和数据,需要考虑两者的数据同步。


nginx在做负载均衡时如何配置 nginx的负载均衡怎么配置
5、配置文件配置好以后,使用nginx -t命令测试一下配置文件,保证配置文件是ok状态,然后执行nginx命令启动nginx服务器。6、启动后在浏览器上输入前端web服务器的ip地址192.168.1.210,然后可以看到第一次是node1响应的,然后刷新一下以后,又变成了node2响应的。就这样实现了负载均衡的效果。由两个服务...

Nginx负载均衡配置、限流配置、Https配置详解
Nginx负载均衡、限流配置、Https详解 Nginx通过负载均衡模块实现实时转发,upstream是关键,支持轮询、权重、ip_hash和url_hash等算法。例如,轮询可以按顺序在多个后端服务(如9001-9003)间转发,权重策略则让某些服务更优先处理。ip_hash确保同一IP固定访问一个Server,适合处理Session问题,但可能导致压力不...

nginx在做负载均衡时如何配置nginx的负载均衡怎么配置
3. 配置好前端web服务器的负载均衡设置。首先,在默认的nginx配置文件中,通过添加http块内的upstream指令,定义了名为backend的负载均衡集群,并记录下这个名称。4. 接下来,编辑默认的server配置文件,将所有指向192.168.1.210的流量代理到backend集群。5. 保存配置文件后,使用nginx -t命令测试配置的正...

nginx负载均衡的三种方式
nginx负载均衡的三种方式包括轮询(round robin)、IP哈希(IP hash)以及最少连接(least connections)。1. 轮询(Round Robin):这是nginx默认的负载均衡方式。当请求到来时,nginx按照服务器列表的顺序,将请求依次分配到各个服务器上。当所有服务器都已接收到请求后,nginx再次回到列表的起始位置,进行...

Nginx的负载均衡模式有哪几种
Nginx的负载均衡模式有以下几种:轮询(round-robin):每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器 down 掉,能自动剔除。这种模式适用于后端服务器性能相近的情况。加权轮询(weighted round-robin):指定轮询几率,weight 和访问比率成正比,用于后端服务器性能不均的情况。这种模式可以...

反向代理负载均衡nginx 实现反向代理负载均衡
方法一:通过配置nginx的负载均衡模块,可以根据请求的URL、源IP地址或其他特定参数,将流量均匀地分配到两台Apache服务器上,确保每台服务器都能处理一部分请求,避免单点过载。方法二:利用轮询策略,nginx按顺序轮流将请求发送给后端的每台Apache服务器,这样可以保证所有服务器都有机会处理请求,实现负载...

Nginx如何优雅的实现负载均衡!(建议收藏)
项目准备:Nginx与SpringBoot的集成负载均衡环境。使用作者的SpringBoot项目作为实例(可于github查找)。首先下载项目并打包为jar文件,配置application.properties,并将原文件夹及其内容复制(实际操作中无需真正复制,仅修改端口或重新配置即可)。使用如mvn clean package等命令进行打包,并修改复制文件夹中的...

nginx负载均衡原理
负载均衡在服务端开发中是一个比较重要的特性,除了作为常规的Web服务器外,还被大规模的用于反向代理前端。Nginx是一款轻量级的Web服务器或反向代理服务器及电子邮件代理服务器,在BSDlike协议下发行。其特点是占有内存少,并发能力强nginx仅仅用来处理静态页面响应和动态请求的代理pass,后台的apacheserver作为...

nginx--正向代理、反向代理及负载均衡(图解+配置)
Nginx作为高性能的web服务器,不仅支持反向代理,还具备正向代理和负载均衡功能。正向代理通过代理客户端的请求,隐藏用户真实IP;反向代理则隐藏应用服务器,由代理服务器进行请求转发和负载均衡。理解这两种代理方式,可以从直观的图片中获知其工作原理。配置实践 正向代理配置涉及对https请求的支持,需安装...

几种Nginx实现负载均衡的方式
1、轮询(Nginx自带、默认)该策略是Nginx默认的负载均衡策略,每一个客户端请求按时间顺序轮流分配到不同的服务器上,如果后端服务不可以用,会自动过滤掉。upstream my_test_server { server 192.168.0.100:8080;server 192.168.0.101:8080;} 2、weight 权重(Nginx自带)weight代表权重的意思,...

王益区13993906370: nginx环境navicat怎么连接数据库 -
种玲二十: nginx环境navicat怎么连接数据库 根据你所说的,只能说明OPC服务端是开着的,没办法证明你DCOM已经配置好.所以建议你: 1,检查相同的用户名和密码是否都具有管理员权限; 2,检查两台机器是否防火墙已经关闭; 3,检查两台机器的访问模式是否是经典形式; 4,检查DCOM配置中的权限设置.可以去网上搜索下载个matrikonopcsimulation,来帮助你进行DCOM配置.

王益区13993906370: 利用nginx实现Redis的负载均衡,应该怎么配置? -
种玲二十: 网络的负载均衡是一种动态均衡技术,通过一些工具实时地分析数据包,掌握网络中的数据流量状况,把任务合理均衡地分配出去.这种技术基于现有网络结构,提供了一种扩展服务器带宽和增加服务器吞吐量的廉价有效的方法,加强了网络数...

王益区13993906370: nginx实现tomcat集群的负载均衡有几种方式 -
种玲二十: 一,如果仅是对外提供一个页面访问,不用区分单一用户(不区分每个访问session,不涉及用户权限,用户资料等内容),仅仅配置nginx负载均衡策略即可. nginx负载均衡策略主要分一下四种: 1)、轮询(默认) 每个请求按时间顺序逐一分...

王益区13993906370: nginx的ip hash负载均衡策略怎么配置 -
种玲二十: 这个是很正常的,ip_hash的负载均衡是以客户端的ip地址作为hash错作的key进而计算hash值得.这种策略能保证一个ip访问到的永远是同一台机器. (1)但是有一种情况就是多个ip的hash值是相同的,在这种情况下,这几个不同的ip访问到的就是同一台机器了. (2)还有一种情况就是,虽然你每次用不同的机器,但是这些机器都是通过一个相同的出口ip来访问服务器,这时,你访问到的也永远是一台服务器.

王益区13993906370: 如何访问nodejs服务器上的文件 -
种玲二十: 服务器推荐用nginx,配置简单,性能强悍.nginx可以使用代理访问后端的Node.js应用服务器.配置方法:1)在配置文件http段内容添加后端服务器:http{#添加后端服务器,和nginx负载均衡配置一样upstreamnodejs{server127.0.0.1:8080;}}2)给应用添加虚拟主机:server{listen80;server_nameIPlocation/{proxy_passnodejs;#名字和前面的对应,将所有的请求转发给后端的node}access_loglogs/nodejs.access.logmain;#如果需要日志的话}推荐将静态文件如css、js和图片和应用服务器分开.

王益区13993906370: nginx+tomcat负载均衡 -
种玲二十: 你想 问什么呢? 第一 你下载一个nginx 注册为服务以后 第二 在nginx的配置文件中配置server 就可以分发到那个tomcat上了 一个server对于一个tomcat

王益区13993906370: lvs+keepalived中的session如何共享 -
种玲二十: 如果有nginx负载,只要在nginx配置里面加上ip_hash就行了 如果是只有LVS ,LVS本身是没有这个功能的,可以考虑使用memcached 试试

王益区13993906370: nginx负载均衡时访问的端口是哪个端口 -
种玲二十: 你要设定一下访问后端服务器的方式,是轮询还是ip hash等,设置了才可以切换 server 110.41.90.143 weight=5 max_fails=3 fail_timeout=10s; server 110.41.90.138 weight=5 max_fails=3 fail_timeout=10s; 类似我写的这样,明白了吧

王益区13993906370: nginx使用URL hash进行负载均衡,如何在不影响hash结果的情况下实现高可用? -
种玲二十: 在使用 nginx的 cache时,使用 hash $request_uri; 再加一下行 hash_again 1; 注意,这个是Nginx的的三方模块算法,但是tengine的 consistent_hash 算法是不行的, 还是有连接转到故障后端,

王益区13993906370: 我用nginx配置webservice负载均衡,怎么弄 -
种玲二十: 简单的负载均衡配置 upstream backend { server backend1.example.com weight=5;#weight权重,权重越高发送到此台服务器的请求概率越大 server backend2.example.com:8080; server backup1.example.com:8080 backup;#backup备份服务器,只有在非backup服务器都不能访问时才会向此服务器分流

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网