Nginx Web快速入门-基础

如不知道怎么安装。参考地址://www.greatytc.com/p/5460755dea00

Nginx主配置文件整体分为三块进行学习,分别是CoreModule(核心模块)EventModule(事件驱动模块)HttpCoreModule(http内核模块)

文件路径:/etc/nginx.conf

CoreModule(核心模块)

user  nginx;              # Nginx进程所使用的用户
worker_processes  auto;   # Nginx运行的work进程数量(建议与CPU数量一致或auto) 
error_log  /var/log/nginx/error.log notice;  # Nginx错误日志存放路径 
pid        /var/run/nginx.pid;  # Nginx服务运行后产生的pid进程号

EventModule(事件驱动模块)

events {
    worker_connections  1024;   # 每个worker进程支持的最大连接数 
    use epoll;                  # 事件驱动模型, epoll默认
}

HttpCoreModule(http内核模块)

# http层开始 
http {    
    # 默认以下载方式传输给浏览器(前提是该资源在mime.types中无法找到)
    default_type  application/octet-stream;  
    # 高效文件传输
    sendfile        on;
    # 日志格式
    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  /var/log/nginx/access.log  main;
    # 搭配sendfile使用
    #tcp_nopush     on;
    # 长连接超时时间
    keepalive_timeout  65;
    # 是否开启压缩
    #gzip  on;
    include /etc/nginx/conf.d/*.conf;  # 包含资源类型文件

    #使用Server配置网站, 每个Server{}代表一个网站(简称虚拟主机) 
    server {
    listen       80;    # 监听端口, 默认80
    server_name  www.test.com;     # 提供的域名
    access_log  access.log;       # 该网站的访问日志
    # 控制网站访问路径
    location / {
        root   /code;       # 存放网站源代码的位置 
        index  index.html index.htm;   # 默认返回网站的文件
    }
}

    # 第二个虚拟主机配置     
    server {
        ...     
    }
    
    include /etc/nginx/conf.d/*.conf;  # 包含/etc/nginx/conf.d/目录下所有以.conf结尾的文件 
}   # http结束层

http server location 扩展了解项

http{}层下允许有多个**Server{}层,一个Server{}层下又允许有多个**Location 
http{} 标签主要用来解决用户的请求与响应
server{} 标签主要用来响应具体的某一个网站
location{} 标签主要用于匹配网站具体URL路径

Nginx网站配置

1)新增nginx配置文件

[root@test1 conf.d]# cat test1.conf 
server {
    listen       80;
    server_name  www.test.com;
    
    location / {
        root   /code;
        index  index.html index.htm;
    }
}

2) 放置源代码文件至nginx配置文件root指定的目录

mkdir /code && cd /code 
echo test1 >/code/index.html

3) 检查nginx的语法是否存在错误

nginx -t 

4) 重载Nginx [reload|restart]

nginx -s reload

5) 设置hosts,然后测试 ping域名

echo "192.168.100.103    www.test.com" >>/etc/hosts

[root@test1 conf.d]# ping 1.test1.com
PING 1.test1.com (192.168.100.103) 56(84) bytes of data.
64 bytes from 1.test1.com (192.168.100.103): icmp_seq=1 ttl=64 time=0.056 ms
64 bytes from 1.test1.com (192.168.100.103): icmp_seq=2 ttl=64 time=0.037 ms
64 bytes from 1.test1.com (192.168.100.103): icmp_seq=3 ttl=64 time=0.036 ms

NginxServer配置三种方式

方式一:基于主机多IP方式

1)多网卡多IP的方式

[root@test conf.d]# cat test1.conf 
server {
    listen       192.168.100.103:80;
    server_name  _;
    
    location / {
        root   /code/eth0;
        index  index.html; 
    }
}
server {
    listen       172.16.1.103:80;
    server_name  _;
    
    location / {
        root   /code/eth1;
        index  index.html;
    }
}

# 语法检查
nginx -t
# nginx -s reload不会关掉之前nginx端口,所以要stop后 重新启动nginx
nginx -s stop
# 启动
nginx

# 检查nginx端口80
[root@test  conf.d]# netstat -tnlup|grep 80
tcp        0      0 172.16.1.103:80         0.0.0.0:*               LISTEN      29084/nginx: master 
tcp        0      0 192.168.100.103:80      0.0.0.0:*               LISTEN      29084/nginx: master 

# curl -I 是查看网站的状态码及返回信息
# curl   下载页面信息
[root@test conf.d]# curl 192.168.100.103
eth0_server
[root@test conf.d]# curl 172.16.1.103
eth1_server

2)单网卡多IP的方式

# 添加网卡
ip addr add 192.168.100.113/24 dev eth0
ip addr add 192.168.100.123/24 dev eth0

[root@test conf.d]# cat test1.conf 
server {
    listen       192.168.100.103:80;
    server_name  _;
    
    location / {
        root   /code/test1;
        index  index.html; 
    }
}
server {
    listen       192.168.100.113:80;
    server_name  _;
    
    location / {
        root   /code/test2;
        index  index.html;
    }
}
server {
    listen       192.168.100.123:80;
    server_name  _;
    
    location / {
        root   /code/test3;
        index  index.html;
    }
}

# 创建文件
echo 192.168.100.103 >>/code/test1/index.html
echo 192.168.100.113 >>/code/test2/index.html
echo 192.168.100.123 >>/code/test3/index.html

# curl验证
[root@test conf.d]# curl 192.168.100.103
192.168.100.103
[root@test conf.d]# curl 192.168.100.113
192.168.100.113
[root@testconf.d]# curl 192.168.100.123
192.168.100.123

方式二:基于端口的配置方式

[root@test  conf.d]# cat test1.conf 
server {
   listen  80;
   location / {
        root  /code/80;
        index index.html;
   }
}
server {
   listen  81;
   location / {
        root  /code/81;
        index index.html;
   }
}
server {
   listen  82;
   location / {
        root  /code/82;
        index index.html;
   }
}

# 语法检查
nginx -t
# nginx -s reload不会关掉之前nginx端口,所以要stop后 重新启动nginx
nginx -s stop
# 启动
nginx

[root@test conf.d]# curl 192.168.100.103:80
80
[root@test conf.d]# curl 192.168.100.103:81
81
[root@test conf.d]# curl 192.168.100.103:82
82

[root@test conf.d]# netstat -tnlup|grep nginx
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      29231/nginx: master 
tcp        0      0 0.0.0.0:81              0.0.0.0:*               LISTEN      29231/nginx: master 
tcp        0      0 0.0.0.0:82              0.0.0.0:*               LISTEN      29231/nginx: master 

方式三:基于多个hosts名称方式(多域名方式)

作用环境:
1、常用多端口和多host主机方式
2、多端口常用来做测试和内部访问
3、host主机方式 针对用户提供访问

[root@test conf.d]# ll
total 12
-rw-r--r-- 1 root root 135 Jan  7 17:09 test1.conf
-rw-r--r-- 1 root root 135 Jan  7 17:09 test2.conf
-rw-r--r-- 1 root root 135 Jan  7 17:09 test3.conf


[root@test conf.d]# cat test*.conf
server {
   listen  80;
   server_name  www.test1.com;
   location / {
        root  /code/test1;
        index index.html;
   }
   
}
server {
   listen  80;
   server_name  www.test2.com;
   location / {
        root  /code/test2;
        index index.html;
   }
   
}
server {
   listen  80;
   server_name  www.test3.com;
   location / {
        root  /code/test3;
        index index.html;
   }
}

# 语法检查
nginx -t
# nginx -s reload不会关掉之前nginx端口,所以要stop后 重新启动nginx
nginx -s stop
# 启动
nginx

# /etc/hosts/ 记得添加 IP:域名
[root@test conf.d]# curl www.test3.com
test3
[root@test conf.d]# curl www.test2.com
test2
[root@test conf.d]# curl www.test1.com
test1

Nginx日志管理

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

log_format详解

在nginx默认的配置文件中,log_format已经将日志格式定死,但是我们可不可以修改呢?
1.log_format的作用是定义日志格式语法

# 配置语法: 包括: error.log access.log 
Syntax: log_format name [escape=default|json] string ...; 
Default: log_format combined "..."; 
Context: http

2.nginx默认日志格式语法如下:

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

3.Nginx日志格式允许包含的内置变量

$remote_addr        # 记录客户端IP地址 
$remote_user        # 记录客户端用户名 
$time_local         # 记录通用的本地时间 
$time_iso8601       # 记录ISO8601标准格式下的本地时间 
$request            # 记录请求的方法以及请求的http协议 
$status             # 记录请求状态码(用于定位错误信息) 
$body_bytes_sent    # 发送给客户端的资源字节数,不包括响应头的大小 
$bytes_sent         # 发送给客户端的总字节数 
$msec               # 日志写入时间。单位为秒,精度是毫秒 
$http_referer       # 记录从哪个页面链接访问过来的 
$http_user_agent    # 记录客户端浏览器相关信息 
$http_x_forwarded_for #记录客户端IP地址 
$request_length     # 请求的长度(包括请求行, 请求头和请求正文) 
$request_time       # 请求花费的时间,单位为秒,精度毫秒 
# 注:如果Nginx位于负载均衡器,nginx反向代理之后, web服务器无法直接获取到客 户端真实的IP地址。 
# $remote_addr获取的是反向代理的IP地址。 反向代理服务器在转发请求的http头信息中, 
# 增加X‐Forwarded‐For信息,用来记录客户端IP地址和客户端请求的服务器地址。

4.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

5.Nginx Access日志配置实践

server{     
   listen 80;     
   server_name www.test1.com;     
   
   # 将当前的server网站的访问日志记录至对应的目录,使用main格式     
   access_log /var/log/nginx/test1.log main;    
   location / {         
      root /code;     
   }     
   
   # 当有人请求改favicon.ico时,不记录日志     
   location /favicon.ico {
         access_log off;         
         return 200;     
   } 
}

Nginx日志切割

使用logrotate切割日志

[root@test conf.d]# cat /etc/logrotate.d/nginx 
/var/log/nginx/*.log {
    daily                   # 每天切割日志         
    missingok               # 日志丢失忽略         
    rotate 52               # 日志保留52天         
    compress                # 日志文件压缩         
    delaycompress           # 延迟压缩日志         
    notifempty              # 不切割空文件         
    create 640 nginx adm    # 日志文件权限         
    sharedscripts         
    postrotate      # 切割日志执行的命令                 
            if [ ‐f /var/run/nginx.pid ]; then                         
                    kill ‐USR1 `cat /var/run/nginx.pid`                 
            fi         
    endscript 
}

日志切割后的效果

[root@test ~]# ll /var/log/nginx/ 
total 4044 
‐rw‐r‐‐‐‐‐ 1 www adm  54438 Oct 12 03:28 access.log‐20XXXXX.gz 
‐rw‐r‐‐‐‐‐ 1 www adm  28657 Oct 13 03:48 access.log‐20XXXXX.gz 
‐rw‐r‐‐‐‐‐ 1 www adm  10135 Oct 12 03:28 error.log‐20XXXXX.gz 
‐rw‐r‐‐‐‐‐ 1 www adm   7452 Oct 13 03:48 error.log‐20XXXXX.gz 

.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,240评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,328评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,182评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,121评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,135评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,093评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,013评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,854评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,295评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,513评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,678评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,398评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,989评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,636评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,801评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,657评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,558评论 2 352

推荐阅读更多精彩内容

  • 第一节 Nginx介绍 1.我们为什么选择 Nginx 服务 Nginx 是一个开源且高性能、可靠的 Http W...
    chenkang阅读 143评论 0 0
  • 第一章 Nginx介绍 Nginx是什么 Nginx 是一个开源且高性能、可靠的 Http Web 服务、代理服务...
    哈里波菜阅读 254评论 0 0
  • 第一章 Nginx介绍 Nginx是什么 Nginx 是一个开源且高性能、可靠的 Http Web 服务、代理服务...
    小镇青年Jack阅读 367评论 0 0
  • 1.Nginx是什么 Nginx 是一个开源且高性能、可靠的 Http Web 服务、代理服务。开源: 直接获取源...
    linux_wjh阅读 149评论 0 1
  • Nginx配置文件主要有三个模块 1 CoreModule 核心模块 使用配置文件的配置查看nginx进程号 2 ...
    曾猪666阅读 197评论 0 0