zoukankan      html  css  js  c++  java
  • 利用shell脚本批量提交网站404死链给百度

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

     百度站长平台提供的死链提交工具,可将网站存在的死链(协议死链、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脚本

    我们通过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死链

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

  • 相关阅读:
    liunx 利用管道线kill多个进程
    将多个学生平均分配到多个学校的方法示例
    mysql 根据查询条件进行update
    Mysql 使用临时表比较数据差异以及 临时表的优化
    Netcore 将汉字转化为拼音
    mysql 清除多列重复数据,只保留其中一条
    使用Mysql 存储过程和游标进行同步数据
    Culture is not supported. (Parameter 'name') u0002� is an invalid culture identifier.
    Swagger 过滤特定控制器配置方法(Swashbuckle.AspNetCore 5.0.0)
    System.Linq Distinct 方法使用
  • 原文地址:https://www.cnblogs.com/linuxprobe/p/9750888.html
Copyright © 2011-2022 走看看