运维SRE-19 网站Web中间件服务-http-nginx

news2024/11/13 16:47:20

Ans自动化流程

在这里插入图片描述

1.网站集群核心协议:HTTP

1.1概述

web服务:网站服务,网站协议即可.
协议:http协议,https协议
服务:Nginx服务,Tengine服务....

1.2 HTTP协议

  • http超文本传输协议,负责数据在网站与客户间互相传输(客户要页面,网站给页面.)
  • 超文本传输协议(Hyper Text Transfer Protocol,HTTP)是一个简单的请求-响应协议,它通常运行在[TCP]之上。它指定了客户端可能发送给服务器什么样的消息以及得到什么样的响应。

2)发展

http版本http0.9/1.0http1.1http2.0http3.0
共同点请求-响应请求-响应请求-响应请求-响应
区别短连接(耗费服务端资源)长连接(不会立即断开,连接(会话)保持断开)长连接,效率更高,仅支持https…
tcptcptcpudp
tcp3次握手,建立连接.
发出请求要页面,服务端给你响应页面.
tcp4次挥手,断开连接.

http1.1 vs 2.0 速度区别:http1.1 vs 2.0 速度区别

3)HTTP请求与响应
在这里插入图片描述

4)HTTP请求详解
a)http请求概述

HTTP请求报文(数据包)内容:
	携带用户的基本信息:浏览器,版本
	携带用户的请求信息:http协议版本,域名,请求文件及路径
	还有一些额外信息...
curl -v www.baidu.com或者通过wireshark抓包
这里通过wget --debug www.baidu.com获取请求报文

DEBUG output created by Wget 1.14 on linux-gnu.

URI encoding = “UTF-8”
Converted file name 'index.html' (UTF-8) -> 'index.html' (UTF-8)
Converted file name 'index.html' (UTF-8) -> 'index.html' (UTF-8)
--2023-11-08 02:23:05--  http://www.baidu.com/
正在解析主机 www.baidu.com (www.baidu.com)... 120.232.145.144, 120.232.145.185, 2409:8c54:870:28:0:ff:b049:5cef, ...
Caching www.baidu.com => 120.232.145.144 120.232.145.185 2409:8c54:870:28:0:ff:b049:5cef 2409:8c54:870:2a:0:ff:b0ae:1bcf
正在连接 www.baidu.com (www.baidu.com)|120.232.145.144|:80... 已连接。
Created socket 3.
Releasing 0x0000000002080cb0 (new refcount 1).

