Web服务基础七之Apache日志文件管理、默认网站目录更改、防止php木马跨站设置、禁止空主机头

简介:

Apache按天生成日志文件:

apache默认日志文件就一个,时间长了日子文件会变得很大,而且查看时候打开也会很慢,有可能还会影响网站速度,以下演练如何实现日志按天生成文件

1
2
3
4
5
6
7
[root@justin htdocs] # vim /etc/httpd/conf/httpd.conf
  484  #ErrorLog logs/error_log  --错误日志,注释此行,添加以下一行
  485 ErrorLog  "|rotatelogs /var/log/httpd/error_log%Y%m%d.log 86400 480"    --86400:秒,24小时,表示生成的日志文件按天滚动,也就是每天生成一个日志文件;480:分,时间偏移。
......
  513  #CustomLog logs/access_log common  --访问日志,注释此行,添加以下一行
  514 CustomLog  "|rotatelogs /var/log/httpd/access_log%Y%m%d.log 86400 480"  common
[root@justin htdocs] # service httpd restart

Rotatelogs的用法如下:

rotatelogs [ -l ] rotatelogs [ -l ] logfile[ rotationtime [ offset ]] | [ filesizeM ]

该命令只有两种选项用以对日志文件logfile进行操作,第一种,rotationtime   日志文件以秒为单位滚动,第二种, filesizeM   指定以filesizeM文件大小滚动,而不是按照时间或时差滚动

选项:

-l    使用本地时间代替GMT时间作为时间基准。

logfile    日志文件名

rotationtime     日志文件以秒为单位滚动,如ErrorLog "|/data/apache/bin/rotatelogs /var/log/httpd/error_log%Y%m%d.log 86400 480"

offset    相对于UTC的时差的分钟数。-l  和offset都是和时区相关的,可不理会

filesizeM    指定以文件大小滚动,如ErrorLog "|/data/apache/bin/rotatelogs /var/log/httpd/access_log%Y%m%d.log 5M"此配置会在错误日志大小增长到5兆字节时滚动该日志,

文件名格式对照表

%A 星期名全称(本地的)
%a 3个字符的星期名(本地的)
%B 月份名的全称(本地的)
%b 3个字符的月份名(本地的)
%c 日期和时间(本地的)
%d 2位数的一个月中的日期数
%H 2位数的小时数(24小时制)
%I 2位数的小时数(12小时制)
%j 3位数的一年中的日期数
%M 2位数的分钟数
%m 2位数的月份数
%p am/pm12小时制的上下午(本地的)
%S 2位数的秒数
%U 2位数的一年中的星期数(星期天为一周的第一天)
%W 2位数的一年中的星期数(星期一为一周的第一天)
%w 1位数的星期几(星期天为一周的第一天)
%X 时间(本地的)
%x 日期(本地的)
%Y 4位数的年份
%y 2位数的年份
%Z 时区名
%% 符号"%"本身

定期删除日志文件:

用crontab删除日志文件,只保留近7天的文件,以免日志文件占满磁盘空间。

1
2
3
4
5
6
[root@justin htdocs]# crontab -e
no crontab  for  root - using an empty one
0  3  * *  7  /bin/find / var /log/httpd/ -type f -mtime + 7  -name  "*.log"  -exec rm {} \;
[root@justin htdocs]# crontab -l
0  3  * *  7  /bin/find / var /log/httpd/ -type f -mtime + 7  -name  "*.log"  -exec rm {} \;
[root@justin htdocs]#



Apache默认网站目录更改


Apache默认的网站目录是在/var/www/html,现在要把网站目录更到/usr/local/apache/htdocs

1
2
3
4
5
6
7
8
9
10
[root@justin ~] # mkdir -p /usr/local/apache/htdocs/
[root@justin ~] # vim /etc/httpd/conf/httpd.conf
  292 DocumentRoot  "/usr/local/apache/htdocs"
  317 <Directory  "/usr/local/apache/htdocs" >
[root@justin ~] # service httpd restart
[root@justin ~] # ll -d /usr/local/apache/htdocs/
drwxr-x--- 2 apache apache 4096 Mar  6 10:43  /usr/local/apache/htdocs/
[root@justin ~] # chmod 755 !$
chmod  755  /usr/local/apache/htdocs/
[root@justin ~] #

防止php木马跨站设置

在Apache服务器中,切忌一定要在虚拟主机配置文件中添加以下代码,否则PHP木马脚本可以浏览你服务器上的任意文件,这意味着你的服务器很快会被攻破。

1
2
3
4
5
6
7
8
9
10
[root@justin ~]# vim /etc/httpd/conf/httpd.conf
1002  #<VirtualHost *: 80 >
1003  php_admin_value open_basedir  "/usr/local/apache/htdocs/:/tmp/"
1004  #    ServerAdmin webmaster@dummy-host.example.com
1005  #    DocumentRoot /www/docs/dummy-host.example.com
1006  #    ServerName dummy-host.example.com
1007  #    ErrorLog logs/dummy-host.example.com-error_log
1008  #    CustomLog logs/dummy-host.example.com-access_log common
1009  #</VirtualHost>
[root@justin ~]# service httpd restart

/usr/local/apache/htdocs/为网站目录,如果vhost.conf[/etc/httpd/conf.d/vhost.conf]中设置了open_basedir之后, 虚拟用户就不会再自动继承php.ini中的open_basedir设置值了,这就难以达到灵活的配置措施, 所以建议不要在/etc/httpd/conf.d/vhost.conf

