Nginx Web快速入门-基础
2022-01-06 本文已影响0人
Chris0Yang
如不知道怎么安装。参考地址:https://www.jianshu.com/p/5460755dea00
Nginx主配置文件整体分为三块进行学习,分别是CoreModule(核心模块)
,EventModule(事件驱动模块)
,HttpCoreModule(http内核模块)
文件路径:/etc/nginx.conf
CoreModule(核心模块)
user nginx; # Nginx进程所使用的用户
worker_processes auto; # Nginx运行的work进程数量(建议与CPU数量一致或auto)
error_log /var/log/nginx/error.log notice; # Nginx错误日志存放路径
pid /var/run/nginx.pid; # Nginx服务运行后产生的pid进程号
EventModule(事件驱动模块)
events {
worker_connections 1024; # 每个worker进程支持的最大连接数
use epoll; # 事件驱动模型, epoll默认
}
HttpCoreModule(http内核模块)
# http层开始
http {
# 默认以下载方式传输给浏览器(前提是该资源在mime.types中无法找到)
default_type application/octet-stream;
# 高效文件传输
sendfile on;
# 日志格式
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使用
#tcp_nopush on;
# 长连接超时时间
keepalive_timeout 65;
# 是否开启压缩
#gzip on;
include /etc/nginx/conf.d/*.conf; # 包含资源类型文件
#使用Server配置网站, 每个Server{}代表一个网站(简称虚拟主机)
server {
listen 80; # 监听端口, 默认80
server_name www.test.com; # 提供的域名
access_log access.log; # 该网站的访问日志
# 控制网站访问路径
location / {
root /code; # 存放网站源代码的位置
index index.html index.htm; # 默认返回网站的文件
}
}
# 第二个虚拟主机配置
server {
...
}
include /etc/nginx/conf.d/*.conf; # 包含/etc/nginx/conf.d/目录下所有以.conf结尾的文件
} # http结束层
http server location 扩展了解项
http{}层下允许有多个**Server{}层,一个Server{}层下又允许有多个**Location
http{} 标签主要用来解决用户的请求与响应
server{} 标签主要用来响应具体的某一个网站
location{} 标签主要用于匹配网站具体URL路径
Nginx网站配置
1)新增nginx配置文件
[root@test1 conf.d]# cat test1.conf
server {
listen 80;
server_name www.test.com;
location / {
root /code;
index index.html index.htm;
}
}
2) 放置源代码文件至nginx配置文件root指定的目录
mkdir /code && cd /code
echo test1 >/code/index.html
3) 检查nginx的语法是否存在错误
nginx -t
4) 重载Nginx [reload|restart]
nginx -s reload
5) 设置hosts,然后测试 ping域名
echo "192.168.100.103 www.test.com" >>/etc/hosts
[root@test1 conf.d]# ping 1.test1.com
PING 1.test1.com (192.168.100.103) 56(84) bytes of data.
64 bytes from 1.test1.com (192.168.100.103): icmp_seq=1 ttl=64 time=0.056 ms
64 bytes from 1.test1.com (192.168.100.103): icmp_seq=2 ttl=64 time=0.037 ms
64 bytes from 1.test1.com (192.168.100.103): icmp_seq=3 ttl=64 time=0.036 ms
NginxServer配置三种方式
方式一:基于主机多IP方式
1)多网卡多IP的方式
[root@test conf.d]# cat test1.conf
server {
listen 192.168.100.103:80;
server_name _;
location / {
root /code/eth0;
index index.html;
}
}
server {
listen 172.16.1.103:80;
server_name _;
location / {
root /code/eth1;
index index.html;
}
}
# 语法检查
nginx -t
# nginx -s reload不会关掉之前nginx端口,所以要stop后 重新启动nginx
nginx -s stop
# 启动
nginx
# 检查nginx端口80
[root@test conf.d]# netstat -tnlup|grep 80
tcp 0 0 172.16.1.103:80 0.0.0.0:* LISTEN 29084/nginx: master
tcp 0 0 192.168.100.103:80 0.0.0.0:* LISTEN 29084/nginx: master
# curl -I 是查看网站的状态码及返回信息
# curl 下载页面信息
[root@test conf.d]# curl 192.168.100.103
eth0_server
[root@test conf.d]# curl 172.16.1.103
eth1_server
2)单网卡多IP的方式
# 添加网卡
ip addr add 192.168.100.113/24 dev eth0
ip addr add 192.168.100.123/24 dev eth0
[root@test conf.d]# cat test1.conf
server {
listen 192.168.100.103:80;
server_name _;
location / {
root /code/test1;
index index.html;
}
}
server {
listen 192.168.100.113:80;
server_name _;
location / {
root /code/test2;
index index.html;
}
}
server {
listen 192.168.100.123:80;
server_name _;
location / {
root /code/test3;
index index.html;
}
}
# 创建文件
echo 192.168.100.103 >>/code/test1/index.html
echo 192.168.100.113 >>/code/test2/index.html
echo 192.168.100.123 >>/code/test3/index.html
# curl验证
[root@test conf.d]# curl 192.168.100.103
192.168.100.103
[root@test conf.d]# curl 192.168.100.113
192.168.100.113
[root@testconf.d]# curl 192.168.100.123
192.168.100.123
方式二:基于端口的配置方式
[root@test conf.d]# cat test1.conf
server {
listen 80;
location / {
root /code/80;
index index.html;
}
}
server {
listen 81;
location / {
root /code/81;
index index.html;
}
}
server {
listen 82;
location / {
root /code/82;
index index.html;
}
}
# 语法检查
nginx -t
# nginx -s reload不会关掉之前nginx端口,所以要stop后 重新启动nginx
nginx -s stop
# 启动
nginx
[root@test conf.d]# curl 192.168.100.103:80
80
[root@test conf.d]# curl 192.168.100.103:81
81
[root@test conf.d]# curl 192.168.100.103:82
82
[root@test conf.d]# netstat -tnlup|grep nginx
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 29231/nginx: master
tcp 0 0 0.0.0.0:81 0.0.0.0:* LISTEN 29231/nginx: master
tcp 0 0 0.0.0.0:82 0.0.0.0:* LISTEN 29231/nginx: master
方式三:基于多个hosts名称方式(多域名方式)
作用环境:
1、常用多端口和多host主机方式
2、多端口常用来做测试和内部访问
3、host主机方式 针对用户提供访问
[root@test conf.d]# ll
total 12
-rw-r--r-- 1 root root 135 Jan 7 17:09 test1.conf
-rw-r--r-- 1 root root 135 Jan 7 17:09 test2.conf
-rw-r--r-- 1 root root 135 Jan 7 17:09 test3.conf
[root@test conf.d]# cat test*.conf
server {
listen 80;
server_name www.test1.com;
location / {
root /code/test1;
index index.html;
}
}
server {
listen 80;
server_name www.test2.com;
location / {
root /code/test2;
index index.html;
}
}
server {
listen 80;
server_name www.test3.com;
location / {
root /code/test3;
index index.html;
}
}
# 语法检查
nginx -t
# nginx -s reload不会关掉之前nginx端口,所以要stop后 重新启动nginx
nginx -s stop
# 启动
nginx
# /etc/hosts/ 记得添加 IP:域名
[root@test conf.d]# curl www.test3.com
test3
[root@test conf.d]# curl www.test2.com
test2
[root@test conf.d]# curl www.test1.com
test1
Nginx日志管理
Nginx有非常灵活的日志记录模式,每个级别的配置可以有各自独立的访问日志。日志格式通过log_format命令定义格式
log_format详解
在nginx默认的配置文件中,log_format已经将日志格式定死,但是我们可不可以修改呢?
1.log_format的作用是定义日志格式语法
# 配置语法: 包括: error.log access.log
Syntax: log_format name [escape=default|json] string ...;
Default: log_format combined "...";
Context: http
2.nginx默认日志格式语法如下:
log_format main '$remote_addr ‐ $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
3.Nginx日志格式允许包含的内置变量
$remote_addr # 记录客户端IP地址
$remote_user # 记录客户端用户名
$time_local # 记录通用的本地时间
$time_iso8601 # 记录ISO8601标准格式下的本地时间
$request # 记录请求的方法以及请求的http协议
$status # 记录请求状态码(用于定位错误信息)
$body_bytes_sent # 发送给客户端的资源字节数,不包括响应头的大小
$bytes_sent # 发送给客户端的总字节数
$msec # 日志写入时间。单位为秒,精度是毫秒
$http_referer # 记录从哪个页面链接访问过来的
$http_user_agent # 记录客户端浏览器相关信息
$http_x_forwarded_for #记录客户端IP地址
$request_length # 请求的长度(包括请求行, 请求头和请求正文)
$request_time # 请求花费的时间,单位为秒,精度毫秒
# 注:如果Nginx位于负载均衡器,nginx反向代理之后, web服务器无法直接获取到客 户端真实的IP地址。
# $remote_addr获取的是反向代理的IP地址。 反向代理服务器在转发请求的http头信息中,
# 增加X‐Forwarded‐For信息,用来记录客户端IP地址和客户端请求的服务器地址。
4.access_log日志配置语法
Syntax: access_log path [format [buffer=size] [gzip[=level]] [flush=time] [if=condition]];
access_log off;
Default: access_log logs/access.log combined;
Context: http, server, location, if in location, limit_except
5.Nginx Access日志配置实践
server{
listen 80;
server_name www.test1.com;
# 将当前的server网站的访问日志记录至对应的目录,使用main格式
access_log /var/log/nginx/test1.log main;
location / {
root /code;
}
# 当有人请求改favicon.ico时,不记录日志
location /favicon.ico {
access_log off;
return 200;
}
}
Nginx日志切割
使用logrotate
切割日志
[root@test conf.d]# cat /etc/logrotate.d/nginx
/var/log/nginx/*.log {
daily # 每天切割日志
missingok # 日志丢失忽略
rotate 52 # 日志保留52天
compress # 日志文件压缩
delaycompress # 延迟压缩日志
notifempty # 不切割空文件
create 640 nginx adm # 日志文件权限
sharedscripts
postrotate # 切割日志执行的命令
if [ ‐f /var/run/nginx.pid ]; then
kill ‐USR1 `cat /var/run/nginx.pid`
fi
endscript
}
日志切割后的效果
[root@test ~]# ll /var/log/nginx/
total 4044
‐rw‐r‐‐‐‐‐ 1 www adm 54438 Oct 12 03:28 access.log‐20XXXXX.gz
‐rw‐r‐‐‐‐‐ 1 www adm 28657 Oct 13 03:48 access.log‐20XXXXX.gz
‐rw‐r‐‐‐‐‐ 1 www adm 10135 Oct 12 03:28 error.log‐20XXXXX.gz
‐rw‐r‐‐‐‐‐ 1 www adm 7452 Oct 13 03:48 error.log‐20XXXXX.gz
.