1. 安装

(1)  Nginx下载地址:https://nginx.org/download/nginx-1.14.0.tar.gz

(2)  安装时可能出现依赖库不存在,比如prec包,可以使用yum install pcre pcre-devel进行安装。安装的整体命令如下:

cd /usr/local/src
# 下载
wget https://nginx.org/download/nginx-1.14.0.tar.gz
tar -zxvf nginx-1.14..tar.gz
cd nginx-1.14.
# 编译安装
./configure --prefix=/usr/local/nginx
make && make install  

2. 启动

(1) 安装后,进入/usr/local/nginx可以看到如下目录:

  a. conf: 配置文件

  b. html: 网页文件

  c. logs: 日志文件

  d. sbin: 主要二进制程序

  注意:启动时可能会遇到 nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use) 异常,表示80端口已被占用,原因可能是先前已经安装了nginx、apache等,更多情况是操作系统自带了apache并作为服务启动。解决方法是将占用80端口的软件或服务关闭即可。

3. Nginx信号控制

(1) Nginx控制信号选项如下:

TERM, INT 快速关闭
QUIT 优雅关闭进程,即等待请求结束后再关闭
HUP 配置文件更改后,平滑地重读配置文件
USR1 重读日志,在日志按月/日分割时有用
USR2 平滑地升级
WINCH 优雅地关闭旧的进程(配合USR2来进行升级)

  具体命令格式:1) kill -信号选项 nginx的主进程号 或 2) kill -信号选项 `cat /your/path/log/nginx.pid`

  例:

  1) 快速关闭nginx:kill -INT `cat ./logs/nginx.pid`

  2) 平滑重读配置文件:

  a. 在nginx.conf中增加ab.html的配置(如下)

server {
listen ;
server_name localhost; access_log logs/host.access.log main; location / {
root html;
index ab.html index.html index.htm;
} error_page /50x.html;
location = /50x.html {
root html;
}
}

  b. ab.html的内容如下:

<html>
only test for HUP
<script>
<!-- 链接赋值给自身,执行刷新操作 -->
window.location.href = "/";
</script>
</html>

  

  c. 访问localhost,使用kill -HUP `cat ./logs/nginx.pid`重读配置文件,等待几秒,即可看到页面信息从"Welcome to nginx!"转换为"only test for HUP"页面信息

  3) 重读日志:

  a. 查看2)中配置的host.access.log,如果使用mv host.access.log host.access.log.bak,可以发现日志仍然会向host.access.log.bak文件中记录,原因是linux的文件指向的是Inode文件标识符,名称的改变并不能改变inode信息。

  b. 使用kill -USR1 `cat ./logs/nginx.pid`,再访问localhost,即可发现日志不再向host.access.log.bak中写入,而向新建的host.access.log中写入

4. Nginx配置

Nginx配置段如下:

##### 全局区
# 有1个工作子进程,可以自行修改,但太大无益,因为要争夺CPU,一般设置为CPU数*核数
worker_processes ; events {
// 此处一般配置nginx连接的特性,如一个worker能同时允许多少链接
worker_connections ; // 一个子进程最大允许连1024个连接
} http {
// 此处是配置http服务器的主要段
include mime.types;
default_type application/octet-stream; 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 logs/access.log main;
sendfile on;
keepalive_timeout ; server {
     // 此处为虚拟主机段
listen ; // 监听端口
server_name localhost; // 监听域名 access_log logs/host.access.log main; location / {
       // 定位,把特殊的路径或文件再次定位,如image目录单独处理
root html; // 根目录定位
index ab.html index.html index.htm;
} error_page /50x.html;
location = /50x.html {
root html;
}
}
}

5. 日志管理

基于nginx配置文件,可以看到nginx的Server段包含"access_log logs/host.access.log main;"信息,其含义为该server的访问日志的文件是logs/host.access.log,使用的格式为"main"格式。除了"main"格式,也可以自定义格式。main格式的信息如下:

log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';

main格式是我们定义好的日志格式,并起个名字,便于引用。

(1) 日志格式包含的选项:

a. $remote_addr是指远程地址

b. $remote_user是指远程用户

c. $time_local是指用户时间

d. $request是指请求方法,如GET/POST

e. $status是指请求状态,如200, 404

f. $body_bytes_sent是指请求体body长度

g. $http_referer是指referer来源信息,如上一级页面

h. $http_user_agent是指用户代理信息,如代理信息、浏览器信息等

i. $http_x_forwarded_for是指经过代理时,代理将本来的IP加在此头信息中,传输你的原始IP

(2) 自定义日志格式

自定义日志格式的形式为:log_format mylog '$remote_addr'。Nginx允许针对不同的server制定不同的日志格式(lighttp)。在server段,可以使用如下格式来记录该server对应的日志:

声明log log位置 log格式; 例如:access_log logs/access_8080.log mylog;

(3) 实际应用,定时按照日志存储某个server日志

run.sh脚本信息如下:

#!/bin/bash

base_path='/usr/local/nginx/log'
log_path=$(date -d yesterday +"%d")
mkdir -p $base_path/$log_path
mv $base_path/access.log $base_path/$log_path/access_$day.log
kill -USR1 `cat /usr/local/nginx/logs/nginx.pid`

crontab 定时任务:01 00 * * * /***/path/run.sh,即每天0时1分执行(建议在02-04点之间执行,系统负载较小)

