一. Nginx的诞生

Nginx是一个高效的web及反向代理服务器,它的第一版发布于2012年,晚于如今占据最大市场份额的Apache。那么Nginx的诞生肩负了哪些使命呢?或者说它于Apache的差别在哪里?

低效的Apache!Apahce诞生于上世纪90年代。那个时候硬件技术还不是很成熟,服务器大多是单核单cpu的,而且网络请求数也不是很多。和大多数那个年代诞生的组件一样,Apache的底层采用的是同步多进程的模型。如今服务器向着多核多cpu发展,处理的网络请求也动辄十万级 百万级,尤其是物联网的诞生,以亿为单位的qps也出现在大家的视野中。在这样的场景下,Apache低效的底层模型就无法应对了。一个服务器能开启的进程数是有限的,而且操作系统在多个进程之间的切换也会消耗大量的资源和时间,导致Apache无法跑满多核cpu的性能。

高效的Nginx!Nginx的底层采用了多路复用的技术,轻松应对百万级的连接。如果说同步、多进程代表着低效,那么异步、多路复用就是高性能的代名词了。Nginx可以在一个线程中处理多个请求,避免了进程、线程间的切换,在用户态中实现并发的处理。而且Nginx几乎是用纯C开发的,可直接编译成机器语言,这也是其高效的原因之一。

比较一下Apache和Nginx,Nginx有如下几个优点:1. 高并发,高性能;2. 可扩展性好(拥有丰富的模块);3. 高可靠性;4. 热部署;5. BSD许可证(允许修改源码并用到商业场景)

如此看来也就不难理解,为什么Nginx的短时间内能占据这么大的市场。虽然Apahce现在依然是市场占有率第一的web容器,但是Nginx与其的差距在逐年递减。不仅创业公司和新的项目大多采用Nginx,而且一些老项目也在慢慢的由Apache转向Nginx。

二. Nginx的主要引用场景

Nginx主要提供了三个功能:1. 静态资源的访问;2. 反向代理 3. API服务

1. Nginx允许用户直接访问服务器的静态资源,依托于Nginx强大的性能,使其访问速度远高于配置在应用服务器上的静态资源。

2. 应用服务一般要中和开发效率、程序的可读性、可扩展性等等因素,其响应速度一般远低于Nginx。Nginx提供了反向代理的功能,利用负载均衡、缓存的手段,允许用户通过Nginx访问服务来获取更高的体验。值得一提的是,多路复用的模型只是应对高并发的情景下比多进程、多线程模型的效率高,并不能对单个连接的处理的更快,而是能较快的处理更多的连接。

3. 就像上诉提到的,应用服务的执行效率一般会比较低,所以Nginx还提供了另一种方式来提升用户请求数据的速度,这就是API服务。Nginx的API服务可以直接访问数据库或者缓存服务,并将拿到的数据直接返回给用户。

三. Nginx的版本

​免费版:Nginx.org、OpenResty.org

​商业版:Nginx.com、OpenResty.com

三. Nginx安装与启动

1. 安装Prce

    • 打开Prce官网下载页面:https://ftp.pcre.org/pub/pcre/

    • 复制想安装的Prce版本下载链接

    • 使用wget命令下载:wget https://ftp.pcre.org/pub/pcre/pcre-8.37.tar.gz

    • 使用tar命令解压:tar -xzf pcre-8.37.tar.gz

    • 使用chmod命令配置Prce解压文件夹的全部读写权限:chmod -R 777 pcre-8.37

    • 使用cd命令切换到Prce解压文件夹:cd pcre-8.37

    • 使用configure命令配置安装:./configure

    • 使用make命令编译:make

    • 使用make install命令安装:make install

2. 安装Nginx

      • 打开Nginx官网下载页面:http://nginx.org/en/download.html

      • 复制想安装的Nginx版本下载链接,有最新版本和稳定版本两个选择

      • 使用wget命令下载:wget http://nginx.org/download/nginx-1.16.1.tar.gz

      • 使用tar命令解压:tar nginx-1.16.1.tar.gz

      • 使用cd命令切换到Nginx解压文件夹:cd nginx-1.16.1

      • 使用configure命令配置安装:./configure --prefix=/home/user/nginx --with-pcre=/home/user/tool/pcre-8.37/

      • 使用make命令编译:make

      • 使用make install命令安装:make install

