使用Apache服务部署静态网站2019-7-5

时间:2022-12-18 23:13:33

使用Apache服务部署静态网站

第1步:把镜像挂载到系统中

第2步:使用vim文件编辑器创建YUM仓库的配置文件

[root@study ~]# vim /etc/yum.repos.d/abc.repo

[abc]

name=abc

baseurl=file:///media/

enabled=1

gpgcheck=0

第3步:安装Apache服务程序

[root@study ~]# yum install httpd -y

第4步:启用httpd服务程序并将其加入开机启动项中

[root@study ~]# systemctl start httpd

[root@study ~]# systemctl enable httpd

Created symlink from /etc/systemd/system/multi-user.target.wants/httpd.service to /usr/lib/systemd/system/httpd.service.

第5步:在浏览器输入系统IP 地址是否出现测试页面。

 使用Apache服务部署静态网站2019-7-5

配置服务文件参数

httpd服务程序的主要配置文件及存放位置

配置文件的名称 存放位置
服务目录 /etc/httpd
主配置文件 /etc/httpd/conf/httpd.conf
网站数据目录 /var/www/html
访问日志 /var/log/httpd/accesss_log
错误日志 /var/log/httpd/error_log

httpd的主配置文件存在三种类型的信息:注释行信息、全局配置、区域配置

参数 用途
ServerROOT 服务目录
ServerAdmin 管理员邮箱
User 运行服务的用户
Group 运行服务的用户组
ServerName  网站服务器的域名
DocumentRoot 网站数据目录
Directory 网站数据目录的权限
Listen  监听的IP地址与端口号
DirectoryIndex 默认的索引页页面
ErrorLog 错误日志文件
CustomLog 访问日志文件
Timeout 网页超时时间,默认为300秒

DocumentRoot参数用于定义网站数据的保存路径,其参数的默认值是把网站数据存放到/var/www/html目录中,而当前网站普遍的首页面名称时index.html,因此可以向/var/www/html目录中写入一个文件,替换掉httpd服务程序的默认首页面,该操作会立即生效。

[root@study ~]# echo "Welcome to Purple Cloud Fairy" > /var/www/html/index.html

使用Apache服务部署静态网站2019-7-5

修改网站数据目录

1、建立网站数据的保存目录,并创建首页文件

root@study ~]# mkdir /home/wwwroot
[root@study ~]# echo "The New Web Directory" > /home/wwwroot/index.html

2、打开httpd服务程序的主配置文件,将第119行用于定义网站数据保存的参数DocumentRoot修改为/home/wwwroot,同时还需要将第124行定义目录权限的参数Directory后面的路径也修改为/home/wwwroot

[root@study ~]# mkdir /home/wwwroot
[root@study ~]# echo "The New Web Directory" > /home/wwwroot/index.html
[root@study ~]# vim /etc/httpd/conf/httpd.conf 
[root@study ~]# systemctl restart httpd

使用Apache服务部署静态网站2019-7-5

个人用户主页功能

第1步:在httpd服务程序中,默认没有开启个人用户主页功能。

需要编辑/etc/httpd/conf.d/userdir.conf文件,然后在第17行的UserDir disabled注释掉,表示让httpd服务程序开启个人用户主页功能;同时再把第24行的UserDir public_html参数前面的注释去掉(UserDir参数表示网站数据在用户目录中的保存目录名称,即public_html目录)

第2步:在用户家目录中建立用于保存网站数据的目录及首页文件。另外,还需要把家目录的权限修改为755,保证其他人也有权限读取里面的内容。

[root@study ~]# su - linux

-bash-4.2$ mkdir public_html

-bash-4.2$ echo "This is purple's website" > public_html/index.html 

-bash-4.2$ chmod -Rf 755 /home/linux

使用Apache服务部署静态网站2019-7-5

添加个人主页口令

1、先使用htpasswd命令生成密码数据库。-c参数表示第一次生成;后面在分别添加密码数据库的存放文件,以及验证要用到的用户名称。

[root@study ~]# htpasswd -c /etc/httpd/passwd linux
New password: 输入网页验证密码
Re-type new password:再输入一遍进行确认

Adding password for user linux

2、编辑个人用户主页功能的配置文件。把第31~40行的参数信息修改称下列内容,保存并退出配置文件,重启httpd服务程序即可生效。

