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 - nginx

Nginx的安装和设置的更多相关文章

  1. Nginx的安装及反向代理设置

    因为项目的缘故,接触到了Nginx的安装和反向代理设置,和大家分享下. 一.Nginx的下载.安装cd /homewget http://nginx.org/download/nginx-1.0.5. ...

  2. nginx简单安装设置

    1.Nginx ("engine x") 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器.Nginx是由Igor Sysoev为俄罗斯访问量第二 ...

  3. Centos下安装并设置nginx开机自启动

    一.在centos环境下安装下载并安装nginx,由于nginx需要依赖一些环境才能安装,主要依赖g++.gcc.openssl-devel.pcre-devel和zlib-devel这些环境,首先得 ...

  4. 小白搭建WNMP详细教程---NGINX安装与设置

    一.Nginx下载 Nginx (engine x) 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器.Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Ramble ...

  5. 简易nginx TCP反向代理设置

    nginx从1.9.0开始支持TCP反向代理,之前只支持HTTP.这是我的系统示意图: 为何需要? 为什么需要反向代理?主要是: 负载均衡 方便管控 比如我现在要更新后端服务器,如果不用负载均衡的话, ...

  6. Django Nginx+uwsgi 安装配置

    使用 python manage.py runserver 来运行服务器.这只适用测试环境中使用. 正式发布的服务,我们需要一个可以稳定而持续的服务器,比如apache, Nginx, lighttp ...

  7. nginx的安装

    1,,nginx的安装 为什么使用nginx我就不多说了,很优秀的,请再行google 在安装前,先安装pcre,安装zlib,安装openssl,以及一些其他包 yum install -y gcc ...

  8. nginx服务器绑定域名和设置根目录的方法

    nginx服务器绑定域名以及设置根目录非常方便,首先进入nginx安装目录,然后执行 vim conf/nginx.conf 打开nginx的配置文件,找到 server { ..... ..... ...

  9. nginx 的安装

    一.必要软件准备1.安装pcre 为了支持rewrite功能,我们需要安装pcre 复制代码代码如下: # yum install pcre* //如过你已经装了,请跳过这一步 2.安装openssl ...

随机推荐

  1. 去除HTML5 SUMMARY 标签前的三角形

    在CSS添加如下代码(Chrome): details summary::-webkit-details-marker { display:none; }

  2. Redis与Zookeeper实现分布式锁的区别

    Redis实现分布式锁 1.根据lockKey区进行setnx(set not exist,如果key值为空,则正常设置,返回1,否则不会进行设置并返回0)操作,如果设置成功,表示已经获得锁,否则并没 ...

  3. hdu 1385 Floyd 输出路径

    Floyd 输出路径 Sample Input50 3 22 -1 43 0 5 -1 -122 5 0 9 20-1 -1 9 0 44 -1 20 4 05 17 8 3 1 //收费1 3 // ...

  4. POJ 2184 Cow Exhibition (带负值的01背包)

    题意:给你N(N<=100)只牛,每只牛有一个智慧值Si和一个活泼值Fi,现在要从中找出一些来,使得这些牛智慧值总和S与活泼值总和F之和最大,且F和S均为正.Si和Fi范围在-1000到1000 ...

  5. 转载 c++指针 指针入门

    这是一篇我所见过的关于指针的最好的入门级文章,它可使初学者在很短的时间内掌握复杂的指针操作.虽然,现在的Java.C#等语言已经取消了指针,但作为一个C++程序员,指针的直接操作内存,在数据操作方面有 ...

  6. openstack学习-nove控制节点部署(四)

    nove在openstack非常重要,主要负责创建虚拟机 nova计算服务 API :负责接收和响应外部请求.支持openstack API,EC2 API Cert:负责身份认证EC 2 Sched ...

  7. BZOJ1059 [ZJOI2007]矩阵游戏 二分图匹配 匈牙利算法

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1059 题意概括 有一个n*n(n<=200)的01矩阵,问你是否可以通过交换整行和整列使得左 ...

  8. 096实战 在windows下新建maven项目

    1.拷贝settings到.m2文件下 2.修改文件 3.新建Project项目 4.转换为maven项目 config下转换 5.拷贝pom文件 <project xmlns="ht ...

  9. Floyd-傻子也能看懂的弗洛伊德算法(转)

                暑假,小哼准备去一些城市旅游.有些城市之间有公路,有些城市之间则没有,如下图.为了节省经费以及方便计划旅程,小哼希望在出发之前知道任意两个城市之前的最短路程.          ...

  10. QT学习之菜单栏与工具栏

    QT学习之菜单栏与工具栏 目录 简单菜单栏 多级菜单栏 上下菜单栏 工具栏 简单菜单栏 程序示例 from PyQt5.QtWidgets import QApplication, QMainWind ...