编译成功后可以看到这样的四个文件夹:sbin(Nginx的可执行文件)、conf(配置文件)、logs(日志文件)、html(静态页面示例)。

四. Nginx的组成

​1. 二进制可执行文件(sbin目录下)

​2. 配置文件(conf目录下的Nginx.conf,可在Nginx启动时指定)

​3. 访问日志(logs目录下的access.log,可在配置文件中配置)

​4. 错误日志(logs目录下的error.log,可在配置文件中配置)​

五. Nginx配置语法(config)

  配置语法:

  1. 配置文件由指令和指令块组成

      2. 每条指令以;结尾,指令和指令之间以空格符分隔

      3. 指令块以{}大括号将多条指令组织在一起

      4. include语句允许组合多个配置文件以提升可维护性

      5. 使用符号#添加注释,增加可读性

      ​6. 使用符号$使用变量

      ​7. 部分执行的参数支持正则表达式

  配置参数:

​  1. 时间单位

​        ​y:years

     ​    ​M:months

      ​    ​d:days

    ​    ​h:hours

     ​    ​m:minutes
        ​    ​S:seconds

     ​    ​w:weeks

       ​    ​ms:milliseconds

   ​2. 空间单位

​    ​        ​空:bytes

​        ​k/K:kilobytes

​        ​m/M:megabytes

​        ​g/g:gigabytes

  配置指令块:

  1. http

      2. server

      3. location

      4. upstream

六. Nginx命令行(sbin)

帮助:nginx -?

nginx -h

使用指定的配置文件:nginx -c

使用指定的配置指令:nginx -g

使用指定的运行目录:nginx -p

发送信号:nginx -s

测试配置文件是否有语法错误:-t    -T

打印nginx的版本信息、编译信息等:-v    -V

命令行的应用:

首先应进入sbin目录中

1. 启动:./nginx

2. 重载配置文件:./nginx -s reload

3. 热部署:

a)备份原二进制文件

b)覆盖新二进制文件到原文件

注:新二进制文件是nginx源码make编译后的objs文件中nginx.sh

热部署不需要执行make install 安装命令

c)向Nginx的master进程发送信号,告诉其要开始热部署了。

命令:kill -USER2 12345(12345为master进程pid)

注:接收到信号后nginx会新开一个master进程,并在新的进程中使用新的二进制可执行文件。此时新旧master进程都在运行,但是旧的master进程已经不再监听80端口了,所有新的请求都会到新的master进程中。

d)向旧的master进程发送信号,告诉其可以优雅的结束自己了。

命令:kill -WINCH 12345

注:此时旧的worker进程已经消失了,但是旧的master进程还在。这是因为一旦新二进制文件有错误,直接reload旧master,并down掉新master进程,做版本回退。

4. 切割日志文件

​    ​    ​a)mv 原文件名 新文件名 (这里只能使用mv命令,linux系统会保证指向旧文件名的写入直接写入到新文件名而不会发生错误)

​    ​    ​b)重置配置文件

​    ​    ​    ​    ​命令:./nginx -s reopen

