Nginx简单实现网站的负载均衡

在大型网站搭建时,都会考虑如果用户量每日不断增加,大量的并发访问,会不会给网站、数据库带来崩盘的灾难。今天我们就讨论一下,现实中如何解决这些问题的一套最为容易实现的方案。

控制并发,大家都会首先考虑的就是分布式、负载均衡等经常听到的It名词。那网站如何才能实现负载均衡呢,除了世面上的一些负载均衡器外,我们有哪些软件上的解决方案呢,这时候,Nginx、lvs 等名词就会在脑海中浮现。那这些负载均衡的软件如何使用呢,如何读者是.net工程师,大家会选择Nginx,因为它支持Windows服务器,这时候,好多网友会批判一下,说lvs更好更优秀。其实大家不必太在意,其实都一样,只要你能掌控它们就Ok,各有优劣。Nginx配置简单,在中小型项目中使用更为方便,下面我们看下Niginx在Windows下的配置。

概述:使用Nginx搭建反向服务器,实现网站服务器集群负载均衡

1、下载Nginx——Windows版,(nginx-1.6.2.zip)

可以到Linux公社资源站下载:

------------------------------------------分割线------------------------------------------

免费下载地址在

用户名与密码都是

具体下载目录在 /2017年资料/2月/7日/Nginx简单实现网站的负载均衡/

下载方法见

------------------------------------------分割线------------------------------------------

解压

Nginx简单实现网站的负载均衡

2、使用winsw-1.8-bin(windows服务工具).exe工具将Niginx发布成Domain模式,通过Windows服务的方式控制Niginx的运行。在博客末端可下载

(1)配置 winsw运行的Xml文件,如上图:将Winsw工具移植到解压的Niginx文件下,将工具名字修改成“nginxServer.exe”,创建一个xml配置文件“nginxServer.xml”文件,它跟工具的名字一致,当然你也可以不要改名字。xml文件如下:

<?xml version="1.0" encoding="UTF-8" ?>
<service>
<id>nginx</id>
<name>ngixServer</name>
<description>High Performance Nginx Service</description>
<executable>E:\2014newT\Practise\nginx1.62Server\nginx.exe</executable>
<logpath>E:\2014newT\Practise\nginx1.62Server\</logpath>
<logmode>roll</logmode>
<depend></depend>
<startargument>-p E:\2014newT\Practise\nginx1.62Server</startargument>
<stopargument>-p E:\2014newT\Practise\nginx1.62Server -s stop</stopargument>
</service>

winsw 文件配置

配置很简单主要指定Nginx.exe的位置\log位置等,可以谷歌一下Winsw看看具体的配置信息。

(2)点击nginxServer.exe安装服务,如果你是Win8以上的系统可能装不上,是因为兼容问题,调制兼容Win7模式,以管理员的身份运行即可,如图:

Nginx简单实现网站的负载均衡

这时查看Windows服务,启动NginxServer服务,如图:

这时,ngixServer服务成功启动了。

3、修改Nginx配置,将代理指向服务器集群,实现网站负载均衡

在解压的Nginx文件夹下找到conf/nginx.conf文件,打开进行配置:

#user  nobody;
worker_processes  4;#启动的线程数

#错误的位置和级别 
#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;#pid进程文件的位置 


events {
    worker_connections  1024;#每个进程的最大连接数 
}


http {
    include      mime.types;
    default_type  application/octet-stream;
    #nginx日志格式定义,在下面可以进行引用 
    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

#access_log  logs/access.log  main;

sendfile        on;
    #tcp_nopush    on;

#keepalive_timeout  0;
    keepalive_timeout  65;
    upstream linuxidc.com{
        server 127.0.0.1:8091;    #服务器集群A
        server 127.0.0.1:8092;    #服务器集群B
    }
    #gzip  on;

server {
        listen      8090;
        server_name  localhost;

#charset koi8-r;

#access_log  logs/host.access.log  main;

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/99f06900c89eee19edee023412d42340.html