PHP每15分钟自动更新网站地图(减少服务器消耗)

最近在弄一个短网址,自己写的代码。锻炼一下自己。在做html网站地图这块,想着把所有生成的短连接都展示出来,方便收录。就写了一个sitemap.php,后来发现,如果以后人流量大或者数据过多的话,服务器负担就会特别重,假如有10w条数据,每个人访问的时候都会从数据库索引这10w条数据,一秒钟有100个人访问,服务器根本负担不过来。然后就萌生了生成html地图这个想法。

由于学艺不精,可能思路上有些不对的。希望有更好思路能够批评指正!

原理:

需要三个文件:

sitemap.html (这个文件为系统自动生成,sitemap.php的克隆版)

sitemap.php (主要页面,决定页面的样式等,完全=sitemap.html)

timeSitemap.php (为更新程序,生成html页面。可在监控宝设置监控。)

sitemap.php为页面文件,sitemap.html为sitemap.php的克隆版,监控宝设置定时监控timeSitemap.php文件,实现每15分钟生成网站地图,当然,频率是按照监控宝的监控频率来决定,如果地图生成失败,会返回404,监控宝会报警。sitemap.xml同理

下面共享代码(用使用的mysql查询等类为自己简单封装的数据库类,这里就不展示了):

sitemap.php

  1. <?php
  2. /*
  3. @ sitemap html版地图
  4. */
  5. // 引入数据库操作类
  6. require_once 'c/class.class.php';
  7. // 引入系统参数
  8. $config = require 'c/config.php';
  9. ?>
  10. <html>
  11. <head>
  12. <meta charset="utf-8">
  13. <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
  14. <title>网站地图 - <?php echo $config['web_title']; ?></title>
  15. <meta name="keywords" content="<?php echo $config['web_keywords'];?>">
  16. <meta name="description" content="<?php echo $config['web_description']; ?>">
  17. <link href="<?php //echo $config['web_url'];?>/css/bootstrap.min.css" rel='stylesheet' type='text/css'>
  18. <!--
  19. <link href="<?php //echo $config['web_url'];?>/css/style.css" rel='stylesheet' type='text/css'>
  20. <link href="<?php //echo $config['web_url'];?>/css/media.css" rel='stylesheet' type='text/css'>
  21. <script src="<?php //echo $config['web_url'];?>/css/jquery-3.1.1.min.js"></script>
  22. -->
  23. <link type="favicon" rel="shortcut icon" href="<?php //echo $config['web_url'];?>/favicon.ico" />
  24. <link type="favicon" rel="icon" href="<?php //echo $config['web_url'];?>/favicon.ico" />
  25. <style>
  26. .table tr {
  27. text-align: center;
  28. }
  29. a {
  30. display: inline-block;
  31. padding: 10px;
  32. }
  33. </style>
  34. </head>
  35. <body>
  36. <!--先提示-->
  37. <?php
  38. // <!-- 取出所有短网址 -->
  39. $cons = new con();
  40. $consSql = "select * from urls order by id desc";
  41. $consQuery = $cons->query($consSql);
  42. // >> 总数量
  43. $consNum = mysql_num_rows($consQuery);
  44. ?>
  45. <div class="container">
  46. <!--<table class="table table-striped table-bordered table-hover table-condensed">-->
  47. <hr>
  48. <div >
  49. 共<?php echo $consNum; ?>条数据</div><div >本页面每15分钟更新一次
  50. </div>
  51. </hr>
  52. 本站链接:<a href="http://bba.fun">bba.fun短网址</a><a href="http://bba.fun/page/api">api接口</a><a href="http://bba.fun/sitemap.html">网站地图</a>
  53. <br>
  54. 生成链接:
  55. <br>
  56. <?php
  57. // >> 显示总数量
  58. echo "";
  59. // >> 开始循环取出
  60. while($rows = mysql_fetch_array($consQuery)){
  61. echo "<a href='{$rows['short_url']}' target='_blank' rel='external nofollow'>".$rows['short_url']."</a>";
  62. }
  63. ?>
  64. <!--</table>-->
  65. <div >2017© <a href="<?php echo $config['web_url'];?>"><?php echo $config['web_title']; ?></a></div><hr>
  66. </div>
  67. </body>
  68. </html>

timeSitemap.php

  1. <?php
  2. /*
  3. @ 定时更新网站地图
  4. */
  5. // 定义获取的url
  6. $url = "http://www.phpfensi.com/sitemap.php";
  7. // 定网站地图名字
  8. $name = "sitemap.html";
  9. // 获取源码
  10. $html = file_get_contents($url);
  11. // 写入html
  12. $write = file_put_contents($name,$html);
  13. if($write){
  14. header("HTTP/1.1 200");
  15. }else {
  16. header("HTTP/1.1 404");
  17. }
  18. ?>