[Day1] 初识Nginx的更多相关文章

  1. 初识nginx——内存池篇

    初识nginx——内存池篇 为了自身使用的方便,Nginx封装了很多有用的数据结构,比如ngx_str_t ,ngx_array_t, ngx_pool_t 等等,对于内存池,nginx设计的十分精炼 ...

  2. 初识Nginx及编译安装Nginx

    初识Nginx及编译安装Nginx 环境说明: 系统版本    CentOS 6.9 x86_64 软件版本    nginx-1.12.2 1.什么是Nginx? 如果你听说或使用过Apache软件 ...

  3. 初识nginx之第一个demo

    商城项目做了一个多月了,想到必须用到负载均衡,简单了解了一下nginx,首先分享第一个demo,五月份上线后,会继续分享一系列相关知识. 在nginx根目录下,用了一个园友的批处理文件nginx.ba ...

  4. 初识nginx

    先来一波官方站点关于nginx介绍.nginx相关历史这里不再赘述啦.   nginx 是免费,开源,高性能 HTTP 服务器和反向代理服务器,也可作为IMAP/POP3代理服务器.nginx以它的高 ...

  5. nginx(四)初识nginx日志文件

    nginx 日志相关指令主要有两条,一条是log_format,用来设置日志格式,另外一条是access_log,用来指定日志文件的存放路径.格式和缓存大小,通俗的理解就是先用log_format来定 ...

  6. 初识nginx+tomcat

    百度百科说: Nginx ("engine x") 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器.Nginx是由Igor Sysoev为俄罗斯 ...

  7. nginx(一)初识nginx

    什么是nginx?Nginx (engine x) 是一款轻量级的Web 服务器 .反向代理服务器及电子邮件(IMAP/POP3)代理服务器. Nginx应用场景(都很常用): 1:http服务器.N ...

  8. 初识 Nginx

    Nginx 是一个免费的,开源的,高性能的HTTP服务器和反向代理,以及IMAP / POP3代理服务器. Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名.很多高知名度的网站 ...

  9. 初识nginx反向代理和缓存机制

    实现的需求图:   环境: nginx缓存和反向代理服务器:192.168.0.224 实际存储数据机器:192.168.0.37 一.实现反向代理 1.安装nginx,两台服务器都需要安装 1)安装 ...

随机推荐

  1. maven项目引入外部第三方jar包,引入、本地编译、第三方jar一起打到jar中、在linux机器中解决classnotfound(配置classpath),笔记整理。

    文章目录 引用的第三方jar的目录结构(示例) 引入第三方jar进行dependency使项目内能import 本地编译 第三方jar一起打到jar中 在linux机器中解决classnotfound ...

  2. Laravel5.4中自定义404等错误页面

    1.在resources/views/下简历文件夹error,在error文件中建立"404.blade.php文件". <!DOCTYPE html PUBLIC &quo ...

  3. day 53 Django基础二之URL路由系统

    Django基础二之URL路由系统   本节目录 一 URL配置 二 正则表达式详解 三 分组命名匹配 四 命名URL(别名)和URL反向解析 五 命名空间模式 一 URL配置 Django 1.11 ...

  4. C# SQL 多条件查询技巧

    #region 多条件搜索时,使用List集合来拼接条件(拼接Sql) StringBuilder sql = new StringBuilder("select * from PhoneN ...

  5. C# 反射的委托创建器

    原文:C# 反射的委托创建器 .Net 的反射是个很好很强大的东西,不过它的效率却实在是不给力.已经有很多人针对这个问题讨论过了,包括各种各样的 DynamicMethod 和各种各样的效率测试,不过 ...

  6. selenium基础(控制浏览器)

    python基础(控制浏览器) 控制浏览器 控制浏览器窗口大小 设置浏览器屏幕大小方法:set_window_size() 浏览器最大化:maximize_window() 浏览器最小化:minimi ...

  7. Qt plugins(插件)目录

    今天在打包Qt程序时,出现了因为缺少插件,导致背景图无法显示的问题.第一次将plugins目录全部拷贝到了应用程序根目录下,还是无法运行.查阅资料,需要拷贝plugins子目录到应用程序跟目录.虽然最 ...

  8. csps-s模拟测试62,63Graph,Permutation,Tree,Game题解

    题面:https://www.cnblogs.com/Juve/articles/11631298.html permutation: 参考:https://www.cnblogs.com/clno1 ...

  9. 移动端,fixed bottom问题

    //不显示 .bar { position:fixed; bottom:0; z-index:99; } //显示 .bar{ position:fixed; bottom:calc(90vh); / ...

  10. tip:删除数组中的undefined

    this.checkedImg = this.checkedImg.filter(Boolean)