我们已经准备好了,你呢?

2020我们与您携手共赢,为您的企业形象保驾护航!

 

前言

每个网站的站长都会想尽办法提升网站的流量,从而获得更高的广告收入。那么评判一个网站好坏的标准,如Google的PR(PageRank),百度权重等。从PV(Page View)流量的角度,一个非常重要指标就是Alexa网站排名。

同全球的网站相比,你就能了解到自己网站的位置,让我们先挤进全球前10万的排名吧,不然都不好意思跟同行说,“自己有一个网站”。

目录

1. Alexa介绍

2. 用Node开发Alexa服务

3. 作者介绍

1. Alexa介绍

Alexa (http://www.alexa.com/)是一家发布世界网站排名的网站,以搜索引擎起家的Alexa创建于1996年4月(美国),目的是让互联网网友在分享虚拟世界资源的同时,更多地参与互联网资源的组织。Alexa每天在网上搜集超过1TB的信息,不仅给出多达几十亿的网址链接,而且为其中的每一个网站进行了排名。可以说,Alexa是当前拥有URL数量最庞大,排名信息发布最详尽的网站。

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,如下图所示。
 

官方提供了多语言的SDK工具包,我觉得还是Node.js最方便。我构建的一个Alexa数据查询服务,http://fens.me/alexa

 

 

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

创建项目


  1. ~ D:workspace odejs>mkdir nodejs-alexa && cd nodejs-alexa 

新建Node项目配置文件:package.json


  1. ~ vi package.json   
  2. {    "name": "alexa-demo",  
  3.   "version": "0.0.1",    "description": "alexa web demo",  
  4.   "license": "MIT",    "dependencies": {  
  5.     "awis": "0.0.8"    }  

安装awis包


  1. ~ D:workspace odejs odejs-alexa>npm install  npm WARN package.json alexa-demo@0.0.1 No repository field.  
  2. npm WARN package.json alexa-demo@0.0.1 No README data  alexarank@0.1.1 node_modulesalexarank  
  3. ├── xml2js@0.4.13 (sax@1.1.4, xmlbuilder@3.1.0)  └── request@2.30.0 (forever-agent@0.5.2, aws-sign2@0.5.0, qs@0.6.6, tunnel-agent@0.3.0, oauth-sign@0.3.0, json-stringify-safe@5.0.1, mime@1.2.11, node-uuid@1.4.3, tough-cookie@0.9.15, form-data@0.1.4, hawk@1.0.0, http-signature@0.10.1)  
  4.  awis@0.0.8 node_modulesawis  
  5. ├── xml2js@0.4.13 (sax@1.1.4, xmlbuilder@3.1.0)  ├── lodash@3.10.1  
  6. └── request@2.65.0 (aws-sign2@0.6.0, forever-agent@0.6.1, caseless@0.11.0, stringstream@0.0.4, oauth-sign@0.8.0, tunnel-agent@0.4.1, isstream@0.1.2, json-stringify-safe@5.0.1, extend@3.0.0, node-uuid@1.4.3, qs@5.2.0, tough-cookie@2.2.0, combined-stream@1.0.5, mime-types@2.1.7, form-data@1.0.0-rc3, http-signature@0.11.0, hawk@3.1.0, bl@1.0.0, har-validator@2.0.2) 

新建文件alexa.js,调用AWS Alexa网站排名API。


  1. ~ vi alexa.js   
  2. // 定义AWS密钥  var key = 'xxxxxxxxxxxxxxx';  
  3. var sercet = 'xxxxxxxxxxxxxxx';   
  4. // 创建awis实例化对象  var awis = require('awis');  
  5. var client = awis({    key: key,  
  6.   secret: sercet  });  
  7.  // 调用UrlInfo接口  
  8. console.log("=============UrlInfo=================");  client({  
  9.   'Action': 'UrlInfo',                         //UrlInfo接口    'Url': 'fens.me',                            //查询的网站  
  10.   'ResponseGroup': 'TrafficData,ContentData'   //需要的数据组  }, function (err, data) {  
  11.   if(err) console.log(err);    console.log(data);    
  12. });  

运行程序node alexa.js


  1. ~ D:workspace odejs odejs-alexa>node alexa.js  =============UrlInfo=================  
  2. { contentData:     { dataUrl: 'fens.me',  
  3.      siteData:        { title: '粉丝日志',  
  4.         description: '跨界的IT博客|Hadoop家族, R, RHadoop, Nodejs, AngularJS, NoSQL, IT金融' },       speed: { medianLoadTime: '982', percentile: '70' },  
  5.      adultContent: '',       language: '',  
  6.      linksInCount: '198',       keywords: '',  
  7.      ownedDomains: '' },    trafficData:  
  8.    { dataUrl: 'fens.me',       rank: '122616',  
  9.      usageStatistics: { usageStatistic: [Object] },       contributingSubdomains: { contributingSubdomain: [Object] } } } 

简简单单地几行代码,都获得了Alexa的排名信息。后台打印时Object没有转到成对象,我做了一个服务,可以通过HTTP输出查看完整的返回。http://api.fens.me/alexa/fens.me

我们查检一下awis包的源代码可以发现,其实AWS Alexa服务返回是XML,awis的自动帮我们做了JSON的转型处理,如果想查看原始的返回值,可以修改awis包中index.js文件parse()函数。


  1. function parse(xml, req, cb) {    console.log(xml); //打印  
  2.    ....  
  3. }  

运行程序


  1. D:workspace odejs odejs-alexa>node alexa.js =============UrlInfo=================  
  2. <?xml version="1.0"?> <aws:UrlInfoResponse xmlns:aws="http://alexa.amazonaws.com/doc/2005-10-05/"><aws:Response xmlns:aws="http://awis.amazonaws.com/doc/2005-07-11"><aws:OperationRequest><aws:RequestId>1e7d8406-4b62-3460-27fb-325fc3dc3e85</aws:RequestId></aws:OperationRequest><aws:UrlInfoResult><aws:Alexa> 
  3.    <aws:ContentData> 
  4.     <aws:DataUrl type="canonical">fens.me</aws:DataUrl>     <aws:SiteData> 
  5.       <aws:Title>粉丝日志</aws:Title>       <aws:Description>跨界的IT博客|Hadoop家族, R, RHadoop, Nodejs, AngularJS, NoSQL, IT金融</aws:Description> 
  6.     </aws:SiteData>     <aws:Speed> 
  7.       <aws:MedianLoadTime>982</aws:MedianLoadTime>       <aws:Percentile>70</aws:Percentile> 
  8.     </aws:Speed>     <aws:AdultContent/> 
  9.     <aws:Language/>     <aws:LinksInCount>198</aws:LinksInCount> 
  10.     <aws:Keywords/>     <aws:OwnedDomains/> 
  11.   </aws:ContentData>   <aws:TrafficData> 
  12.     <aws:DataUrl type="canonical">fens.me</aws:DataUrl>     <aws:Rank>122616</aws:Rank> 
  13.     <aws:UsageStatistics>       <aws:UsageStatistic> 
  14.         <aws:TimeRange>           <aws:Months>3</aws:Months> 
  15.         </aws:TimeRange>         <aws:Rank> 
  16.           <aws:Value>122616</aws:Value>           <aws:Delta>+28849</aws:Delta> 
  17.         </aws:Rank>         <aws:Reach> 
  18.           <aws:Rank>             <aws:Value>110056</aws:Value> 
  19.             <aws:Delta>+25785</aws:Delta>           </aws:Rank> 
  20.           <aws:PerMillion>             <aws:Value>12.5</aws:Value> 
  21.             <aws:Delta>-24.68%</aws:Delta>           </aws:PerMillion> 
  22.         </aws:Reach>         <aws:PageViews> 
  23.           <aws:PerMillion>             <aws:Value>0.27</aws:Value> 
  24.             <aws:Delta>-24.84%</aws:Delta>           </aws:PerMillion> 
  25.           <aws:Rank>             <aws:Value>194189</aws:Value> 
  26.             <aws:Delta>43945</aws:Delta>           </aws:Rank> 
  27.           <aws:PerUser>             <aws:Value>1.9</aws:Value> 
  28.             <aws:Delta>0%</aws:Delta>           </aws:PerUser> 
  29.         </aws:PageViews>       </aws:UsageStatistic> 
  30.       <aws:UsageStatistic>         <aws:TimeRange> 
  31.           <aws:Months>1</aws:Months>         </aws:TimeRange> 
  32.         <aws:Rank>           <aws:Value>102621</aws:Value> 
  33.           <aws:Delta>-30257</aws:Delta>         </aws:Rank> 
  34.         <aws:Reach>           <aws:Rank> 
  35.             <aws:Value>95663</aws:Value>             <aws:Delta>-20326</aws:Delta> 
  36.           </aws:Rank>           <aws:PerMillion> 
  37.             <aws:Value>15</aws:Value>             <aws:Delta>+20%</aws:Delta> 
  38.           </aws:PerMillion>         </aws:Reach> 
  39.         <aws:PageViews>           <aws:PerMillion> 
  40.             <aws:Value>0.37</aws:Value>             <aws:Delta>+60%</aws:Delta> 
  41.           </aws:PerMillion>           <aws:Rank> 
  42.             <aws:Value>153976</aws:Value>             <aws:Delta>-69981</aws:Delta> 
  43.           </aws:Rank>           <aws:PerUser> 
  44.             <aws:Value>2.2</aws:Value>             <aws:Delta>+30%</aws:Delta> 
  45.           </aws:PerUser>         </aws:PageViews> 
  46.       </aws:UsageStatistic>       <aws:UsageStatistic> 
  47.         <aws:TimeRange>           <aws:Days>7</aws:Days> 
  48.         </aws:TimeRange>         <aws:Rank> 
  49.           <aws:Value>114709</aws:Value>           <aws:Delta>+32390</aws:Delta> 
  50.         </aws:Rank>         <aws:Reach> 
  51.           <aws:Rank>             <aws:Value>103552</aws:Value> 
  52.             <aws:Delta>+27312</aws:Delta>           </aws:Rank> 
  53.           <aws:PerMillion>             <aws:Value>14</aws:Value> 
  54.             <aws:Delta>-28.59%</aws:Delta>           </aws:PerMillion> 
  55.         </aws:Reach>         <aws:PageViews> 
  56.           <aws:PerMillion>             <aws:Value>0.3</aws:Value> 
  57.             <aws:Delta>-37.28%</aws:Delta>           </aws:PerMillion> 
  58.           <aws:Rank>             <aws:Value>188124</aws:Value> 
  59.             <aws:Delta>58655</aws:Delta>           </aws:Rank> 
  60.           <aws:PerUser>             <aws:Value>2.0</aws:Value> 
  61.             <aws:Delta>-12.11%</aws:Delta>           </aws:PerUser> 
  62.         </aws:PageViews>       </aws:UsageStatistic> 
  63.       <aws:UsageStatistic>         <aws:TimeRange> 
  64.           <aws:Days>1</aws:Days>         </aws:TimeRange> 
  65.         <aws:Rank>           <aws:Value>74860</aws:Value> 
  66.           <aws:Delta>-93163</aws:Delta>         </aws:Rank> 
  67.         <aws:Reach>           <aws:Rank> 
  68.             <aws:Value>70563</aws:Value>             <aws:Delta>-54001</aws:Delta> 
  69.           </aws:Rank>           <aws:PerMillion> 
  70.             <aws:Value>20</aws:Value>             <aws:Delta>+60%</aws:Delta> 
  71.           </aws:PerMillion>         </aws:Reach> 
  72.         <aws:PageViews>           <aws:PerMillion> 
  73.             <aws:Value>0.6</aws:Value>             <aws:Delta>+300%</aws:Delta> 
  74.           </aws:PerMillion>           <aws:Rank> 
  75.             <aws:Value>111541</aws:Value>             <aws:Delta>-210757</aws:Delta> 
  76.           </aws:Rank>           <aws:PerUser> 
  77.             <aws:Value>2</aws:Value>             <aws:Delta>+</aws:Delta> 
  78.           </aws:PerUser>         </aws:PageViews> 
  79.       </aws:UsageStatistic>     </aws:UsageStatistics> 
  80.     <aws:ContributingSubdomains>       <aws:ContributingSubdomain> 
  81.         <aws:DataUrl>blog.fens.me</aws:DataUrl>         <aws:TimeRange> 
  82.           <aws:Months>1</aws:Months>         </aws:TimeRange> 
  83.         <aws:Reach>           <aws:Percentage>99.19%</aws:Percentage> 
  84.         </aws:Reach>         <aws:PageViews> 
  85.           <aws:Percentage>99.64%</aws:Percentage>           <aws:PerUser>2.2</aws:PerUser> 
  86.         </aws:PageViews>       </aws:ContributingSubdomain> 
  87.       <aws:ContributingSubdomain>         <aws:DataUrl>OTHER</aws:DataUrl> 
  88.         <aws:TimeRange>           <aws:Months>1</aws:Months> 
  89.         </aws:TimeRange>         <aws:Reach> 
  90.           <aws:Percentage>0</aws:Percentage>         </aws:Reach> 
  91.         <aws:PageViews>           <aws:Percentage>0.36%</aws:Percentage> 
  92.           <aws:PerUser>0</aws:PerUser>         </aws:PageViews> 
  93.       </aws:ContributingSubdomain>     </aws:ContributingSubdomains> 
  94.   </aws:TrafficData> </aws:Alexa></aws:UrlInfoResult><aws:ResponseStatus xmlns:aws="http://alexa.amazonaws.com/doc/2005-10-05/"><aws:StatusCode>Success</aws:StatusCode></aws:ResponseStatus></aws:Response></aws:UrlInfoResponse> 

除了UrlInfo接口还有几个接口可以使用。

 

TrafficHistory接口


  1. console.log("=============TrafficHistory=================");  client({  
  2.   'Action': 'TrafficHistory',    'Url': 'fens.me',  
  3.   'ResponseGroup': 'History'  }, function (err, res) {  
  4.     if(err) console.log(err);      console.log(res.trafficHistory);  
  5.     console.log(res.trafficHistory.range);      console.log(res.trafficHistory.site);  
  6.     console.log(res.trafficHistory.start);      console.log(res.trafficHistory.historicalData);  
  7.     console.log(res.trafficHistory.historicalData.data);      console.log(res.trafficHistory.historicalData.data.length);  
  8.     res.trafficHistory.historicalData.data.forEach(function (item) {        console.log(item.date);  
  9.       console.log(item.pageViews);        console.log(item.rank);  
  10.       console.log(item.reach);      });  
  11. }); 

运行程序


  1. ~ D:workspace odejs odejs-alexa>node alexa.js =============TrafficHistory=================  
  2. { range: '31',    site: 'fens.me',  
  3.   start: '2015-09-23',    historicalData:  
  4.    { data:        [ [Object],  
  5.         [Object],          [Object],  
  6.         [Object],          [Object],  
  7.         [Object],          [Object],  
  8.         [Object],          [Object],  
  9.         [Object],          [Object],  
  10.         [Object],          [Object],  
  11.         [Object],          [Object],  
  12.         [Object],          [Object],  
  13.         [Object],          [Object],  
  14.         [Object],          [Object],  
  15.         [Object],          [Object],  
  16.         [Object],          [Object],  
  17.         [Object],          [Object],  
  18.         [Object],          [Object],  
  19.         [Object],          [Object] ] } }  
  20.  // 省略输出 

SitesLinkingIn接口


  1. console.log("=============SitesLinkingIn=================");  client({  
  2.   'Action': 'SitesLinkingIn',    'Url': 'fens.me',  
  3.   'ResponseGroup': 'SitesLinkingIn'  }, function (err, data) {  
  4.   if(err) console.log(err);    console.log(data);  
  5. }); 

运行程序


  1. ~ D:workspace odejs odejs-alexa>node alexa.js =============SitesLinkingIn=================  
  2. { sitesLinkingIn:     { site:  
  3.       [ [Object],          [Object],  
  4.         [Object],          [Object],  
  5.         [Object],          [Object],  
  6.         [Object],          [Object],  
  7.         [Object],          [Object] ] } } 

CategoryBrowse接口


  1. console.log("=============CategoryBrowse=================");  client({  
  2.   'Action': 'CategoryBrowse',    'Url': 'fens.me',  
  3.   'Path': 'Top/china',    'ResponseGroup': 'LanguageCategories'  
  4. }, function (err, data) {    if(err) console.log(err);  
  5.   console.log(data);  });  

运行程序


  1. ~ D:workspace odejs odejs-alexa>node alexa.js =============CategoryBrowse=================  
  2. { categoryBrowse: { languageCategories: '' } }  

最后,我们只需要把这个程序用web封装一下,就可以提供对用户的服务了,参考我的网站http://fens.me/alexa 。

本文对应的代码请通过github进行下载,下载地址为:https://github.com/bsspirit/nodejs-alexa 。

Alexa网站排名以第三方的视角给全球的每个网站进行了排名,甚至是定价。做为一个的网长,我们要使用好Alexa工具,了解自己的网站和竞争对手的网站,才能网站脱颖而出,成为成功的站长!

3. 作者介绍

张丹,况客科技(北京)有限公司,创始人/CTO。

《R的极客理想》系列图书作者,个人博客: http://blog.fens.me

从程序员开始到架构师,再到金融量化创业者,倡导跨学科思维,多语言编程!我认为这是技术复合人才未来的发展方向。抓住机会!!程序员,加油!

我们凭借多年的网站建设经验,坚持以“帮助中小企业实现网络营销化”为宗旨,累计为1000多家客户提供品质建站服务,得到了客户的一致好评。如果您有网站建设网站改版百度优化、名注册、主机空间、手机网站建设公众号开发小程序制作、网站备案等方面的需求...
请立即点击咨询我们或拨打咨询热线: 13820372851,我们会详细为你一一解答你心中的疑难。项目经理在线

我们已经准备好了,你呢?

2020我们与您携手共赢,为您的企业形象保驾护航!

在线客服
联系方式

热线电话

13820372851

上班时间

周一到周五

公司电话

022-26262675

二维码
线
在线留言