5.Nginx日志配置

Nginx有非常灵活的日志记录模式。每个级别的配置可以有各自独立的访问日志。日志格式 通过log_format命令定义格式

1.log_format指令

# 配置语法:包括:error.log access.log
Syntax: log_format name [escape=default|json|none] string ...;
Default:
log_format combined "...";
Context: http # 默认Nginx定义的日志语法
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';

10.0.1.1 - - [07/Feb/2020:12:50:29 +0800] "GET /img/favicon.png HTTP/1.1" 401 581 "http://www.xiao.com/" "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.88 Safari/537.36" "-"

# Nginx日志格式允许包含的变量
$remote_addr # 记录客户端的IP地址
$remote_user # 记录客户端的用户名
$body_bytes_sent # 发送给客户端的字节数,不包括头部响应的大小
$http_x_forwarded_for # 记录客户端的IP地址
$http_user_agent # 记录客户端的浏览器的相关信息
$http_referer # 记录从哪个页面链接过来访问的
$bytes_sent # 发送给客户端的字节数
$connection # 连接序列号
$connection_requests # 通过连接发出的当前请求数(1.1.)
$msec # 日志写入时的时间(以毫秒为单位),以毫秒为单位
$pipe # “ p”(如果请求已传递),.否则为“ ”
$request # 记录请求的方法及请求的协议
$request_length # 请求长度(包括请求行,标头和请求正文)
$request_time # 要求以毫秒为单位的处理时间(以毫秒为单位);从客户端读取第一个字节到将最后一个字节发送到客户端后的日志写入之间经过的时间
$status # 回应状态
$time_iso8601 # ISO 8601标准格式的当地时间
$time_local # 通用日志格式的本地时间

# 注:如果Nginx位于负载均衡器,nginx反向代理之后,web服务器无法直接获取到客户端真实的IP地址。
# $remote_addr获取的是反向代理的IP地址。反向代理服务器在转发请求的http头信息中。
# 增加X-Forward-For信息,用来记录客户端IP地址和客户端请求的服务器地址。

2.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 Example:
server {
...
access_log /var/log/nginx/www.oldboy.com.log main;
...
}

$http_x_forwarded_for

6.Nginx虚拟站点

环境:在一台服务器上实现多个站点
托管业务:
小型机
unix
工作站
unix
X86服务器 实现虚拟就主机的方式:
基于IP
不同的IP
基于端口 ***
相同的IP,不同的端口
基于域名 *****
相同的IP,相同的端口,不同的域名

需求,公司需要三个站点,分别是www,bbs,blog

解法1:基于IP的虚拟主机

) 创建目录
mkdir -p /var/www/(www,bbs,blog) ) 创建对应的配置文件
vim /etc/nginx/conf.d/www.conf
server {
listen 172.16.1.7:;
server_name www.xiao.com; location / {
root /var/www/www;
index index.html;
}
} vim /etc/nginx/conf.d/bbs.conf
server {
listen 172.16.1.8:;
server_name bbs.xiao.com; location / {
root /var/www/bbs;
index index.html;
}
} vim /etc/nginx/conf.d/blog.conf
server {
listen 172.16.1.9:;
server_name blog.xiao.com; location / {
root /var/www/blog;
index index.html;
}
}

解法2:基于端口

vim /etc/nginx/conf.d/www.conf
server {
listen ;
server_name www.xiao.com; location / {
root /var/www/www;
index index.html;
}
} vim /etc/nginx/conf.d/bbs.conf
server {
listen ;
server_name bbs.xiao.com; location / {
root /var/www/bbs;
index index.html;
}
} vim /etc/nginx/conf.d/blog.conf
server {
listen ;
server_name blog.xiao.com; location / {
root /var/www/blog;
index index.html;
}
} ) 语法测试,重载nginx
nginx -t
nginx -s reload ) 写hosts解析
10.0.1.7 www.xiao.com bbs.xiao.com blog.xiao.com [root@web01 ~]# mkdir -p /var/www/{www,bbs,blog}
[root@web01 ~]# echo www > /var/www/www/index.html
[root@web01 ~]# echo bbs > /var/www/bbs/index.html
[root@web01 ~]# echo blog > /var/www/blog/index.html
验证结果:
在验证过程中,使用www.xiao.com后加81、82端口号,都能访问到bbs.xiao.com,blog.xiao.com的首页,反之一样

解法3:基于域名

vim /etc/nginx/conf.d/www.conf
server {
listen ;
server_name www.xiao.com; location / {
root /var/www/www;
index index.html;
}
} vim /etc/nginx/conf.d/bbs.conf
server {
listen ;
server_name bbs.xiao.com; location / {
root /var/www/bbs;
index index.html;
}
} vim /etc/nginx/conf.d/blog.conf
server {
listen ;
server_name blog.xiao.com; location / {
root /var/www/blog;
index index.html;
}
} ) 语法测试,重载nginx
nginx -t
nginx -s reload ) 写hosts解析
10.0.1.7 www.xiao.com bbs.xiao.com blog.xiao.com ) 测试
http://www.xiao.com/
http://bbs.xiao.com/
http://blog.xiao.com/

增加需求:实现每个站点日志独立

)修改配置文件
/etc/nginx/nginx.conf
# access_log /var/log/nginx/access.log main; /etc/nginx/conf.d/www.conf
access_log /code/log/www.xiao.com.log main;
/etc/nginx/conf.d/bbs.conf
access_log /code/log/bbs.xiao.com.log main;
/etc/nginx/conf.d/blog.conf
access_log /code/log/blog.xiao.com.log main; )创建对应的目录
[root@web01 ~]# mkdir -p /code/log

7.Nginx Location

使用Nginx Location可以控制访问网站的路径

