网站运营人员对于死链这个概念一定不陌生,网站的一些数据删除或页面改版等都容易制造死链,影响用户体验不说,过多的死链还会影响到网站的整体权重或排名。

百度站长平台提供的死链提交工具,可将网站存在的死链(协议死链、404页面)进行提交,可快速删除死链,帮助网站SEO优化。在提交死链的文件中逐个手动填写死链的话太麻烦,工作中我们提倡复杂自动化,所以本文我们一起交流分享Apache服务中通过shell脚本整理网站死链,便于我们提交。

1.配置Apache记录搜索引擎

Apache是目前网站建设最为主流的web服务,但是apache的日志文件默认是不记录百度、谷歌等各大搜索引擎的爬取程序的,所以首先需要我们设置Apache的配置文件。

找到Apache的配置文件httpd.conf,在配置文件中找到下面两行:

CustomLog "logs/access_log" common
#CustomLog "logs/access_log" combined

默认采用的是common,这里我们只需要将common这一行前面加#注释掉,然后将combined这一行前的#去掉即可。然后保存重启Apache服务。

注:如果你的服务器上添加了多个站点,每个站点有单独的配置文件,则我们只需要在相应站点的配置文件中设置CustomLog项即可,例如:

vim /usr/local/apache/conf/vhost/www.chanzhi.org.conf

    ServerAdmin [email protected] DocumentRoot "/data/wwwroot/www.chanzhi.org"
ServerName www.chanzhi.org
ServerAlias chanzhi.org
ErrorLog "/data/wwwlogs/www.chanzhi.org_error_apache.log"
CustomLog "/data/wwwlogs/www.chanzhi.org_apache.log" combined SetOutputFilter DEFLATE
Options FollowSymLinks ExecCGI
Require all granted
AllowOverride All
Order allow,deny
Allow from all
DirectoryIndex index.html index.php

下面是配置前后的网站日志记录格式:

配置前:

配置后:

2.编写shell脚本

我们通过shell脚本获取网站日志中指定爬虫的抓取记录,然后汇总到一个文件中,便于后期使用。代码如下,比如保存为deathlink.sh

#!/bin/bash
#初始化变量
#定义蜘蛛UA信息(默认是百度蜘蛛)
UA='+http://www.baidu.com/search/spider.html' #前一天的日期(apache日志)
DATE=`date +%Y%m%d -d "1 day ago"` #定义日志路径
logfile=/data/wwwlogs/www.chanzhi.org_apache.log-${DATE}.log #定义死链文件存放路径
deathfile=/data/wwwroot/www.chanzhi.org/deathlink.txt #定义网站访问地址
website=http://www.chanzhi.org #分析日志并保存死链数据
for url in `awk -v str="${UA}" '$9=="404" && $15~str {print $7}' ${logfile}`
do
grep -q "$url" ${deathfile} || echo ${website}${url} >>${deathfile}
done
 

大家在使用该脚本时,根据自己服务器情况调整下路径和字段即可,然后执行脚本,:

bash deathlink.sh
 
3.提交死链

执行上面脚本时候,就会在指定目录下生成包含所有获取的404页面链接的文件,每个连接占一行。例如:

最后在站长平台提交死链页面中,填写自己的死链文件地址即可,例如:

百度在审核通过之后,会将已经收录的失效链接删除,以避免失效页面链接对网站造成不良的影响。

最新文章

  1. PowerDesigner修改生成mysql视图
  2. python学习之——调用adb命令完成移动端界面测试
  3. Jquery 查看DOM上绑定的事件列表
  4. JNI Java调用C代码 示例
  5. 在systemd(CentOS7)自启动zookeeper
  6. python socket.error: [Errno 10054] 解决方法
  7. IO 异常:The Network Adapter could not establish the connection 怎么解决
  8. Java之mybatis详解
  9. C#中MessageBox.Show问题(让提示窗口不显示在任务栏中)
  10. RC1015 cannot open include file 'atlres.h'
  11. Go指南练习_斐波纳契闭包
  12. [android] 帧动画和补间动画
  13. Kubernetes并发控制与数据一致性的实现原理
  14. [R]Kick start
  15. Ubuntu16.04 释放/boot目录空间
  16. ASP.NET Web Pages:C# 和 VB 实例
  17. mysql,存储引擎,事务,锁,慢查询,执行计划分析,sql优化
  18. UNIX环境高级编程 第14章 高级I/O
  19. STM8S AD转换
  20. Javascript获取当月的天数

热门文章

  1. spring-boot 速成(7) 集成dubbo
  2. Complete uninstall on Mac, HELP!
  3. HDU 1075 What Are You Talking About (strings)
  4. jeffy-vim-v3.2
  5. 在ASP.NET MVC下限制同一个IP地址单位时间间隔内的请求次数
  6. ASP.NET MVC异步验证是如何工作的02,异步验证表单元素的创建
  7. ASP.NET Web API实践系列02,在MVC4下的一个实例, 包含EF Code First,依赖注入, Bootstrap等
  8. iOS 获取本地视频的缩略图
  9. Eclipse 进入代码定位文件位置
  10. 异步图片下载引擎(升级版——ExecutorService+handler)