????????在配置 Apache 网站服务之前,需要正确安装好 httpd 服务器软件。httpd 服务器的安装可以选用 RPM 安装、源码编译安装这两种方式,前者相对比较简单、快速,但是在功能上存在一定的局限性。在实际的生产环境中,使用源码编译安装的方式要更加普遍。本次将以下载的源码包httpd-2.4.25.tar.gz 为例,介绍 httpd 服务的定制安装过程。
1. 准备工作
为了避免发生端口冲突、程序冲突等现象,建议卸载使用 RPM 方式安装的 httpd。httpd 服务编译安装时需要依赖 apr-util-devel、pcre-devel 等软件,因此在 httpd 编译安装之前需要先安装依赖软件。
[root@Linux01 ~]# rpm -e httpd --nodeps
错误:未安装软件包 httpd
[root@Linux01 ~]# yum install -y apr-util-devel pcre-devel
2. 源码编译及安装
(1)解包
将下载获得的 httpd 源码包解压并释放到/usr/src 目录下,且切换到展开后的源码目录中。
[root@Linux01 ~]# tar zxf httpd-2.4.25.tar.gz -C /usr/src/
[root@Linux01 ~]# cd /usr/src/httpd-2.4.25/
[root@Linux01 httpd-2.4.25]#
(2)配置
根据服务器的实际应用需要,可以灵活设置不同的定制选项,如指定安装路径、启用字符集支持等。若要获知可用的各种配置选项及其含义,可以执行“./configure --help” 命令。
root@Linux01 httpd-2.4.25]# ./configure --prefix=/usr/local/httpd --enable-so --enable-rewrite --enable-charset-lite --enable-cgi
上述配置命令中,各选项的含义如下。
(3)编译及安装
完成配置以后,执行“make”命令进行编译,将源代码转换为可执行的程序;然后执行“make install”命令完成最后的安装过程;将编译完的 httpd 程序及相关目录、文件自动复制到预设的安装目录(由配置时的“--prefix”选项指定)。其中“make”的过程可能会需要较长的时间。
[root@Linux01 httpd-2.4.25]# make && make install
3. 确认安装结果
由于指定的安装目录为/usr/local/httpd,因此 httpd 服务的各种程序、模块、帮助文件等都将复制到此目录下。
[root@Linux01 ~]# ls /usr/local/httpd/
bin build cgi-bin conf error htdocs icons include logs man manual modules
在安装后的/usr/local/httpd 目录下包含 httpd 服务相关的各种子目录,主要子目录的用途如下。?
4. 优化执行路径
通过源码编译安装的 httpd 服务,程序路径并不在系统默认的搜索路径中,为了使该服务在使用时更加方便,可以为相关程序添加符号链接。
[root@Linux01 ~]# ln -s /usr/local/httpd/bin* /usr/local/bin/
[root@Linux01 ~]# ls -l /usr/local/bin/httpd /usr/local/bin/apachectl
这样,在执行相关命令时就不用输入冗长的路径了。例如,当执行“httpd-v”命令(用于查看程序版本)时,即相当于执行“/usr/local/httpd/bin/httpd-v”命令。
[root@Linux01 ~]# httpd -v
Server version: Apache/2.4.25 (Unix)
Server built: Jan 3 2024 11:31:48
[root@Linux01 ~]#
?5. 添加 httpd 系统服务
在/lib/systemd/system/目录下,建立一个以.service 结尾的单元(unit)配置文件,用于控制由 Systemd 管理或监控的 httpd 服务。
[root@Linux01 ~]# cd /lib/systemd/system
[root@Linux01 system]# vim httpd.service
[Unit]
Description=The Apache HTTP Server
After=network.target
[Service]
Type=forking
PIDFile=/usr/local/httpd/logs/httpd.pid
ExecStart=/usr/local/bin/apachectl $OPTIONS
ExecReload=/bin/kill -HUP $MAINPID
KillMode=process
Restart=on-failure
RestartSec=42s
[Install]
WantedBy=graphical.target
[root@Linux01 system]# systemctl enable httpd.service
Created symlink from /etc/systemd/system/graphical.target.wants/httpd.service to /usr/lib/systemd/system/httpd.service.
[root@Linux01 system]# systemctl is-enabled httpd.service
enabled
[root@Linux01 system]#
成功执行上述操作后,在日常维护过程中,可直接使用 apachectl 工具或 systemctl命令控制 httpd 服务。?
在 CentOS 7.3 系统中,使用 httpd 服务部署 Web 站点的基本过程分析如下。
1. 确定网站名称、IP地址
????????若要向 Internet 中发布一个 Web 站点,需要申请一个合法的互联网 IP 地址,并向 DNS 服务提供商注册一个完整的网站名称。在企业内部网络中,这些信息可以自行设置。例如 Web 主机的 IP 地址为 192.168.56.10,网站名称为 www.ymk.com。
????????若要在客户机的浏览器中通过地址 www.ymk.com 来访问此 Web 站点,还应该有可用的 DNS 域名服务。例如,客户机所使用的 DNS 服务器应能够将 www.ymk.com 解析为 IP 地址 192.168.56.10。
????????在 Web 服务器本机中,将 IP 地址设置为 192.168.56.10;将主机名称设置为www.ymk.com;并修改/etc/hosts 文件,添加相应的映射记录以提高本地解析速度。
[root@Linux01 ~]# hostname www.ymk.com
[root@Linux01 ~]# vim /etc/hostname
www.ymk.com
[root@Linux01 ~]# vim /etc/hosts
192.168.56.10 www.ymk.com
[root@Linux01 ~]# bash
[root@www ~]#
2. 配置并启动 httpd 服务
(1)配置 httpd 服务
编辑 httpd 服务的主配置文件 httpd.conf,查找配置项“ServerName”,在附近添加一行内容“ServerName www.ymk.com”,用于设置网站名称。
[root@www ~]# vim /usr/local/httpd/conf/httpd.conf
......//省略部分内容
Servername www.ymk.com
......//省略部分内容
修改 httpd.conf 文件的配置内容后,建议使用带“-t”选项的 apachectl 命令对配置内容进行语法检查(或使用“httpd-t”命令)。如果没有语法错误,将会显示“Syntax OK”的信息,否则需要根据错误提示信息来修正配置。?
[root@www ~]# /usr/local/httpd/bin/apachectl -t
Syntax OK
(2)启动 httpd 服务
使用 systemctl 命令启动 httpd 服务。正常启动 httpd 服务以后,默认将监听 TCP 协议的 80 端口。
[root@www ~]# systemctl start httpd
[root@www ~]# netstat -anpt | grep httpd
tcp6 0 0 :::80 :::* LISTEN 36547/httpd
3. 部署网页文档
对于新编译安装的 httpd 服务,网站根目录位于/usr/local/httpd/htdocs 下,需要将 Web 站点的网页文档复制或上传到此目录下。httpd 服务器默认已提供了一个名为 index.html 的测试网页(可显示字串“It works!”),作为访问网站时的默认首页。
[root@www ~]# cat /usr/local/httpd/htdocs/index.html
<html><body><h1>It works!</h1></body></html>
4. 在客户机中访问Web站点?
在客户机的网页浏览器中,通过域名或 IP 地址访问 httpd 服务器,将可以看到 Web 站点的页面内容。若使用的是 httpd 服务默认的首页,则页面会显示“It works!”,表示 httpd 服务已经正常运作。
5. 查看 Web 站点的使用情况
????????httpd 服务器使用了两种类型的日志:访问日志和错误日志。这两种日志的文件名分别为 access_log 和 error_log,均位于/usr/local/httpd/logs 目录下。
????????通过查看访问日志文件 access_log,可以及时了解 Web 站点的访问情况。访问日志中的每一行对应一条访问记录,记录了客户机的 IP 地址、访问服务器的日期和时间、请求的网页对象等信息。例如,当从客户机 192.168.56.1?访问 Web 站点以后,访问日志将会记录“192.168.56.1……"GET/HTTP/1.1"……”的消息。
[root@www ~]# tail /usr/local/httpd/logs/access_log
192.168.56.1 - - [03/Jan/2024:12:16:10 +0800] "GET / HTTP/1.1" 200 45
192.168.56.1 - - [03/Jan/2024:12:16:10 +0800] "GET /favicon.ico HTTP/1.1" 404 209
192.168.56.1 - - [03/Jan/2024:12:17:02 +0800] "-" 408 -
????????通过查看错误日志文件 error_log,可以为排查服务器运行故障提供参考依据。错误日志文件中的每一行对应一条错误记录,记录了发生错误的日期和时间、错误事件类型、错误事件的内容描述等信息上述过程是使用 httpd 服务器部署并验证 Web 站点的基本步骤,其中涉及 httpd.conf 配置文件的改动量非常少,要搭建一台简单的 Web 服务器还是十分容易的。?
????????若要对 Web 站点进行更加具体、更加强大的配置,仅仅学会添加“ServerName”配置项显然是远远不够的,还需要进一步熟悉 httpd.conf 配置文件,了解其他各种常见的配置项。
????????主配置文件 httpd.conf 由注释行、设置行两部分内容组成。与大多数 Linux 配置文件一样,注释性的文字以“#”开始,包含了对相关配置内容进行的说明和解释。除了注释行和空行以外的内容即设置行,构成了 Web 服务的有效配置。根据配置所作用的范围不同,设置行又可分为全局配置、区域配置。
1. 全局配置
????????全局配置决定 httpd 服务器的全局运行参数,使用“关键字 值”的配置格式。例如,配置网站名称时使用的“ServerName www.ymk.com”,其中“ServerName”为配置关键字,而“www.ymk.com”为对应的值。
????????每一条全局配置都是一项独立的配置,不需要包含在其他任务区域中。以下列出了 httpd.conf 文件中最常用的一些全局配置项。
ServerRoot "/usr/local/httpd"
Listen 80
User daemon
Group daemon
ServerAdmin webmaster@kgc.com
ServerName www.kgc.com
DocumentRoot "/usr/local/httpd/htdocs"
DirectoryIndex index.htmlindex.php
ErrorLog "logs/error_log"
LogLevel warn
CustomLog logs/access_log common
PidFile logs/httpd.pid
AddDefaultCharset UTF-8
Include conf/extra/httpd-default.conf
在上述设置行中,各全局配置项的含义如下。?
????????以上配置项是 httpd.conf 文件中主要的全局配置项。还有其他很多配置项,在此不一一列举,如果需要使用可以查看 Apache 服务器中的相关帮助手册文档。
2. 区域配置项
????????除了全局配置项以外,httpd.conf 文件中的大多数配置是包括在区域中的。区域配置使用一对组合标记,限定了配置项的作用范围。例如,最常见的目录区域配置的形式如下所示。
<Directory /> //定义"/"目录区域的开始
Options FollowSymLinks //控制选项,允许使用符号链接
AllowOverride None //不允许隐含控制文件中的覆盖配置
Require all denied //禁止任何人访问此区域
</Directory> //定义"/"目录区域的结束
????????在以上区域定义中,设置了一个根目录的区域配置,其中添加的访问控制相关配置只对 httpd 服务的根目录有效,而不会作用于全局或其他目录区域。