黄东旭解析 TiDB 的核心优势
860
2023-04-28
为网站构建自己的Aleax查询服务
前言
每个网站的站长都会想尽办法提升网站的流量,从而获得更高的广告收入。那么评判一个网站好坏的标准,如Google的PR(PageRank),百度权重等。从PV(Page View)流量的角度,一个非常重要指标就是Alexa网站排名。
同全球的网站相比,你就能了解到自己网站的位置,让我们先挤进全球前10万的排名吧,不然都不好意思跟同行说,“自己有一个网站”。
目录
1. Alexa介绍
2. 用Node开发Alexa服务
3. 作者介绍
1. Alexa介绍
1999年,Alexa被美国电子商务旗舰企业“亚马逊”收购,成为后者的全资子公司。2002年春,Alexa放弃了自己的搜索引擎,转而与Google合作。
Alexa提供了网站流量统计的服务,对全球有域名的网站进行流量记录。也就是说,只要你申请了域名,在Alexa中就可以查询到你的网站的排名。Alexa的网站排名是按照每个特定网站的被浏览率进行排名的。浏览率越大,排名越靠前。
通常情况,如果你的域名刚刚注册,排名在1千万以上;接下来,你每天都经心运营网站,小有起色时,排名会进入前1百万;然后,你继续发布优质内容,坚持了一段时间,排名会升至前50万;当你的网站在某一领域小有名气时,排名可以到达10万,如粉丝日志122616(2015-10-25),这时就会有广告主愿意来投放广告了;如果你做的是以盈利为目的的网站,那么你需要再加油,进入到前1万,这个时候你的流量已经可以为你带来生意了;如果能做的更好,排名进入前2000,像雪球排名到2109(2015-10-25),那么你将会有一个很高的估值了;如果能赶上一个天大的机遇,你的网站排名到了前100,那么你的网站将给你带来上市公司的价值,如京东105(2015-10-25);如果你是天才型的CEO,网站进了前10名,那么你将会成为一个产业的***,甚至是某个区域的首富,如百度4(2015-10-25)。
站长们,加油!
2. 用Node开发Alexa服务
2.1 Alexa开放API
Alexa网站排名被业界普通的认可,排名数据会经常地被引用,每次都在网站上查询就会显得不方便。Amazon提供的Alexa的API,让开发者可以构建自己的Alexa查询的应用。
Alexa有2个主要的数据API服务。
• Alexa Web Information Service,查询单个网站的排名信息
• Alexa Top Sites,查询网站的综合排名
通常情况,只需要调用UrlInfo数据接口,就可以获得网站的流量数据了。当然,这个接口的定义,并不像我之前想象的那么好用,而且开放出来的数据有限。
UrlInfo接口的API,如下图所示。
#p#
2.2 创建AWS的API密钥
我们在使用AWS的API之前,需要先创建密钥,类似于OAuth2的访问的机制。
1. 注册AWS账号,请大家自己完成。注册
2. 进入AWS账号管理控制台,控制台
3. 从控制台选择“安全证书”
4. 创建访问密钥(访问密钥 ID 和私有访问密钥)
我们一会写程序的时候,需要输入创建的访问密钥 ID 和私有访问密钥。
2.3 用Node开发Alexa服务
接下来,介绍用Node构建一个Alexa的项目。
我的系统环境
• Win10 64bit
• Node v0.12.3
• NPM 2.9.1
创建项目
~ D:\workspace\nodejs>mkdir nodejs-alexa && cd nodejs-alexa
新建Node项目配置文件:package.json
~ vi package.json { "name": "alexa-demo", "version": "0.0.1", "description": "alexa web demo", "license": "MIT", "dependencies": { "awis": "0.0.8" } }
安装awis包
新建文件alexa.js,调用AWS Alexa网站排名API。
~ vi alexa.js // 定义AWS密钥 var key = 'xxxxxxxxxxxxxxx'; var sercet = 'xxxxxxxxxxxxxxx'; // 创建awis实例化对象 var awis = require('awis'); var client = awis({ key: key, secret: sercet }); // 调用UrlInfo接口 console.log("=============UrlInfo================="); client({ 'Action': 'UrlInfo', //UrlInfo接口 'Url': 'fens.me', //查询的网站 'ResponseGroup': 'TrafficData,ContentData' //需要的数据组 }, function (err, data) { if(err) console.log(err); console.log(data); });
运行程序node alexa.js
~ D:\workspace\nodejs\nodejs-alexa>node alexa.js =============UrlInfo================= { contentData: { dataUrl: 'fens.me', siteData: { title: '粉丝日志', description: '跨界的IT博客|Hadoop家族, R, RHadoop, Nodejs, AngularJS, NoSQL, IT金融' }, speed: { medianLoadTime: '982', percentile: '70' }, adultContent: '', language: '', linksInCount: '198', keywords: '', ownedDomains: '' }, trafficData: { dataUrl: 'fens.me', rank: '122616', usageStatistics: { usageStatistic: [Object] }, contributingSubdomains: { contributingSubdomain: [Object] } } }
我们查检一下awis包的源代码可以发现,其实AWS Alexa服务返回是XML,awis的自动帮我们做了JSON的转型处理,如果想查看原始的返回值,可以修改awis包中index.js文件parse()函数。
function parse(xml, req, cb) { console.log(xml); //打印 .... }
运行程序
除了UrlInfo接口还有几个接口可以使用。
#p#
TrafficHistory接口
console.log("=============TrafficHistory================="); client({ 'Action': 'TrafficHistory', 'Url': 'fens.me', 'ResponseGroup': 'History' }, function (err, res) { if(err) console.log(err); console.log(res.trafficHistory); console.log(res.trafficHistory.range); console.log(res.trafficHistory.site); console.log(res.trafficHistory.start); console.log(res.trafficHistory.historicalData); console.log(res.trafficHistory.historicalData.data); console.log(res.trafficHistory.historicalData.data.length); res.trafficHistory.historicalData.data.forEach(function (item) { console.log(item.date); console.log(item.pageViews); console.log(item.rank); console.log(item.reach); }); });
运行程序
~ D:\workspace\nodejs\nodejs-alexa>node alexa.js =============TrafficHistory================= { range: '31', site: 'fens.me', start: '2015-09-23', historicalData: { data: [ [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object] ] } } // 省略输出
SitesLinkingIn接口
console.log("=============SitesLinkingIn================="); client({ 'Action': 'SitesLinkingIn', 'Url': 'fens.me', 'ResponseGroup': 'SitesLinkingIn' }, function (err, data) { if(err) console.log(err); console.log(data); });
运行程序
~ D:\workspace\nodejs\nodejs-alexa>node alexa.js =============SitesLinkingIn================= { sitesLinkingIn: { site: [ [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object] ] } }
CategoryBrowse接口
console.log("=============CategoryBrowse================="); client({ 'Action': 'CategoryBrowse', 'Url': 'fens.me', 'Path': 'Top/china', 'ResponseGroup': 'LanguageCategories' }, function (err, data) { if(err) console.log(err); console.log(data); });
运行程序
~ D:\workspace\nodejs\nodejs-alexa>node alexa.js =============CategoryBrowse================= { categoryBrowse: { languageCategories: '' } }
Alexa网站排名以第三方的视角给全球的每个网站进行了排名,甚至是定价。做为一个优秀的网长,我们要使用好Alexa工具,了解自己的网站和竞争对手的网站,才能网站脱颖而出,成为成功的站长!
3. 作者介绍
张丹,况客科技(北京)有限公司,创始人/CTO。
从程序员开始到架构师,再到金融量化创业者,倡导跨学科思维,多语言编程!我认为这是技术复合人才未来的发展方向。抓住机会!!程序员,加油!
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。