设为首页 收藏本站
查看: 1009|回复: 0

[经验分享] Apache下通过shell脚本提交网站404死链

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2017-12-24 19:36:32 | 显示全部楼层 |阅读模式
  网站运营人员对于死链这个概念一定不陌生,网站的一些数据删除或页面改版等都容易制造死链,影响用户体验不说,过多的死链还会影响到网站的整体权重或排名。
  百度站长平台提供的死链提交工具,可将网站存在的死链(协议死链、404页面)进行提交,可快速删除死链,帮助网站SEO优化。在提交死链的文件中逐个手动填写死链的话太麻烦,工作中我们提倡复杂自动化,所以本文我们一起交流分享Apache服务中通过shell脚本整理网站死链,便于我们提交。
DSC0000.png


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
  

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

  配置后:
DSC0002.png


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

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

  

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

总结:
  本文和大家分享了在Apache服务环境下,如何利用shell脚本自动获取百度蜘蛛等爬虫抓取的死链,并生成汇总文件提交给搜索引擎。如果大家还有其他更好的方法或者疑问,欢迎一起分享交流。
  


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-427612-1-1.html 上篇帖子: Spring Boot常见问题(二)Unable to start embedded container; nested exception is java.l 下篇帖子: wamp 3.0.6(apache 2.4.23) 403 forbidden 解决办法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表