• Nginx的安装和设置


    Nginx是一个高性能的HTTP服务器和反向代理服务器。当一个服务器访问量太大时(比如C10k问题,Concurrent 10,000 Connection),就可以安装设置一个Nginx服务器,将客户端的访问映射到多个服务器上,从而降低每一个服务器的负载。

    1. Nginx的编译和安装

    在CentOS虚拟机(master)上下载nginx-1.13.1.tar.gz文件,用

    tar -zxvf 

    解压。依次输入

    ./configure
    make
    make install

    命令,编译并安装Nginx。安装的默认路径是/usr/local/nginx,编译和安装过程中还可以设置一些参数,这里就不详述了。

    2. Tomcat服务器设置

    在三台CentOS虚拟机(master、slave03、slave04)上均安装Tomcat服务器,为了能够看出来是映射到了哪一台服务器,需要修改Tomcat的默认页面。

    在${CATALINA_HOME}/webapps/下面新建一个目录myjsp文件夹,在文件夹下面新建一个index2.html:

    <html><head>
    <META http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
    <title>Apache Tomcat 7 (7.0.78) - Documentation Index</title>
    </head>
    
    <p>This is master!</p>
    
    </html>

    修改${CATALINA_HOME}/conf/server.xml:

          <Host name="localhost"  appBase="webapps"
                unpackWARs="true" autoDeploy="true">
    
          <Context path="" docBase="myjsp" debug="0" reloadable="true"/>
            <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
                   prefix="localhost_access_log." suffix=".txt"
                   pattern="%h %l %u %t &quot;%r&quot; %s %b" />
    
          </Host>

    最后修改${CATALINA_HOME}/conf/web.xml:

        <welcome-file-list>
          <welcome-file>index2.html</welcome-file>
            <welcome-file>index.html</welcome-file>
            <welcome-file>index.htm</welcome-file>
            <welcome-file>index.jsp</welcome-file>
        </welcome-file-list>

    3. Nginx的设置

    Nginx的设置主要通过配置文件/usr/local/nginx/conf/nginx.conf实现:

    #user hadoop hadoop;  
    #worker_processes 2;  
    #pid /pid/nginx.pid;   
    error_log /usr/local/nginx/logs/error.log debug;
    events {
        accept_mutex on;   
        multi_accept on;  
        #use epoll;      
        select|poll|kqueue|epoll|resig|/dev/poll|eventport
        worker_connections  512;    
    }
    http {
        include       mime.types;   
        #default_type  application/octet-stream; 
        #access_log off;     
        log_format myFormat '$remote_addr–$remote_user [$time_local] $request $status $body_bytes_sent $http_referer $http_user_agent $http_x_forwarded_for'; #自定义格式
        access_log log/access.log myFormat; 
        sendfile on;   
        #sendfile_max_chunk 100k; 
        keepalive_timeout 100;  
    
        upstream servers {  
          server master:18080 weight=4;
        server slave03:8080 weight=3;
        server slave04:8080 weight=3;
        }
        error_page 404 https://www.126.com; 
        server {
            keepalive_requests 120; 
            listen       18081;   
            server_name  master;          
            location  ~*^.+$ {      
               proxy_pass  http://servers;           
            } 
        }
    } 

    其中比较重要的是:

        upstream servers {  
          server master:18080 weight=4;
          server slave03:8080 weight=3;
          server slave04:8080 weight=3;
        }

    这实际上是定义了3个服务器及其端口号,后面的weight表示这个服务器被映射的权重,也可以使用下面的设置:

        upstream servers {
          ip_hash;
          server master:18080;
          server slave03:8080;
          server slave04:8080;
        }

    这样的设置根据库户端IP的Hash值来决定映射到哪一个服务器。

        server {
            keepalive_requests 120; 
            listen       18081;   
            server_name  master;          
            location  ~*^.+$ {      
               proxy_pass  http://servers;           
            } 
        }

    设置了监听的服务器名称以及端口号,以及映射的服务器的集合(为上面定义的servers),当Nginx监听到这个服务器及其端口有访问请求时,就会把这个请求映射到服务器集合里面的某一台服务器。

    4. Nginx的运行

    运行之前,先测试一下Nginx的设置是否正确,输入命令:

    nginx -t

    Successful说明设置是正确的!

    然后就可以启动了:

    nginx -c /usr/local/nginx/conf/nginx.conf

    启动以后,在浏览器的地址栏输入http://master:18081,并多次刷新,可以看见下面3个网页:

    并且这3个网页出现的概率差不多,master要稍微多一点,这是因为3个网页被访问的概率是4:3:3。

    5. Nginx停止运行

    首先输入命令查看Nginx的进程号:

    ps -ef | grep nginx

    然后可以用不同的方法结束这个进程:

    kill -QUIT PID
    kill -TERM PID
    pkill -9 nginx
  • 相关阅读:
    WebFrom 小程序【分页功能 】
    WebForm 【Repeater】展示数据
    WebForm 小项目【人员管理系统】分析
    WebFrom 【内置对象】— —跳转页面,页面传值
    WebForm 【复合控件】
    WebForm 【简单控件】【表单元素】
    WebForm 基础学习
    js对元素属性.内容的操作。定时器。元素的平级,父级,子集关系。
    常用事件【由浅入深】1
    document 对象
  • 原文地址:https://www.cnblogs.com/mstk/p/6957974.html
Copyright © 2020-2023  润新知