介绍
Apache HTTP 服务器是世界上使用最广泛的 Web 服务器,它提供了许多强大的功能,包括动态可加载的模块,强大的媒体支持,以及与其他流行的软件的广泛集成。
在本指南中,您将在 Debian 11 服务器上安装 Apache Web 服务器。
前提条件
在开始本指南之前,您需要一个 Debian 11 服务器,安装一个非root 用户,具有sudo
权限,并启用防火墙来阻止非必不可少的端口。
一旦你完成了设置,登录作为你的非root 用户,并继续到第一步。
步骤 1 - 安装 Apache
Apache 可在 Debian 的默认软件存储库中使用,因此可以使用传统的包管理工具安装。
首先,更新本地包索引以反映最新的上游变化:
1sudo apt update
然后,安装apache2
包:
1sudo apt install apache2
确认安装后,apt 将安装 Apache 和所有所需的依赖。
第2步:调整防火墙
在测试 Apache 之前,需要修改防火墙设置以允许外部访问默认 Web 端口. 如果您遵循先决条件中的指示,您应该有一个 UFW 防火墙配置来限制访问您的服务器。
在安装过程中,Apache 会与 UFW 注册,以提供几个应用程序配置文件,可用于通过防火墙启用或禁用对 Apache 的访问。
列出ufw
应用程序配置文件,运行如下:
1sudo ufw app list
您的输出将是应用程序配置文件的列表:
1[secondary_label Output]
2Available applications:
3 AIM
4 Bonjour
5 CIFS
6. . .
7 WWW
8 WWW Cache
9 WWW Full
10 WWW Secure
11. . .
Apache 配置文件从 WWW 开始:
WWW
:此配置文件只打开端口80
(正常,未加密的网络流量)WWW Cache
:此配置文件只打开端口8080
(有时用于缓存和网络代理)WWW Full
:此配置文件打开端口80
(正常,未加密的网络流量)和端口443
(TLS/SSL加密的流量)WW Secure
:此配置文件只打开端口443
(TLS/SSL加密的流量)
建议您启用最限制的配置文件,仍然允许您配置的流量. 由于您尚未在本指南中为您的服务器配置SSL,您只需要在端口 `80'上允许流量:
1sudo ufw allow 'WWW'
您可以通过检查状态来验证变更:
1sudo ufw status
输出将提供允许的 HTTP 流量列表:
1[secondary_label Output]
2Status: active
3
4To Action From
5-- ------ ----
6OpenSSH ALLOW Anywhere
7WWW ALLOW Anywhere
8OpenSSH (v6) ALLOW Anywhere (v6)
9WWW (v6) ALLOW Anywhere (v6)
正如输出所示,该配置文件已被激活,以允许访问Apache Web 服务器。
步骤3 - 检查您的Web服务器
在安裝過程結束時,Debian 11 會啟動 Apache. Web 伺服器應該已經啟動並運行。
通过运行systemd
init 系统的命令来确保该服务是活跃的:
1sudo systemctl status apache2
1[secondary_label Output]
2● apache2.service - The Apache HTTP Server
3 Loaded: loaded (/lib/systemd/system/apache2.service; enabled; vendor prese>
4 Active: active (running) since Wed 2022-07-06 22:05:45 UTC; 23s ago
5 Docs: https://httpd.apache.org/docs/2.4/
6 Main PID: 2796 (apache2)
7 Tasks: 55 (limit: 9509)
8 Memory: 21.0M
9 CPU: 67ms
10 CGroup: /system.slice/apache2.service
11 ├─2796 /usr/sbin/apache2 -k start
12 ├─2798 /usr/sbin/apache2 -k start
13 └─2799 /usr/sbin/apache2 -k start
此输出证实该服务已成功启动,但是,测试此方法的最佳方法是请求来自Apache的页面。
您可以访问默认的 Apache 定位页面,以确认软件通过您的 IP 地址正确运行. 如果您不知道您的服务器的 IP 地址,您可以从命令行获得几种不同的方式。
尝试在您的服务器的命令提示中写下以下内容:
1hostname -I
您将收到几个空间分开的地址,您可以在您的 Web 浏览器中尝试每个地址,以确定它们是否有效。
另一种选择是使用icanhazip.com
工具,这是一个网站,当访问时,返回您的机器的公共IP地址,如从互联网上的另一个位置读取。
1sudo apt install curl
然后,使用弯曲
来获取icanhazip.com
使用IPv4:
1curl -4 icanhazip.com
当您有您的服务器的IP地址时,请将其输入到您的浏览器的地址栏:
1http://your_server_ip
您应该看到默认的 Debian 11 Apache 网页:
此页面表示 Apache 运行正确,还包含有关重要 Apache 文件和目录位置的一些基本信息。
步骤 4 – 管理 Apache 过程
现在你有你的网页服务器运行,让我们看看一些使用systemctl
的基本管理命令。
要停止您的 Web 服务器,运行:
1sudo systemctl stop apache2
要在停止时启动 Web 服务器,请运行:
1sudo systemctl start apache2
要停止,然后重新启动服务,运行:
1sudo systemctl restart apache2
如果您只是在进行配置更改,Apache 通常可以重新加载而不会放弃连接。
1sudo systemctl reload apache2
默认情况下,Apache配置为在服务器启动时自动启动。
1sudo systemctl disable apache2
要重新启用服务在启动时启动,运行:
1sudo systemctl enable apache2
现在,Apache在服务器重新启动时会自动启动。
步骤 5 — 设置虚拟主机(推荐)
在使用Apache Web 服务器时,您可以使用 virtual hosts(类似于 Nginx 中的服务器块)来封装配置细节,并从单个服务器中托管多个域。
<$>[info] 信息: 如果您正在使用 DigitalOcean 设置域名,请参阅我们的 网络文档。
在 Debian 11 上,Apache 默认允许一个服务器块,可配置为从/var/www/html
目录中服务的文档。虽然这对单个网站非常有效,但如果您托管多个网站,它可能会变得不便。
创建 your_domain 的目录如下:
1sudo mkdir -p /var/www/your_domain
接下来,将目录的所有权分配给您当前登录的用户,如$USER
环境变量:
1sudo chown -R $USER:$USER /var/www/your_domain
如果您尚未修改umask
值,则 Web 根的权限应该是正确的,从而设置了默认文件权限。 若要确保您的权限是正确的,并允许所有者阅读、写入和执行文件,同时只向组和其他人授予阅读和执行权限,则可以输入以下命令:
1sudo chmod -R 755 /var/www/your_domain
接下来,使用您喜爱的文本编辑器创建一个样本 index.html
页面. 在这里,我们将使用 nano
:
1nano /var/www/your_domain/index.html
内部,添加以下样本HTML:
1[label /var/www/your_domain/index.html]
2<html>
3 <head>
4 <title>Welcome to your_domain!</title>
5 </head>
6 <body>
7 <h1>Success! The your_domain virtual host is working!</h1>
8 </body>
9</html>
如果您正在使用nano
,您可以通过按CTRL + X
,然后按Y
和ENTER
来做到这一点。
为了使 Apache 能够提供此内容,需要创建一个具有正确指令的虚拟主机文件,而不是直接修改位于 /etc/apache2/sites-available/000-default.conf
的默认配置文件,请在 /etc/apache2/sites-available/your_domain.conf
创建一个新的文件:
1sudo nano /etc/apache2/sites-available/your_domain.conf
插入以下配置块,类似于默认,但为您的新目录和域名更新:
1[label /etc/apache2/sites-available/your_domain.conf]
2<VirtualHost *:80>
3 ServerAdmin webmaster@localhost
4 ServerName your_domain
5 ServerAlias www.your_domain
6 DocumentRoot /var/www/your_domain
7 ErrorLog ${APACHE_LOG_DIR}/error.log
8 CustomLog ${APACHE_LOG_DIR}/access.log combined
9</VirtualHost>
请注意,我们已将DocumentRoot
更新到我们的新目录中,并将ServerAdmin
更新到网站管理员可以访问的电子邮件中,我们还添加了两个指令:ServerName
,该指令建立了将匹配这个虚拟主机定义的基域,以及ServerAlias
,该指令定义了将匹配基础名称的其他名称。
保存并关闭文件,当你完成。
现在使用a2ensite
工具启用文件:
1sudo a2ensite your_domain.conf
禁用在000-default.conf
中定义的默认网站:
1sudo a2dissite 000-default.conf
接下来,测试配置错误:
1sudo apache2ctl configtest
你应该得到以下的输出:
1[secondary_label Output]
2AH00558: apache2: Could not reliably determine the server's fully qualified domain name, using 127.0.1.1. Set the 'ServerName' directive globally to suppress this message
3Syntax OK
重新启动 Apache 以实现更改:
1sudo systemctl restart apache2
您可以通过导航到http://your_domain
,在那里您将看到如下内容:
步骤 6 – 熟悉重要的 Apache 文件和目录
现在你知道如何管理Apache服务本身,你应该花几分钟来熟悉一些重要的目录和文件。
内容
/var/www/html
:实际的网页内容,默认情况下仅由您之前看到的默认Apache页面组成,是从/var/www/html
目录中提供的。
服务器配置
- `/etc/apache2': Apache 配置目录 。 所有Apache配置文件都住在这里.
- `/etc/apaches2/apache2.conf' : Apache 主配置文件 。 这可以被修改为修改Apache全局配置. 此文件负责在配置目录中加载许多其他文件.
/etc/apache2/ports.conf': 此文件指定了 Apache 会收听的端口 。 默认情况下,Apache在端口
80'上听取,在启用一个提供SSL能力的模块时,在端口`443'上额外听取./etc/apaches2/可用网站/' : 每个站点虚拟主机可以存储的目录. Apache 将不会使用此目录中找到的配置文件, 除非它们与
站点启用目录相链接 。 通常情况下,所有服务器块配置都是在这个目录中完成的,然后通过用
a2ensite`命令连接到另一个目录而启用.- `/etc/apaches2/sites -- -- 启用/': 允许存储每个站点虚拟主机的目录 。 通常,通过将 " 站点可用 " 目录中的配置文件与 " a2ensite " 相连接来创建这些系统。 Apache 读取此目录中找到的配置文件和链接, 当它开始或重新加载以编译一个完整的配置时.
/etc/apache2/conf- 可用/',
/etc/apache2/conf- 启用/': 这些目录与 " 可用网站 " 和 " 可用网站 " 目录有着相同的关系,但被用于存储不属于虚拟主机的配置碎片。 在conf-captable
目录中的文件可以用a2enconf
命令启用,而用a2disconf
命令禁用。/etc/apaches2/mods-可用/',
/etc/apaches2/mods-启用/': 这些目录分别载有可用的和启用的模块。 以.load'结尾的文件包含装入特定模块的碎片,而以
.conf'结尾的文件包含这些模块的配置。 模块可以使用 " a2enmod " 和 " a2Dismod " 命令启用和被禁用。 (英语)
服务器日志
/var/log/apache2/access.log
:默认情况下,您的 Web 服务器的每一个请求都记录在这个日志文件中,除非 Apache 配置为另行。
结论
现在,您已经安装了 Web 服务器,您有许多选择,您可以提供的内容类型以及您可以使用的技术来创建更丰富的体验。
如果你想构建一个更完整的应用程序堆栈,你可以阅读这篇文章在 如何在 Debian 11 上配置 LAMP 堆栈。