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,具体指令不在此阐述。自己动手搜搜。

初入Nginx--配置篇的更多相关文章

  1. 初入TensorFlow————配置TensorFlow

    能看到这说明你对python已经有一定的了解了,因此很多基础直接跳过. 一.TensorFlow环境配置: TensorFlow的环境配置在网上很多的教程都是用anaconda的方式,但是很容易出现冲 ...

  2. Git初入

    Git记录 使用git 也有一段时间了, git的入门级了解也就不再多说, 但平常使用中, 仍然会遇到很多问题, 在此记录一二. 在查资料的过程中, 发现了两个比较好的资料: 特别是第二个, 相当详细 ...

  3. nginx介绍(三) 配置篇

    3. nginx配置 nginx配置系统受益于Igor Sysoev(nginx创始人)在Apache(阿帕奇软件基金会)的经历.Igor Sysoev洞察出可扩展的配置系统对于一个web服务器来说是 ...

  4. nginx入门篇----nginx服务器基础配置

    1.nginx.conf文件结构...                         #全局块  events{  ...  }  http                      #http块{ ...

  5. 初识nginx——配置解析篇

    一.nginx的介绍 nginx是由俄罗斯人开发的一款高性能的http和反向代理服务器,也可以用来作为邮件代理.相比较于其他的服务器,具有占用内存少,稳定性高等优势 二.nginx的配置 nginx的 ...

  6. Nginx入门篇(四)之常用配置解析

    1.Nginx状态信息功能 Nginx的模块当中有一个ngx_http_stub_status_module模块,这个模块主要记录Nginx的基本访问信息,要使用该模块,需要在编译的时候增加http_ ...

  7. Linux服务之nginx服务篇四(配置https协议访问)

    一.配置nginx支持https协议访问 编译安装nginx的时候需要添加相应的模块--with-http_ssl_module和--with-http_gzip_static_module(可通过/ ...

  8. Nginx配置详解

    序言 Nginx是lgor Sysoev为俄罗斯访问量第二的rambler.ru站点设计开发的.从2004年发布至今,凭借开源的力量,已经接近成熟与完善. Nginx功能丰富,可作为HTTP服务器,也 ...

  9. Nginx配置详解 http://www.cnblogs.com/knowledgesea/p/5175711.html

    Nginx配置详解 序言 Nginx是lgor Sysoev为俄罗斯访问量第二的rambler.ru站点设计开发的.从2004年发布至今,凭借开源的力量,已经接近成熟与完善. Nginx功能丰富,可作 ...

随机推荐

  1. 源码分析:Semaphore之信号量

    简介 Semaphore 又名计数信号量,从概念上来讲,信号量初始并维护一定数量的许可证,使用之前先要先获得一个许可,用完之后再释放一个许可.信号量通常用于限制线程的数量来控制访问某些资源,从而达到单 ...

  2. 干货 MySQL常见的面试题 + 索引原理分析

    常见的面试必备之MySQL索引底层原理分析: MySQL索引的本质 MySQL索引的底层原理 MySQL索引的实战经验 面试 1)问题:数据库中最常见的慢查询优化方式是什么? 回答:加索引 2)问题: ...

  3. springboot中使用Filter、Interceptor和aop拦截REST服务

    在springboot中使用rest服务时,往往需要对controller层的请求进行拦截或者获取请求数据和返回数据,就需要过滤器.拦截器或者切片. 过滤器(Filter):对HttpServletR ...

  4. 关于Boom 3D预设音效的妙用,如何鉴赏音乐流派

    音乐流派,亦可理解为音乐的曲风.类型.不同的音乐流派表达的音乐形式也更不相同.例如民族音乐.古典音乐等这种传统乐器的应用,流行音乐则更注重节奏.韵律的变化.带给我们的音乐感受也不尽相同. Boom 3 ...

  5. 「CSP-S 2019」划分

    description loj 3212 solution 首先容易想到\(n^3\)DP,即令\(f_{i,j}\)表示前\(i\)个数的划分,其中最后一段是从\(j\)开始时的答案 于是有 \[f ...

  6. pytest和unittest中参数化如何做

    参数化应用场景,一个场景的用例会用到多条数据来进行验证,比如登录功能会用到正确的用户名.密码登录,错误的用户名.正确的密码,正确的用户名.错误的密码等等来进行测试,这时就可以用到框架中的参数化,来便捷 ...

  7. nginx学习sub_filter模块

    用户替换html中的字符 location / { root /opt/app/code/; random_index on; index index.html index.htm; sub_filt ...

  8. 宝塔Linux面板安装

    宝塔linux6.0版本是基于centos7开发的,务必使用centos7.x 系统 提示:Centos官方已宣布在2020年停止对Centos6的维护更新,各大软件开发商也逐渐停止对Centos6的 ...

  9. 15.java设计模式之访问者模式

    基本需求: 电脑需要键盘鼠标等固定的组件组成 现在分为个人,组织等去买电脑,而同一种组件对不同的人(访问者)做出不同的折扣,从而电脑的价格也不一样 传统的解决方法:在组件内部进行判断访问人的类型,从而 ...

  10. LeetCode周赛#208

    本周周赛的题面风格与以往不太一样,但不要被吓着,读懂题意跟着模拟,其实会发现并不会难到哪里去. 1599. 经营摩天轮的最大利润 #模拟 题目链接 题意 摩天轮\(4\)个座舱,每个座舱最多可容纳\( ...