更多>>关于我们
西安鲲之鹏网络信息技术有限公司从2010年开始专注于Web(网站)数据抓取领域。致力于为广大中国客户提供准确、快捷的数据采集相关服务。我们采用分布式系统架构,日采集网页数千万。我们拥有海量稳定高匿HTTP代理IP地址池,可以有效获取互联网任何公开可见信息。
您只需告诉我们您想抓取的网站是什么,您感兴趣的字段有哪些,你需要的数据是哪种格式,我们将为您做所有的工作,最后把数据(或程序)交付给你。
数据的格式可以是CSV、JSON、XML、ACCESS、SQLITE、MSSQL、MYSQL等等。
更多>>技术文章
场景:公司的一台服务器放在联通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()