31 <Directory "/home/*/public_html">
32 AllowOverride all
33 #刚刚生成出来的密码验证文件保存路径
34 authuserfile "/etc/httpd/passwd"
35 #当用户尝试访问个人用户网站时的提示信息
36 authname "My privately website"
37 authtype basic
38 #用户进行账户密码登录时需要验证的用户名称
39 require user linux
40 </Directory>

 使用Apache服务部署静态网站2019-7-5

 虚拟主机功能

虚拟主机功能,可以把一台处于运行状态的物理服务器分割成多个“虚拟的服 务器”Apache 的虚拟主机功能是服务器基于用户请求的不同 IP 地址、主机域名或端口号,实 现提供多个网站同时为外部提供访问服务的技术。

1、基于IP地址

第1步:添加IP

[root@study ~]# cd /etc/sysconfig/network-scripts/

[root@study network-scripts]# touch ifcfg-eno16777736:1 ifcfg-eno16777736:2

[root@study network-scripts]# cat ifcfg-eno16777736 >ifcfg-eno16777736:1

[root@study network-scripts]# cat ifcfg-eno16777736 >ifcfg-eno16777736:2

将这两个配置文件IP地址分别修改为192.168.218.139、192.168.218.140

重启网络服务、查看IP地址

[root@study network-scripts]# /etc/init.d/network restart
Restarting network (via systemctl): [ OK ]
[root@study network-scripts]# ip a
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft forever
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
2: eno16777736: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 00:0c:29:da:49:b1 brd ff:ff:ff:ff:ff:ff
inet 192.168.218.138/24 brd 192.168.218.255 scope global dynamic eno16777736
valid_lft 1803sec preferred_lft 1803sec
inet 192.168.218.140/24 brd 192.168.218.255 scope global secondary eno16777736:1
valid_lft forever preferred_lft forever
inet 192.168.218.139/24 brd 192.168.218.255 scope global secondary eno16777736:2
valid_lft forever preferred_lft forever
inet6 fe80::20c:29ff:feda:49b1/64 scope link
valid_lft forever preferred_lft forever

第2步:分别在/home/wwwroot 中创建用于保存不同网站数据的 3 个目录,并向其中分别写入网站的首页文件。

[root@study network-scripts]# mkdir -p /home/wwwroot/138 139 149

[root@study network-scripts]# echo "IP:192.168.138" > /home/wwwroot/138/index.html 

[root@study network-scripts]# echo "IP:192.168.139" > /home/wwwroot/139/index.html 

[root@study network-scripts]# echo "IP:192.168.140" > /home/wwwroot/140/index.html 

第3步:在 httpd 服务的配置文件中大约 113 行处开始,分别追加写入三个基于 IP 地址的虚 拟主机网站参数,然后保存并退出。

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

113 <VirtualHost 192.168.218.138>
114 DocumentRoot /home/wwwroot/138
115 ServerName www.purple.com
116 <Directory /home/wwwroot/138>
117 AllowOverride None
118 Require all granted
119 </Directory>
120 </VirtualHost>
121 <VirtualHost 192.168.218.139>
122 DocumentRoot /home/wwwroot/139
123 ServerName bbs.purple.com
124 <Directory /home/wwwroot/139>
125 AllowOverride None
126 Require all granted
127 </Directory>
128 </VirtualHost>
129 <VirtualHost 192.168.218.140>
130 DocumentRoot /home/wwwroot/140
131 ServerName www.purple.com
132 <Directory /home/wwwroot/140>
133 AllowOverride None
134 Require all granted
135 </Directory>
136 </VirtualHost>

[root@study ~]# systemctl restart httpd

在浏览器访问这3个IP

使用Apache服务部署静态网站2019-7-5

使用Apache服务部署静态网站2019-7-5

使用Apache服务部署静态网站2019-7-5

 基于主机域名

第1步:手动定义IP地址与域名之间的对应关系的配置文件,保存并退出后会立即生效。

通过PING来验证是否成功解析为IP地址

[root@study ~]# vim /etc/hosts

127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.218.138 www.purple.com bbs.purple.com blogs.purple.com

第2步:分别在/home/wwwroot中创建用于保存不同网站数据的三个目录,并向其中分 别写入网站的首页文件。

[root@study ~]# mkdir -p /home/wwwroot/www

[root@study ~]# mkdir -p /home/wwwroot/bbs

[root@study ~]# mkdir -p /home/wwwroot/blogs

[root@study ~]# echo "www.purple.com" > /home/wwwroot/www/index.html

[root@study ~]# echo "bbs.purple.com" > /home/wwwroot/bbs/index.html

[root@study ~]# echo "blogs.purple.com" > /home/wwwroot/blogs/index.html

