初入Nginx--配置篇
Nginx的主配置文件为/path/to/nginx/nginx.conf。Nginx.conf的配置文件结构主要由以下几个部分组成:
.....
events{
....
}
http{
....
server{
....
}
server{
....
}
}
events module:控制nginx处理连接的方式。
http module:Nginx的HTTP模块用于控制Nginx的HTTP进程。
server module:虚拟主机。
1、虚拟主机的配置
1.1 什么是虚拟主机?
把一台运行在因特网伤德服务器主机分成一台台“虚拟”的主机,每台虚拟主机都可以是一个独立的站点,可以具有独立的域名、IP等,具有完整德Internet服务器功能,同一台主机上的虚拟主机之间是完全独立的,对于访问者来说,它们就是一台台独立的主机。跟Apache一样,Nginx支持多种类型的虚拟主机:基于IP的虚拟主机、基于域名的虚拟主机、基于端口的虚拟主机。
1.2 基于IP的虚拟主机
无论是通过IP别名在一台服务器上配置多个IP地址,还是通过多块网卡在服务器上配置多个IP地址,在Nginx中都能将其配置成为基于IP地址德虚拟主机。本文中采用的是通过IP别名配置虚拟机。
1.2.1 添加IP别名
在eth0网卡设备上添加1个IP别名192.168.8.43,通过如下命令来运行:
1 sudo ifconfig eth0:1 192.168.8.43 broadcast 192.168.8.255 netmask 255.255.255.0 up
2 route add -host 192.168.8.43 dev eth0:1
再执行ifconfig命令就可以看到eth0网卡上多了一个IP。这种方式服务器重启后会消失。
1.2.2 配置虚拟主机
在nginx.conf中。配置1个纯静态HTML支持的虚拟主机。下面是配置代码:
1 http{
2 Server {
3 listen 80; #监听德端口
4 server_name 192.168.8.43; #监听的IP地址
5 access_log logs/access.log; #访问日志文件存放路径
6 error_log logs/errors.log; #错误日志文件存放路径
7 #日志格式可以自定义,默认的是combined。格式后面再说。
8
9 location / {
10 index index.html index.htm #默认首页文件,顺序从左到右
11 root //htdocs/server1 #HTML网页文件存放的位置
12 }
13 }
14 }
这里只配置了一个IP虚拟主机,配置多个如上所示向http块中添加server即可。
1.3、基于域名的虚拟主机
基于域名的虚拟主机是最常见的。只需要配置好本地的hosts文件或者你的DNS服务器,将域名能够正确的映射到相应的IP地址上即可。
下面是配置代码:
1 http{
2 Server {
3 listen 80; #监听德端口
4 server_name www.domain.com; #监听的域名
5 access_log logs/access.log; #访问日志文件存放路径
6 error_log logs/errors.log; #错误日志文件存放路径
7 #日志格式可以自定义,默认的是combined。格式后面再说。
8
9 location / {
10 index index.html index.htm #默认首页文件,顺序从左到右
11 root /htdocs/server1 #HTML网页文件存放的位置
12 }
13 }
14 }
然后在/etc/hosts文件中添加一项
127.0.0.1(这里是要映射的IP地址) www.domain,com
接下来访问www.domain.com 这个域名就会映射到htdocs/server1/index.html文件了。
2、Nginx的日志文件配置
与Nginx日志相关的指令主要有两条,一条log_format,用来设置日志的格式;另外一条是access_log,用来指定日志文件的存放路径、格式和缓存。
2.1 用log_format指令设置日志格式
语法:log_format name format [format ...]
其中name表示定义的格式名称,format表示定义的格式样式。Log_format有一个默认的格式combined,其格式为:
log_format combined ‘$remote_addr - $remote_user [$time_local] ”$request” $status $body_bytes_sent “$http_referer” “$http_user_agent”’;
注意:log_format指令设置德name名称不可以重复。
当用户使用代理访问时,$remote_addr无法记录用户的真实IP地址,可以换成$http_x_forwarded_for变量代替。
2.2 用access_log指令指定日志文件存放路径
语法:access_log path [format [buffer=size] | off]]
其中path表示日志文件的存放路径,format表示使用log_format指令设置的日志文件的名称,buffer=size表示设置内存缓冲区的大小,off表示不记录日志。
如果使用默认的combined格式德日志记录,可以使用以下示例:
Access_log /data1/logs/filename.log; 或者: Access_log /data1/logs/filename.log combined;
如果使用自定资格的日志记录,可以使用以下示例:
Access_log /data1/logs/access.log myformat buffer=32k;
在Nginx0.7.4之后的版本中,access_log指令中的日志文件路径可以包含变量,例如:
Access_log /data1/logs/$server_name.log combined;
注意:
1、Nginx进程必须有对目标路径创建文件权限。
2、缓冲不会被使用。
3、对于每一条日志记录,日志文件都将先打开文件,再写入日志记录,然后关闭
为了提高包含变量的日志文件存放路径德性能,须配合使用open_log_file_cache指令设置经常被使用的日志文件描述符缓存。
语法:open_log_file_cache max=N [inactive=time] [min_uses=N] [valid=time] | off
参数:
Max:指设置缓存中德最大文件描述符数量,如果超过了这个数量会采用LRU算法清除。
Inactive:设置一个时间,如果在设置的时间内没有使用此文件描述符,则自动删除此描述符。
Min_uses:在参数inactive指定的时间内,如果日志文件超过被使用德次数,则将该日志文件的描述符记入缓存。默认为1。
valid:设置多长时间检查一次,看一看变量指定的日志文件路径与文件名是否仍然存在。默认60秒。
Off:禁止使用缓存。
示例:
open_log_file_cache max=1000 inactive=20s min_uses=2 valid=1m;
3、nginx日志文件的分割
指令如下:
mv /data1/logs/access.log /data1/logs/20131225.log kill -USR1 Nginx主进程号(可以使用`cat /usr/local/nginx/nginx.pid`代替若配置文件中指定了pid文件的位置)
当然不可能每次都是手动去完成切割,我们需要让服务器自己定时的去切割日志文件。这时我们需要借助crontab,具体指令不在此阐述。自己动手搜搜。
最新文章
- Hibernate全套增删改查+分页
- Eclipse右下角一直提示Computing additional info解决办法
- Python起步(2)
- android log
- Python scikit-learn机器学习工具包学习笔记:feature_selection模块
- JavaScript设计模式与开发实践 - 观察者模式
- Oracle 删表前验证表名是否存在并且删除
- 关于django批量上传图片
- android AsyncTask异步下载并更新进度条
- RR模式下的事务隔离
- 关于11G DataGuard 日志传输的案例
- ios开发之--NSURL的用法
- windows与linux换行符
- [Android] 压缩图片并保存
- 20172319 2018.10.12《Java程序设计教程》第6周课堂实践(补写博客)
- Java:多线程,CountDownLatch同步器
- 浅析Spring框架之一(Spring简介)
- @objc vs @objc dynamic官方解释
- MVC中使用AngularJS-01,基本
- hiberante 二级缓存设置