nginx 基本配置 | 学习笔记(一)

简介: 快速学习 nginx 基本配置。

开发者学堂课程【Linux Web 服务器 Nginx 搭建与配置nginx 基本配置学习笔记,与课程紧密联系,让用户快速学习知识.

课程地址:https://developer.aliyun.com/learning/course/579/detail/7989


nginx 基本配置


目录:

一.nginx 介绍

二.nginx 的程序架构

三.nginx 模块

四.nginx 的功用

五.nginx 的安装

六.nginx 目录结构和命令

七.nginx 配置

八.nginx 配置文件

九.http 协议相关的配置结构


一.Nginx 介绍

特性:

1.模块化设计,较好的扩展性

2.高可靠性

3.支持热部署:不停机更新配置文件,升级版本,更换日志文件(假设Nginx现在为1.0版本,想升级为2.0版本,可在不停机的情况下进行更新。就是当用户新发起请求用新版本进行响应,当旧用户发请求时,如果已经有人开始连接,还可以用旧版本进行服务,当访问结束后会自动切换到新版本上,起到平滑升级的效果。)

4.低内存消耗:10000个keep-alive连接模式下的非活动连接,仅需2.5M内存(消耗内存很小,可忽略不计)

  • event-driven,aio,mmap,sendfile(易在面试中问到的原理性的东西)

基本功能:

  • 静态资源的 web 服务器(突出功能)

http 协议反向代理服务器(突出功能)

pop3/imap4 协议反向代理服务器

FastCGI(LNMP),uWSGI(python) 等协议

模块化(非DSO),如 zip,SSL 模块

注:1.Nginx 一个性能优秀的作为静态资源的web服务器,换句话说他只是一个静态服务器,若要充当 http 服务器是充当不了的,要想运行http服务器,需要专门安装对应的软件程序,而且 Nginx 不支持模块方式,比如之前在apache搭建一个lamp 的网站时,apache 要想支持 http 有两种方式,一种是php模块,对应的包php是,依赖于apache的这个模块,相当于拓展apache的功能,使其成为apache的一个模块,让其能处理php程序。

当然,使用最多的是第二种 php-fpm 模式,这种模式下 FastCGI以独立的进程方式运行的,它与 apache 是两个独立的不同软件,对应的是TCP的9000端口。

对于 Nginx 来说,它也只支持 FastCGI,不支持模块。换句话说以后要搭建一个Nginx 的 php 程序,实现的名字为 lnmp 或 lemp(少用,取自于engine X音译)。

在这种情况下Nginx 与php程序运行是以FastCGI这种方式通讯的,即由linux nginx php-fpm mysql这四个独立的软件来支撑lemp、lnmp。

2.当静态资源的web服务器想支持FastCGI(LNMP)时,实际上充当了FastCGI(LNMP),的客户端

image.png

前端客户端发请求到nginx服务器,由于nginx服务器处理不了于是发送给php。总体来讲nginx 充当php-fpm 的客户端,php-fpm充当mysic 的客户端。

此外 nginx 还可以充当http协议反向代理服务器,可搭建多个web 服务器

image.png

Nginx是一个应用层的反向代理服务器,功能强但性能弱

当然web服务器还可以充当邮件的反向代理,FastCGI(LNMP),uWSGI(python)等协议同理。

image.png

模块化早期是不支持动态加载的,DSO指动态加载模块,它不支持动态加载,是静态加载,即编译完是什么样就是什么样。现在已经支持动态加载了。

二.nginx 的程序架构

1.web 服务相关的功能:

虚拟主机(server)

支持keep-alive 和管道连接

访问日志(支持基于日志缓冲提高其性能)

url rewirte

路径别名

基于IP及用户的访问控制

支持速率限制及并发数限制

重新配置和在线升级而无须中断客户的工作进程

Memcached的GET接口

注:url rewirte的意思是当访问一个网站。

http://www.magedu.com/bbs为例,这种称呼已经老套了,我们不叫bbs,叫forum,http://www.magedu.com/forum

路径别名以alias实现跳转在一个文件夹中。

总的来说,在功能上与apache类似。

下图是nginx的架构的整个工作环境

image.png

在nginx中一个master开若干个worker,但一个worker可以并发支持若干个用户的请求。每个worker可以支持很多模块,每个模块有自己特定的功能。当客户端发送请求时,由worker进程提供响应,对外进行服务。Master与worker的关系相当于指挥者与被指挥者。

作为反向代理,除了代理功能外还有储存功能。储存与磁盘或者内存中,缓存存放方式在后面进行进一步学习。

在前面的ppt展示中:

select/poll/epoll

epoll:在Linux 2.6内核中提出的select和poll的增强版本
支持水平触发LT和边缘触发ET,最大的特点在于边缘触发,它只告诉进程哪些fd刚刚变为就需态,并且只会通知一次
使用“事件”的就绪通知方式,通过epoll_ctl注册fd,一旦该fd就绪,内核就会采用类似callback的回调机制来激活该fd,epoll_wait便可以收到通知

优点:
没有最大并发连接的限制:能打开的FD的上限远大于1024(1G的内存能监听约10万个端口)
效率提升:非轮询的方式,不会随着FD数目的增加而效率下降;只有活跃可用的FD才会调用callback函数,即epoll最大的优点就在于它只管理“活跃”的连接,而跟连接总数无关
内存拷贝,利用mmap(Memory Mapping)加速与内核空间的消息传递;即epoll使用mmap减少复制开销

poll

本质上和select没有区别,它将用户传入的数组拷贝到内核空间,然后查询每个fd对应的设备状态

其没有最大连接数的限制,原因是它是基于链表来存储的

大量的fd的数组被整体复制于用户态和内核地址空间之间,而不管这样的复制是不是有意义

poll特点是“水平触发”,如果报告了fd后,没有被处理,那么下次poll时会再次报告该fd

边缘触发:只通知一次

Nginx 介绍

Nginx:engineX,2002年,开源,商业版

NGINX是免费,开源,高性能的HTTP和反向代理服务器,邮件代理服务器,通用TCP/UDP代理服务器

解决C10K问题(10K Connections)

官网:http://nginx.org

二次开发版

Tengine,OpenResty(章亦春)

nginx 的程序架构

nginx的程序架构:

master/worker结构

1.一个master进程:

负载加载和分析配置文件、管理worker进程、平滑升级

2.一个或多个worker进程

处理并响应用户请求

3.缓存相关的进程:

cache loader:载入缓存对象

cache manager:管理缓存对象


三、nginx 模块

1.nginx高度模块化,但其模块早期不支持DSO机制;1.9.11版本支持动态装载和卸载

2.模块分类:

  1. 核心模块:core module

(2)标准模块:
•HTTP 模块:ngx_http_
HTTP Core modules 默认功能
HTTP Optional modules 需编译时指定
•Mail 模块ngx_mail_*
•Stream 模块 ngx_stream-*
(3)第三方模块
其中标准模块分为三个功能:http功能、邮件功能、stream功能(可以作为tcp协议的代理)

在官方网站里说的很清楚,有权威,例如:Core functionality

核心模块:

Core functionality

标准模块(模块类型很多):

ngx http core module

ngx http access module

ngx.http addition.module

ngx http api module

ngx htte auth basic module

ngx.http_auth jwt.module

ngx.http_auth_request_module

ngx http autoindex module

ngx_http_browser_module

ngx_htlp_charset,_module

ngx.http_dav module

ngx.http_empty_git_module

ngx http f4f module

ngx.http.fastcg_module

ngx.http.fy.module

ngx_htlp_geo module

ngx.http.geop_module

ngx.http_grpc module

ngx.http.gunzp.module

第三方模块

Ngx google perftools module

分类也很明显


四、nginx 的功用

1.静态的 web 资源服务器:html,图片,js,css,txt等静态资源

2.结合 FastCGI/uWSGI/SCGI 等协议反向代理动态资源请求

3.http/https 协议的反向代理

4.imap4/pop3 协议的反向代理

5.tcp/udp 协议的请求转发(反向代理)

反向代理与请求转发的区别:

从 top 结构上来说都是一样的,区别在于lvs只是接收请求转发,但不进行解决,而nginx 会进行解决。表面看一样,但实现方式却不同。

image.png

相关文章
|
11小时前
|
移动开发 前端开发 JavaScript
前端vue2、vue3去掉url路由“ # ”号——nginx配置(一)
前端vue2、vue3去掉url路由“ # ”号——nginx配置
56 0
|
11小时前
|
JavaScript 前端开发 应用服务中间件
angular引入包、路由权限配置、打包问题与nginx配置问题(简单部署)
angular引入包、路由权限配置、打包问题与nginx配置问题(简单部署)
24 0
|
11小时前
|
安全 应用服务中间件 Linux
linux nginx的配置总结
linux nginx的配置总结
19 0
|
11小时前
|
前端开发 JavaScript 应用服务中间件
前端vue2、vue3去掉url路由“ # ”号——nginx配置(二)
前端vue2、vue3去掉url路由“ # ”号——nginx配置
59 0
|
11小时前
|
应用服务中间件 nginx
nginx配置集群轮训策略
nginx配置集群轮训策略
13 0
|
11小时前
|
安全 网络协议 应用服务中间件
一文读懂HTTPS⭐揭秘加密传输背后的原理与Nginx配置攻略
一文读懂HTTPS⭐揭秘加密传输背后的原理与Nginx配置攻略
|
11小时前
|
应用服务中间件 PHP nginx
php如何实现检测nginx配置的正确性
请确保在执行此操作时,PHP有足够的权限来执行Nginx命令和访问Nginx配置文件。另外,将上述代码嵌入到您的应用程序中时,要注意安全性,以防止潜在的命令注入攻击。
53 3
|
11小时前
|
安全 应用服务中间件 网络安全
linux_nginx中添加ssl配置(open ssl)
linux_nginx中添加ssl配置(open ssl)
27 1
|
11小时前
|
JSON JavaScript 前端开发
vue2_vite.config.js的proxy跨域配置和nginx配置代理有啥区别?
vue2_vite.config.js的proxy跨域配置和nginx配置代理有啥区别?
33 1
|
11小时前
|
安全 应用服务中间件 网络安全
SSL原理、生成SSL密钥对、Nginx配置SSL
现在,你的Nginx虚拟主机应该已经配置了SSL,可以通过HTTPS安全访问。确保在生产环境中使用有效的SSL证书来保护通信的安全性。
32 0