在上一篇的文章写给后端的Nginx初级入门教程:基础篇中,咱们主要说了Nginx是什么,能作什么,以及Nginx最重要的四个基本概念,分别是 正向代理, 反向代理,负载均衡,以及动静分离 。javascript
本章做为实战篇,将从实际的命令行出发,经过安装,启动,配置Nginx来逐渐认识和使用Nginx,并可以本身实现一些简单的反向代理,负载均衡的配置。css
不废话,直接上干货。html
Nginx的安装仍是比较容易的,有离线安装,在线安装多种安装方式,这里我只说最简单的一种,打开咱们的命令行终端,直接输入yum命令进行安装java
yum install -y nginx
复制代码
当终端显示出Complete!字样时,则表明咱们的Nginx已经安装成功了。node
查看Nginx版本:jquery
nginx -v
#在这里我安装的是1.16.1版本的nginx
复制代码
和咱们以前的docker同样,nginx也有一些包括服务的启动,中止,重载等基本操做。linux
启动nginx:nginx
##在centos7+ 启动nginx服务
systemctl start nginx.service
#centos6+ 上启动nginx服务
service nginx start
#或,简单粗暴一句
nginx
复制代码
中止nginx:git
##在centos7+ 中止nginx服务
systemctl stop nginx.service
#centos6+ 上中止nginx服务
service nginx stop
#粗鲁的中止,下班了,不干了,就算请求来了我也不接了。
nginx -s stop
##优雅的中止,Nginx在退出前完成已经接受的链接请求。
nginx -s quit
复制代码
重启nginx:github
当咱们修改了nginx的某些配置,为了使配置生效,咱们每每须要重启nginx,一样的,linux下依然有两种方式来重启咱们的nginx服务:
##在centos7+ 重启nginx服务
systemctl restart nginx.service
#centos6+ 上重启nginx服务
service nginx restart
#使用nginx命令中止,推荐这个
nginx -s reload
复制代码
而具体使用nginx原生的nginx -s 操做仍是linux提供的systemctl ,这个主要看我的喜爱,实际二者的功能是差很少的,并无什么明显的不一样。
其余命令:
查看配置文件是否ok:
#若是配置文件有问题的话会显示failed,若是没得问题的话,会显示successful
nginx -t
复制代码
显示帮助信息:
nginx -h
#或者
nginx -?
复制代码
nginx自己做为一个完成度很是高的负载均衡框架,和不少成熟的开源框架同样,大多数功能均可以经过修改配置文件来完成,使用者只须要简单修改一下nginx配置文件,即可以很是轻松的实现好比反向代理,负载均衡这些经常使用的功能,一样的,和其余开源框架好比tomcat同样,nginx配置文件也遵循着相应的格式规范,并不能一顿乱配,在讲解如何使用nginx实现反向代理,负载均衡等这些功能的配置前,咱们须要先了解一下nginx配置文件的结构。
既然要了解nginx的配置文件,那我总得知道nginx配置文件在哪啊,nginx配置文件默认都放在nginx安装路径下的conf目录,而主配置文件nginx.conf天然也在这里面,咱们下面的操做几乎都是对nginx.conf这个配置文件进行修改。
但是,我怎么知道我nginx装哪了?我要是不知道nginx装哪了咋办?
这个,细心的朋友们可能会发现,运行nginx -t命令,下面除了给出nginx配置文件是否OK外,同时也包括了配置文件的路径。诺,就是这个
[root@izuf61d3ovm5vx1kknakwrz ~]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
复制代码
使用vim打开该配置文件,咱们一探究竟,不一样版本的配置文件可能稍有不一样,个人配置文件内容以下:
# For more information on configuration, see:
# * Official English Documentation: http://nginx.org/en/docs/
# * Official Russian Documentation: http://nginx.org/ru/docs/
user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;
# Load dynamic modules. See /usr/share/doc/nginx/README.dynamic.
include /usr/share/nginx/modules/*.conf;
events {
worker_connections 1024;
}
http {
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;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
types_hash_max_size 2048;
include /etc/nginx/mime.types;
default_type application/octet-stream;
# Load modular configuration files from the /etc/nginx/conf.d directory.
# See http://nginx.org/en/docs/ngx_core_module.html#include
# for more information.
include /etc/nginx/conf.d/*.conf;
server {
listen 80 default_server;
listen [::]:80 default_server;
server_name _;
root /usr/share/nginx/html;
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
location / {
}
error_page 404 /404.html;
location = /40x.html {
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
}
}
复制代码
? ? ?
这一堆都是啥玩意er,彻底没有头绪啊
不要紧,下面咱们就来详细分析一下nginx.conf这个文件中的内容。
按照功能划分,咱们一般将nginx配置文件分为三大块,全局块,events块,http块。
首先映入眼帘的这一堆:
user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;
# Load dynamic modules. See /usr/share/doc/nginx/README.dynamic.
include /usr/share/nginx/modules/*.conf;
复制代码
咱们称之为全局块,知识点呐朋友们,要记住,这里呢,主要会设置一些影响 nginx 服务器总体运行的配置指令,主要包括配 置运行 Nginx 服务器的用户(组)、容许生成的 worker process 数,进程 PID 存放路径、日志存放路径和类型以及配置文件的引入等。
好比 worker_processes auto; 这一行,worker_processes 值越大,咱们nginx可支持的并发数量就越多,不少人想这不就爽了吗,我设置成正无穷,无限并发flag达成,秒杀问题轻松解决,这个,受本身服务器硬件限制的,不能乱来。
events {
worker_connections 1024;
}
复制代码
这一堆,就是咱们配置文件的第二部分,events 块
起名字这么随意的么,那第三部分是否是叫http块?
wc,这你都知道,是的
events 块涉及的指令主要影响 Nginx 服务器与用户的网络链接,经常使用的设置包括是否开启对多 work process 下的网络链接进行序列化,是否容许同时接收多个网络链接,选取哪一种事件驱动模型来处理链接请求,每一个 word process 能够同时支持的最大链接数等。
内容太多,略
http {
server {
}
}
复制代码
注意:
http是一个大块,里面也能够包括不少小块,好比http全局块,server块等。
http 全局块配置的指令包括文件引入、MIME-TYPE 定义、日志自定义、链接超时时间、单连接请求数上限等。
而http块中的server块则至关于一个虚拟主机,一个http块能够拥有多个server块。
server块又包括全局server块,和location块。
全局server块主要包括了本虚拟机主机的监听配置和本虚拟主机的名称或 IP 配置
location块则用来对虚拟主机名称以外的字符串进行匹配,对特定的请求进行处理。地址定向、数据缓 存和应答控制等功能,还有许多第三方模块的配置也在这里进行。好比,对/usr相关的请求交给8080来处理,/admin则较给8081处理。
说了这么多,我仍是不是特别理解咋办,问题不大,接下来咱们经过几个实例来帮助你们更好的理解这些配置在实际中所发挥的做用。
接下来咱们将经过对nginx配置文件的修改来完成反向代理,负载均衡,动静分离的简单配置。
我发现不少教程说nginx配置反向代理的时候上来就改host文件,这里的话,由于上一篇文章咱们有总结过反向代理的精髓,也就是:
反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器 IP 地址。
因此接下来咱们经过一个小栗子,当咱们访问服务器的时候,因为个人服务器没备案,阿里云默认80端口没开,因此这里咱们设置对外服务的端口为8888,当咱们访问8888端口的时候,其实是跳转到8080端口的。
首先咱们用docker启动一个tomcat容器,而后配置端口映射为8080。
等等,不会docker怎么办?不会docker的话,能够看韩数最新的docker初级入门教程(滑稽)
若是对docker不是很了解的话,可使用传统的linux下运行tomcat,道理是同样的。
而后修改咱们的配置文件nginx.conf里面的server块,修改以后的内容以下:
server {
listen 8888 ; ##设置咱们nginx监听端口为8888
server_name [服务器的ip地址];
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
location / {
proxy_pass http://127.0.0.1:8080; ##须要代理的服务器地址
index index.html;
}
error_page 404 /404.html;
location = /40x.html {
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
}
复制代码
而后在浏览器中输入:服务器ip:8888 发现浏览器显示出来了8080端口tomcat的欢迎界面,从而实现了隐藏真实服务器地址这样一个反向代理的要求。
哦?看着好神奇哦,那,我以前常常有看到那种,就是各类/image /video 不一样的连接对应的是不一样的网站,那也是这么作的咯?
聪明,这里咱们再新建一个tomcat容器,端口为8081,同时把在容器中tomcat webapps目录新建一个咱们本身的目录,这里叫hello,里面新建一个hello.html文件,内容为
<h1>I am Hello<h1>
复制代码
同时咱们在端口为8080的tomcat容器中,在webapps新建咱们的文件家hi,并新建hi.html文件,内容为
<h1>I am Hi<h1>
复制代码
啊,这样的话配置是否是很难啊?
你想多了,敲简单的。
修改咱们配置文件中的server快,以下:
server {
listen 8888 ; ##设置咱们nginx监听端口为8888
server_name [服务器的ip地址];
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
location /hi/ {
proxy_pass http://127.0.0.1:8080; ##须要代理的服务器地址
index index.html;
}
location /hello/ {
proxy_pass http://127.0.0.1:8081; ##须要代理的服务器地址
index index.html;
}
error_page 404 /404.html;
location = /40x.html {
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
}
复制代码
在浏览器中输入:服务器ip:8888/hi/hi.html
浏览器显示 I am hi 对应服务器端口为 8080
在浏览器中输入:服务器ip:8888/hello/hello.html
浏览器显示 I am hello 对应服务器端口为 8081
从而实现了针对不一样url请求分发给不一样服务器的功能配置。
少侠,且慢,你是否是忘了什么东西,location /hello/ 是什么意思,只能这么写么?
固然不是。学会location指令匹配路径,随便换姿式
location指令说明:
功能:用于匹配URL
语法以下:
一、= :用于不含正则表达式的 uri 前,要求请求字符串与 uri 严格匹配,若是匹配
成功,就中止继续向下搜索并当即处理该请求。
二、~:用于表示 uri 包含正则表达式,而且区分大小写。
三、~*:用于表示 uri 包含正则表达式,而且不区分大小写。
四、^~:用于不含正则表达式的 uri 前,要求 Nginx 服务器找到标识 uri 和请求字
符串匹配度最高的 location 后,当即使用此 location 处理请求,而再也不使用 location
块中的正则 uri 和请求字符串作匹配。
复制代码
注意:
若是 uri 包含正则表达式,则必需要有 ~ 或者 ~* 标识。
到这里,关于nginx如何简单的配置一个反向代理服务器就大功告成了,下面咱们来讲一下怎么实现负载均衡的简单配置。
在nginx中配置负载均衡也是十分容易的,同时还支持了多种负载均衡策略供咱们灵活选择。首先依旧是准备两个tomcat服务器,一个端口为8080,一个端口为8081,这里呢,推荐你们用docker部署,太方便了,什么,不会docker,能够移步个人面向后端的docker初级入门教程,真的挺好用,省了不少工做量。
卧槽,广告
而后修改咱们的http块以下:
http {
###此处省略一大堆没有改的配置
##自定义咱们的服务列表
upstream myserver{
server 127.0.0.1:8080;
server 127.0.0.1:8090;
}
server {
listen 8888 ; ##设置咱们nginx监听端口为8888
server_name [服务器的ip地址];
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
location / {
proxy_pass http://myserver; ##叮,核心配置在这里
proxy_connect_timeout 10; #超时时间,单位秒
}
error_page 404 /404.html;
location = /40x.html {
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
}
}
复制代码
这就完了?固然尚未,以前就有说过,nginx提供了三种不一样的负载均衡策略供咱们灵活选择,分别是:
轮询(默认方式): 每一个请求按时间顺序逐一分配到不一样的后端服务器,若是后端服务器 down 掉,能自动剔除。
用法:啥也不加,上文实例就是默认的方式,就是默认的
权重(weight): weight 表明权重,默认为 1,权重越高被分配的客户端越多,权重越大,能力越大,责任越大,处理的请求就越多。
用法:
upstream myserver{
server 127.0.0.1:8080 weight =1;
server 127.0.0.1:8090 weight =2;
}
复制代码
ip_hash:每一个请求按访问 ip 的 hash 结果分配,这样每一个访客固定访问一个后端服务器,能够解决 session 的问题。
用法:
upstream myserver{
ip_hash;#可与weight配合使用
server 127.0.0.1:8080 weight =1;
server 127.0.0.1:8090 weight =2;
}
复制代码
接下来讲最后一个实例,动静分离的简单配置。
等等,我记得明明是四个,明明还有一个正向代理呢?
这个,爱国守法,人人有责,有须要访问某些国内不能访问的网站需求的同窗,能够自行下去查阅资料。
至于怎么配置正向代理,咱也不知道,咱也不敢说,咱也不敢问。
基础篇回顾:
动静分离就是把不多会发生修改的诸如图像,视频,css样式等静态资源文件放置在单独的服务器上,而动态请求则由另一台服务器上进行,这样一来,负责动态请求的服务器则能够专一在动态请求的处理上,从而提升了咱们程序的运行效率,与此同时,咱们也能够针对咱们的静态资源服务器作专属的优化,增长咱们静态请求的响应速度。
具体的动静分离配置也不是十分的复杂,和负载均衡,反向代理差很少。
为了演示动静分离呢,首先咱们须要准备两个文件夹,一个是data文件夹,用来存放咱们js,css这些静态资源文件,一个是html文件夹,用来存放咱们的html文件。
在html文件夹新建一个html文件,index.html,内容以下
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>我是一个静态界面</title>
</head>
<script type="text/javascript" src="jquery.js"></script>
<body>
<h1>我是一个静态界面</h1>
<div id="test_div"></div>
</body
</html>
复制代码
注意,这里咱们并无将jquery.js 这个文件放在html目录下,而是将它放在了另一个目录data里面,当服务器接须要请求jquery.js这个文件时,并不会去index.html所在的那个服务器去请求这个文件,而是会直接去咱们配置好的服务器或者路径去寻找这个js文件,在本实例中,会去data文件夹下面去找这个jquery.js这个文件。
修改server的配置以下:
server {
listen 8886 ;
server_name [你的服务器ip地址];
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
location / {
root /html/;
index index.html;
}
#拦截静态资源,static里面存放的咱们图片什么的静态资源
location ~ .*\.(gif|jpg|jpeg|bmp|png|ico|js|css)$ {
root /data/;
}
error_page 404 /404.html;
location = /40x.html {
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
}
复制代码
测试:
在浏览器中输入ip地址:8888/index.html,屏幕上显示我是一个静态界面,同时打开浏览器自带的开发者工具
会发现jquery.js已经被正常请求到了。
写到这里实战篇结束了吗?并无,尽管上面给出了负载均衡,反向代理,动静分离的实例,但仍然只是最基础的配置,好比多层负载均衡,缓存等高级配置,都须要咱们在往后的开发生活逐渐的去接触和了解。下一篇呢,咱们将深刻nginx腹地,去稍微稍微简单不细致大体看一眼那种去了解一下nginx内部是如何保持如此高效率的工做的。
最后,韩数的学习笔记目前已经悉数开源至github,必定要点个star啊啊啊啊啊啊啊
万水千山老是情,给个star行不行
欢迎点赞,关注我,有你好果子吃(滑稽)