---request begin---
GET / HTTP/1.1
User-Agent: Wget/1.14 (linux-gnu)
Accept: */*
Host: www.baidu.com
Connection: Keep-Alive

---request end---
已发出 HTTP 请求,正在等待回应... 
---response begin---
HTTP/1.1 200 OK
Content-Length: 2381
Content-Type: text/html
Server: bfe
Date: Tue, 07 Nov 2023 18:23:06 GMT

---response end---
200 OK
Registered socket 3 for persistent reuse.
长度:2381 (2.3K) [text/html]
正在保存至: “index.html”

在这里插入图片描述

b)http请求-起始行
请求办法: 用户如何访问网站(上传,下载)

http请求办法
GET请求下载,一般对应"看"
POST请求上传,一般对应的是"登录",“上传图片,视频,头像”
HEAD请求只查看,响应头部信息(服务端),一般应用"检查网站是否可以访问",“查看服务端信息”
URL:统一资源定位符,url地址.网址.用于让用户找出网站及资源的位置.
URI:统一资源标识符:正常来说URI范围会更广泛. web服务器中uri仅仅表示域名/(斜线后面的内容)

在这里插入图片描述
在这里插入图片描述

http协议版本
http1.0/1.1
请求起始行核心

请求方法: GET/POST/HEAD
URI:知道URL哪一部分即可

c) http请求-请求头

提供客户端的基本信息:浏览器,访问域名
  • User-Agent: Windows NT 10.0; Win64; x64
  • User-Agent:用户的客户端(用户使用什么访问的网站
谷歌浏览器信息:
#windows
Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36

#苹果
mac/ios

#移动设备
iphone/android
  • Host: www.baidu.com
  • 用户访问域名部分

浏览器调试

1.打开网站与页面
2.找出 请求起始行信息和请求头信息
3.浏览器F12功能

5)http响应详解

http响应报文中主要显示的是服务端的信息
	服务端是否有这个文件,文件类型..
	服务端基本信息:服务名字,版本..

a)http响应起始行
http状态码

  • 服务端发送给客户端,表示索要资源的状态(有/没有)
  • 应用场景: 排错与监控分析网站情况.
http状态码分类含义
2xx正常:找到了,有这个,这个文件存在…
3xx正常:搬家了,跳转
4xx错误:客户端原因
5xx错误:服务端原因
http常见错误码含义
200表示正常,索要的内容已经得到,上传成功.
301 Moved Permanently永久跳转
302 Found或Moved Temporarily临时跳转
304 Not modified用户访问的是浏览器缓存.浏览器访问网站的时候,用户访问的是缓存.
403 Forbidden拒绝访问/权限拒绝.一般是网站权限设置,网站首页文件问题
404 Not Found没有这个文件/目录, 你访问的资源服务器的站点目录上没有. 用户访问写错了. 网站配置文件.
500 Internal ServerError服务器内部错误,原因一般是服务端配置文件,selinux开启,服务模块没安装…一般配合服务的错误日志一起查看
502 Bad GateWay网关错误,一般在负载均衡,代理服务器中出现,后端的节点都挂了(无法访问)
503 Service Unavaliable服务临时不可用故障:后端节点因为负载高,导致临时不可用,显示这个提示.系统升级:网站升级的时候可以显示这个状态码
504 Gateway Timeout与上面类型:临时不可用,网络,负载…

在这里插入图片描述

在这里插入图片描述

状态码大全
Server:
web服务器使用的是什么:nginx,tengine
6)http请求与响应小结

应用:nginx相关web服务排错必备.面试常问.
http请求报文结构与核心内容
	http请求起始行:请求办法 url
	http请求头中:User-Agent客户端浏览器,Host域名
http响应报文结构:
	响应报文起始行:状态码
	响应报文头部:Server:什么web服务

1.3 用户请求与http协议

面试题:用户访问网站流程/介绍公司网站架构/介绍你公司app数据流

  • 1.用户输入域名,域名进行DNS解析(得到域名的ip)
  • 2.tcp3次握手(ip+端口80/443) 建立连接
  • 3.客户端向服务端发出http请求报文: 请求起始行,客户端信息
  • 4.服务端收到请求后进行处理(未来可以讲解网站架构).
  • 5.服务端给客户端发出http响应报文: 响应起始行,服务端信息
  • 6.tcp 4次挥手,断开连接

在这里插入图片描述

在这里插入图片描述

1.4网站核心指标

衡量网站访问情况的一些指标.

网站的访问情况指标含义应用如何计算
IP访问你网站的ip数量(公网ip)分析用户访问情况,只看这个指标容易估算访问量的小了.统计访问日志对ip去重.
PVPage View页面访问量(每个页面被访问的次数)分析用户访问情况的时候,只看这个指标容易导致估算过大统计日志行数
UVUnique Vistor独立访客数量(用户)分析用户访问情况的时候,相对准确些.统计的加上客户端的浏览器类型…未来通过第三方插件实现
DAUDaily Active User日活:日活跃用户.(app)用于分析app活跃度通过代码与数据库分析
MAU月活:月度活跃用户.用于分析app活跃度.通过代码与数据库分析.
如何统计这些指标:
	ip,pv,uv,通过日志统计.
	一般的统计方法,第3方插件/代码,进行统计,比如:百度,谷歌统计.
	通过开源统计工具: matomo(原名piwiki) 测试网站:https://demo.matomo.org
	
	查询网站访问情况:https://alexa.chinaz.com

2.网站核心WEB服务: Nginx

2.1 概述

网站架构中的WEB服务.
web服务(网站服务)也可以叫做WEB中间件.
Nginx : Engine X,俄罗斯人开发出来.被F5(硬件负载均衡企业)收购.
Apache: web服务.

2.2 WEB中间件

WEB中间件特点官网
Nginx高性能,配置简单,要求对http://nginx.org
Tengine淘宝对ngx二次开发,增加内置功能,优化.http://tengine.taobao.org
OpenResty对ngx进行二次开发,lua的web服务.https://openresty.org
Tomcat主要处理JAVA语言http://tomcat.apache.org
apacheweb服务,目前应用较少http://httpd.apache.org

2.3Nginx-特点

1)Nginx功能

nginx作为web服务.
nginx作为负载均衡与代理服务. (lvs,haproxy)
nginx作为缓存服务.
nginx安全功能.

2)Nginx特点

1.支持高并发:能支持几万并发连接(特别是静态小文件业务环境)
2.资源消耗少:在3万并发连接下,开启10个Nginx线程消耗不到200MB内存
3.可以做HTTP反向代理及加速缓存,即负载均衡功能。内置对RS节点服务器健康检查功能,这相当于专业的Haproxy软件或者lvs的功能
4.具备squid等专业缓存软件等的缓存功能
5.支持异步网络IO事件原型epoll(linux 2.6+)

3)Ngx vs Apache

ginx使用的是一种异步网络IO模型。
Apache使用的是一种同步的网络io模式。

同步:网站处理慢。 用户发出请求,网站立刻处理,如果不处理客户排队或丢弃。
异步:网站处理快,一般利用缓存实现。 用户发出请求,网站不立刻处理,网站找个地方把请求存放起来,然后网站一个一个快速处理。。

步目标:通过缓存,队列把用户请求临时存放,减轻用户大量访问对服务器要求。网站优化的一句话:缓存无处不在。


su-幼儿园叔叔。
su-同步模式: 挨个去问小朋友,是否要去洗手间。
su-异步模式: 画个圈圈,需要去洗手间的小朋友,请进入圈中,su定时把圈里的带到洗手间。


su-舍管大爷(女生)郑同学来女朋友。
su-同步模式: 苏大爷带着郑同学一个一个寝室找。
su-异步模式: 苏大爷拿出本本说你要找的人叫啥,根据本子找出寝室,然后找人。

4)Ngx vs Tengine
Tengine需要编译安装。

NgxTengine
安装方式yum/rpm/编译编译安装.
使用增加额外功能,编译安装。Tengine编译安装.软件包中自带很多常用软件(功能)。使用方法,错误提示优化。最新的是基于nginx 1.18.0.
使用使用方便,错误提示默认的。使用方便,错误提示优化。
版本新版本。1.20.2最新的是基于nginx 1.18.0.

在这里插入图片描述

2.4 Ngx版本选择

  • 1.稳定版本。 (偶数)
  • 2.距今6个月-1年版本。1.18 2020年 1.14 2018年
  • 3.日常搜搜准备要用的版本的漏洞情况 nginx 1.20.2 漏洞

2.5 Ngx急速使用指南

nginx yum安装
CentOS 7的epel源中有nginx 1.20.1  #旧的。
手动在linux配置nginx源:1.20.2  1.21.xxx

安装过程

1.配置yum源
cat nginx.repo
[nginx]
baseurl = http://nginx.org/packages/centos/$releasever/$basearch/
enabled = 1
gpgcheck = 0
name = nginx stable repo

#安装
yum install -y nginx

#安装并配置自启动
3.systemctl start nginx
4.systemctl enable nginx

#查状态以及端口和线程
5.systemctl status nginx
6.ss -lntup|grep nginx
7.ps -ef|grep nginx

在这里插入图片描述

总结

1.HTTP请求报文结构和核心内容. ⭐⭐ ⭐ ⭐ ⭐ 
2.HTTP响应报文结构和核心内容.⭐⭐ ⭐ ⭐ ⭐ 
3.用户访问网站流程⭐⭐ ⭐ 
4.网站访问量指标.知道(熟悉)常见WEB中间件(web服务)Nginx vs Apache (同步vs异步)⭐⭐ ⭐ ⭐ 
5.部署nginx(手动配置yum源)安装nginx启动nginx
6.	常用命令:查看端口,查看进程,curl/wget

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1464612.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【思扬赠书 | 第3期】由面试题“Redis是否为单线程”引发的思考

⛳️ 写在前面参与规则!!! ✅参与方式:关注博主、点赞、收藏、评论,任意评论(每人最多评论三次) ⛳️本次送书1~4本【取决于阅读量,阅读量越多,送的越多】 很多人都遇到…

Day10-面向对象-抽象类和接口

文章目录 学习目标1. 抽象类1.1 抽象类注意事项1.2 修饰符的使用 2. 接口2.1 定义接口2.2 接口里可以定义的成员2.2 实现接口2.2.1 实现接口语法格式2.2.2 如何调用对应的方法2.2.3 练习 2.3 接口的多实现2.3.1 练习 2.4 冲突问题2.5 接口的多继承(了解)2.6 部分内置接口 学习目…

2024转行要趁早!盘点网络安全的岗位汇总

前段时间,知名机构麦可思研究院发布了《2024年中国本科生就业报告》,其中详细列出近五年的本科绿牌专业,信息安全位列第一。 对于网络安全的发展与就业前景,知了姐说过很多,作为当下应届生收入较高的专业之一&#xf…

【Python笔记-设计模式】对象池模式

一、说明 用于管理对象的生命周期,重用已经创建的对象,从而减少资源消耗和创建对象的开销 (一) 解决问题 主要解决频繁创建和销毁对象所带来的性能开销问题。如数据库连接、线程管理、网络连接等,对象的创建和销毁成本相对较高&#xff0c…

C 语言基本语法及实用案例分享

一、什么是 C 语言? C语言是一种较早的程序设计语言,诞生于1972年的贝尔实验室。1972 年,Dennis Ritchie 设计了C语言,它继承了B语言的许多思想,并加入了数据类型的概念及其他特性。C语言是一门面向过程的计算机编程语…

基于单片机和LabVIEW的多路数据采集系统设计

摘 要:以8位高速、低功耗微控制器STC12C5A60S2为硬件控制核心,以Labview为上位机软件开发平台,设计了一个多路数据采集系统。由下位机单片机对多路模拟信号量进行数据采集,通过串口将采集的模拟量信息上传到上位机,上位机Labview对采集的数据进行存储、显示及处理、分析…

Node.js中如何处理异步编程

在Node.js中,处理异步编程是至关重要的技能。由于Node.js的单线程执行模型,异步编程可以极大地提高程序的性能和响应速度。本文将介绍几种常见的异步编程处理方式,并附上示例代码,帮助您更好地理解和应用异步编程技术。 回调函数…

GitLab代码库提交量统计工具

1.说明 统计公司所有项目的提交情况,可指定分支和时间段,返回每个人的提交新增数、删除数和总数。 2.API 文档地址:http://公司gitlab域名/help/api/README.md 项目列表查询 返回示例: [{"id": 1, //项目ID"http…

软考29-上午题-【数据结构】-排序

一、排序的基本概念 1-1、稳定性 稳定性指的是相同的数据所在的位置经过排序后是否发生变化。若是排序后,次序不变,则是稳定的。 1-2、归位 每一趟排序能确定一个元素的最终位置。 1-3、内部排序 排序记录全部存放在内存中进行排序的过程。 1-4、外部…

TF-A之供应链威胁模型分析

目录 一、简介 二、TF-A 概述 2.1、TF-A 存储库 2.2、外部依赖 2.3、附加二进制文件 2.4、TF-A工具链 2.5、基础设施 三、TF-A数据流 四、攻击树 五、威胁评估与缓解 5.1、影响和可能性评级 5.2、威胁和缓解措施 六、附录 一、简介 软件供应链攻击旨在向软件产品…

《深入浅出 Spring Boot 3.x》预计3月份发版

各位,目前本来新书《深入浅出 Spring Boot 3.x》已经到了最后编辑排版阶段,即将在3月份发布。 目录: 现在把目录截取给大家: 主要内容: 本书内容安排如下。 ● 第 1 章和第 2 章讲解 Spring Boot 和传统 Spri…

IT资讯——全速推进“AI+鸿蒙”战略布局!

文章目录 每日一句正能量前言坚持长期研发投入全速推进“AI鸿蒙”战略 人才战略新章落地持续加码核心技术生态建设 后记 每日一句正能量 人总要咽下一些委屈,然后一字不提的擦干眼泪往前走,没有人能像白纸一样没有故事,成长的代价就是失去原来…

【东京都立大学主办多重会议奖项】第六届计算机通信与互联网国际会议

ICCCI 2024 - Hosted by Tokyo Metropolitan University, Japanhttps://www.iccci.org/ 会议简介 第六届计算机通信与互联网国际会议将于2024年6月14-16日在日本东京都立大学举行。ICCCI 2024由东京都立大学主办,华中师范大学和美国科学工程学会联合赞助、并得到了…

Curfew e-Pass 管理系统存在Sql注入漏洞 附源代码

免责声明:本文所涉及的信息安全技术知识仅供参考和学习之用,并不构成任何明示或暗示的保证。读者在使用本文提供的信息时,应自行判断其适用性,并承担由此产生的一切风险和责任。本文作者对于读者基于本文内容所做出的任何行为或决…

使用备份工具xtrabackup进行增量备份详细讲解

增量备份 第一次修改数据 mysql> insert into tb_user values (4,sxx,0); Query OK, 1 row affected (0.01 sec)mysql> select * from tb_user; ------------------- | id | name | sex | ------------------- | 1 | Tom | 1 | | 2 | Trigger | 0 | | …

深入学习TS的高阶语法(泛型、类型检测、内置工具)

文章目录 概要一.TS的类型检测1.鸭子类型2.严格的字面量类型检测 二.TS的泛型1.基本使用2.传递多个参数3.泛型接口4.泛型类5.泛型约束6.映射类型(了解) 三.TS的知识扩展1.模块的使用-- 内置类型导入 2.类型的查找3.第三方库的类型导入4.declare 声明文件…

深度学习中的样本分类:如何区分正样本、负样本、困难样本和简单样本?

深度学习中的样本分类:如何区分正样本、负样本、困难样本和简单样本? 🌈 个人主页:高斯小哥 🔥 高质量专栏:Matplotlib之旅:零基础精通数据可视化、Python基础【高质量合集】、PyTorch零基础入…

思维导图教你工作日报怎么写?

工作日报撰写秘诀:轻松提升效率,让你的每一天都闪闪发光 在快节奏的现代工作中,如何高效地规划和管理工作任务成为了职场人士必须面对的挑战。思维导图作为一种强大的思维工具,正逐渐受到越来越多人的青睐。本文将探讨为什么使用…

MySQL 索引原理以及 SQL 优化

索引 索引:一种有序的存储结构,按照单个或者多个列的值进行排序。索引的目的:提升搜索效率。索引分类: 数据结构 B 树索引(映射的是磁盘数据)hash 索引(快速锁定内存数据)全文索引 …

opencv的图像上下、左右和对角线翻转—flip函数

在OpenCV中,flip函数用于翻转图像。你可以沿x轴、y轴或两者同时翻转图像。这个函数非常直接,可以用于创建镜像图像或旋转图像。 void flip(InputArray src, OutputArray dst, int flipCode);src:输入图像。 dst:翻转后的输出图像…