目录
一、Nginx和Apache
1.Nginx
Nginx是一个高性能的HTTP和反向代理服务器。
是一款轻量级的web服务器/反向代理服务器/电子邮件(IMAP/POP3)代理服务器
单台物理服务器可支持30 000~50 000个并发请求。
2.Apache
Apache是以进程为基础的结构,进程要比线程消耗更多的系统开支,不太适用于多处理器环境,因此,在一个apache Web站点扩容时,通常是增加服务器或扩充群集节点而不是增加理器
3.Apache三种工作模式
(1)prefork模型
(2)work模型
(3)event模型
4.优点比较
(1)nginx相对于apache的优点
所占用的内存和资源相对较少
nginx处理请求是异步非阻塞的,在高并发的情况下,nginx能够低消耗高效率得进行工作
(2)apache相对于nginx的优点
Rewrite比nginx的rewrite强大(rewrite的主要功能就是实现统一资源定位符(URL)的跳转)
模块多,基本想到的都可以找到
apche的bug相对nginx较少,比较稳定
5.两者的区别(重要)
Nginx:异步非阻塞,并发性好,消耗的资源和内存少,适合处理静态文件
Apache:同步,一个连接对应一个进程,bug少,稳定,适合处理动态文件
二、Linux的I/O
I/O在计算机中指Input/Output,lOPS (Input/Output Per Second)即每秒的输入输出量(或读写次数),是衡量磁盘性能的主要指标之一。IOPS是指单位时间内系统能处理的I/O请求数量,一般以每秒处理的IO请求数量为单位,I/O请求通常为读或写数据操作请求
1.磁盘I/O
(1)cache/buff的区别
2.网络I/O
(1)本质
一切皆文件,本质为对socket文件的读写
(2)网络I/O模型
获取请求数据,客户端与服务器建立连接发出请求,服务器接受请求(1-3)
构建响应,当服务器接收完请求,并在用户空间处理客户端的请求,直到构建响应完成(4)
返回数据,服务器将已构建好的响应再通过内核空间的网络I/0发还给客户端(5-7)
3.同步/异步
(1)同步
被调用者并不提供事件的处理结果相关的通知消息,需要调用者主动询问事情是否处理完成
(2)异步
被调用者通过状态、通知或回调机制主动通知调用者被调用者的运行状态
4.阻塞/非阻塞
阻塞/非阻塞:关注调用者在等待结果返回之前所处的状态
(1)阻塞
指IO操作需要彻底完成后才返回到用户空间,调用结果返回之前,调用者被挂起,干不了别的事情
(2)非阻塞
指IO操作被调用后立即返回给用户一个状态值,而无需等到IO操作彻底完成,在最终的调用结果返回之前,调用者不会被挂起,可以去做别的事情
5.网络I/O模型
(1)阻塞型
(2)非阻塞型同步
(3) 异步非阻塞I/O模型(最优)
三、 编译安装
1.上传安装包(先关闭防火墙和selinux)
安装包获取方式:
链接:https://pan.baidu.com/s/1iGH3Mep3lw2UHdbBjoUg4Q
提取码:ebmn
2.安装依赖关系
3.新建用户和组
nginx 服务程序默认 以 nobody 身份运行,建议为其创建专门的用户账户,以便更准确的控制访问权限
4.进行编译安装
查看进程号的方法
①[root@localhost logs]# ls
access.log error.log nginx.pid
[root@localhost logs]# cat nginx.pid
6166
②[root@localhost logs]# ps aux |grep nginx
root 6166 0.0 0.0 20496 600 ? Ss 14:52 0:00 nginx: master process nginx
nginx 6167 0.0 0.0 23024 1388 ? S 14:52 0:00 nginx: worker process
root 6198 0.0 0.0 112676 984 pts/0 S+ 14:54 0:00 grep --color=auto nginx
③[root@localhost logs]# ss -ntap |grep 80
LISTEN 0 128 *:80 *:* users:(("nginx",pid=6167,fd=6),("nginx",pid=6166,fd=6))
④[root@localhost logs]# lsof -i :80
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
nginx 6166 root 6u IPv4 40307 0t0 TCP *:http (LISTEN)
nginx 6167 nginx 6u IPv4 40307 0t0 TCP *:http (LIS
5.添加Nginx服务
(1)方法一
[root@localhost init.d]# vim /etc/init
#!/bin/bash
#chkconfig: - 99 20
#description:Nginx Service Control Script
PROG="/usr/local/nginx/sbin/nginx"
PIDF="/usr/local/nginx/logs/nginx.pid"case "$1" in
start) $PROG
;;
stop)
kill -s QUIT $(cat $PIDF)
;;
restart)
$0 stop $0 start
;;
reload)
kill -s HUP $(cat $PIDF)
;;
*) echo "Usage: $0 {start|stop|restart|reload}"
exit 1
esac
exit 0:wq
[root@localhost init.d]# chmod +x nginx
[root@localhost init.d]# chkconfig --add nginx
[root@localhost init.d]# ss -ntap |grep 80
[root@localhost init.d]# service nginx start
(2)方法二
[root@localhost system]# vim nginx.service
[Unit]
Description=nginx 描述
After=network.target 描述服务类别
[Service]
Type=forking 后台运行形式
PIDFile=/usr/local/nginx/logs/nginx.pid PID文件位置
ExecStart=/usr/local/nginx/sbin/nginx 启动服务
ExecReload=/usr/bin/kill -s HUP $MAINPID 根据PID重新加载配置
ExecStop=/usr/bin/kill -s QUIT $MAINPID 根据PID终止进程
PrivateTmp=true
[Install]
WantedBy=multi-user.target
[root@localhost system]# systemctl daemon-reload
[root@localhost system]# ss -ntap |grep 80
[root@localhost system]# systemctl start nginx
[root@localhost system]# ss -ntap |grep 80
LISTEN 0 128 *:80 *:* users:(("nginx",pid=7232,fd=6),("nginx",pid=7231,fd=6))
ps:信号编号以及含义
信号编号 | 信号名 | 含义 |
---|---|---|
0 | EXIT | 程序退出时收到该信息。 |
1 | HUP | 挂掉电话线或终端连接的挂起信号,这个信号也会造成某些进程在没有终止的情况下重新初始化。 |
2 | INT | 表示结束进程,但并不是强制性的,常用的 "Ctrl+C" 组合键发出就是一个 kill -2 的信号。 |
3 | QUIT | 退出。 |
9 | KILL | 杀死进程,即强制结束进程。 |
11 | SEGV | 段错误。 |
15 | TERM | 正常结束进程,是 kill 命令的默认信号。 |
(重点记住红色标记的部分,用的比较多)
四、配置文件
由各种配置语句组成,不使用特定的界定标记。全局配置部分包括 Nginx 服务的运行 用户、工作进程数、错误日志、PID 存放位置等基本设置
1.全局配置
2. I/O事件配置
events {
use epoll; 使用 epoll 模型以提高性能,2.6 以上版本建议使用
worker_connections 1024; 每个进程处理1024个连接
}
(1)epoll
epoll(socket描述符)是Linux内核]为处理大批量文件描述符而作了改进的poll,是Linux下多路复用IO接口select/poll的增强版本,它能显著提高程序在大量并发连接中只有少量活跃的情况下的系统CPU利用率
(2)ulimit
可使用ulimit -a命令查看系统允许当前用户进程打开的文件数限制
3.http配置
/usr/local/nginx/conf
[root@localhost conf]# vim nginx.conf
检验
日志格式设定
$remote_addr与$http_x_forwarded_for用以记录客户端的ip地址;
$remote_user:用来记录客户端用户名称;
$time_local:用来记录访问时间与时区;
$request:用来记录请求的url与http协议;
$status:用来记录请求状态:成功是200,300,400,500
$body bytes_sent :记录发送给客户端文件主体内容大小;
$http_referer:用来记录从哪个页面链接访问过来的;
$http_user_agent:记录客户浏览器的相关信息;
通常web服务器放在反向代理的后面,这样就不能获取到客户的IP地址了,通过$remote add拿到的IP地址是反向代理服务器的IP地址。反向代理服务器在转发请求的http头信息中,可以增加x forwarded for信息,用以记录原有客户端的IP地址和原来客户端的请求的服务器地址。
4. 访问状态统计配置
[root@localhost html]# vim test/index.html
检验
5. 基于授权密码的访问控制
[root@localhost conf]# vim nginx.conf
检验
6.基于客户端的访问控制
[root@localhost conf]# vim nginx.conf
7. 基于域名的nginx 虚拟主机
[root@localhost conf]# vim nginx.conf
[root@localhost conf]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@localhost conf]# systemctl restart nginx.service
[root@localhost ~]# vim /etc/hosts
分别在网址输入:
www.wb.com
www.wb1.com
8.基于IP地址
[root@localhost conf]# vim nginx.conf
进入浏览器查看效果
输入192.168.174.11
192.168.174.12
9.基于端口
[root@localhost conf]# vim nginx.conf
进入浏览器查看效果
输入192.168.174.10:81
192.168.174.10:82
五、总结
本章主要讲了Nginx安装以及概念希望能狗帮助到大家!