nginx介绍1

1.1 nginx 是什么?

是一个高性能的web服务器和反向代理服务器

http://www.nginx.cn/
nginx中文手册

1.2 nginx的优点

1 支持高并发:能支持几万并发连接(特别是静态小文件业务环境)

2 资源消耗少: 在三万并发连接下,开启10个nginx线程消耗的内存不到200MB

3 可以做HTTP反向代理及加速缓存、既负载均衡功能、内置对RS节点服务器健康检查功能、这相当于Haproxy软件或LVS的功能

4 具备squid 等专业缓存软件等的缓存功能

5 支持异步网络I/O事件横行epoll(linux2.6+)

1.3 nginx的应用场景

Nginx作为Web服务器的主要应用场景:

   1)使用Nginx运行HTML、JS、CSS、小图片等静态数据(此功能类似lighttpd软件)。

   2)Nginx结合FastCGI运行PHP等动态程序(例如使用fastcgi_pass方式)。

   3)Nginx结合tomcat/resin等支持Java动态程序(常用proxy_pass方式)。

1.4 正向代理、反向代理、负载均衡

正向代理 由内向外 代替局域网内pc,请求外部应用服务

反向代理 由外向内 代替外部的用户 请求内部的应用服务器

负载均衡 转发给内部的web服务器

1.5 为什么Nginx总体性能比Apache高?

Nginx使用最新的epoll(Linux2.6内核)和kqueue(freebsd)异步网络I/O模型,

而Apache则使用的是传统的select模型。

目前Linux下能够承受高并发访问的Squid、Memcached软件都采用的是epoll模型

第一个比喻:

 

假设你在大学读书,住的宿舍楼有很多房间,你的朋友要来找你。select版宿管大妈就会带着你的朋友到各房间挨个去找,直到找到你为止。而epoll版宿管大妈会先记下每位入住同学的房间号,你的朋友来找你时,只需告诉你的朋友你住在哪个房间即可,不用亲自带着你的朋友满宿舍楼找人了。如果同时来了100个人,都要找自己住这栋楼的同学,select版和epoll版宿管大妈,谁的效率更高,就很明显了。

 

第二个比喻:

 

select的调用复杂度是线性的,即O(n)。举个例子,一个保姆照看照看一群孩子,如果把孩子是否需要尿尿比作网络I/O事件,select的作用就好比这个保姆挨个询问每个孩子"你要尿尿吗?”如果孩子回答是,保姆则把孩子领出来放到另外一个地方。当所有孩子询问完之后,保姆领着这些要尿尿的孩子去上厕所(处理网络I/O事件).在epoll机制下,保姆不再需要挨个询问每个孩子是否需要尿尿。取而代之的是,如果孩子需要尿尿,他就自己主动站到事先约定好的地方,而保姆的职责就是查看事先约定好的地方是否有孩子。如果有小孩,则领着孩子去上厕所(网络事件处理)。因此,epoll的这种机制,能够高效地处理成千上万的并发连接,并且性能不会随着连接数増加而下降太多。

1.5.1 IO的介绍

IO 简单了解就是计算机的读写

 

IO的类型(关注消息通知机制)

同步IO

调用方向被调用方发起请求 被调用方接受请求时不立即返回消息 但一旦返回 则返回最终结果

异步IO

调用方向被调用方发起请求 被调用方接收到请求后返回确认信息,但不是最终结果; 请求处理完后,通过通知机制通知调用者

 

IO模型的介绍

比如cat 查看一个数据由进程通知内核 内核将数据从磁盘加载至内核内存 内核空间将数据cp到进程内存。此时IO过程分为两步, ①数据从磁盘加载至内核内存 ② 从内核内存cp一份至进程内存

阻塞IO : 进程在IO操作中 为挂起状态,进入不可中断睡眠状态 既阻塞IO

非阻塞IO:进程在IO操作①中 可执行其他操作 但是需要不断查看内核是否操作成功,既忙等待状态,随后进入进入IO②操作中,又为阻塞状态

多路复用IO:进程在IO操作中,加入select机制 通过select 同时处理多个IO 但是有上限1024 当并发超过1024后,又为阻塞状态

事件驱动式IO: 加入通知机制 通知机制分为水平触发(多次通知),边缘触发(只通知一次)。进程在IO操作中,内核将数据加载至内核内存后,就通知进程。 

异步IO:加入select机制 通知机制(边缘触发) 并且是内核将IO操作完成后 数据已经在进程内存了 再通知进程

 

1.6 nginx的安装

linux系统安装软件方法:

1)yum install nginx -y(rpm包,自动解决所有依赖软件)

简单,没法定制。

 

2)rpm -ivh rpm包(自己解决所有依赖软件)

简单,没法定制,没法自动解决所有依赖软件

 

3)编译安装(c语言)

可以定制,编译过程复杂,时间长。

./configure 配置

make 编译

make install 安装

 

4)利用源码制作符合企业需求的rpm软件包,放到yum仓库里,最后yum安装。

简单,可以随意定制。

rpm包定制

http://blog.oldboyedu.com/autodeploy-rpm/

yum仓库搭建

http://blog.oldboyedu.com/autodeploy-yum/

 

 

mkdir /home/oldboy/tools

cd /home/oldboy/tools

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

tar xf nginx-1.14.0.tar.gz

cd nginx-1.14.0

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

useradd -s /sbin/nologin www -M

yum install pcre pcre-devel -y

yum install openssl openssl-devel  -y

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

./configure  --user=www --group=www --prefix=/application/nginx-1.14.0/ --with-http_stub_status_module  --with-http_ssl_module --with-pcre

make

make istall

ln -s /application/nginx-1.14.0/ /application/nginx

 

echo $? 返回0代表步骤正确。

验证:

 

[root@web01 nginx-1.14.0]# ls /application/nginx/

conf  html  logs  sbin

[root@web01 nginx-1.14.0]# /application/nginx/sbin/nginx

[root@web01 nginx-1.14.0]# lsof -i :80

COMMAND  PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME

nginx   8898 root    6u  IPv4  23954      0t0  TCP *:http (LISTEN)

nginx   8899  www    6u  IPv4  23954      0t0  TCP *:http (LISTEN)

[root@web01 nginx-1.14.0]# wget 10.0.0.7

--2018-06-22 12:36:30--  http://10.0.0.7/

Connecting to 10.0.0.7:80... connected.

HTTP request sent, awaiting response... 200 OK

Length: 612 [text/html]

Saving to: “index.html”

OVER.

 

 

 

 

--prefix=PATH  路径

--user=USER    用户

--group=GROUP  组

--with-pcre    伪静态

--with-http_stub_status_module 状态

--with-http_ssl_module      加密 443

posted @ 2018-06-22 20:18  口水哥  阅读(188)  评论(0编辑  收藏  举报