第四十四天-Apache虚拟主机测试
一、虚拟机主机简介
部署多个站点,每个站点,希望用不同的域名和站点目录,或者是不同的端口,或不同的ip,就需要虚拟主机功能。简单的说一个http服务要配置多个站点,就需要虚拟主机。
二、虚拟主机分类
- 基于域名
- 基于端口
- 基于ip
所谓的基于XX,就是靠XX来区分不同的站点,支持各种混合,N多个虚拟主机。
三、基于域名虚拟主机实例
域名 站点
www.lrz.com /var/html/www
blog.lrz.com /var/html/blog
bbs.lrz.com /var/html/bbs
1、准备工作,创建虚拟主机目录
[root@A extra]# mkdir -p /var/html/{www,blog,bbs}
[root@A extra]# touch /var/html/{www,blog,bbs}/index.html
[root@A www]# for name in www blog bbs ;do echo "http://$name.oldboy.com" >/var/html/$name/index.html;done
[root@A www]# for name in www blog bbs ;do cat /var/html/$name/index.html;done
http://www.oldboy.com
http://blog.oldboy.com
http://bbs.oldboy.com
2、修改配置文件
[root@A conf]# grep ^Include httpd.conf
Include conf/extra/httpd-vhosts.conf #打开加载,加载虚拟主机配置文件
[root@A extra]# vim httpd-vhosts.conf
<VirtualHost *:80>
ServerAdmin 1126785053@qq.com #配置管理员邮箱
DocumentRoot "/var/html/www" #配置虚拟主机目录
ServerName www.lrz.com #配置域名
ErrorLog "logs/www-error_log" #配置错误日志路径
CustomLog "logs/www-access_log" common #配置访问日志路径
</VirtualHost>
<VirtualHost *:80>
ServerAdmin 1126785053@qq.com
DocumentRoot "/var/html/blog"
ServerName blog.lrz.com
ErrorLog "logs/blog-error_log"
CustomLog "logs/blog-access_log" common
</VirtualHost>
<VirtualHost *:80>
ServerAdmin 1126785053@qq.com
DocumentRoot "/var/html/bbs"
ServerName bbs.lrz.com
ErrorLog "logs/bbs-error_log"
CustomLog "logs/bbs-access_log" common
</VirtualHost>
<Directory /var/html>
Options FollowSymLinks #FollowSymLinks表示禁止使用符号链接,Indexes表示允许目录浏览
AllowOverride None #表示禁止用户对目录配置文件(.htaccess进行修改)重载
Order allow,deny #以allow优先处理,没有明确说明允许的话都将拒绝访问
allow from all #允许所有的访问
</Directory>
3、修改hosts 文件
xiaorui@xiaorui:~$ cat /etc/hosts
127.0.0.1 localhost
192.168.1.113 www.lrz.com
192.168.1.113 blog.lrz.com
192.168.1.113 bbs.lrz.com
4、优雅启动apache
[root@A apache]# bin/apachectl graceful
httpd: Could not reliably determine the server's fully qualified domain name, using 192.168.1.110 for ServerName
解决办法:
将httpd.conf 里第99行,修改ServerName 127.0.0.1:80
[root@A apache]# bin/apachectl graceful
[root@A apache]#
再启动就不报错误了
提示:这里的graceful参数,而不是restart参数,graceful表示优雅重启,这个参数可以在重启时使正在浏览的访问的用户无感知,即重启时不会强行中断用户访问,而是处理完毕请求后再重新启动,这个graceful参数在生产环境中那是非常重要,请在重启时务必使用之代替restart参数。
5、Apache日志格式详细说明
通用日志格式(CommonLog Format)
组合日志格式(CombinedLOG Format)
6、Apache的日志轮询
安装日志轮询工具cronolog
cd tools/
wget http://cronolog.org/download/cronolog-1.6.2.tar.gz
tar xf cronolog-1.6.2.tar.gz
cd cronolog-1.6.2
./configure
make
make install
cd /usr/local/sbin/
pwd
生成的命令
[root@A sbin]# ll /usr/local/sbin/
总用量 52
-rwxr-xr-x. 1 root root 40446 1月 10 04:40 cronolog
-rwxr-xr-x. 1 root root 9673 1月 10 04:40 cronosplit
提示:cronolog轮询日志的正确写法,被轮询的日志路径要写全路径
这是大多数网站的常规配置方法(按天记录日志,日志不会自动覆盖)
修改配置文件日志
<VirtualHost *:80>
ServerAdmin 1126785053@qq.com
DocumentRoot "/var/html/www"
ServerName www.lrz.com
ErrorLog "|/usr/local/sbin/cronolog /application/apache/logs/www-error_%Y%m%d.log"
CustomLog "|/usr/local/sbin/cronolog /application/apache/logs/www-access_%Y%m%d.log" combined
</VirtualHost>
[root@A logs]# ls -lh
总用量 56K
srwx------. 1 www root 0 1月 10 05:01 cgisock.1548
-rw-r--r--. 1 root root 5 1月 10 05:01 httpd.pid
-rw-r--r--. 1 root root 938 1月 10 05:02 www-access_20160110.log
-rw-r--r--. 1 root root 99 1月 10 05:02 www-error_20160110.log
四、案例
案例1:apache不记录图片的日志
答:因为统计日志PV时一个页面才算一个PV,而图片,JS,CSS等只是图片的元素,如果记录在日志里,然后按日志行进行计算PV就不准确了,所以可以考虑不记录图片等日志。
<FilesMatch "\.(css|js|gif|jpg|ico|swf)">
setEnv IMAG 1
</FilesMatch>
CustomLog "|/usr/local/sbin/cronolog /application/apache/logs/www-access_%Y%m%d.log" combined env=!IMAG
案例2:RS服务器不记录负载均衡健康检查日志
虚拟主机不记录负载均衡向下健康检查文件的日志(check.txt)
SetEnvIf Request_URI "^/check\.txt$" dontlog
CustomLog "|/usr/local/sbin/cronolog /application/apache/logs/www-access_%Y%m%d.log" combined env=!dontlog
案例3:日志统计
[root@server4host nginx]# awk '{print $1}' access.log-20160110|sort|uniq -c|sort -rn |head -10
23220 61.172.242.213
21555 61.172.242.219
20736 123.135.52.66
18403 61.172.242.212
18403 61.172.242.210
17308 61.172.242.214
17059 61.172.242.218
16111 61.172.242.222
15540 61.172.242.216
14414 61.172.242.215
[root@server4host nginx]# awk '{++S[$1]} END {for(key in S) print S[key],key}' access.log-20160111|sort -rn -k1|head -10
162216 5.9.83.211
41546 88.198.180.41
37858 115.29.178.56
24147 61.172.242.213
22794 61.172.242.214
19257 61.172.242.218
18371 61.172.242.222
18283 61.172.242.219
16434 123.135.52.66
16311 61.172.242.215