Apache虚拟主机和日志分割
一.访问主机服务的本质
访问web服务,本质上看(从协议上)是访问某个IP的主机上的某个端口(默认是8O),通常需要通过访问不同的域名或者端口,实现对不同网站的访问(具体到服务器里就是不同目录),这个时候就需要设置网站空间。通常分为3种:基于域名、基于端口、基于IP以及它们的混合。
简单来说,Apache虚拟主机就是在一个Apache服务器上配置多个虚拟空间,实现一个服务器提供多站点服务,其实就是访问同一个服务器上的不同目录。
同时在同一台服务器中运行多个web站点,其中每一个站点并不独立占用一台真正的计算机通过虚拟web主机可以充分利用服务器的硬件资源,从而大大降低网站构建及运行成本。
使用httpd可以非常方便的构建虚拟主机服务器,只需要运行一个httpd服务就能够同时支撑大量的web站点。
二.Apache支持的虚拟主机类型
1.基于域名
① 为每个虚拟主机使用不同的域名,但是其对应的IP地址是相同的
② 域名不同,IP相同,端口相同
③ 基于域名是最为普遍的虚拟web主机类型
2.基于IP地址
① 为每个虚拟主机使用不同的域名,且各自对应的IP地址也不相同
② 这种方式需要为服务器配备多个网络接口(加网卡,虚拟网卡),因此应用不是很广泛
③ IP不同,端口相同
3.基于端口
① 这种方式并不使用域名,IP地址来区分不同的站点内容,而是使用不同的TCP端口号
② 因此用户在浏览不同的虚拟站点时需要同时制定端口号才能访问
③ IP相同,端口不同
三.基于域名访问虚拟主机
1.为虚拟主机提供域名解析
在 /etc/hosts 文件中配置域名与IP 地址的映射关系
[root@localhost ~]# vim /etc/hosts
2.为虚拟主机准备网页文档
[root@localhost ~]# mkdir -p /var/www/html/wudi
[root@localhost ~]# mkdir -p /var/www/html/jimo
[root@localhost ~]# cd /var/www/html
[root@localhost html]# ls
jimo wudi
[root@localhost html]# cd wudi/
[root@localhost wudi]# ls
[root@localhost wudi]# vim index.html
[root@localhost wudi]# cd ..
[root@localhost html]# cd jimo/
[root@localhost jimo]# vim index.html
[root@localhost jimo]# cat /var/www/html/wudi/index.html
<h1>www.wudi.com</h1>
[root@localhost jimo]# cat /var/www/html/jimo/index.html
<h1>www.jimo.com</h1>
[root@localhost jimo]#
3.添加虚拟主机配置
[root@localhost ~]# vim /usr/local/httpd/conf/extra/httpd-vhosts.conf
模板参数说明
<VirtualHost *:80> #设置虚拟站点区域
ServerAdmin webmaster@dummy-host.example.com #设置管理员邮箱,这行可注释掉
DocumentRoot "/usr/local/httpd/docs/dummy-host.example.com" #设置网站根目录
ServerName dummy-host.example.com #设置Web站点的完整域名(主机名+域名)
ServerAlias www.dummy-host.example.com
ErrorLog "logs/dummy-host.example.com-error_log" #设置错误日志文件的路径
CustomLog "logs/dummy-host.example.com-access_log" common #设置访问日志文件的路径
</VirtualHost> #结束标签
combined 表示组合日志
common表示通用日志
4.加载独立扩展的配置文件
[root@localhost ~]# vim /usr/local/httpd/conf/httpd.conf
5.检查语法
[root@localhost ~]# httpd -t
Syntax OK
6.重启服务
[root@localhost ~]# systemctl restart httpd
7.网页验证
访问www.wudi.com
访问www.jimo.com
四.基于IP地址访问虚拟主机
1.创建虚拟网卡
[root@localhost ~]# ifconfig ens33:0 192.168.206.100 netmask 255.255.255.0
[root@localhost ~]# ifconfig
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.206.7 netmask 255.255.255.0 broadcast 192.168.206.255
ether 00:0c:29:f7:67:91 txqueuelen 1000 (Ethernet)
RX packets 1028109 bytes 1287145388 (1.1 GiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 366372 bytes 24585739 (23.4 MiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
ens33:0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.206.100 netmask 255.255.255.0 broadcast 192.168.206.255
ether 00:0c:29:f7:67:91 txqueuelen 1000 (Ethernet)
lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536
inet 127.0.0.1 netmask 255.0.0.0
inet6 ::1 prefixlen 128 scopeid 0x10<host>
loop txqueuelen 1000 (Local Loopback)
RX packets 86837 bytes 7425043 (7.0 MiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 86837 bytes 7425043 (7.0 MiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
virbr0: flags=4099<UP,BROADCAST,MULTICAST> mtu 1500
inet 192.168.122.1 netmask 255.255.255.0 broadcast 192.168.122.255
ether 52:54:00:b5:13:98 txqueuelen 1000 (Ethernet)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
2.修改虚拟主机配置文件
[root@localhost ~]# vim /usr/local/httpd/conf/extra/httpd-vhosts.conf
[root@localhost ~]# vim /usr/local/httpd/conf/httpd.conf
3.重启服务并进行网页验证
[root@localhost ~]# httpd -t
Syntax OK
[root@localhost ~]# systemctl stop httpd
[root@localhost ~]# systemctl start httpd
[root@localhost ~]# netstat -antp | grep httpd
tcp 0 0 192.168.206.100:80 0.0.0.0:* LISTEN 122570/httpd
tcp 0 0 192.168.206.7:80 0.0.0.0:* LISTEN 122570/httpd
网页访问192.168.206.7
网页访问192168.206.100
五.基于端口访问虚拟主机
1.修改配置文件修改端口
[root@localhost ~]# vim /usr/local/httpd/conf/extra/httpd-vhosts.conf
[root@localhost ~]# vim /usr/local/httpd/conf/httpd.conf
2.重启服务网页验证
[root@localhost ~]# httpd -t
Syntax OK
[root@localhost ~]# systemctl restart httpd
[root@localhost ~]# netstat -antp | grep httpd
tcp 0 0 192.168.206.7:8080 0.0.0.0:* LISTEN 123013/httpd
tcp 0 0 192.168.206.7:80 0.0.0.0:* LISTEN 123013/httpd
网页访问192.168.206.7:80
网页访问192.168.206.7:8080
六.Apache连接保持
为什么要保持连接
HTTP协议是基于TCP协议之上的,在进行HTTP连接之前,要先进行TCP连接,每个TCP连接都要进行三次握手与四次挥手。建立与关闭连接对于HTTP协议而言会消耗很多的内存与CPU资源。
解决办法是HTTP连接保持。就是尽量地保持客户端的连接,通过一个TCP连接传送多个HTTP请求响应,对于客户端可以提高50%以上的响应时间,对于服务器可以降低建立与关闭连接时的资源消耗。
[root@localhost ~]# vim /usr/local/httpd/conf/extra/httpd-default.conf
说明:
KeepAlive On:设置是否打开连接保持功能,后面接OFF表示关闭,接On表示打开。可以根据网站的并发请求量决定是否打开,即在高并发时打开连接保持功能,并发量不高时关闭此功能。
MaxKeepAliveRequests 100:用于设置在一次长连接中可以传输的最大请求数量,超过此最大请求数量就会断开连接,最大值的设置决定于网站中网页的内容,一般设置数量会多于网站中所有的元素。
KeepAliveTimeout 5 ##保持长时间连接的间隔时间:设置来自同一个客户端一次连接多次请求之间的最大间隔时间,即两次请求之间超过该时间连接就会自动断开,从而避免客户端占用连接资源。
七.Apache日志分割
1.修改配置文件日志相关配置
[root@localhost ~]# vim /usr/local/httpd/conf/httpd.conf
说明:
-l:表示使用本地时间
/error_log:日志名称
%Y-%m-%d:年-月-日
86400:表示日志分隔的间隔是1天,单位是秒
2.检查语法重启服务
[root@localhost ~]# httpd -t
Syntax OK
[root@localhost ~]# systemctl stop httpd
[root@localhost ~]# systemctl start httpd
[root@localhost ~]# netstat -antp | grep httpd
tcp 0 0 192.168.206.7:8080 0.0.0.0:* LISTEN 124200/httpd
tcp 0 0 192.168.206.7:80 0.0.0.0:* LISTEN 124200/httpd
[root@localhost ~]#
3.查看日志
[root@localhost ~]# cd /var/log/httpd/
[root@localhost httpd]# ls
error_log_20210703.log
4.修改系统时间查看
[root@localhost httpd]# date -s 20210704
2021年 07月 04日 星期日 00:00:00 CST
[root@localhost httpd]# ls
error_log_20210703.log
[root@localhost httpd]# systemctl restart httpd
[root@localhost httpd]# ls
error_log_20210703.log error_log_20210704.log
5.日志的消息级别
编号越小越紧急
0 EMERG:紧急,又称疼痛级别;会导致主机系统不可用的情况
1 ALERT:警告;必须马上采取措施解决问题
2 CRIT:临界值,严重;比较严重的情况
3 ERR:错误;运行出现错误
4 WARNING:提醒;提醒但不影响程序运行
5 NOTICE:注意;不会影响系统单值得注意
6 INFO:信息;一般信息
7 DEBUG:调试;程序或系统调试信息等
6.日志的作用
日志的基本职能
(1)用于记录日志类型(包括访问日志,错误日志,二进制,中继日志)的基本信息
(2)根据需求获取想要的信息
① error.log :错误日志,记录的重点是故障报错、异常的内容。可以用于故障定位。
② access.log:访问日志,能够记录查询来访的IP
(3)日志恢复,基于日志内容对文件数据进行恢复
八.总结
主要介绍了Apache的虚拟主机(基于域名访问的虚拟主机,基于IP地址访问的虚拟主机,基于不同端口访问的虚拟主机)还有日志分割。