一,nginx基本介绍
官网:http://nginx.org/
源码:http://github.com/nginx/nginx
- nginx的地位
nginx已超越Apache成为Web Server的霸主。https://news.netcraft.com/archives/category/web-server-survey/
最新市场占有率:https://w3techs.com/technologies/cross/web_server/ranking
2,nginx的历史
在2000年以后,互联网用户数据持续增加,网站的活跃用户也大大增加,如果支撑上万个用户同时访问成了一个突出的问题。Dan Kegel发表了著名的C10K问题的论文,也就是单机1万个并发连接的问题(Concurrency 10K)。http://www.kegel.com/c10k.html
在这样的时候背景下,Nginx诞生了,https://www.nginx.com/people/igor-sysoev
3, nginx的诞生
2000年左右,时年42岁的俄罗斯系统管理员Igor Sysoev开始启动Nginx项目。2002年十月Sysoev发布了第一段公共简码,它是用C语言编写的。2004年nginx开源了。
Nginx轻松解决了C10K的问题,单机性能达到5W左右的并发。
2011年,Igor Sysoev成立了商业公司,12年开始为企业提供商业支持,13年发布了商业版本的Nginx Plus。一般说的Nginx指的是开源版本,域名为nginx.org。商业版本的域名为nginx.com。
2019年5月,美国公司F5 Networks以6.7亿美元的价格收购了Nginx公司。
2019年12月Nginx之父俄罗斯程序员Igor Sysoev被警方带走,他的老东家Rambler集团起诉了他,声称其拥有Nginx Web服务器代码的完全所有权。主要争议点在于Nginx是Sysoev在Rambler上班的时候开发的,所以是属于公司的。后来因证据不足被释放了。
4,nginx和其它Web服务器的对比
Nginx是一个轻量级的HTTP服务器(HTTP Server)。除了Http,Nginx也支持SMTP、POP3和IMAP协议,还可以通过模块支持TCP。
和Apache(Apache HTTP Server Project, https://httpd.apache.org/)一样,它们都是用来处理和响应用户请求的。Nginx和Apache的最大区别是Nginx能支持更大的并发量。
HTTP Server和Tomcat的区别?
Tomcat是Application Server。一般说的应用服务器是用来存放和运行程序的服务器,负责处理程序的业务逻辑。如Tomcat、Weblogic、JBoss。
HTTP服务器一般是用来访问静态的资源,而应用服务器可以动态生成资源内容,比如Java的Servlet。
因为HTTP服务器跑在应用服务器的前面,所以也叫做代理服务器。
二,Nginx安装配置
1,Nginx下载安装
1)下载:从 http://nginx.org/en/download.html 复制下载
cd /usr/local/soft
wget http://nginx.org/download/nginx-1.18.0.tar.gz
2)解压
tar -xzvf nginx-1.18.0.tar.gz
3)安装依赖环境
gcc环境:基本运行环境
pcre:用于nginx的http模块解析正则表达式
zlib:用户进行gzip压缩
openssl:用于nginx https协议的传输
yum install -y gcc-c++ pcre pcre-devel zlib zlib-devel openssl openssl-devel
4)编译安装
–prefix=/usr/local/soft/nginx 的意思是把nginx安装到/usr/local/soft/nginx
所以后面会有一个源码目录nginx-1.18.0,一个编译安装后的目录nginx
cd /usr/local/soft/nginx-1.18.0
./configure --prefix=/usr/local/soft/nginx
make && sudo make install
cd /usr/local/soft/nginx/
测试配置是否成功:
/usr/local/soft/nginx/sbin/nginx -t -c /usr/local/soft/nginx/conf/nginx.conf
5)启动nginx
/usr/local/soft/nginx/sbin/nginx
浏览器直接访问IP(HTTP协议默认80端口,不需要输入)
6)常用命令
nginx -s reopen #重启Nginx
nginx -s reload #重新加载Nginx配置文件,然后以优雅的方式重启Nginx
nginx -s stop #强制停止Nginx服务
nginx -s quit #优雅地停止Nginx服务(即处理完所有请求后再停止服务)
nginx -t #检测配置文件是否有语法错误,然后退出
nginx -?,-h #打开帮助信息
nginx -v #显示版本信息并退出
nginx -V #显示版本和配置选项信息,然后退出
nginx -t #检测配置文件是否有语法错误,然后退出
nginx -T #检测配置文件是否有语法错误,转储并退出
nginx -q #在检测配置文件期间屏蔽非错误信息
nginx -p prefix #设置前缀路径(默认是:/usr/share/nginx/)
nginx -c filename #设置配置文件(默认是:/etc/nginx/nginx.conf)
nginx -g directives #设置配置文件外的全局指令
killall nginx #杀死所有nginx进程
2,Nginx配置文件
指令大全:http://nginx.org/en/docs/dirindex.html
以server指令为例:
Syntax: server_name name ...;
Default: server_name "";
Context: server
Syntax代表语法规则,Default代表默认值,Context代表在哪个模块中使用。
配置块名称 | 作用 |
---|---|
全局块 | 配置影响nginx全局的指令。一般有运行nginx服务器的用户组,nginx进程pid存放路径,日志存放路径,配置文件引入,允许生成worker proces数等 |
events块 | 配置影响nginx或用户的网络连接,有每个进程的最大连接数,选取哪种事件驱动模型处理连接请求,是否允许同时接受多个网络连接,开启多个网络连接序列化等 |
http块 | 可以嵌套多个server,配置代理,缓存,日志定义等绝大多数功能和第三方模块的配置,如文件引入,mime-type定义,日志自定义,是否使用sendfile传输文件,连接超时时间,单连接请求数等 |
server块 | 配置虚拟主机相关参数,一个http中可以有多个server |
location块 | 配置请求的路由,以及各种页面的处理情况 |
规则:
1)用“#”表示注释
2)每行配置的结尾需要加上分号(漏了分号会导致无法启动)
3)如果配置项目中包含语法符号,比如空格符,需要使用单引号或双引号括住配置项值,否则nginx会报语法错误
4)单位简写。当指定空间大小,可以使用的单位符号包括:K或者k千字节(KB),M或者m兆字节(MB),如:
gzip_buffer 48k; client_max_body_size 64M;
当指定时间时,可以使用的单位包括:ms(毫秒)、s(秒)、m(分钟)、h(小时)、d(天)、w(周)、M(月)、y(年)。如:
expires 10y;
proxy_read_timeout 600m;
client_body_timeout 2m;
5)基本配置示例:
user nginx; //配置用户或者组,默认为nobody nobody
worker_processes 2; //工作进程数,默认为1
pid /nginx/pid/nginx.pid; //指定nginx进程运行文件存放地址
error_log /var/log/nginx/error.log debug; //指定日志路径,级别。这个设置可以放入全局块,http块,server块,级别依次为debug|info|warn|error|crit|alert|emerg
events {
accept_mutex on; //设置网络连接序列化,防止惊群现象发生,默认为on
multi_accept on; //设置一个进程是否同时接受多个网络连接,默认为off
#use epoll; //事件驱动模型,select|poll|kqueue|epoll|resig|/dev/poll|eventport
worker_connections 1024; //最大连接数,默认为512
}
http {
include mime.types; //文件扩展名与文件类型映射表
default_type application/octet-stream; //默认文件类型,默认为 text/plain
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"'; //自定义日志格式
access_log /var/log/nginx/access.log main;
sendfile on; //允许sendfile方式传输文件,默认为off
sendfile_max_chunk 100k; //每个进程每次调用传输数量不大于设定的值,默认为0,即不设上限
keepalive_timeout 65; //连接超时时间
#gzip on;
upstream myserver{
server 127.0.0.1:8080;
server 127.0.0.1:8081 backup; //热备
}
server{
keepalive_requests 120; //单连接请求上限次数
listen 4545; //监听端口
server_name 127.0.1; //监听地址
location ~*^.+${ //请求url过滤,正则匹配,~为区分大小写,~*为不区分大小写
proxy_pass http://myserver; //请求转向myserver定义的服务器列表
deny 127.0.0.1; //拒绝的ip
allow 127.0.0.1; //允许的ip
}
}
}
3,nginx的基本命令
在sbin目录下,加上./
命令 | 作用 |
---|---|
nginx -h | 帮助命令 |
killall nginx | 杀死所有nginx进程 |
nginx -q | 在检测配置文件期间屏蔽非错误信息 |
nginx -s reopen | 重启nginx |
nginx -s reload | 重新加载nginx配置文件,然后以优雅的方式重启nginx |
nginx -s stop | 强制停止nginx服务 |
nginx -s quit | 优雅地停止nginx服务(处理完所有的请求再停止服务) |
nginx -t | 检测配置文件是否有语法错误,然后退出 |
nginx -T | 检测配置文件是否有语法错误,转储并退出 |
nginx -v | 显示版本信息并退出 |
nginx -V | 显示版本和配置选项信息,然后退出 |
nginx -?, -h | 打开帮助信息 |
4,nginx日志