web基础+HTTP协议+httpd详细配置

这篇具有很好参考价值的文章主要介绍了web基础+HTTP协议+httpd详细配置。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

一、Web基础

1.1 HTML概述

HTML(全称为Hypertext Markup Language)是一种标记语言,用于创建和组织Web页面的结构和内容。

HTML是构建Web页面的基础,定义了页面的结构和内容,通过标记和元素来实现。

1.1.1 HTML的文件结构

 <html>
     <head>网页的头部信息</head>
     <body>网页内容</body>
 </html>

1.1.2 HTML中的部分基本标签

基本标签 含义
<html> HTML文档的根元素,包含文档的全部内容
<head> 文档的头部,通常用于引入样式表、脚本以及设置文档的元信息
<title> 文档的标题,显示在浏览器的标题栏或标签页上
<body> 文档的主体部分,包含页面上的可见内容
<h1><h6> 标题标签,用于表示不同级别的标题,<h1>是最高级别的标题
<p> 段落标签,用于表示一个段落
<a> 链接标签,用于创建一个超链接,并指定链接的目标URL
<img> 图像标签,用于插入图像到页面中,并指定图像的源文件路径
<ul><li> 无序列表标签,用于创建一个无序列表和列表项
<ol><li> 有序列表标签,用于创建一个有序列表和列表项
<div> 通用的容器标签,用于分组和组织页面中的内容
<span> 内联容器标签,用于对文本的一部分进行特殊处理,如应用样式或事件

1.3 MIME

MIME是一种互联网标准,是一种用于标识文件类型的方法。

MIME类型由一个主类型和一个子类型组成,用斜杠(/)分隔,MIME类型的作用是告诉接收方如何解释和处理接收到的文件。

#常见的MIME类型

text/html  HTML网页
text/plain 纯文本文件
image/jpeg JPEG图像
image/png  PNG图像
audio/mpeg MP3音频
video/mp4  MP4视频
#举个例子
通过指定MIME类型为text/html,服务器可以告诉浏览器接收到的数据是HTML格式的网页,浏览器会相应地解析和显示该网页

1.4 URI 和 URL

1.4 定义

URI(Uniform Resource Identifier):统一资源标识,分为URL 和 URN。

URL(Uniform Resorce Locator):统一资源定位符,用于描述某服务器某特定资源位置

1.4.2 URI 和 URL 的区别

  • 定义范围:URI是一个广义的概念,用于标识和命名互联网上的资源,可以是URL、URN或其他形式。URL是URI的一种具体实现形式,用于资源的定位和访问。

  • 功能重点:URI强调资源的标识性,用于唯一标识和命名资源。URL则更注重资源的位置性,其中包含了定位和访问资源所需的详细信息。

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

二、静态资源和动态资源

静态资源和动态资源是两种常见的网络资源类型

静态资源和动态资源的区别在于内容是否固定不变

2.1 静态资源

静态资源指的是在服务器上保存的文件,其内容在请求和传输过程中不发生变化

静态资源可以是图片、CSS样式表、JavaScript文件、HTML文件等。

静态资源的请求一般是通过URL直接访问,当客户端发送请求时,服务器直接将这些文件返回给客户端,不进行任何处理

2.2 动态资源

动态资源则是在服务器端通过执行脚本或程序生成的内容,需要占用服务器的资源

服务器会根据请求中的参数和数据,执行相应的脚本或程序来生成动态内容,然后将生成的内容返回给客户端。

动态资源可以是动态网页、API接口等。

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

三、HTTP协议

3.1 HTTP协议简介

HTTP协议采用了请求/响应模型

客户端向服务器发送一个请求,请求头包含请求的方法、URL、协议版本、以及包含请求修饰符、客户信息和内容的类似于MIME的消息结构。

服务器以一个状态行作为响应,响应的内容包括消息协议的版本,成功或者错误编码加上服务器信息、实体元信息以及可能的实体内容。

3.2 HTTP协议版本

http 0.9  功能简陋,仅支持GET方法
http 1.0 相较以前版本可以支持POST、HEAD方法,支持HTML文件以外的其他类型,但不支持持久连接
http 1.1 支持持久连接,即在一个TCP连接里面完成多个http请求和响应,但是每个请求和响应是按照顺序一一对应的
http 2.0 支持完全多路复用,在一个连接里,客户端和浏览器都可以同时发送多个请求或回应,而且不用按照顺序一一对应( 也支持压缩,服务端主动推送)。

3.2 HTTP方法

HTTP定义了一组请求方法,用于指定客户端对资源的操作方式,这些请求命令称为HTTP方法。

方法 作用
GET 对服务器资源获取的简单请求
PUT 向服务器上传指定的资源,如果资源已存在,则替换为新的内容
POST 向服务器提交数据
DELETE 删除服务器上的某些资源
HEAD 请求页面的首部,获取资源的元信息
CONNECT 用于ssl隧道的基于代理的请求
OPTIONS 返回所有可用的方法,常用于跨域
TRACE 追踪 请求–响应的传输路径
1、GET请求会向数据库发索取数据的请求,从而来获取信息,该请求不会产生副作用。无论进行多少次操作,结果都是一样的。

2、与GET不同的是,PUT请求是向服务器端发送数据的,从而改变信息,无论进行多少次PUT操作,其结果并没有不同。

3、POST请求同PUT请求类似,都是向服务器端发送数据的,但是该请求会改变数据的种类等资源,几乎目前所有的提交操作都是用POST请求的。

4、DELETE请求顾名思义,就是用来删除某一个资源的。

3.3 HTTP请求访问的完整过程

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

3.4 HTTP状态码

HTTP状态码是服务器在处理请求时返回给客户端的数字代码,用于表示请求的处理结果

HTTP协议状态码分类

状态码首位 范围 含义
1xx 100-101 信息提示,表示请求已被接收,需要进一步处理
2xx 200-206 成功,表示请求已成功处理
3xx 300-305 重定向,表示需要进一步的操作以完成请求
4xx 400-415 客户端错误,表示客户端发送的请求有错误
5xx 500-505 服务器错误,表示服务器在处理请求时发生了错误

HTTP协议常用的状态码

状态码 含义
200 一切正常
301 永久重定向
302 临时重定向
307 浏览器内部重定向
401 用户名或密码错误
403 禁止访问(客户端IP地址被拒绝)
404 请求的资源在服务器上不存在
414 请求URL头部过长
500 服务器内部错误。比如脚本错误,编程语言语法错误
502 无效网关
503 服务器暂时无法处理请求,通常用于服务器维护或过载
504 网关请求超时。程序执行时间过长导致响应超时,例如程序需要执行20秒,而nginx最大响应等待时间为10秒,这样就会出现超时。
#产生502(无效网关)的原因:

数据包没有送到网卡,网络问题;

数据包送进去了(交换机能抓到包),但是网卡没收到,网卡问题或防火墙问题;

网卡接收到了,处理不了,服务问题。(比如服务器当前连接太多,响应太慢;页面素材太多,带宽不够。)

3.5 HTTP的请求报文和响应报文

3.5.1 请求报文

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

#request 报文格式 

<method> <request-URL> <version>
<headers>

<entity-body>

第一行为请求行,包含请求方法、请求目标和HTTP协议版本号
第二行为请求头部,包含与请求相关的各种元数据信息

空行用于分隔头部和请求体的空行
第四行为请求体,可选项,包含实际的请求数据
#举个例子

curl 192.168.2.100 |head #从此服务器获取内容

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

#状态行
> GET / HTTP/1.1
#HTTP GET请求,即获取指定路径的内容,请求的路径为根路径("/"),表示请求服务器的默认页面

#头部字段
> User-Agent: curl/7.29.0
#指定客户端使用的User-Agent,该请求由curl/7.29.0发送
> Host: 192.168.2.100
#指定了要访问的服务器的主机地址
> Accept: */*
#指定了客户端可以接受的响应内容的类型,表示客户端可以接受任何类型的内容

3.5.2 响应报文

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

#response报文格式

<version> <status> <reason-phrase>
<headers>

<entity-body>

第一行为状态行,状态行由协议版本,状态码,状态码描述三部分组成。

第二行为响应头部,响应头包含与响应相关的各种元数据信息。

第三行为空行,用于分隔头部和响应体的空行。

第四行为响应体,可选项,包含实际的响应数据。
#举个例子

curl 192.168.2.100 |head #从此服务器获取内容

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

#响应状态行
< HTTP/1.1 403 Forbidden
#表示请求被拒绝,状态码403表示禁止访问

#头部字段
< Date: Mon, 21 Aug 2023 11:00:34 GMT
#表示响应的日期和时间
< Server: Apache/2.4.6 (CentOS)
#表示服务器正在使用的软件名称和版本
< Last-Modified: Thu, 16 Oct 2014 13:20:58 GMT
#表示所请求资源的最后修改日期和时间
< ETag: "1321-5058a1e728280"
#表示所请求资源的实体标签
< Accept-Ranges: bytes
#服务器是否支持断点续传。
< Content-Length: 4897
#响应实体主体的长度。
< Content-Type: text/html; charset=UTF-8
#实体主体的类型和字符编码,表示响应内容是以UTF-8编码的HTML文本。

3.6 HTTP连接优化

1)并行连接:并行连接通过同时建立多个连接 ,使得客户端可以并发地发送多个请求,以提高并发性和响应速度。

2)持久连接 :持久连接允许客户端和服务器之间在单个连接上发送多个HTTP请求和响应 ,而不是每个请求都要重新建立连接。

3) 管道化连接:管道化连接是一种在持久连接上发送多个请求而无需等待服务器响应 的机制。

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

四、httpd概述

4.1 安装

yum install -y httpd #安装

4.2 httpd相关文件

4.2.1 配置文件

#主配置文件
/etc/httpd/conf/httpd.conf  

#子配置文件
/etc/httpd/conf.d/*.conf 

#模块加载的配置文件
/etc/httpd/conf.d/conf.modules.d/  

检查配置语法httpd -tapache2 -t

站点网页文档根目录/var/www/html

4.2.2 服务单元文件和主服务器程序文件

服务单元文件

/usr/lib/systemd/system/httpd.service

配置文件:/etc/sysconfig/httpd

主服务器程序文件

/usr/sbin/httpd

4.2.3 模块文件

/etc/httpd/modules

/usr/lib64/httpd/modules

4.3 httpd服务控制和启动(命令部分)

#开启自启动/开机自动关闭 httpd服务
systemctl enable|disable httpd.service

开启httpd服务

systemctl start httpd.service
or
apachectl start
or
service httpd start

重启httpd服务

systemctl start httpd.service
or
apachectl restart
or
service httpd restart

停止httpd服务

systemctl stop httpd.service
or
apachectl stop
or
service httpd stop

查看httpd服务的运行状态

systemctl status httpd

配置文件语法检查

apachectl configtest
or
service httpd configtest

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

五、httpd配置

5.1 虚拟主机

httpd虚拟主机的作用是通过一个物理服务器来托管多个域名或网站,实现资源共享、个性化配置和多域名指向不同网站的功能,提高服务器资源利用率和降低成本。

5.1.1 基于ip地址

5.1.1.1 原理

每个虚拟主机分配一个唯一的IP地址,并通过服务器软件来指定每个虚拟主机使用的IP地址。

客户机访问服务器时,服务器会根据客户机的IP地址,在配置文件中寻找对应关系,根据对应关系跳转。

5.1.1.2 模拟实现
systemctl stop firewalld
setenforce 0

rpm -q httpd #没安装就装一下

systemctl start httpd

cd /var/www/html/   #进入httpd站点文件目录
vim  index.html  #设定默认主页,默认主页名字必须为index.html

systemctl restart httpd  //重启httpd服务

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记
服务端配置

cd /var/www/html/
mkdir ipv1  #创建虚拟机 所需目录

vim ./ipv1/index.html  #测试页面主页

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

vim /etc/httpd/conf.d/ipv.conf  #新建配置文件 除了IP地址不同

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

httpd -t #语法检查

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

#有报错时
vim   /etc/httpd/conf/httpd.conf 

ServerName www.example.com:80 #添加到主配置文件中

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

systemctl restart httpd #重启服务

服务端配置完成后,切换到目标客户端,以IP地址为192.168.2.103的客户机为例。

打开客户机的浏览器
输入 192.168.2.102:80
#192.168.2.102为服务端的地址
#服务端收到目标地址的请求,会跳转到目标域名

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

5.1.2 基于端口地址

5.1.2.1 原理

每个虚拟主机使用同一个IP地址,但使用不同的端口号来区分。

5.1.2.2 模拟实现
cd /etc/httpd/conf.d
cp ipv.conf port.conf

vim port.conf #修改配置文件 除了端口不同

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

#测试是否成功
curl 192.168.2.102:8080

curl 192.168.2.102:80

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

5.1.3 基于域名

5.1.3.1 原理

服务器软件根据请求头中的主机名(域名)来区分虚拟主机。

这种方法不需要分配额外的IP地址或端口,可以在同一个IP地址上承载多个虚拟主机。

5.1.3.2 模拟实现
cd /etc/httpd/conf.d
cp ipv.conf dns.conf
vim dns.conf #修改配置文件 除了域名不同

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

mkdir ipv2 #创建所需目录
vim /var/www/html/ipv2/index.html #编辑主页

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记
web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

httpd -t #语法检查

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

#编辑本地hosts文件,添加地址映射

vim /etc/hosts

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

#切换到目标地址为192.168.2.103的虚拟机
#具体操作不再演示

cd /var/www/html 

mkdir ipv1 
mkdir ipv2

vim ./ipv1/index.html
vim ./ipv2/index.html

echo "<h1>www.ipv1.com</h1>" /var/www/html/ipv1/index.html

echo "<h1>www.ipv2.com</h1>" /var/www/html/ipv2/index.html

systemctl start httpd
打开虚拟机的内置浏览器,输入www.ipv1.com 和 www.ipv2.com,观察结果

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

5. 2 三种工作模式

5.2.1 Worker模式

工作线程(Worker)模式适用于资源利用率高的场景

  • Apache在启动时会创建一组预定义数量的线程池。
  • 每个线程都可以处理多个请求,线程之间共享服务器的内存和资源。
  • 当一个请求到达服务器时,一个空闲的线程将被选择来处理该请求。
  • 线程可能会处理多个请求,通过线程池重用来更高效地处理请求。
  • 这种模式下需要注意线程安全的问题,以确保多个线程间的数据访问不会导致冲突。

5.2.2 Event模式

事件驱动(Event MPM)模式适用于高并发场景

  • 在事件驱动模式下,Apache使用I/O多路复用(如epoll或kqueue)来监听多个连接。
  • 当一个连接有数据到达时,Apache将发出事件通知,表示该连接有可读数据。
  • Apache将事件分发给一个空闲的工作线程来处理请求。
  • 工作线程处理请求的过程通常是非阻塞的,通过事件驱动方式读取数据和发送响应。
  • 这种模式下可以处理大量的并发请求,因为它不需要为每个请求创建一个新的进程或线程。

5.2.3 Pre-Fork模式

预产生(Pre-Fork)模式适用于稳定性要求高的场景

  • Apache在启动时会创建一组预定义数量的子进程(称为工作进程)。
  • 每个工作进程都是独立的,有自己的内存空间和资源。
  • 当一个请求到达服务器时,主进程选择一个空闲的工作进程来接受该请求。
  • 选中的工作进程处理该请求,生成响应并将其发送回客户端。
  • 这种模式下每个工作进程只能处理一个请求,处理完请求后会继续等待下一个请求。

web基础+HTTP协议+httpd详细配置,http,网络协议,网络,运维,linux,笔记

六、Cookie和Session

Cookie和Session用于解决http协议无状态

6.1 Cookie

Cookie是服务器在用户的浏览器中存储的小型文本文件。当用户访问一个网站时,服务器可以通过HTTP响应的Set-Cookie标头将一个或多个Cookie发送给浏览器。浏览器会将这些Cookie存储在用户的计算机上,并在以后的请求中将它们发送回服务器。

每个Cookie都包括一个名称、一个值和一些可选的属性,如过期时间、域名、路径等。服务器可以使用Cookie来存储用户的偏好设置、会话标识符、购物车数据等。浏览器会在每次请求中自动发送与特定域名相关联的Cookie,使得服务器能够识别用户。

6.2 Session

Session是在服务器端存储用户状态的一种机制。当用户首次访问一个网站时,服务器会为该用户创建一个唯一的会话标识符(Session ID)。这个标识符通常被存储在Cookie中,但也可以通过其他方式(如URL参数)进行传递。

服务器使用Session来存储用户信息和其他相关数据。在每个请求中,浏览器会将Session ID作为Cookie发送给服务器,使得服务器能够识别并恢复与该用户相关联的会话数据。Session数据通常存储在服务器的内存或持久化存储中。文章来源地址https://www.toymoban.com/news/detail-663107.html

到了这里,关于web基础+HTTP协议+httpd详细配置的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • WEB基础及http协议(Apache)

    http服务基于C/S结构 httpd apache,存在C10K(10K connections)问题 nginx 解决C10K问题lighttpd IIS .asp 应用程序服务器 tomcat .jsp 应用程序服务器 jetty 开源的servlet容器,基于Java的web容器 Resin CAUCHO公司,支持servlets和jsp的引擎 webshpere:IBM公司 weblogic:BEA,Oracle jboss:RedHat,IBM oc4j:Oracle

    2024年02月21日
    浏览(38)
  • web基础及http协议 (二) apache

    http 服务基于 C/S 结构 httpd apache,存在C10K(10K connections)问题 nginx 解决C10K问题lighttpd IIS .asp 应用程序服务器 tomcat .jsp 应用程序服务器 jetty 开源的servlet容器,基于Java的web容器 Resin CAUCHO公司,支持servlets和jsp的引擎 webshpere:IBM公司 weblogic:BEA,Oracle jboss:RedHat,IBM oc4j:Ora

    2024年02月20日
    浏览(36)
  • 网络协议之HTTP详细解释

    可能我接下的讲述可能有些赘述,但这些东西都是我们要了解的内容,循序渐进才行,不能一蹴而就,话不多说,我们开始吧!永远在路上. 在了解什么是协议之前,我们可以先来看看,web的发展阶段, 1.静态 Web 页面阶段:Web 诞生之初,主要是以静态页面为主,HTML 作为页面标记语言,网

    2024年02月06日
    浏览(51)
  • Linux服务第一章:web基础与http协议

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 1、网络上交互是基于TCP/IP协议的,每个主机在逻辑上有一个唯一位置标识(IP地址),物理地址为MAC地址 2、为了保证地址唯一性,用户协议向特地给机构申请注册,分配IP地址网络中的地址有两套方案

    2024年02月09日
    浏览(39)
  • 【Linux】——网络基础:http协议

    目录 前言 应用层 认识协议 协议的概念 传输结构化数据 序列化和反序列化 网络版本计算器 服务器端Server  客户端Client 协议定制 其它 运行效果 HTTP协议 HTTP的简介 认识URL urlencode和urldecode HTTP协议格式 HTTP请求 HTTP响应 HTTP的方法  GET和POST方法 POSTMAN演示 HTTP的状态码 HTTP常见

    2024年02月09日
    浏览(50)
  • 计算机网络:应用层(二) Web与http协议

    我最近开了几个专栏,诚信互三! ==== ||| 《算法专栏》::刷题教程来自网站《代码随想录》。||| ==== ||| 《C++专栏》::记录我学习C++的经历,看完你一定会有收获。||| ==== ||| 《Linux专栏》::记录我学习Linux的经历,看完你一定会有收获。||| ==== ||| 《C#专栏》::记录我复

    2024年02月03日
    浏览(51)
  • 计算机网络第2章-HTTP和Web协议(2)

    一个新型应用即万维网(World Wide Web)Web。 Web的应用层协议是超文本传输协议(HTTP), 它是Web的核心 。 HTTP由两个程序实现:一个用户程序和一个服务器程序。 Web页面(Web Page)(也叫文档)是由对象组成的。 一个对象只是一个文件 ,诸如一个HTML文件、一个JPG图形等等。

    2024年02月07日
    浏览(45)
  • 【应用层】网络基础 -- HTTP协议

    协议是一种 “约定”. socket api的接口,在读写数据时,都是按 “字符串” 的方式来发送接收的(tcp是以字节流的方式发送的,这里便与表述使用\\\"字符串\\\") 如果我们要传输一些\\\"结构化的数据\\\" 怎么办呢? 那么我们(TCP)在收到一个报文的时候,如何保证你收到了一个完整的报文?

    2024年02月11日
    浏览(47)
  • HTTP 和 HTTPS 协议原理【网络基础】

    友情链接: HTTP协议【网络基础/应用层】 简单:HTTP 是一种文本协议,易于理解和实现。HTTP 的请求和响应都由起始行、首部字段和可选的消息主体组成,每个部分都有明确的语法规则。HTTP 的方法、状态码和首部字段都有标准化的定义,方便开发者遵循。 灵活:HTTP 是一种无

    2024年02月09日
    浏览(59)
  • 网络基础2(HTTP,HTTPS,传输层协议详解)

    再谈协议         在之前利用套接字进行通信的时候,我们都是利用 “字符串” 进行流式的发送接收,但是我们平常进行交流通信肯定不能只是简单的发送字符串。         比如我们用QQ进行聊天,我们不仅需要得到对方发送的消息,还要知道对方的昵称,头像等一系列数

    2024年02月13日
    浏览(54)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包