环境:CentOS-6.4
Nginx版本:nginx-1.6.2.tar
Linux连接工具:XShell
VMWare虚拟机上准备两台CentOS:
两台机器做同样操作(后边做负载均衡、高可用的时候用)
1,上传包:
使用rz命令,将准备好的nginx的包上传到Linux:(或者使用 wget下载: http://nginx.org/download/nginx-1.4.2.tar.gz )
2,下载锁需要的依赖库文件:
yum install pcre
yum install pcre-devel
yum install zlib
yum install zlib-devel
3,解压
将nginx压缩包解压到 /usr/local 目录下命令: tar -zxvf nginx-1.6.2.tar.gz -C /usr/local
4,
进行configure配置:cd nginx-1.6.2 && ./configure --prefix=/usr/local/nginx 查看是否报错
出现:
说明没什么问题。
但是我的就报错了,缺少一些包,没报错的略过此步骤。
yum -y install gcc
yum -y install gcc-c++
yum install make
5,编译安装 make && make install
安装完成。
安装完成后,在 /usr/local 下,可以看到两个有关nginx的目录:
nginx目录:
cd /usr/local/nginx目录下: 看到如下4个目录
....conf 配置文件
... html 网页文件
...logs 日志文件
...sbin 主要二进制程序
启动ngxin :cd 到nginx目录下, ./nginx 或者 /usr/local/nginx/sbin/nginx
浏览器输入:http://192.168.85.3 可以看到欢迎页面:
重启:/usr/local/nginx/sbin/nginx -s reload
关闭:/usr/local/nginx/sbin/nginx -s stop
nginx配置文件:
/usr/local/nginx/conf/nginx.conf
Nginx配置段 // 全局区 worker_processes 1; // 有1个工作的子进程,可以自行修改,但太大无益,因为要争夺CPU,一般设置为 CPU数*核数 event { // 一般是配置nginx连接的特性 // 如1个worker能同时允许多少连接 worker_connections 1024; // 这是指 一个子进程最大允许连1024个连接 } http { //这是配置http服务器的主要段 server1 { // 这是虚拟主机段 location { //定位,把特殊的路径或文件再次定位 ,如image目录单独处理 } /// 如.php单独处理 } server2 { } }
例子1: 基于域名的虚拟主机
server { listen 80; #监听端口 server_name a.com; #监听域名 location / { root /var/www/a.com; #根目录定位 index index.html; } }
编辑/usr/local/nginx/conf/nginx.conf,添加配置:
在 /usr/local/nginx/ 下创建目录 lhy ,并在/lhy 下创建 index.html
index.html :
宿主机器配置host: 192.168.85.3 lhy.com
重启nginx,访问 lhy.com:8888 :
日志管理:
access.log : 正确访问日志
error.log : 错误日志
里面有个nginx.pid 文件,记录着当前nginx的进程号:
关闭 nginx 就是根据这个文件来找到nginx进程的,然后kill掉。
查看日志:tail -f -n 200 access.log
日志文件配置:
Nginx允许针对不同的server做不同的Log
我们观察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格式是我们定义好一种日志的格式,并起个名字,便于引用.
以上面的例子, main类型的日志,记录的 remote_addr.... http_x_forwarded_for等选项。
1: 日志格式 是指记录哪些选项
默认的日志格式: 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日志格式,记录这么几项
远程IP- 远程用户/用户时间 请求方法(如GET/POST) 请求体body长度 referer来源信息
http-user-agent用户代理/蜘蛛 ,被转发的请求的原始IP
http_x_forwarded_for:在经过代理时,代理把你的本来IP加在此头信息中,传输你的原始IP
2: 声明一个独特的log_format并命名
log_format mylog '$remote_addr- "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
在下面的server/location,我们就可以引用 mylog
在server段中,这样来声明
Nginx允许针对不同的server做不同的Log ,(有的web服务器不支持,如lighttp)
access_log logs/access_8080.log mylog;
声明log log位置 log格式;
例子:自定义日志文件,指定好目录后,nginx会自动创建该日志文件
Nginx做日志切分
步骤:1、编写shell 2、定时任务对脚本进行调度 :crontab -e
******************************************************************************************************************************************************************************
使用crontab你可以在指定的时间执行一个shell脚本或者一系列Linux命令。例如系统管理员安排一个备份任务使其每天都运行
如何往 cron 中添加一个作业?
# crontab –e
0 5 * * * /root/bin/backup.sh
这将会在每天早上5点运行 /root/bin/backup.sh
*******************************************************************************************************************************************************************************
shell脚本 log.sh:这里演示每分钟一本分,实际一天一备份就行。
#!/bin/sh BASE_DIR=/usr/local/nginx BASE_FILE_NAME=lhy.access.log CURRENT_PATH=$BASE_DIR/logs BAK_PATH=$BASE_DIR/datalogs CURRENT_FILE=$CURRENT_PATH/$BASE_FILE_NAME BAK_TIME=`/bin/date -d yesterday +%Y%m%d%H%M` BAK_FILE=$BAK_PATH/$BAK_TIME-$BASE_FILE_NAME echo $BAK_FILE $BASE_DIR/sbin/nginx -s stop mv $CURRENT_FILE $BAK_FILE $BASE_DIR/sbin/nginx
其中黄色部分应该和 /nginx.conf 中的
一致。
绿色部分是 日志文件存放的目录,提前在 /nginx下建好。
将日志文件上传到 /usr/local/nginx/sbin 并用命令 chmod 777 log.sh 给log.sh 授权,赋予可读可写可执行 权限:
新建定时任务:
输入
*/1 * * * * sh /usr/local/nginx/sbin/log.sh
保存并退出。至此完成。
定时切分日志:
定时任务
Crontab 编辑定时任务
01 00 * * * /xxx/path/b.sh 每天0时1分(建议在02-04点之间,系统负载小)
欢迎关注个人公众号一起交流学习: