WEB服务的配置与使用 Apache HTTPD

服务端:服务器将发送由状态代码和可选的响应正文组成的 响应 。状态代码指示请求是否成功,如果不成功,则指示存在哪种错误情况。这告诉客户端应该如何处理响应。较为流星的web服务器程序有: Apache HTTP Server Nginx
客户端:客户端(例如,Web 浏览器)使用指定的协议连接到服务器(例如,您的 Apache HTTP 服务器),并使用 URL 路径发出资源 请求。 一般来说,最常见的 web 客户端就是浏览器。
HTTP 协议 Web 客户端和服务器之间的交互用的是一个基于文本的应用级协议,叫做 HTTP Hypertext Transfer Protocol ,超文本传输协议)。 HTTP 协议由两部分程序实现:一个客 户端程序和一个服务器程序,它们运行在不同的端系统当中,通过交换HTTP 报文进行会话。 HTTP 定义了这些报文的格式以及客户端和服务器是如何进行报文交换的。

Web 访问过程:

1. 浏览器发送 HTTP 请求:浏览器将用户输入的网址转换为一个 HTTP 请求。该请求包括请求的方法(如 GET、POST 等)以及要访问的资源的 URL。
2. 服务器处理请求:服务器接收到浏览器发送的请求后,根据请求的 URL 和其他信息,定位到相应的资源(例如 HTML 页面、图像、视频等)。
3. 服务器发送响应:一旦服务器找到了请求的资源,它会生成一个 HTTP 响应,并将资源的内容包含在响应中。这个响应包括状态码(如 200 表示成功、404 表示未找到资源等)和相应的内容。
4. 浏览器接收响应:浏览器接收到服务器发送的响应后,会解析响应并根据其中的内容执行相应的操作。如果是 HTML 页面,浏览器会解析其中的标记,并加载其中引用的其他资源,如图像、样式表和脚本。
5. 显示页面内容:一旦浏览器接收到页面的全部内容并解析完成,它会将页面的内容显示给用户。这包括文本、图像、视频和其他媒体内容。

HTTP请求报文(请求行、请求头、请求体)以及响应报文:

http://t.csdnimg.cn/GtEJwicon-default.png?t=N7T8http://t.csdnimg.cn/GtEJw

补充:

请求报文(请求方法)——HTTP请求方法是指客户端与服务器通信时,客户端所请求执行的动作。常见的HTTP请求方法包括:
GET:请求获取指定资源的表示形式。使用GET方法,客户端请求服务器发送某个资源。
POST:向指定资源提交数据,用于处理表单提交、文件上传等操作。
PUT:向指定资源位置上传其最新内容,用于更新资源。
DELETE:请求服务器删除指定资源。
HEAD:请求获取与实体相对应的头部信息,用于获取资源的元数据。
OPTIONS:请求查询服务器支持的HTTP方法。
TRACE:请求服务器回显收到的请求消息,用于测试或诊断。
响应状态码 :响应报文(响应状态码)——HTTP响应状态码是服务器向客户端返回的3位数字,用于表示对请求的处理结果。常见的HTTP响应状态码包括:
200 OK:请求成功。
301 Moved Permanently:永久重定向,请求的资源已经被分配了新的URL。
400 Bad Request:客户端发送的请求有错误,服务器无法理解。
401 Unauthorized:请求要求身份验证,需要提供有效的用户名和密码。
404 Not Found:服务器未找到请求的资源。
500 Internal Server Error:服务器内部错误,无法完成请求。
503 Service Unavailable:服务器暂时无法处理请求,通常是由于维护或过载。

Apache HTTPD服务器的安装与配置

安装:

[root@webserver ~]# yum -y install httpd
[root@webserver ~]# systemctl enable --now httpd
Created symlink /etc/systemd/system/multi-user.target.wants/httpd.service →/usr/lib/systemd/system/httpd.service.
[root@webserver ~]# echo test for apache httpd > /var/www/html/index.html
[root@webserver ~]# cat /var/www/html/index.html
test for apache httpd
[root@webserver ~]# curl 127.0.0.1
test for apache httpd
[root@webserver ~]# curl -I 127.0.0.1
HTTP/1.1 200 OK     //状态码为 200 说明服务端 
                    //为客户端的访问提供了响应代码为200的
响应
Date: Sun, 21 Apr 2024 08:49:55 GMT
Server: Apache/2.4.37 (Red Hat Enterprise Linux)
Last-Modified: Sun, 21 Apr 2024 08:49:23 GMT
ETag: "16-6169765c97f13"
Accept-Ranges: bytes
Content-Length: 22
Content-Type: text/html; charset=UTF-8

 配置:

/etc/httpd/conf/httpd.conf
[root@webserver ~]# grep -v '#' /etc/httpd/conf/httpd.conf | grep -v '^$'
ServerRoot "/etc/httpd" # 使用相对路径引入文件到主配置文件时,相对路径+此处的路径
来形成一个从/开始的绝对路径
Listen 80                   # 监听TCP 80端口,可以使用Ip地址:端口的当时修改
                            # 可以配置多个Listen监听多个不同的端口,但是重复的
Listen配置将导致HTTPD无法启动
Include conf.modules.d/*.conf
                            # 所有/etc/httpd/conf.modules.d/目录下.conf结尾的文件都 
                            # 导入到/etc/httpd/conf/httpd.conf
User apache                 # 程序用户为apache
Group apache                # 程序组账号为apache
ServerAdmin root@localhost # 服务器管理员邮箱
<Directory /> 
# <Directory>块设置指定目录以及所有后代目录的配置指令。
# <Directory>块中的常见指令包括以下几种:
# Allow0verride None:对于按目录的配置设置,将不会查阅
# .htaccess 文件。将其设置为任何其他设置都将导致
# 性能损失以及可能的安全后果。
# Require A11 Denied:httpd 将拒绝提供此目录的内容,
# 当客户端请求时,将返回HTTP/1.1403 Forbidden错误。
# Require A11 Granted:允许访问此目录。对普通内容树之
# 外的目录设置此选项可能会产生安全影响。
# 0ptions[[+|-]0PTIONS]...:为某个目录开启(或关闭)
# 特定选项。例如,如果请求了某个目录并且该目录中不存在
# index.htm1文件,则Indexes 选项将显示一个目录列表。
AllowOverride none
Require all denied
</Directory>
DocumentRoot "/var/www/html"            #此设置确定 httpd 将搜索请求文件的位置。重要的一点是,
                                        # 此处指定的目录可以由httpd(常规权限和 SELinux)读取
                                        # ,并且对应的 <Directory>块已声明为允许访问。
<Directory "/var/www">
AllowOverride None
Require all granted
</Directory>
<Directory "/var/www/html">
Options Indexes FollowSymLinks
AllowOverride None
Require all granted
</Directory>
<IfModule dir_module>                    # 仅当加载指定扩展模块时,此块才会应用其内容。在此情况下,
                                         # 会加载dir_module,因此DirectoryIndex 指令可用于
                                         # 指定在请求目录时应使用的文件。
DirectoryIndex index.html
</IfModule>
<Files ".ht*">                           # 类似于Directory,
Require all denied
</Files>
ErrorLog "logs/error_log"                # 错误日志
LogLevel warn
<IfModule log_config_module>             # 指定了几种日志格式,分别是combined、common、
combinedio;默认场景下均使用combined这种日志格式
LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\""
combined
LogFormat "%h %l %u %t \"%r\" %>s %b" common
<IfModule logio_module>
LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{UserAgent}i\" %I %O" combinedio
</IfModule>
CustomLog "logs/access_log" combined
</IfModule>
<IfModule alias_module>
ScriptAlias /cgi-bin/ "/var/www/cgi-bin/"
</IfModule>
<Directory "/var/www/cgi-bin">
AllowOverride None
Options None
Require all granted
</Directory>
<IfModule mime_module>
TypesConfig /etc/mime.types
AddType application/x-compress .Z
AddType application/x-gzip .gz .tgz
AddType text/html .shtml
AddOutputFilter INCLUDES .shtml
</IfModule>
AddDefaultCharset UTF-8           # 此设置向 text/plain和 text/htm1 资源的
                                  # Content-Type 报头中添加 charset 部分。
                                  # 可以使用 AddDefaultCharset 0ff将其禁用
<IfModule mime_magic_module>
MIMEMagicFile conf/magic
</IfModule>
EnableSendfile on                 # 启用 EnableSendfile 以提高文件传输的性能和效率。
IncludeOptional conf.d/*.conf     # 所有/etc/httpd/conf.d/目录下.conf结尾的文件都
                                  # 导入到/etc/httpd/conf/httpd.conf
修改配置文件,改变 httpd 的一些默认配置:
监听的端口号
修改默认的首页文件保存目录
对于防火墙和 selinux 不熟悉的建议关闭防火墙和修改 SELinux 为宽容模式

 修改首页:

[root@localhost ~]# vim /etc/httpd/conf/httpd.conf

修改 Listen 80 一行 为 Listen 8080
修改 DocumentRoot “/var/www/html“一行为 DocumentRoot "/home/www“
修改<Directory “/var/www/html”> 一行为 <Directory "/home/www">
修改 <IfModule dir_module> 块 内 DirectoryIndex index.html 一行为 DirectoryIndex home.html

打开目录权限 :

 chmod 755 /home/www
 chmod 644 /home/www/home.html

 重启:

 systemctl restart httpd

配置基于端口的虚拟主机

要创建基于 8088 8089 两个不同端口号的虚拟主机,要求不同的虚拟主机对应的主目录不同,默认页面的内容也不同

创建目录、文件,并赋予权限755

 mkdir /home/www/8088
 mkdir /home/www/8089
# 8088 对应的页面
 echo "8088 test" >> /home/www/8088/index.html
# 8089 对应的页面
 echo "8089 test" >> /home/www/8089/index.html

chmod 755   /home/www/8088
chmod 755   /home/www/8089

修改配置

恢复原来的主配置文件为默认,所有的虚拟主机配置,保存在专门的文件中
cp  /etc/httpd/conf/httpd.conf.bac  /etc/httpd/conf/httpd.conf
[root@nfs-server conf]# touch /etc/httpd/conf.d/myvhost.conf
[root@nfs-server conf]# cat /etc/httpd/conf.d/myvhost.conf 

# match a ServerName or ServerAlias in any <VirtualHost> block.
Listen 8088
<VirtualHost *:8088>
DocumentRoot "/home/www/8088"
ServerName localhost
ErrorLog "/var/log/httpd/host8088-error_log"
CustomLog "/var/log/httpd/host8088-access_log" combined
</VirtualHost>
<Directory "/home/www/8088">
AllowOverride None
Require all granted
</Directory>
Listen 8089
<VirtualHost *:8089>
DocumentRoot "/home/www/8089"
ServerName localhost
ErrorLog "/var/log/httpd/host8089-error_log"
CustomLog "/var/log/httpd/host8089-access_log" combined
</VirtualHost>
<Directory "/home/www/8089">
AllowOverride None
Require all granted
</Directory>

重启验证

[root@nfs-server conf]# systemctl restart httpd

基于主机名的虚拟主机配置

创建目录、文件,并赋予权限755

[root@nfs-server conf]# mkdir -p /vhost/server{a,b}
[root@nfs-server conf]# echo servera > /vhost/servera/index.html
[root@nfs-server conf]# echo serverb > /vhost/serverb/index.html
[root@nfs-server conf]# chmod 755 /vhost/servera
[root@nfs-server conf]# chmod 755 /vhost/serverb

配置主机名解析记录

[root@nfs-server conf]#  echo '192.168.68.10 servera.example.com servera' >>/etc/hosts
[root@nfs-server conf]#  echo '192.168.68.10 serverb.example.com serverb' >>/etc/hosts

修改配置文件

/etc/httpd/conf/httpd.conf 加一行
ServerName localhost
[root@nfs-server conf]#  cat /etc/httpd/conf.d/mhost.conf

<VirtualHost *:80>
DocumentRoot "/vhost/servera"
ServerName servera.example.com 
ServerAlias servera 
ErrorLog "/var/log/httpd/servera-error_log"
CustomLog "/var/log/httpd/servera-access_log" combined
</VirtualHost>

<Directory "/vhost/servera">
AllowOverride None
Require all granted
</Directory>

<VirtualHost *:80>
DocumentRoot "/vhost/serverb"
ServerName serverb.example.com
ErrorLog "/var/log/httpd/serverb-error_log"
CustomLog "/var/log/httpd/serverb-access_log" combined
</VirtualHost>

<Directory "/vhost/serverb">
AllowOverride None
Require all granted
</Directory>

重启测试

systemctl restart httpd

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

揭秘npm:高效包管理的绝佳技巧(AI写作)

首先&#xff0c;这篇文章是基于笔尖AI写作进行文章创作的&#xff0c;喜欢的宝子&#xff0c;也可以去体验下&#xff0c;解放双手&#xff0c;上班直接摸鱼~ 按照惯例&#xff0c;先介绍下这款笔尖AI写作&#xff0c;宝子也可以直接下滑跳过看正文~ 笔尖Ai写作&#xff1a;…

整合阿里云OSS 对象存储

1. 创建Bucket 填写属性参数 2. 获取秘钥accessKey 2.1 进入accessKey管理页面 2.2 创建accessKey&#xff0c;并获取信息 需要自行进行安全验证 记录自己的 信息 3. 查看官方SDK文档 位置 找到开发参考Java 4. 具体实现-参考官网 4.1 添加依赖 <dependency&…

Java | Leetcode Java题解之第42题接雨水

题目&#xff1a; 题解&#xff1a; class Solution {public int trap(int[] height) {int n height.length;if (n 0) {return 0;}int[] leftMax new int[n];leftMax[0] height[0];for (int i 1; i < n; i) {leftMax[i] Math.max(leftMax[i - 1], height[i]);}int[] …

element中file-upload组件的提示‘按delete键可删除’,怎么去掉?

问题描述 element中file-upload组件会出现这种提示‘按delete键可删除’ 解决方案&#xff1a; 这是因为使用file-upload组件时自带的提示会盖住上传的文件名&#xff0c;修改一下自带的样式即可 ::v-deep .el-upload-list__item.is-success.focusing .el-icon-close-tip {d…

SQL基础(关系模型)

目录 SQL及定义域概念 SQL是什么 定义域 关系简介 关系的定义 关系的封闭性 关系模型简介 关系模型 谓词逻辑 运算基础 SQL的加减乘除 SQL的除法1 SQL的除法2 SQL的除法3 三值逻辑 NULL的危害 消除NULL SQL及定义域概念 SQL是什么 Structured Query Languag…

【计算机毕业设计】药品销售系统产品功能介绍——后附源码

&#x1f389;**欢迎来到我的技术世界&#xff01;**&#x1f389; &#x1f4d8; 博主小档案&#xff1a; 一名来自世界500强的资深程序媛&#xff0c;毕业于国内知名985高校。 &#x1f527; 技术专长&#xff1a; 在深度学习任务中展现出卓越的能力&#xff0c;包括但不限于…

Cellebrite Inseyets- 一站式流线型提取

Cellebrite Inseyets - &#xff08;原Cellebrite Premium/ES/SAAS&#xff09;一站式流线型数据提取 Premium现已迎来重大更新升级&#xff0c;简化您的数据处理流程&#xff0c;加快处理速度&#xff01; Cellebrite Inseyets- 提高设备优先级、减少处理时间并增加有意义的数…

用html画一个四叶草

<!DOCTYPE html> <html lang"en" > <head> <meta charset"UTF-8"> <title>四叶草</title> <link href"" rel"stylesheet"> <link rel"stylesheet" href"css/style.css&q…

Barnes-Hut t-SNE:大规模数据的高效降维算法

在数据科学和分析中&#xff0c;理解高维数据集中的底层模式是至关重要的。t-SNE已成为高维数据可视化的有力工具。它通过将数据投射到一个较低维度的空间&#xff0c;提供了对数据结构的详细洞察。但是随着数据集的增长&#xff0c;标准的t-SNE算法在计算有些困难&#xff0c;…

Spring SpringBoot(详解)

1. Spring简介 1.1 Spring 核心设计思想 1.1.1 Spring 是什么&#xff1f; Spring 是包含了众多⼯具⽅法的 IoC 容器。Spring 指的是 Spring Framework&#xff08;Spring 框架&#xff09;&#xff0c;它是⼀个开源框架&#xff0c;Spring ⽀持⼴泛的应⽤场景&#xff0c;它…

Spring Cloud学习笔记(Ribbon):Ribbon的应用样例

这是本人学习的总结&#xff0c;主要学习资料如下 - 马士兵教育 1、Ribbon简介1.1、架构图1.2、简单实现负载均衡 2、配置负载均衡策略2.1、IRule2.2、使用IRule简单示例2.2.1、Overview2.2.1、注入IRule2.2.2、关联IRule和服务 1、Ribbon简介 我们都知道Ribbon是用于负载均衡…

5-内核开发-/proc File System 学习

5-内核开发-/proc File System 学习 课程简介&#xff1a; Linux内核开发入门是一门旨在帮助学习者从最基本的知识开始学习Linux内核开发的入门课程。该课程旨在为对Linux内核开发感兴趣的初学者提供一个扎实的基础&#xff0c;让他们能够理解和参与到Linux内核的开发过程中。…

Nacos采坑:非集群Nacos不要使用同一个MySQL数据库

系列文章目录 文章目录 系列文章目录前言 前言 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站&#xff0c;这篇文章男女通用&#xff0c;看懂了就去分享给你的码吧。 Nacos 致力于帮助您…

第27章 筹集资金

< 回到目录 第六部分 流程 在各关键职能安排好了关键人员之后&#xff0c;公司有效运作&#xff0c;数据系统正常运行&#xff0c;经理和团队成员之间的双向信息交流顺畅。现在&#xff0c;剩下的就是你与外部世界的交流&#xff0c;包括与投资者、招聘者和客户的互动。这些…

银行买的黄金怎么卖出去?了解黄金交易的步骤和注意事项

黄金一直以来都是备受投资者关注的贵金属之一。银行提供了购买黄金的机会&#xff0c;但投资者也需要了解如何卖出银行买的黄金。 选择适合的购买方式 投资者可以通过多种途径购买黄金&#xff0c;其中包括银行提供的黄金交易服务。银行买黄金的方式可以是通过黄金交易账户、黄…

力扣HOT100 - 114. 二叉树展开为链表

解题思路&#xff1a; class Solution {List<TreeNode> list new ArrayList<>();public void flatten(TreeNode root) {recur(root);for (int i 1; i < list.size(); i) {TreeNode pre list.get(i - 1);TreeNode cur list.get(i);pre.left null;pre.right…

SpringBoot学习之Kafka下载安装和启动【Mac版本】(三十三)

一、配置Java环境变量 在启动Kafka之前,你需要先正确配置好你的Java环境变量。可以在终端输入java -version检查java环境变量是否配置正确,在Mac上如何配置java环境变量,请读者自行网上搜索操作之,此处不赘叙。 二、下载安装Kafka 1、下载Kafka:Apache Kafka,这两个版本…

python简易小时钟

import time import turtledef getTime():tt time.localtime() # 结构化的时间ss time.strftime(%Y年%m月%d日 %H:%M:%S, tt)return sspen turtle.Turtle()pen.backward(100) pen.speed(0)while True:time.sleep(1)times getTime()pen.clear()pen.write(times, font("…

中颖51芯片学习10. Touch Key触摸按键功能

中颖51芯片学习10. Touch Key触摸按键功能 一、SH79F9476 资源介绍1. 特性2. 系统框图&#xff1a;3.准备环境 二、准备工具三、开发步骤1. 新建项目流程&#xff08;1&#xff09;新建工程&#xff08;2&#xff09;选择芯片和封装&#xff08;3&#xff09;触摸配置按键&…

Tomcat架构设计精髓分析-Connector高内聚低耦合设计

优秀的模块化设计通常都会采用高内聚、低耦合 高内聚是指相关度比较高的功能要尽可能集中&#xff0c;不要分散。低耦合是指两个相关的模块要尽可能减少依赖的部分和降低依赖的程序&#xff0c;不要让两个模块产中强依赖。 Tomca连接器需要实现的功能: 监听网络端口 接受网络…