1. 什么是nginx.

Nginx是一款高性能的http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。由俄罗斯的程序设计师Igor Sysoev所开发,官方测试nginx能够支支撑5万并发链接,并且cpu、内存等资源消耗却非常低,运行非常稳定。


#2. Nginx的应用场景

1 . http服务器。Nginx是一个http服务可以独立提供http服务。可以做网页静态服务器。

2 . 虚拟主机。可以实现在一台服务器虚拟出多个网站。例如个人网站使用的虚拟主机。

3 . 反向代理,负载均衡。当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用nginx做反向代理。并且多台服务器可以平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况。


3. nginx安装(两种方式)

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

2. wget http://nginx.org/download/nginx-1.14.0.tar.gz


4.  nginx安装环境

nginx是C语言开发,建议在linux上运行,本教程使用Centos作为安装环境。

1.安装nginx需要先将官网下载的源码进行编译,编译依赖gcc环境,如果没有gcc环境,需要安装gcc:
       yum install gcc-c++


2. PCRE(Perl Compatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。
nginx的http模块使用pcre来解析正则表达式,所以需要在linux上安装pcre库。
        yum install -y pcre pcre-devel


3. zlib库提供了很多种压缩和解压缩的方式,nginx使用zlib对http包的内容进行gzip,所以需要在linux上安装zlib库。
      yum install -y zlib zlib-devel


4. OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。nginx不仅支持http协议,还支持https(即在ssl协议上传输http),所以需要在linux安装openssl库。
          yum install -y openssl openssl-devel


5. 编译安装

解压: tar -zxvf nginx-1.14.0.tar.gz

cd nginx-1.14.0

参数设置如下:

./configure \
--prefix=/usr/local/nginx \
--pid-path=/var/run/nginx/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/temp/nginx/client\
--http-proxy-temp-path=/var/temp/nginx/proxy\
--http-fastcgi-temp-path=/var/temp/nginx/fastcgi\
--http-uwsgi-temp-path=/var/temp/nginx/uwsgi\
--http-scgi-temp-path=/var/temp/nginx/scgi


**注意:上边将临时文件目录指定为/var/temp/nginx****,需要在/var****下创建temp****及nginx****目录**

编译安装

make

make install


启动nginx

cd /usr/local/nginx/sbin/

./nginx


查看Nginx进程

ps aux|grep nginx

注意:执行./nginx启动nginx,这里可以-c指定加载的nginx配置文件,如下:

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

如果不指定-c**,nginx在启动时默认加载conf/nginx.conf文件,此文件的地址也可以在编译安装nginx时指定./configure的参数(–conf-path= 指向配置文件(nginx.conf))**


停止nginx

方式1,快速停止:

cd /usr/local/nginx/sbin

./nginx -s stop

此方式相当于先查出nginx进程id再使用kill命令强制杀掉进程。

方式2,完整停止(建议使用):

cd /usr/local/nginx/sbin

./nginx -s quit

此方式停止步骤是待nginx进程处理任务完毕进行停止。


重启nginx

方式1,先停止再启动(建议使用):

对nginx进行重启相当于先停止nginx再启动nginx,即先执行停止命令再执行启动命令。

如下:

./nginx -s quit

./nginx

方式2,重新加载配置文件:

当nginx的配置文件nginx.conf修改后,要想让配置生效需要重启nginx,使用-s reload不用先停止nginx再启动nginx即可将配置信息在nginx中生效,如下:

./nginx -s reload


安装测试

安装好后,启动Nginx ,访问 IP/域名 地址即可。

jsp放在nginx下 nginx部署jsp_tomcat


6. 配置虚拟主机

在192.168.0.105上创建/usr/local/aaa_html,此目录为aaa.test.com域名访问的目录

在192.168.0.105上创建/usr/local/bbb_html,此目录为bbb.test.com域名访问的目录

目录中的内容使用nginx自带的html文件,将/usr/local/nginx/html中的内容拷贝分别拷贝到上边两个目录中,并且将aaa_html目录中的index.html内容改为:“Welcome to aaa nginx!”

将bbb_html目录中的index.html内容改为“Welcome to bbb

nginx!”

修改/usr/local/nginx/conf/nginx.conf文件,添加两个虚拟主机,如下:

[#](https://www.jianshu.com/writer)配置虚拟主机aaa.test.com

server {

                   #监听的ip和端口,配置本机ip和端口

       listen 192.168.101.3:80;         

                   #虚拟主机名称是aaa.test.com,请求域名aaa.test.com的url将由此server配置解析

       server_name[aaa.test.com](https://www.jianshu.com/writer);  

                   #所有的请求都以/开始,所有的请求都可以匹配此location

       location / {

                   #使用root指令指定虚拟主机目录即网页存放目录

                   #比如访问http://ip/test.html将找到/usr/local/aaa_html/test.html

                   #比如访问http://ip/item/test.html将找到/usr/local/aaa_html/item/test.html

                root /usr/local/aaa_html;       

                                #指定欢迎页面,按从左到右顺序查找

                index index.html index.htm;   

       }

    }

#配置虚拟主机bbb.test.com

   server {

       listen 192.168.101.3:80;

       server_name bbb.test.com;

       location / {

                root /usr/local/bbb_html;

                index index.html index.htm;

       }

    }

```        

## 测试

访问aaa.test.com、bbb.test.com

* * *

# 7. 基于端口的虚拟主机

            nginx对外提供80和8080两个端口监听服务。

            请求80端口则请求html80目录下的html

            请求8080端口则请求html8080目录下的html

* * *

将原来nginx的html目录拷贝两个目录“html80”和“html8080”,为了方便测试需要修改每个目录下的index.html内容使之个性化。

参考基于ip或域名的虚拟主机章节。

* * *

修改/usr/local/nginx/conf/nginx.conf文件,添加两个虚拟主机,如下:
#user  nobody;
worker_processes  1;
events {
worker_connections  1024;
}
http {
include       mime.types;
default_type  application/octet-stream;
sendfile        on;
keepalive_timeout  65;
#配置虚拟主机
server {
#监听的ip和端口,配置80
listen       80;
#虚拟主机名称这里配置ip地址
server_name  192.168.0.105;
#所有的请求都以/开始,所有的请求都可以匹配此location
location / {
#使用root指令指定虚拟主机目录即网页存放目录
#比如访问http://ip/test.html将找到/usr/local/html3/test.html
#比如访问http://ip/item/test.html将找到/usr/local/html3/item/test.html
root   /usr/local/nginx/html80;
#指定欢迎页面,按从左到右顺序查找
index  index.html index.htm;
}
}

#配置虚拟主机

server {
listen       8080;
server_name  192.168.0.105;
location / {
root   /usr/local/nginx/html8080;
index  index.html index.htm;
}
}

}

启动 nginx,分别访问下面两个地址.

http://192.168.0.105

http://192.168.0.105:8080

* * *

# 8.nginx反向代理

通常的代理服务器,只用于代理内部网络对Internet的连接请求,客户机必须指定代理服务器,并将本来要直接发送到Web服务器上的http请求发送到代理服务器中由代理服务器向Internet上的web服务器发起请求,最终达到客户机上网的目的。而反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。

         两个tomcat服务通过nginx反向代理,本例子使用三台虚拟机进行测试,

         nginx服务器:192.168.101.3

         tomcat1服务器:192.168.101.5

         tomcat2服务器:192.168.101.6

tomcat使用apache-tomcat-8.0.53版本,在192.168.101.5和192.168.101.6虚拟机上启动tomcat。

根据上边的需求在nginx.conf文件中配置反向代理,如下:

#配置一个代理即tomcat1服务器
upstream tomcat_server1 {
server 192.168.101.5:8080;
}
#配置一个代理即tomcat2服务器
upstream tomcat_server2 {
server 192.168.101.6:8080;
}
#配置一个虚拟主机
server {
listen 80;
server_name aaa.test.com;
location / {
#域名aaa.test.com的请求全部转发到tomcat_server1即tomcat1服务上
proxy_passhttp://tomcat_server1;
#欢迎页面,按照从左到右的顺序查找页面
index index.jsp index.htmlindex.htm;
}
}
server {
listen 80;
server_name bbb.test.com;
location / {
#域名bbb.test.com的请求全部转发到tomcat_server2即tomcat2服务上
proxy_passhttp://tomcat_server2;
index index.jsp index.htmlindex.htm;
}
}
分别修改两个tomcat下的webapps/ROOT/index.jsp的内容,使用tomcat1和tomcat2两个服务首页显示不同的内容

分别访问aaa.test.com、bbb.test.com测试反向代理。

* * *

# 9. 负载均衡

        负载均衡建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性。负载均衡,英文名称为Load Balance,其意思就是分摊到多个操作单元上进行执行,例如Web服务器、FTP服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务。

         nginx作为负载均衡服务器,用户请求先到达nginx,再由nginx根据负载配置将请求转发至 tomcat服务器。

         nginx负载均衡服务器:192.168.101.3

         tomcat1服务器:192.168.101.5

         tomcat2服务器:192.168.101.6

根据上边的需求在nginx.conf文件中配置负载均衡,如下:

upstream tomcat_server_pool{
server 192.168.101.5:8080 weight=10;
server 192.168.101.6:8080 weight=10;
}
server {
listen 80;
server_name aaa.test.com;
location / {
proxy_passhttp://tomcat_server_pool;
index index.jsp index.htmlindex.htm;
}
}
请求aaa.test.com,通过nginx负载均衡,将请求转发到tomcat服务器。

通过观察tomcat的访问日志或tomcat访问页面即可知道当前请求由哪个tomcat服务器受理。