baiyunjn 发表于 2017-12-23 09:52:01

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; ">
  
<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">
  
<Valve>  
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_connections512;   
  
}
  
http {
  
include       mime.types;   
  
#default_typeapplication/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_namemaster;         
  
location~*^.+$ {      
  
proxy_passhttp://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_namemaster;         
  
location~*^.+$ {      
  
proxy_passhttp://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  
页: [1]
查看完整版本: Nginx的安装和设置