Nginx学习使用

介绍

Nginx是世界上第二大Web服务器,其他Web服务器有:Apache、Lighttpd、Tomcat、Jetty、IIS。

区别:

  • Tomcat、Jetty面向Java语言,先天就是重量级的Web服务器,他们的性能与Nginx没有可比性;
  • IIS只能在Windows操作系统上运行;
  • Apache发展时期最长,是毫无争议的第一大Web服务器,然而它被设计为一个重量级的、不支持高并发的Web服务器,这决定了Apache不可能成为高性能Web服务器。
  • Nginx是俄罗斯的Igor Sysoev用C语言开发的 跨平台的支持高并发的Web服务器,以性能为王。

特点:

  • 更快。一方面单次请求将会得到更快的响应;另一方面 在数以万计的并发请求时,Nginx比其他Web服务器更快的响应请求。
  • 高扩展性。它完全由不同功能、不同层次、不同类别且耦合度极低的模块组成。
  • 高可靠性。nginx的高可靠性来自于其核心框架代码的优秀设计、模块设计的简单性。
  • 低内存消耗。1万个非活跃的Http Keep-Alive连接在Nginx中仅消耗2.5MB的内存,这是nginx支持高并发连接的基础。
  • 单机支持10万以上的并发连接。
  • 热部署。7X24小时不间断的服务的前提下,升级nginx的可执行文件。
  • 最自由的BSD许可协议。用户不仅免费使用nginx,而且可以参与修改源代码

选择Nginx的核心理由是:它能够在支持高并发请求的同时 保持高效的服务。Nginx先天的事件驱动型设计、全异步的网络I/O处理机制、极少的进程间切换以及许多优化设计,使得它天生善于处理高并发压力下的互联网请求。

安装和常用命令 

以Linux(Ubuntu)为例,Nginx的软件包在Ubuntu默认软件仓库中可用。 安装非常简单,只需键入以下命令:

sudo apt update
sudo apt install nginx

安装后,配置文件默认位置   /etc/nginx/nginx.conf

安装完成后,请检查Nginx服务的状态和版本:sudo systemctl status nginx

查看版本:sudo nginx -v

  • 使用systemctl管理Nginx服务

您可以像任何其他systemd单位一样管理Nginx服务。 要停止Nginx服务,请运行:sudo systemctl stop nginx

要再次启动,请键入:sudo systemctl start nginx

重新启动Nginx服务:sudo systemctl restart nginx

在进行一些配置更改后重新加载Nginx服务:sudo systemctl reload nginx

  • 也可以使用service管理Nginx服务

停止Nginx服务,请运行:sudo service nginx stop

Nginx的配置

 Nginx有很多的模块,这些模块可以帮助我们实现Web服务器上很多的功能。使用这些模块时,仅仅需要增加、修改一些配置项即可。

运行中的Nginx进程间的关系:部署Nginx时 都是使用一个master进程来管理多个worker进程,一般情况下,worker进程的数量与服务器上的CPU核心数相等。(这样进程间切换的代价是最小的)

配置的通用语法

  • 块配置项:{}括起来的
  • 配置项的语法格式:配置项名 配置项值1 配置项值2 ;   【空格作为分隔符,多个值之间也是空格,最后以分号结尾】
  • 配置项的注释:# 开头

Nginx服务的基本配置

基本配置是其他模块执行时都依赖的配置项。分为以下4类:

1、用于调试、定位问题的配置项;

(1) 是否以守护进程方式运行Nginx

daemon on|off  默认是on,且配置文件中不用写

(2)是否以master/worker方式工作

master_process on|off  默认是on

(3)error日志的设置

error_log  logs/error.log  error   【分别是 路径和级别,当设置为error级别时,debug和info的日志则不会输出到文件中】

2、正常运行的必备配置项;

(1)定义环境变量

env VAR= Value;

(2)嵌入其他配置文件

include /path/file;   可以将其他配置文件嵌入到当前的nginx.conf文件中,可以是绝对路径,也可以相对路径

(3)pid文件的路径

pid path/file;  保存master进程ID的pid文件存放路径。

默认:pid logs/nginx.pid;

(4)Nginx worker进程运行的用户及用户组

user ;username [groupname];    

