Nginx简介
Nginx是一款轻量级的Web服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,在一个BSD-like协议下发行,由俄罗斯人IgorSysoev开发,共俄罗斯大型的搜索引擎Rambler使用。nginx特点是占内存少,并发能力强。
据 Netcraft 统计,在 2012 年 8 月份,世界上最繁忙的网站中有 11.48%使用 Nginx 作为其服务器或者代理服务器。目前互联网主流公司360、百度、新浪、腾讯、阿里等,目前中国互联网企业 70%以上公司都在使用 nginx 作为自己的 web 服务器。
Nginx由内核和模块组成,内核的设计非常微小、简洁,完成的工作也非常简单,仅仅通过一个配置文件将客户端的请求映射到一个location block,而这个location中配置的每个指令将会启动不同的模块去完成相应的工作。
Nginx相对于Apache的优点:
- 高并发响应性能非常好,官方Nginx处理静态文件并发 5w/s,并发量非常可观
- 法相代理性能非常强,可用于做负载均衡
- 内存和cpu占用率低,约为Apache的1/5-1/10
- 对后端服务有健康检查功能
- 支持php cgi 方式和fastcgi方式
- 配置代码简洁且容易上手
Nginx 工作原理及安装配置
nginx的工作原理
Nginx 由内核和模块组成,内核的设计非常微小和简洁,完成的工作也非常简单,仅仅通过配置文件将客户端的请求映射到一个location block,而在location中配置的每个指令将会启动不同的模块去完成相应的工作。
- Nginx 从结构上分为核心模块、基础模块、第三方模块
1. 核心模块:HTTP模块、EVENT模块、MAIL模块
2. 基础模块:HTTP Access模块、HTTP FASTCGI模块、HTTP Proxy模块和HTTP Rewrite模块
3. 第三方模块:HTTP Upstream Request Hash模块、Notice模块和HTTP Access Key模块
Nginx 的高并发得益于其采用了epoll 模型,于传统的服务器程序架构不同,epoll 是linux内核2.6以后才出现的,Nginx采用 epoll 模型,异步非阻塞,而Apache 采用的是 select 模型。
- select 特点:选择句柄时,是遍历所有句柄,也就是说句柄有事件响应时,select 需要遍历所有句柄才能获取到哪些句柄有事件通知,因此效率非常低。
- epoll 特点:epoll可以理解为event poll,epoll对句柄事件的选择不是遍历,epoll会把哪个流发生了怎样的I/O事件通知我们,所以epoll 实际上是事件驱动的(每个事件关联上fd),不需要遍历整个句柄链表,因此效率非常高
Nginx 安装
安装背景:centos 7.4 使用docker拉取Nginx镜像
- 查询一下Nginx 镜像:docker search nginx
- 我们选择拉取第一个镜像:docker pull nginx
- 查看本地镜像:docker images
- 启动Nginx镜像:docker run -d -p 8080:8080 nginx
- 查看容器启动情况:docker ps
- 这时,访问localhost:8080,发现是404,原因是我们还没用配置Nginx的配置文件,默认文件里面没有配置server
- 进入docker容器:docker exec -it 容器id bash
- 编辑配置文件:vim etc/nginx/nginx.conf
- 在配置文件的 http 下 添加 server 配置:
server{
listen 8080;
server_name localhost;
location / {
root /usr/local/share/fonts;
index index.html;
}
}
- 在 /usr/local/share/fonts 目录下创建一个index.html文件
- 访问一下localhost:8080
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/83679.html