Linux相关知识的第二十一回合

本文介绍了PV、UV、QPS的概念及其计算方法,详细阐述了一次HTTP请求的完整过程,包括域名解析、建立连接、发送请求等步骤。此外,还展示了如何在Linux上部署httpd并创建两个虚拟主机www.X.com和www.Y.com,以及http状态码的常见类型。通过对这些知识的掌握,可以更好地理解和管理Web服务器。
摘要由CSDN通过智能技术生成

Linux相关知识的第二十一回合

简述PV、UV、QPS的含义及计算方式

PV(Page View) 访问量 页面浏览量或者点击量;用户每次刷新即算一次;PV反映的是浏览某个网站的页面数,PV与来访者的数量成正比,PV并不是页面的来访者数量,而是网站被访问的页面数量
通过PV计算网站带宽:网站带宽 = PV / 统计时间(换算到秒) * 平均页面大小(单位KB) * 8

UV(Unique Visitor)独立访客 访问网站的一台电脑为一个访客,一天内相同客户端只被计算一次,可以理解成访问某网站的电脑的数量;网站判断来访电脑的身份是通过cookies实现的,如果更换IP后不清楚cookies,再访问相同网站,该网站的统计中UV数不变

QPS(reQuest Per Second) 每秒请求数
QPS = PV * 页面衍生连接次数 / 统计时间(一天86400) 页面衍生连接次数:一个页面请求,会有好几次http连接,如外部的css,js,图片等

并发连接数 = QPS * http平均响应时间
峰值时间: 每天80%的访问集中在20%的时间里,这20%时间为峰值时间
峰值时间每秒请求数(QPS) = ((总PV数 * 页面衍生连接次数) * 80% ) / (每天秒数 * 20%)

一次完整的HTTP请求过程

一次完整的http请求过程主要包括:域名解析 ---> 建立连接 ---> 发送请求 ---> 接受接收 ---> 处理请求 ---> 访问资源 ---> 构建响应报文 ---> 发送响应报文 ---> 记录日志

域名解析:检查浏览器自身DNS缓存 —> 操作系统DNS缓存 —> hosts文件 —> DNS解析,hosts文件解析与DNS解析谁先谁后,在/etc/nsswitch.conf中设置

建立连接TCP的3次握手建立链接

向服务端发送http请求:一个HTTP请求报文由请求行(request line)、请求头部(headers)、空行(blank line)和请求数据(request body)4个部分组成

服务器接收客户端http请求:服务器接收客户端请求报文中对某资源的一次请求,有如下四种模式
单进程I/O模型 启动一个进程处理用户请求,而且一次只处理一个,多个请求被串行响应
多进程I/O模型 并行启动多个进程,每个进程响应一个连接请求
复用I/O结构 启动一个进程,同时响应N个连接请求
复用的多进程I/O模型 启动M个进程,每个进程响应N个连接请求,同时接收M*N个请求

处理请求:服务器对请求报文进行解析,并获取请求的资源及请求方法等相关信息,根据方法,资源,首部和可选的主体部分对请求进行处理

访问资源:服务器获取请求报文中请求的资源web服务器,即存放了web资源的服务器,负责向请求者提供对方请求的静态资源,或动态运行后生成的资源

构建响应报文:一旦Web服务器识别除了资源,就执行请求方法中描述的动作,并构建响应报文

发送响应报文:服务器可能有很多条到各个客户端的连接,有些是空闲的,有些在向服务器发送数据,还有一些在向客户端回送响应数据。服务器要记录连接的状态,还要特别注意对持久连接的处理,以便正确、高效地发送响应报文

记录日志:当事务结束时,Web服务器会在日志文件中添加一个条目,来描述已执行的事务

部署httpd 并创建两个虚拟主机

创建www.X.com虚拟主机

www.X.com,页面文件目录为/web/vhosts/x;错误日志为/var/log/httpd/x.err,访问日志为/var/log/httpd/x.access

# yum安装httpd
yum install httpd

# 创建站点目录
mkdir -p /web/vhosts/x
echo 'Welcome www.X.com' > /web/vhosts/x/index.html
chown -R apache:apache  /web

# 创建虚拟主机配置文件
vim /etc/httpd/conf.d/x.conf
#####################################################################
<VirtualHost *:80>
ServerName www.X.com
DocumentRoot "/web/vhosts/x"
<Directory "/web/vhosts/x">
Options None
AllowOverride None
Require all granted
</Directory>
ErrorLog "/var/log/httpd/x.err"
CustomLog "var/log/httpd/x.access" combined
</VirtualHost>
#####################################################################

# 启动httpd服务
systemctl enable httpd --now

# 添加hosts
192.168.168.66  www.X.com  www.Y.com

# 访问X网站
curl www.X.com

# 查看日志
ls /var/log/httpd/
access_log  error_log  x.access  x.err

创建www.Y.com虚拟主机

www.Y.com,页面文件目录为/web/vhosts/y;错误日志为/var/log/httpd/www2.err,访问日志为/var/log/httpd/y.access

# 创建站点目录
mkdir -p /web/vhosts/y
echo 'Welcome www.Y.com' > /web/vhosts/y/index.html
chown -R apache:apache /web

# 创建虚拟主机配置文件
vim /etc/httpd/conf.d/y.conf
#####################################################################
<VirtualHost *:80>
ServerName www.Y.com
DocumentRoot "/web/vhosts/y"
<Directory "/web/vhosts/y">
Options None
AllowOverride None
Require all granted
</Directory>
ErrorLog "/var/log/httpd/www2.err"
CustomLog "var/log/httpd/y.access" combined
</VirtualHost>
#####################################################################

# 测试语法是否错误
httpd -t

# 重载配置文件
systemctl reload httpd

# 访问Y网站
curl www.Y.com

# 查看日志
ls /var/log/httpd/
access_log  error_log  www2.err  x.access  x.err  y.access

为两个虚拟主机建立各自的主页文件index.html,内容分别为其对应的主机名

同上

http状态码总结

http协议状态码分类

1xx:100-101 信息提示
2xx:200-206 成功
3xx:300-307 重定向
4xx:400-415 错误类信息,客户端错误
5xx:500-505 错误类信息,服务器端错误

http协议常用的状态码

200: 成功,请求数据通过响应报文的entity-body部分发送;OK
301: 请求的URL指向的资源已经被删除;但在响应报文中通过首部Location指明了资源现在所处的新位置;Moved Permanently
302: 响应报文Location指明资源临时新位置; Moved Temporarily
304: 客户端发出了条件式请求,但服务器上的资源未曾发生改变,则通过响应此响应状态码通知客户端;Not Modified
307: 浏览器内部重定向
401: 需要输入账号和密码认证方能访问资源;Unauthorized
403: 请求被禁止;Forbidden
404: 服务器无法找到客户端请求的资源;Not Found
500: 服务器内部错误;Internal Server Error
502: 代理服务器从后端服务器收到了一条伪响应,如无法连接到网关;Bad Gateway
503: 服务不可用,临时服务器维护或过载,服务器无法处理请求
504: 网关超时

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值