linux安装nginx并配置负载均衡

安装nginx

                 官网下载安装包

http://nginx.org/en/download.html

将安装包拷贝到192.168.9.182服务器,解压到D盘

安装完成。

测试:

双击nginx.exe文件,然后用浏览器输入url:http://ip弹出如下界面即说明成功:

 

配置Nginx

配置文件为..\nginx-1.14.2\conf\nginx.conf

主要修改nginx的端口、配置负载均衡分配方法以及节点,如下:

如果web应用不支持session共享,分配方式使用ip_hash,绑定ip。缺点:此方法根据ip进行hash分配,这样每个用户访问的是固定的服务器,如果某台web服务器宕机,会导致部分用户访问不了,即使清除浏览器缓存依然不行。

#user  nobody;

worker_processes  1; # 工作进程的个数,一般与计算机的cpu核数一致 

 

#error_log  logs/error.log;

#error_log  logs/error.log  notice;

#error_log  logs/error.log  info;

 

#pid        logs/nginx.pid;

 

 

events {

    worker_connections  1024;     # 单个进程最大连接数(最大连接数 = 连接数 * 进程数)

}

 

 

http {

    include       mime.types;              # 文件扩展名与文件类型映射表

    default_type  application/octet-stream;         # 默认文件类型

 

    #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;   # 开启高效文件传输模式,sendfile指令指定nginx是否调用sendfile函数来输出文件,对于普通应用设为on,如果用来进行下载等应用磁盘IO重负载应用,可设置为off,以平衡磁盘与网络I/O处理速度,降低系统的负载。注意:如果图片显示不正常把这个改成off。

    #tcp_nopush     on;

 

    #keepalive_timeout  0;

    keepalive_timeout  65;            # 长连接超时时间,单位是秒

 

    #gzip  on;           # 启用Gizp压缩

 

    #服务器的集群 

    upstream myweb {  # 服务器集群名字  

              ip_hash;

        server    ip1:port  weight=1;    # 服务器配置   weight是权重的意思,权重越大,分配的概率越大。 

        server    ip2:port  weight=2; 

        server    ip3:port  weight=2; 

    }  

      

    # 当前的Nginx的配置      

    server {

        listen       8001;      # 监听端口,可以改成其他端口 默认80

        server_name  ip;        # 当前服务的域名

 

        #charset koi8-r;

 

        #access_log  logs/host.access.log  main;

 

        location / {

            #root   html;

            #index  index.html index.htm;

            proxy_pass http://myweb;               # 此处的地址保持和服务器集群名字一致 36行 upstream myweb

            proxy_redirect default;

                     proxy_set_header Host $host:8001; 

                     proxy_set_header X-Real-Ip $remote_addr; 

                     proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 

                     proxy_connect_timeout 3600;

                     proxy_read_timeout 3600;

                     proxy_send_timeout 3600;

        }

 

        #error_page  404              /404.html;

 

        # redirect server error pages to the static page /50x.html

        #

        error_page   500 502 503 504  /50x.html;

        location = /50x.html {

            root   html;

        }

 

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80

        #

        #location ~ \.php$ {

        #    proxy_pass   http://127.0.0.1;

        #}

 

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000

        #

        #location ~ \.php$ {

        #    root           html;

        #    fastcgi_pass   127.0.0.1:9000;

        #    fastcgi_index  index.php;

        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;

        #    include        fastcgi_params;

        #}

 

        # deny access to .htaccess files, if Apache's document root

        # concurs with nginx's one

        #

        #location ~ /\.ht {

        #    deny  all;

        #}

    }

 

 

    # another virtual host using mix of IP-, name-, and port-based configuration

    #

    #server {

    #    listen       8000;

    #    listen       somename:8080;

    #    server_name  somename  alias  another.alias;

 

    #    location / {

    #        root   html;

    #        index  index.html index.htm;

    #    }

    #}

 

 

    # HTTPS server

    #

    #server {

    #    listen       443 ssl;

    #    server_name  localhost;

 

    #    ssl_certificate      cert.pem;

    #    ssl_certificate_key  cert.key;

 

    #    ssl_session_cache    shared:SSL:1m;

    #    ssl_session_timeout  5m;

 

    #    ssl_ciphers  HIGH:!aNULL:!MD5;

    #    ssl_prefer_server_ciphers  on;

 

    #    location / {

    #        root   html;

    #        index  index.html index.htm;

    #    }

    #}

 

}

配置一个nginx控制台,用于在dos窗口中通过简单的命令重启nginx。

新建一个批处理文件,内容如下:

(之后重启nginx直接执行此文件并通过相应的命令进行操作即可)

控制面板界面如下:

 

 

====================================================

@echo off

rem 当前bat的作用

 

echo ==================begin========================

 

cls

SET NGINX_PATH=D:

SET NGINX_DIR=

color 0a

TITLE Nginx 管理程序控制面板

 

CLS

 

ECHO.

ECHO. * Nginx 管理程序 *

ECHO. * 创建时间2019/03/08 *

ECHO. * 当前时间%date:~0,10% *

ECHO.

 

:MENU

 

ECHO. * nginx 进程list *

tasklist|findstr /i "nginx.exe"

 

ECHO.

ECHO. [1] 启动Nginx

ECHO. [2] 关闭Nginx

ECHO. [3] 重启Nginx

ECHO. [4] 退 出

ECHO.

 

ECHO.请输入选择项目的序号:

set /p ID=

IF "%id%"=="1" GOTO start

IF "%id%"=="2" GOTO stop

IF "%id%"=="3" GOTO restart

IF "%id%"=="4" EXIT

PAUSE

 

:start

call :startNginx

GOTO MENU

 

:stop

call :shutdownNginx

GOTO MENU

 

:restart

call :shutdownNginx

call :startNginx

GOTO MENU

 

:shutdownNginx

ECHO.

ECHO.关闭Nginx......

taskkill /F /IM nginx.exe > nul

ECHO.OK,关闭所有nginx 进程

goto :eof

 

:startNginx

ECHO.

ECHO.启动Nginx......

IF NOT EXIST "%NGINX_DIR%nginx.exe" ECHO "%NGINX_DIR%nginx.exe"不存在

 

%NGINX_PATH%

 

cd "%NGINX_DIR%"

 

IF EXIST "%NGINX_DIR%nginx.exe" (

echo "start '' nginx.exe"

start "" nginx.exe

)

ECHO.OK

goto :eof

 

部署完成。

之后用户访问系统直接通过url

http://ip:8001/应用名/

进行访问,nginx会自动将用户分配到三台web服务器 ip1 ip2 ip3。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值