Linux如何搭建Apache网站服务
前言:上一篇文档我们已经了解了如何简单的搭建Apache(httpd)网站服务了,接下来让我们一起来了解怎么将httpd服务添加为系统服务,以及httpd服务器的一些基本的配置。
一、添加httpd系统服务
CentOS7系统下,将编译安装的程序添加为系统服务有一下两种方式:
- 通过chkconfig命令添加为系统服务,然后由systemctl进行管理。
- 在/lib/systemd/system/目录下,手动编写以.service结尾的单元(unit)配置文件。
1.使用chkconfig添加系统服务
若希望将httpd添加为系统服务,以便通过chkconfig进行管理,需要建立可控的服务脚本。其实原理很简单,例如,可将apachectl脚本复制为/etc,然后编辑"/etc/rc.d"文件,在 #!/bin/sh 下增加两行文字如下:
# chkconfig: 35 70 30 (添加chkconfig识别配置)
# description: Apache
然后将其添加为标准的linux系统服务。(如下图所示)
注:cp /usr/local/apache/bin/apachectl /etc/rc.d ,如果有其他的版本的Apache存在,也可以直接覆盖掉
2.建立[service].service配置文件
在/lib/systemd/system/目录下,建立一个以.service结尾的单元(unit)配置文件,用于控制由systemd控制或监控的httpd服务。配置文件主要分为三个部分,控制单元[unit]的定义、服务[Service]的定义以及安装部分[Install],具体内容如下所示:
上图所示配置文件的各配置项的作用如下所示:
- Description:设置服务单元描述字符串。
- After:设置服务单元的启动先后顺序。例如,单元文件中出现"After=ne;表示启动时先启动ne,后启动,关闭时顺序相反。与After字段相应的还有一个Before字段,如单元文件中出现"Before=ne;表示启动时,后启动ne。
- Type:设置服务进程的启动类型。需要注意的是,当启动类型为forKing时需要同时设置PIDFile配置项,以帮助systemd准确定位到服务的主进程。
- PIDFile:设置服务的守护进程的PID文件
- ExecStart:设置服务启动时执行的命令
- ExecReload:设置服务重新加载时执行的命令
- KillMode:设置在单元停止时,杀死进程的方法。Process表示仅杀死主进程。
- Restart:设置服务进程正常退出、异常退出、被杀死、超时的时候,是否重启该服务。On-failure表示仅在进程异常退出时重启。
- RestartSec:设置在重启服务前暂停多长时间,默认值是100毫秒(ms)
- WantedBy:设置该服务所在的Target(运行目标)。WantedBy=gra(图形界面多用户系统)是指,httpd所在的Target是gra运行目标时,该目录下的所有服务均开机启动。该配置项常用的Target除了gra之外,还有mul(非图形界面多用户系统)
文件编辑完之后,就可以使用systemctl工具控制httpd服务了。如下图:
在日常维护的过程中,既可以使用apachectl工具来控制httpd服务,也可以使用systemctl命令控制httpd服务。其实,执行"systemctl start httpd"命令,等同于执行"/usr/local/httpd/bin/apachectl start"命令。
二、web站点的简单部署
1.确定网站名称、IP地址
若要向Internet中发布一个Web站点,需要申请一个合法的互联网IP地址,并向DNS服务提供商注册一个完整的网站名称。在实验环境中,我们可以自行设置。如:Web主机的IP地址设为:192.168.1.1,网站名称改为:www.。如果我们实验环境中最后想通过域名访问到网站,可以在客户机的hosts文件中添加一行主机记录。如下图:
2.配置并启动httpd服务
编辑httpd服务的主配置文件,查找配置项"ServerName",修改web站点的完整主机名为自己定义的主机名(如:www.),用于设置网站名称。这里我们先就简单的修改这一个地方就行,关于其他的更多配置项后面有详细的介绍。修改完配置文件之后,可以使用"apachectl -t或httpd -t"命令对配置文件进行语法检查,如果没有语法错误,会返回ok的信息。然后启动httpd服务。(如下图)
3.部署网页文档
对于新编译安装的httpd服务,网站根目录位于/usr/local/httpd/htdocs下,需要将Web站点的网页文档复制或上传到此目录下。这里我们自己编辑一个简单的网页内容,用来测试。如下图:
4.访问web站点
在客户机的网页浏览器上,通过域名或IP地址访问httpd服务器,将可以看到web站点的页面内容中是我们刚刚编辑的那个简单网页,表示httpd符已经在正常运行。如下图:
5.查看web站点的访问情况
httpd服务有两种类型的日志:访问日志和错误日志,这两种日志的文件名分别为access_log和error_log,均位于/usr/local/httpd/logs目录下。
可以通过查看日志文件access_log,及时了解web站点的访问情况,访问日志中的每行对应一条访问记录,记录了客户机的IP地址、访问时间、请求的网页对象信息。如下图:
当然也可以通过查看错误日志文件error_log,可以为排查服务器运行故障提供参考依据。
三、配置文件
要对web站点进行更加具体、更加强大的配置、仅仅学会添加"ServerName"配置项显然是不够的,还需要进一步熟悉配置文件,了解其他各种常见的配置项。
主配置文件由注释行、设置行两部分组成,与大多数linux配置文件一样,注释行以"#"开始,包含了对相关配置内容进行的说明和解释。除了注释行和空行以外的内容为配置行,构成了web服务的有效配置。根据配置所作用的范围不同,设置行又可分为全局配置、区域配置。
1.全局配置项(如下图)
全局配置决定了httpd服务器的全局运行参数,使用"关键字 值"的配置格式。如:"ServerName www.",其中"ServerName"为配置关键字,"www."为对应的值。
在全局配置中常见的配置项的含义如下:
ServerRoot:设置httpd服务器的根目录,该目录下包括了运行web站点必需的子目录和文件。默认情况下,httpd服务器的根目录为httpd的安装目录。在配置文件中,如果指定目录或文件位置时不使用绝对路径,则该目录或文件位置都认为是在服务器的根目录下。
- Listen:监听的IP地址、端口号,默认为80
- User:运行服务的用户身份,默认为daemon
- Group:运行服务的组身份,默认为daemon
- ServerAdmin:管理员邮箱
- ServerName:网站服务器的域名
- DocumentRoot:网页文档的根目录,网页文档在系统中的实际存放路径。比较容易和ServerRoot混淆,需格外注意
- DirectoryIndex:默认的索引(首页)页文件,可以设置多个首页文件,以空格分开,默认的首页文件为index.html
- ErrorLog:设置错误日志文件的路径,默认路径为logs/error_log
- LogLevel:记录日志的级别,默认为warn(警告)
- CustomLog:访问日志文件的位置、日志类型,默认路径为logs/access_log,使用的类型为common(通用格式)
- PidFile:保存httpd进程PID号的文件,默认保存路径为log,logs目录位于Apache的服务器根目录下
- AddDefaultCharset:设置站点中的网页默认使用的字符集编码
- Timeout:网络连接超时,默认为300秒
- KeepAlive:是否保持连接,可选On或Off
- MaxKeepAliveRequests:每次连接最多请求文件数
- KeepAliveTimeout:保持连接状态时的超时时间
- Include:包含另一个配置文件的内容,可以实现将一些特殊功能的配置放到一个单独的文件中,再使用Include配置项将其包含到文件中,这样便于独立进行配置功能的维护而不影响主配置文件
2.区域配置项
除了全局配置以外,文件中的大多数配置是包括在区域中的。区域配置使用一对组合标记,限定了配置的作用范围。最常见的目录区域配置形式如下图所示:
在以上区域定义中,设置了一个根目录的区域配置,其中添加的访问控制相关配置只对根目录有效,而不会作用于全局或其他目录区域。
注:这里所说的根目录是指设置httpd服务器的根目录(ServerRoot所设置的值),而不是CentOS系统的根目录。
下面的视频是我自己做实验时的视频(没有声音),有兴趣的话可以看一下。
####### 本节完 #######
Apache(httpd)服务的搭建到这里,我们已经有了一个大概的了解了,下个文档让我们一起再了解一下如何设置httpd服务的访问控制,以及虚拟Web主机的搭建等。