user用于设置master进程启动后,fork出的worker进程运行在哪个用户和用户组下。

默认:user nobody nobody;

3、优化性能的配置项;

(1)worker进程个数

worker_processes number;

默认 number=1 ,一般cpu核心数为几则设置为多少

(2)绑定worker进程到指定的CPU内核 。eg:

worker_processes 4;

worker_cup_affinity 1000 0100 0010 0001;

4、事件类配置项;

(1)每个worker的最大连接数

worker_connections number;

用HTTP核心模块配置一个静态Web服务器

静态Web服务器的主要功能有ngx_http_core_module模块(HTTP框架的主要成员)实现。Nginx为配置一个完整的静态Web服务器提供了非常多的功能,把这些配置项分为以下8类:

(1)虚拟主机与请求的分发

http块中的每个Server就是一个虚拟主机,它只处理与之对应的主机域名请求。所以以下配置均是在Server块中。

1、监听端口

默认:listen 80;

listen参数决定Nginx服务如何监听端口。在listen后可以只加IP地址、端口或者主机名,非常灵活。eg:

listen 127.0.0.1:8000;

listen 8000;

listen localhost:8000;

设置默认虚拟主机,listen后加default或者default_server,将所在的server块作为整个Web服务的默认server块。

2、主机名称

默认:server_name "";

可以设置多个主机名称,eg:server_name localhost www.testweb.com download.testweb.com;

在处理HTTP请求时,nginx会取出header头中的Host,与每个server中的server_name进行匹配,

3、location

语法:location [=|~|~*|^~|@] /uri/ {...}

location会尝试根据用户请求中的URI来匹配上面的/uri表达式,如果可以匹配,就选择location{} 块中的配置来处理用户请求。

location / {

# 这个配置可以匹配所有请求

}

(2)文件路径的定义

1、以root方式设置资源路径

root path;

默认:root html;

配置块:http、server、location、if

eg:location /download {

root /opt/web/html;}

如果有一个请求的uri是/download/index/test.html,那么Web服务器将会返回服务器上/opt/web/html/download/index/test.html 文件的内容。

2、访问首页

index file...;

默认:index index.html;

eg:

location /{

root  path;

index /index.html /html/index.php;}   请求的文件是path/index.html ,若不存在,则访问配置的第二个文件。

3、根据HTTP返回码重定向页面

例如:error_page 404 /404.html

(3)内存及磁盘资源的分配

用HTTP proxy module配置一个反向代理服务器

 反向代理(reverse proxy)方式是指 用代理服务器来接受Internet上的连接请求,然后将请求转发给内部网络中的上游服务器来处理。此时代理服务器对外的表现就是一个Web服务器。

Nginx通常可以配置为静态的Web服务器,也可以配置为反向代理服务器。

 

负载均衡的基本配置

作为代理服务器,一般都需要向上游服务器的集群转发请求。这里的负载均衡是指:选择一种策略,尽量把请求平均地分到每一台上游服务器上。

(1)upstream块

语法:upstream name {...}

配置块:http 即upstream是位于HTTP块中的

upstream块定义了一个上游服务器的集群,便于反向代理中的proxy_pass使用。

eg:upstream backend{

server  backend1.example.com;

server  backend2.example.com;

}

(2)server

配置块:upstream块

语法:server name [parameters];

name可以是域名、ip地址端口;

参数,可以是 weight=number,设置这台上游服务器转发的权重,默认为1;

....

 

反向代理的基本配置

(1)proxy_pass

语法:proxy_pass URL;

配置块:location,if

将当前请求反向代理到URL参数指定的服务器上,可以是主机名 或者IP地址加端口,还可以是负载均衡的upstream块名,eg:proxy_pass http://backend;

默认情况下,反向代理是不会转发请求中的Host头部的。如果需要转发,那么必须加上配置:

proxy_set_header Host $host; 

 

kill -9杀掉nginx主进程、reload失败解决办法 

kill -9 5767 14801

 

其他学习

Nginx教程(一) Nginx入门教程

整理得很全面的Nginx学习资源

Nginx教程

使用Nginx+IIS的部署方案实现负载均衡

 

posted @ 2020-02-01 20:08  peterYong  阅读(462)  评论(0编辑  收藏  举报