最近在搭建一个网站,就不可避免地要用到 Nginx,索性就出一期 Nginx 的入门教程,希望也可以帮助到大家~??
作为开发者,相信大家都知道 Nginx 的重要性,Nginx 是一个高性能的 HTTP 和反向代理 Web 服务器,由俄罗斯的伊戈尔·赛索耶夫开发,第一个版本发布于 2004 年 10 月 4 日,
Nginx 的特点是:
- 存储器占用少
- 并发能力强(可支持大约 50000 个并发连接)
- 配置超简洁
- bug 非常少
- 安装超简单
- 服务特别稳(几个月也不需要重启)
基于这些特点,越来越多的网站开始使用 Nginx,于是,掌握 Nginx 就变成了开发者的一项必不可少的技能,
这篇已经收录到《Java 程序员进阶之路》专栏的「Nginx」篇,喜欢这个专栏的小伙伴可以去点个 star 关注下了,冲个 1000 star!
https://github.com/itwanger/toBeBetterJavaer
一、Nginx 的作用
反向代理是 Nginx 作为 Web 服务器最常用的功能之一,什么是反向代理呢?很多初学者在第一次遇到这个名词的时候总免不了出现很多问号,
那要想搞明白什么是反向代理,就必须得搞明白什么是正向代理,
举个例子,小二的浏览器是无法直接访问谷哥的,但香港的代理服务器是可以访问谷哥的,于是小二访问了香港的代理服务器,也就间接地访问了谷哥,那这台代理服务器也就是正向代理,
总结一句就是,正向代理是代理客户端的,让你能正常访问目的服务器,
与之相反,反向代理是代理服务器的,让大量的请求均衡地访问到某一台服务器上,
举个例子,10 万个小二同时在访问 itwanger.com, 如果只有一台服务器的话,很容易就瘫痪了,于是高并发的情况下会有很多台服务器(假如 10 台吧)来接这个活,那怎么让 10 万个小二访问到这 10 台服务器呢?
这就需要一个反向代理服务器了,反向代理服务器让 1 万个小二访问服务器 A,1 万个小二访问服务器 B,1 个小二访问服务器 C,这样的话,每台服务器的压力就相应减小了,是不是很 nice?
那问题来了,每台服务器的能力可能不同,比如说服务器 A 的存储器比较大一点,有 100 个 G;服务器 B 的存储器小一点,有 10 个 G;服务器 C 的存储器更小一点,只有 1 个 G,怎么才能让没台服务器承担起它能力范围内的访问呢?
Nginx 内置了轮询和加权轮询来达到负载均衡的目的,服务器 A 牛逼就把它的权重加大一点,让 5 万个小二访问它;服务器 B 弱一点,权重就再小一点,让 2 万个小二访问它;服务器 C 更弱,权重就最小,让 1 万个小二访问它,
除此之外,Nginx 还有一个很牛逼的功能是动静分离,
在我们的软件开发中,有些请求是需要后台处理的;有些请求是不需要后台处理的,比如说 css、js 这些档案请求,这些不需要经过后台处理的档案就叫静态档案,
我们可以根据一些规则,把动态资源和静态资源分开,然后通过 Nginx 把请求分开,静态资源的请求就不需要经过 Web 服务器处理了,从而提高整体上的资源的回应速度,
二、Nginx 的安装
针对不同的作业系统,Nginx 的安装各不相同,Windows 可以直接到官网下载 zip 绿色安装包,解压后就可以了,
http://nginx.org/en/download.html
之前带大家白票过阿里云的服务器,有 Linux 服务器的话,直接通过宝塔面板这个神器就可以安装了,
不过,如果在安装宝塔面板必备工具包的时候,如果选择了 phpmyadmin(MySQL 的管理工具),会覆写掉 80 埠,就导致没办法直接通过默认配置的方式访问 Nginx 启动页面了,
我这里以 macOS 环境为例,来演示一下,
第一步,通过 brew info nginx
命令查看 Nginx 是否安装,
第二步,通过 brew install nginx
命令安装 Nginx,
从以上信息可以得出:
- 根目录是
/usr/local/var/www
- 组态档是
/usr/local/etc/nginx/nginx.conf
- 默认埠是 8080
第三步,通过 nginx
命令启动 Nginx,
第四步,在浏览器地址栏通过 localhost:8080
访问,可以看到以下欢迎页面,
三、Nginx 常用命令
通常来说,Nginx 一旦启动后,我们是很少让它退出的,使用最多的就是 reload 命令,当我们修改了组态档,是需要执行一次 reload 命令让 Nginx 生效的,
nginx 启动
nginx -s stop 停止
nginx -s quit 安全退出
nginx -s reload 重新加载组态档
ps aux|grep nginx 查看nginx行程
要知道,Nginx 的 reload 对用户是无感的,这一点我觉得很牛逼~
四、Nginx 的配置
我们先来看一下 Nginx 的配置结构图:
main # 全域配置
├── events # 配置网络连接
├── http # 配置代理、快取、日志等
│ ├── upstream # 配置负载均衡
│ ├── server # 配置虚拟主机,可以有多个 server
│ ├── server
│ │ ├── location # 用于匹配 URI(URL 是 URI 的一种),可以有多个 location
│ │ ├── location
│ │ └── ...
│ └── ...
└── ...
再把 Nginx 的默认配置拉出来看一下,我把注释加了进去,这样大家很容易就明白这行配置是用来干嘛的了,
worker_processes 1; # Nginx 行程数,一般设定为和 CPU 核数一样
events {
worker_connections 1024; # 每个行程允许最大并发数
}
http {
include mime.types; # 档案扩展名与型别映射表
default_type application/octet-stream;
sendfile on; # 开启高效传输模式
keepalive_timeout 65; # 保持连接的时间,也叫超时时间,单位秒
server {
listen 8080; # 配置监听的埠
server_name localhost; # 配置的域名
location / {
root html; # 网站根目录
index index.html index.htm; # 默认首页档案
}
error_page 500 502 503 504 /50x.html; # 默认50x对应的访问页面
location = /50x.html {
0 评论