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
nginx介绍1的更多相关文章
- Nginx 介绍和安装
Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器. Nginx 是由 Igor Sysoev ...
- LNMP架构介绍、MySQL和PHP安装、Nginx介绍
6月6日任务 12.1 LNMP架构介绍12.2 MySQL安装12.3/12.4 PHP安装12.5 Nginx介绍 扩展Nginx为什么比Apache Httpd高效:原理篇 http://w ...
- Nginx介绍和使用
Nginx介绍和使用 一.介绍 Nginx是一个十分轻量级并且高性能HTTP和反向代理服务器,同样也是一个IMAP/POP3/SMTP代理服务器. 二.特性 HTTP服务器 反向代理服务器 简单的负载 ...
- nginx介绍及相关实验
一.nginx介绍 1.nginx简介 Nginx是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP 服务.Nginx 是由伊戈尔·赛索耶夫为俄罗斯访问量第二的 R ...
- Linux centosVMware LNMP架构介绍、MySQL安装、PHP安装、Nginx介绍
一. LNMP架构介绍 和LAMP不同的是,提供web服务的是Nginx 并且php是作为一个独立服务存在的,这个服务叫做php-fpm Nginx直接处理静态请求,动态请求会转发给php-fpm ...
- 三十六、www服务nginx介绍
一.Nginx介绍 ,相对于LAMP经典组合而言,LNMP是近几年来流行的组合.(linux+nginx+mysql+php) Nginx是一个开源www服务软件,是俄罗斯人开发的,本身是一款静态ww ...
- nginx介绍及其原理
nginx介绍及其原理 nginx是一款轻量级的Web服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like协议下发行. nginx由俄罗斯程序设计师lgor Sy ...
- Nginx介绍,安装,配置
引言 为什么要学习Nginx 问题一: 客户端到底要将请求发送给哪台服务器? 问题二: 如果所有客户端的请求都发送给了服务器1,那另一台岂不是废了 问题三: 客户端发送的请求可能是申请动态资源的,也可 ...
- Nginx介绍
原文:http://www.aosabook.org/en/nginx.html 作者: Andrew Alexeev nginx(发音"engine x")是俄罗斯软件工程师Ig ...
- nginx介绍(三) 配置篇
3. nginx配置 nginx配置系统受益于Igor Sysoev(nginx创始人)在Apache(阿帕奇软件基金会)的经历.Igor Sysoev洞察出可扩展的配置系统对于一个web服务器来说是 ...
随机推荐
- modprobe: FATAL: Module ceph not found解决办法
问题 有可能你在进行 Ceph 文件系统挂载的时候出现下面的提示: modprobe: FATAL: Module ceph not found. mount.ceph: modprobe faile ...
- SpringBoot 之 @ControllerAdvice 拦截异常并统一处理
在spring 3.2中,新增了@ControllerAdvice 注解,可以用于定义@ExceptionHandler.@InitBinder.@ModelAttribute,并应用到所有@Requ ...
- 软链接mongo
ln -s /usr/local/mongodb/bin/mongo /usr/bin/mongo
- 学好Flex布局并不容易
1. Flex布局介绍 CSS的传统布局解决方案,基于盒状模型,依赖display属性.position属性.float属性,对于一些特殊的布局,例如垂直居中,往往要想很多hack的方法来解决. 20 ...
- python中操作excel数据
python操作excel,python有提供库 本文介绍openpyxl,他只支持新型的excell( xlsx)格式,读取速度还可以 1.安装 pip install openpyxl 2.使用 ...
- Flink-1-状态化流处理概述
第1章 状态化流处理概述 参考书籍 Stream Processing with Apache Flinkhttps://www.oreilly.com/library/view/stream-pro ...
- 关于Java里方法重载
覆盖和重载很重要,并且比较容易混淆,所以面试中常见.基础回答:覆盖(Override),又叫重写,是指子类对父类方法的一种重写,方法名.参数列表必须相同,返回值小于父类,只能比父类抛出更少的异常,访问 ...
- Java中的接口与抽象类的区别
由于随着jdk版本的更新,在jdk1.8时,接口也增强了,所以我们分别来说明一下. (1)jdk1.8之前 在jdk1.8之前,接口里面只能定义抽象方法和常量:而抽象类比普通类有一点不同,就是抽象类里 ...
- A:与指定数字相同的数的个数
总时间限制: 1000ms 内存限制: 65536kB 描述 输出一个整数序列中与指定数字相同的数的个数. 输入 输入包含三行:第一行为N,表示整数序列的长度(N <= 100):第二行为N ...
- Oracle11gR2 RAC voting disk error
故障现象:2+3节点配置,alert日志中提示vote盘错误,集群无法拉起来. 分析过程:Oracle 11g RAC依据OLR,OCR,VOTE磁盘进行节点信息注册,维护集群状态以及完成选举投票.其 ...