中设置此项限制。可以在php.ini中设置open_basedir = .:/tmp/;这个设置表示允许访问当前目录(即PHP脚本文件所在之目录)和/tmp/目录,有效防止php木马跨站运行。


禁止空主机头

为了防止域名解析恶意指向,需要禁止apache默认的空主机头

1
2
3
4
5
6
7
[root@justin ~] # vim /etc/httpd/conf/httpd.conf
NameVirtualHost *
       <VirtualHost *:80>
     ServerAdmin yourmail@mail.com
     DocumentRoot  /error
     ServerName abc.com
< /VirtualHost >

1
2
3
4
5
6
<VirtualHost *: 80 >
     ServerAdmin yourmail@mail.com
     DocumentRoot  "你的站点路径"
     ServerName yourWebsite.com
     ServerAlias *.yourWebsite.com
</VirtualHost>

第一部分是需要添加的,第二部分是使用的站点配置




本文转自 justin_peng 51CTO博客,原文链接:http://blog.51cto.com/ityunwei2017/1369871,如需转载请自行联系原作者

相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
相关文章
|
8月前
|
数据采集 人工智能 程序员
PHP 程序员如何为 AI 浏览器(如 ChatGPT Atlas)优化网站
OpenAI推出ChatGPT Atlas,标志AI浏览器新方向。虽未颠覆现有格局,但为开发者带来新机遇。PHP建站者需关注AI爬虫抓取特性,优化技术结构(如SSR、Schema标记)、提升内容可读性与语义清晰度,并考虑未来agent调用能力。通过robots.txt授权、结构化数据、内容集群与性能优化,提升网站在AI搜索中的可见性与引用机会,提前布局AI驱动的流量新格局。
464 8
|
前端开发 关系型数据库 MySQL
PHP外链网盘系统网站源码
> 本文将详细介绍如何从零构建一个基于PHP和MySQL的文件管理系统,分解项目代码并剖析每个模块的功能。我们将以`index.php`、`config.php`和`api.php`这三个核心文件为例,详细展示如何设计文件列表、数据库配置和文件上传接口,从而实现一个完整的文件管理系统。该文章可以作为学术研究和代码实现的参考。
625 98
|
关系型数据库 MySQL PHP
免登录游客卡密发放系统PHP网站源码
这是一个简单易用的卡密验证系统,主要功能包括: 卡密管理和验证,多模板支持,响应式设计,验证码保护,防刷机制,简洁的用户界面, 支持自定义模板,移动端优化,安全性保护,易于部署和维护。
1089 77
|
存储 JSON Go
PHP 日志系统的最佳搭档:一个 Go 写的远程日志收集服务
为了不再 SSH 上去翻日志,我写了个 Go 小脚本,用来接收远程日志。PHP 负责记录日志,Go 负责存储和展示,按天存储、支持 API 访问、可远程管理,终于能第一时间知道项目炸了。
369 10
|
存储 监控 算法
基于 PHP 语言的滑动窗口频率统计算法在公司局域网监控电脑日志分析中的应用研究
在当代企业网络架构中,公司局域网监控电脑系统需实时处理海量终端设备产生的连接日志。每台设备平均每分钟生成 3 至 5 条网络请求记录,这对监控系统的数据处理能力提出了极高要求。传统关系型数据库在应对这种高频写入场景时,性能往往难以令人满意。故而,引入特定的内存数据结构与优化算法成为必然选择。
369 3
|
PHP
2025简约的打赏系统PHP网站源码
2025简约的打赏系统PHP网站源码
445 20
|
JSON API Go
基于责任链与策略模式的轻量级PHP日志库设计
项目日志乱成一团,bug 时好时坏,服务器问题难以复现?我写了个 PHP 日志系统,第一时间发现问题,避免跑路。实现了责任链模式+策略模式,让日志存储更灵活,支持多种输出方式。
|
安全 大数据 数据挖掘
课时9:阿里云Web应用防火墙:全面保障网站的安全与可用性
阿里云Web应用防火墙(WAF)基于阿里巴巴十年攻防经验,提供全面的网站安全防护。它通过Web应用防护、CC攻击防护和业务风控,有效应对各类网络威胁,确保网站的安全与可用性。智能双引擎技术降低误报率,实时数据分析和虚拟补丁更新保障系统安全。WAF已成功护航多个重大活动,为企业提供高效、简便的安全解决方案。
501 0
|
8月前
|
算法 Java Go
【GoGin】(1)上手Go Gin 基于Go语言开发的Web框架,本文介绍了各种路由的配置信息;包含各场景下请求参数的基本传入接收
gin 框架中采用的路优酷是基于httprouter做的是一个高性能的 HTTP 请求路由器,适用于 Go 语言。它的设计目标是提供高效的路由匹配和低内存占用,特别适合需要高性能和简单路由的应用场景。
625 4
|
缓存 JavaScript 前端开发
鸿蒙5开发宝藏案例分享---Web开发优化案例分享
本文深入解读鸿蒙官方文档中的 `ArkWeb` 性能优化技巧,从预启动进程到预渲染,涵盖预下载、预连接、预取POST等八大优化策略。通过代码示例详解如何提升Web页面加载速度,助你打造流畅的HarmonyOS应用体验。内容实用,按需选用,让H5页面快到飞起!