Nginx实践:(1) Nginx安装及日志配置的更多相关文章

  1. Nginx实践01-ngnix编译安装-测试

    1.下载nginx安装包 下载地址:http://nginx.org/en/download.html(里面有nginx各个版本) 解压到指定目录: 解压出来的目录简单介绍: src:软件的所有源代码 ...

  2. haproxy安装及日志配置

    1.yum安装 yum install haproxy -y 2.配置文件修改,经典配置 vim /etc/haproxy/haproxy.cfg #------------------------- ...

  3. linux环境手动编译安装Nginx实践过程 附异常解决

    1.下载nginx源码包并解压 可在http://nginx.org/en/download.html下载.tar.gz的源码包,如(nginx-1.4.7.tar.gz) 或者使用云盘下载   ht ...

  4. virtualBox安装centos7并配置nginx php mysql运行环境

    virtualBox安装centos7并配置nginx php mysql运行环境 一:virtualBox安装centos7并进行基础设置 1.下载dvd.iso安装文件,下载地址:https:// ...

  5. Nginx反代服务器进阶学习最佳配置实践指南

    转载自:https://www.bilibili.com/read/cv16150010?spm_id_from=333.999.0.0 0x00 编译实践 描述:在企业线上生产环境中推荐进行Ngin ...

  6. nginx(五)nginx与php的安装配置

    经过前面学习,对nginx有个大概的了解,来配置LNMP;只要是在系统安装过程中选择安装比较齐全的包,基本上系统都能满足安装要求,下面是我一个一个测试的,基本上全部安装所需的库文件,放心安装: [ro ...

  7. Nginx - Windows下Nginx基本安装和配置

    Nginx 是一个轻量级的高性能 Http WebServer,以事件驱动方式编写,因此相比 Apache 而言,Nginx 更加稳定.性能更好,而且配置简单,资源占用较低. 1. 安装 Nginx ...

  8. Nginx的安装及简单配置

    Nginx安装 1.下载相关组件 yum install -y gcc gcc-c++                                   #安装C/C++编译器 yum -y ins ...

  9. Nginx 之一:编译安装nginx 1.8.1 及配置

    一:基介绍 官网地址www.nginx.org,nginx是由1994年毕业于俄罗斯国立莫斯科鲍曼科技大学的同学为俄罗斯rambler.ru公司开发的,开发工作最早从2002年开始,第一次公开发布时间 ...

随机推荐

  1. 提取pfx证书公钥和私钥

    从pfx提取密钥信息,并转换为key格式(pfx使用pkcs12模式补足) 1.提取密钥对(如果pfx证书已加密,会提示输入密码.) openssl pkcs12 -in 1.pfx -nocerts ...

  2. 抽象类(abstract class)和接口(Interface)的区别

    前言 抽象类(abstract class)和接口(Interface)是Java语言中对于抽象类定义进行支持的两种机制,赋予了Java强大的面向对象能力. 二者具有很大的相似性,甚至可以相互替换,因 ...

  3. B - EXCEL排序(sort+结构体)

    Excel可以对一组纪录按任意指定列排序.现请你编写程序实现类似功能. Input测试输入包含若干测试用例.每个测试用例的第1行包含两个整数 N (<=100000) 和 C,其中 N 是纪录的 ...

  4. poj3167(kmp)

    题目链接: http://poj.org/problem?id=3167 题意: 给出两串数字 s1, s2, 求主串 s1 中的 s2 匹配数并输出每个匹配的开头位置. 区间 [l, r] 是 s2 ...

  5. 老男孩Day6作业:计算器

    作业需求: 1.实现加减乘除及拓号优先级解析 2.用户输入 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) ...

  6. 2017第八届蓝桥杯决赛(C++ B组)2.磁砖样式

    磁砖样式 小明家的一面装饰墙原来是 310 的小方格. 现在手头有一批刚好能盖住2个小方格的长方形瓷砖. 瓷砖只有两种颜色:黄色和橙色. 小明想知道,对于这么简陋的原料,可以贴出多少种不同的花样来. ...

  7. 数据结构4:顺序表(线性表的顺序存储结构)及C语言实现

    逻辑结构上呈线性分布的数据元素在实际的物理存储结构中也同样相互之间紧挨着,这种存储结构称为线性表的顺序存储结构. 也就是说,逻辑上具有线性关系的数据按照前后的次序全部存储在一整块连续的内存空间中,之间 ...

  8. [国家集训队]特技飞行 贪心BZOJ2697

    题目背景 1.wqs爱好模拟飞行. 2.clj开了一家神犇航空,由于clj还要玩游戏,所以公司的事务由你来打理. 注意:题目中只是用了这样一个背景,并不与真实/模拟飞行相符 题目描述 神犇航空开展了一 ...

  9. [HAOI2012]音量调节 BZOJ2748 dp

    题目描述 一个吉他手准备参加一场演出.他不喜欢在演出时始终使用同一个音量,所以他决定每一首歌之前他都需要改变一次音量.在演出开始之前,他已经做好一个列表,里面写着每首歌开始之前他想要改变的音量是多少. ...

  10. springcloud系列六 整合security

    一 Eureka注册中心认证: Eureka自带了一个管理界面,如果不加密,所有人都可以进行访问这个地址,这样安全问题就来了,所以需要对其进行加密认证: 那么该如何进行整合呢: 1 在注册中心模块添加 ...