匹配符    匹配规则                        优先级
= 精确匹配
^~ 以某个字符开头
~ 区分大小写的正则匹配
~* 不区分大小写的正则匹配
!~ 区分大小写不匹配的正则
!~* 不区分大小写不匹配的正则
/ 通用匹配,任何请求都会匹配到

Location应用场景

# 通用匹配,任何请求都会匹配到
location / { } # 严格区分大小写,匹配以.php结尾的都走这个location
location ~ \.php$ {
fastcgi_pass http://127.0.0.1:9000;
} # 严格区分大小写,匹配以.jsp结尾的都走这个location
location ~ \.jsp$ {
proxy_pass http://127.0.0.1:8080;
} # 不区分大小写匹配,只要用户访问.jpg,gif,png,js,css都走这条location
location ~* .*\.(jpg|png|gif|js|css)$ {
rewrite (.*) http://cdn:xiao.com$requet_uri;
} # 不区分大小写匹配
location ~* "\.(sql|bak|tgz|tar.gz|.git)$" {
default_type text/html;
return "启用访问控制成功";
}

NGINX常用模块(二)的更多相关文章

  1. 常用模块二(hashlib、configparser、logging)

    阅读目录 常用模块二 hashlib模块 configparse模块 logging模块   常用模块二 返回顶部 hashlib模块 Python的hashlib提供了常见的摘要算法,如MD5,SH ...

  2. nginx常用模块(三)

    Nginx常用模块(三) ngx_http_proxy_module模块配置(http或https协议代理) proxy_pass URL; 应用上下文:location, if in locatio ...

  3. Nginx 常用模块

    Nginx 常用模块 1. ngx_http_autoindex_module # ngx_http_autoindex_module模块处理以斜杠字符(' / ')结尾的请求,并生成一个目录列表. ...

  4. (转)nginx 常用模块整理

    原文:http://blog.51cto.com/arm2012/1977090 1. 性能相关配置 worker_processes number | auto: worker进程的数量:通常应该为 ...

  5. python之常用模块二(hashlib logging configparser)

    摘要:hashlib ***** logging ***** configparser * 一.hashlib模块 Python的hashlib提供了常见的摘要算法,如MD5,SHA1等等. 摘要算法 ...

  6. python14 常用模块 二

    一.json模块 强大:不同语言之间可以进行数据交换 序列化:把对象(变量)从内存中变成可存储或传输的过程称之为序列化,在Python中叫pickling,在其他语言中也被称之为serializati ...

  7. Python自动化开发 - 常用模块(二)

    本节内容 1.shutil模块 2.shelve模块 3.xml处理模块 4.configparser模块 5.hashlib模块 6.subprocess模块 7.re模块 一.shutil模块 高 ...

  8. Python常用模块二

    一.time & datetime #_*_coding:utf-8_*_ import time # print(time.clock()) #返回处理器时间,3.3开始已废弃 , 改成了t ...

  9. Python常用模块(二)

    一.json与pickle json与pickle模块是为了完成数据的序列化. 序列化是指把对象(变量)从内存中变成可存储或传输的过程,在Python中叫picking,在其他语言中也由其他的叫法,但 ...

随机推荐

  1. 记--linux 下svn安装配置,同步web目录

    安装#yum install subversion 1.创建版本库 # svnadmin create /svn/project 2.配置svn服务的配置文件svnserver.conf文件 anon ...

  2. jupiter的@TempDir 等不生效

    jupiter与junit是 完全独立的测试组件,要严防在测试中将二者混用.最好在依赖引入jupiter 时 就将junit的依赖干掉,以防在写测试用例时将二者混用.不会报错,但是会导致 jupite ...

  3. CSU-ACM2020寒假集训比赛2

    A - Messenger Simulator CodeForces - 1288E 两种解法,我选择了第二种 mn很好求,联系过就是1,没联系过就是初始位置 第一种:统计同一个人两次联系之间的出现的 ...

  4. 学习spring的第三天

    1.手动的依赖注入出了昨天所讲的利用<property>和<constructor-arg>标签设置注入外还可以通过属性值设置,这样就少些了一些代码... 1.1:直接在< ...

  5. HDU - 6043 KazaQ's Socks(找规律)

    题意:有n双袜子,编号1到n,放在衣柜里,每天早晨取衣柜中编号最小的袜子穿,晚上将这双袜子放在篮子里,当篮子里有n-1双袜子时,清洗袜子,直到第二天晚上才洗好,并将洗好的袜子重新放回衣柜. 分析:规律 ...

  6. (转)null和NULL和nullptr和””区别

    突然想到这个有趣的问题:C语言和C++对大小写是敏感的,也就是说null和NULL是区别对待的.NULL代表空地址,null只是一个符号.便来深究,看了很多资料,总结如下: 其实null和NULL都是 ...

  7. VM15上安装macOS操作系统

    (该篇博客已经成功安装上Xcode,放心下载) 因为要开学了,需要学习mac操作系统,自己没有苹果电脑只能虚拟机上下载喽 我在电脑上安装的VM15虚拟机,不会安装的可以来这里下载软件VM15虚拟机   ...

  8. POJ 2771 最大点独立集

    这是经典的最大点独立集 还是可以转化成最大匹配数,为什么呢,因为求出最大匹配数之和,匹配的边的两个端点互斥,只能去一个,所以最后结果就用总点数-最大匹配数即可 #include <iostrea ...

  9. 2019.1的IDEA的Pulgins无法使用解决

    第一步 第二步

  10. part8 vue内置标签keep-alive对网页性能优化

    我们网页请求时候 我们点击路由切换 可以看network中数据请求 因为每次路由切换都会执行mounted钩子函数 我们这个函数中数据请求 //每次切换路由,页面都会重新渲染 在根组件中使用 路由切换 ...