博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
利用shell脚本批量提交网站404死链给百度
阅读量:5964 次
发布时间:2019-06-19

本文共 1832 字,大约阅读时间需要 6 分钟。

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

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

 如何在Apache中用shell脚本提交网站404死链如何在Apache中用shell脚本提交网站404死链

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

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

配置前:

如何在Apache中用shell脚本提交网站404死链如何在Apache中用shell脚本提交网站404死链

配置后:

如何在Apache中用shell脚本提交网站404死链如何在Apache中用shell脚本提交网站404死链

2.编写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页面链接的文件,每个连接占一行。例如:

如何在Apache中用shell脚本提交网站404死链如何在Apache中用shell脚本提交网站404死链

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

如何在Apache中用shell脚本提交网站404死链如何在Apache中用shell脚本提交网站404死链

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

转载地址:http://hztax.baihongyu.com/

你可能感兴趣的文章
HDU1848 Fibonacci again and again
查看>>
HTML思维导图
查看>>
office2016选择性安装
查看>>
C# 自定义控件入门
查看>>
git改密码出现授权问题
查看>>
Hadoop IO 特性详解(2)
查看>>
ORA-02266: 表中的唯一/主键被启用的外键引用
查看>>
MySQL类型转换 使用CAST将varchar转换成int类型排序
查看>>
Django的POST请求时因为开启防止csrf,报403错误,及四种解决方法
查看>>
Apache common-fileupload用户指南
查看>>
day-6 and day-7:面向对象
查看>>
IE维护(IEM)策略不再适用于IE10及后续IE版本
查看>>
Java7中的ForkJoin并发框架初探(下)—— ForkJoin的应用
查看>>
java中的重量级与轻量级概念
查看>>
Linux设备驱动工程师之路——硬件访问及混杂设备LED驱动
查看>>
进程和线程<一>
查看>>
远程算数程序——版本v1.0
查看>>
Mysql常见四种索引的使用
查看>>
说说Android桌面(Launcher应用)背后的故事(一)——揭开她神秘的面纱
查看>>
第一篇:zc706 开箱及开发环境搭建
查看>>