更多>>关于我们

西安鲲之鹏网络信息技术有限公司从2010年开始专注于Web(网站)数据抓取领域。致力于为广大中国客户提供准确、快捷的数据采集相关服务。我们采用分布式系统架构,日采集网页数千万。我们拥有海量稳定高匿HTTP代理IP地址池,可以有效绕过各种反采集策略。

您只需告诉我们您想抓取的网站是什么,您感兴趣的字段有哪些,你需要的数据是哪种格式,我们将为您做所有的工作,最后把数据(或程序)交付给你。

数据的格式可以是CSV、JSON、XML、ACCESS、SQLITE、MSSQL、MYSQL等等。

更多>>官方微博

西安鲲之鹏
陕西 西安

加关注

  • 【CSV转Excel(XLSX格式)脚本分享】
    背景:大多数情况下CSV转Excel可以使用Openoffice或者Excel实现,但是偶尔也会遇到一些BT的情况,比如转换后Excel打开显示文件异常的(如图2所示)。于是乎利用xlsxwriter这个库写了个小脚本,用法如下:
    python csv2xlsx.py path-of-csv-file  file-encoding(default is utf-8)
    运行效果如图1所示。csv2xlsx.py源码链接分享 >>>http://t.cn/Rrhexmx
    发布时间:2018-06-21 18:57:26
  • 全国各类POI(美食、休闲娱乐、丽人、酒店、生活服务等等)用户评论数据7.09亿条,更新至2018年6月15日。点击查看示例数据 >>> http://t.cn/Rrv3RpO ​​​​
    发布时间:2018-06-21 10:21:20
  • 【经验分享】如何让Squid Web隧道支持SSH协议?
    默认Web隧道下连接22端口是不被允许的,会返回403错误。
    编辑/etc/squid3/squid.conf,加入如下配置行
    acl SSL_ports port 22
    acl Safe_ports port 22
    然后重启Squid即可。 ​​​​
    发布时间:2018-05-16 11:41:42
  • 当当网有多少图书,你知道吗?>>> http://t.cn/R3h6hiH ​​​​
    发布时间:2018-05-08 13:53:19
  • 【经验分享】Ubuntu下如何识别无线网卡?
    以普联的TL-WDN6200为例,使用的是rtl8812au(http://t.cn/RuR1Drh这个驱动):
    wget http://t.cn/RuR1DrP
    unzip master.zip
    cd rtl8812au-master
    make
    sudo install
    然后重启系统,运气好的话你就能看到Wifi图标和热点列表了,如下图所示(Ubuntu14.04下亲测)。
    发布时间:2018-05-03 19:10:52
  • 【经验分享】DeleGate跑了3天日志吃了18G硬盘,如何关掉日志呢?
    查文档(ftp://www.delegate.org/pub/DeleGate/Manual.htm#LOGDIR),找到了方法,加上参数LOGFILE=""即可,原文:
    You can stop logging by specifying null file name like LOGFILE="" or PROTOLOG="". ​​​​
    发布时间:2018-04-28 18:08:15
  • 【经验分享】命令下如何优雅地展示JSON数据?
    jq is a lightweight and flexible command-line JSON processor. >>> http://t.cn/Ry7MrH2
    示例:curl http://t.cn/Rui9UFI |jq '.'
    效果如附图所示。 ​​​​
    发布时间:2018-04-27 17:15:06
  • 最常见浏览器User Agent列表(Most Common User Agents)  >>> http://t.cn/R5ZC20T
    PS:隐约感觉某网站开始通过随机UA检测爬虫了。 ​​​​
    发布时间:2018-04-27 13:08:00
  • 【经验分享】在多网络接口(IP)环境下Squid,Tinyproxy和DeleGate如何指定出口(IP) >>> http://t.cn/RucmfQu ​​​​
    发布时间:2018-04-25 18:16:40
  • 【经验分享】Linux网络接口名称最大允许长度为15字符 >>> http://t.cn/RuG4k0R ​​​​
    发布时间:2018-04-24 11:05:16
当前位置: 首页 > 技术文章 >
DNSPod API + Cron实现动态域名解析(DDNS)
发布时间:2015-12-11 来源:未知 浏览:

场景:公司的一台服务器放在联通ADSL内网(IP是动态的),需要经常从外面访问它。

首先想到的是花生壳这种DDNS服务,但是很遗憾,花生壳免费版只支持电信线路,联通网络上花生壳客户端登录不上去。

于是决定“自己动手,丰衣足食”。DNSPod API支持动态修改一个域名的解析地址,我们恰好有好几个域名托管在DNSPod,于是决定尝试一下这个思路。

1)仔细阅读了下相关文档,准备好相关参数。修改记录的API相关说明在这里:http://www.dnspod.cn/docs/records.html#record-modify。

要调用这个接口我们需要DNSPod的账号、密码以及域名的ID、记录的ID,后面这两个参数可以结合DNSPod的其它API获取到,因为是固定的,所以只需要获取一次。

2)编写一个Python脚本,实现在发现IP发生变化时向“修改记录”API发出请求,对记录对应的IP进行更新。

PS:刚开始想到的是定时去更新(比如每1分钟),但是DNSPod API有这个限制“如果1小时之内,提交了超过5次没有任何变动的记录修改请求,该记录会被系统锁定1小时,不允许再次修改。比如原记录值已经是 1.1.1.1,新的请求还要求修改为 1.1.1.1。”。

所以必须要在程序里判断一下路由器的IP是否发生了变化,当发生变化后再进行调用。

这Python脚本大概是这个样子的:

# coding: utf-8
# update_domain_ip.py
# Update the IP of jamp.webscraping.cn via DNSPod API

import os
import sys
os.chdir(os.path.dirname(os.path.realpath(sys.argv[0])))
import re
import time
import urllib

# A file used to store local IP address
IP_FILE = 'ip_last.txt'

def update():
    print time.strftime('%Y-%m-%d %H:%M:%S')
    # The previous IP address
    ip_last = open(IP_FILE).read().strip() if os.path.exists(IP_FILE) else None
    # The current IP address
    html = urllib.urlopen('http://httpbin.org/ip').read()
    print html
    ip_current = None
    m = re.compile(r'"origin":\s+"([^"]+)"').search(html)
    if m:
        ip_current = m.groups()[0]
    if ip_current and ip_last != ip_current:
        print 'IP changed. Is going to update the domain IP.'
        command = "curl -X POST https://dnsapi.cn/Record.Modify -d 'login_email=DNSPOD账号&login_password==DNSPOD密码&format=json&domain_id=域名ID&record_id=记录ID&sub_domain=jamp&value={}&record_type=A&record_line=默认'".format(ip_current)
        os.system(command)
        open(IP_FILE, 'w').write(ip_current)

if __name__ == '__main__':
    update()
3)增加一个Cron任务,大概是这样子的:
*/5 * * * * /usr/bin/python /home/qi/update_domain_ip.py > /home/qi/update_domain_ip.log
 
总结,这种方案我们实际测试了一周了,效果非常好,目前还没有出现过掉链子的情况。
特别说明:该文章为鲲鹏数据原创文章 ,您除了可以发表评论外,还可以转载到别的网站,但是请保留源地址,谢谢!!(尊重他人劳动,我们共同努力)
☹ Disqus被Qiang了,之前的评论内容都没了。如果您有爬虫相关技术方面的问题,欢迎发到我们的问答平台:http://spider.site-digger.com/
QQ在线客服
欢迎咨询,点击这里给我发送消息。
欢迎咨询,点击这里给我发送消息。