第3步:在 httpd 服务的配置文件 113 行处开始,分别追加写入三个基于主机名的 虚拟主机网站参数,然后保存并退出。

113 <VirtualHost 192.168.218.138>
114 DocumentRoot /home/wwwroot/www
115 ServerName www.purple.com
116 <Directory /home/wwwroot/www>
117 AllowOverride None
118 Require all granted
119 </Directory>
120 </VirtualHost>
121 <VirtualHost 192.168.218.138>
122 DocumentRoot /home/wwwroot/bbs
123 ServerName bbs.purple.com
124 <Directory /home/wwwroot/bbs>
125 AllowOverride None
126 Require all granted
127 </Directory>
128 </VirtualHost>
129 <VirtualHost 192.168.218.138>
130 DocumentRoot /home/wwwroot/blogs
131 ServerName blogs.purple.com
132 <Directory /home/wwwroot/blogs>
133 AllowOverride None
134 Require all granted
135 </Directory>
136 </VirtualHost>

使用curl命令测试

[root@study ~]# systemctl restart httpd

[root@study ~]# curl www.purple.com
www.purple.com
[root@study ~]# curl bbs.purple.com
bbs.purple.com
[root@study ~]# curl blogs.purple.com
blogs.purple.com

 基于端口号

第1步:分别在/home/wwwroot中创建用于保存不同网站数据的两个目录,并向其中分别写入网站的首页文件。

[root@study ~]# mkdir -p /home/wwwroot/2345

[root@study ~]# mkdir -p /home/wwwroot/2346

[root@study ~]# echo "port:2345" > /home/wwwroot/2345/index.html
[root@study ~]# echo "port:2346" > /home/wwwroot/2346/index.html

第2步:在httpd服务配置文件的第43行和第44行分别添加用于监听2345和2346端口的参数。

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

43 Listen 2345
44 Listen 2346

第3步:在httpd服务的配置文件中大约113行开始,分别追加写入两个基于端口号的虚拟网站参数,然后保存退出。

<VirtualHost 192.168.218.138:2345>
 DocumentRoot "/home/wwwroot/2345"
 ServerName www.purple.com
 <Directory "/home/wwwroot/2345">
 AllowOverride None
 Require all granted
 </Directory>
 </VirtualHost>
 <VirtualHost 192.168.218.138:2346>
 DocumentRoot "/home/wwwroot/2346"
 ServerName www.purple.com
 <Directory "/home/wwwroot/2346">
 AllowOverride None
 Require all granted
 </Directory>

</Virtualhost>

[root@study ~]# systemctl restart httpd

使用Apache服务部署静态网站2019-7-5

使用Apache服务部署静态网站2019-7-5

Apache的访问控制

Apache可以基于源主机名、源IP地址或源主机上的浏览器特征等信息对网站上的资源进行访问控制。它通过Allow指令允许某个主机访问服务器上的网站资源,通过Deny指令实现禁止访问。在允许或禁止访问网站资源时,还会用到Order命令,这个指令用来定义Allow或Deny指令其作用的顺序,其匹配原则时按照顺序进行匹配,若匹配成功则执行后面的默认指令。

第1步:现在服务器上的网站数据目录中新建一个子目录,并在这个子目录中创建一个包含Successful单词的首页文件。

[root@study ~]# mkdir /var/www/html/server

[root@study ~]# echo "Successful" > /var/www/html/server/index.html

第2步:打开httpd服务的配置文件,在第129行后面添加规则来限制源主机的访问。这段规则的含义时允许使用Chrome浏览器的主机访问,除此之外所有请求都会被拒绝。

129 <Directory "/var/www/html/server">
130 SetEnvIf User-Agent "Chrome" ff=1
131 Order allow,deny
132 Allow from env=ff
133 </Directory>

[root@study ~]# systemctl restart httpd

使用Chrome浏览器访问。

使用Apache服务部署静态网站2019-7-5

使用QQ浏览器访问

使用Apache服务部署静态网站2019-7-5

 通过匹配IP地址进行访问控制,例如只允许IP地址为192.168.218.138的主机访问网站资源

在httpd配置文件第129行添加下列规则,

129 <Directory "/var/www/html/server">
130 Order allow,deny
131 Allow from 192.168.218.138
132 Order allow,deny
133 </Directory>

[root@study ~]# systemctl restart httpd

[root@study ~]# curl 192.168.218.138/server/
Successful

浏览器访问

使用Apache服务部署静态网站2019-7-5