网站统计中的数据收集原理及实现

news/2024/5/12 11:33:17/文章来源:https://blog.csdn.net/weixin_33964094/article/details/90652224

网站数据统计分析工具是网站站长和运营人员经常使用的一种工具,比较常用的有谷歌分析、百度统计和腾讯分析等等。所有这些统计分析工具的第一步都是网站访问数据的收集。目前主流的数据收集方式基本都是基于javascript的。本文将简要分析这种数据收集的原理,并一步一步实际搭建一个实际的数据收集系统。

数据收集原理分析

简单来说,网站统计分析工具需要收集到用户浏览目标网站的行为(如打开某网页、点击某按钮、将商品加入购物车等)及行为附加数据(如某下单行为产生的订单金额等)。早期的网站统计往往只收集一种用户行为:页面的打开。而后用户在页面中的行为均无法收集。这种收集策略能满足基本的流量分析、来源分析、内容分析及访客属性等常用分析视角,但是,随着ajax技术的广泛使用及电子商务网站对于电子商务目标的统计分析的需求越来越强烈,这种传统的收集策略已经显得力不能及。

后来,Google在其产品谷歌分析中创新性的引入了可定制的数据收集脚本,用户通过谷歌分析定义好的可扩展接口,只需编写少量的javascript代码就可以实现自定义事件和自定义指标的跟踪和分析。目前百度统计、搜狗分析等产品均照搬了谷歌分析的模式。

其实说起来两种数据收集模式的基本原理和流程是一致的,只是后一种通过javascript收集到了更多的信息。下面看一下现在各种网站统计工具的数据收集基本原理。

流程概览

首先通过一幅图总体看一下数据收集的基本流程。

图1. 网站统计数据收集基本流程

首先,用户的行为会触发浏览器对被统计页面的一个http请求,这里姑且先认为行为就是打开网页。当网页被打开,页面中的埋点javascript片段会被执行,用过相关工具的朋友应该知道,一般网站统计工具都会要求用户在网页中加入一小段javascript代码,这个代码片段一般会动态创建一个script标签,并将src指向一个单独的js文件,此时这个单独的js文件(图1中绿色节点)会被浏览器请求到并执行,这个js往往就是真正的数据收集脚本。数据收集完成后,js会请求一个后端的数据收集脚本(图1中的backend),这个脚本一般是一个伪装成图片的动态脚本程序,可能由php、python或其它服务端语言编写,js会将收集到的数据通过http参数的方式传递给后端脚本,后端脚本解析参数并按固定格式记录到访问日志,同时可能会在http响应中给客户端种植一些用于追踪的cookie。

上面是一个数据收集的大概流程,下面以谷歌分析为例,对每一个阶段进行一个相对详细的分析。

埋点脚本执行阶段

若要使用谷歌分析(以下简称GA),需要在页面中插入一段它提供的javascript片段,这个片段往往被称为埋点代码。下面是我的博客中所放置的谷歌分析埋点代码截图:

图2. 谷歌分析埋点代码

其中_gaq是GA的的全局数组,用于放置各种配置,其中每一条配置的格式为:

_gaq.push(['Action','param1','param2',...]);

Action指定配置动作,后面是相关的参数列表。GA给的默认埋点代码会给出两条预置配置,_setAccount用于设置网站标识ID,这个标识ID是在注册GA时分配的。_trackPageview告诉GA跟踪一次页面访问。更多配置请参考:https://developers.google.com/analytics/devguides/collection/gajs/。实际上,这个_gaq是被当做一个FIFO队列来用的,配置代码不必出现在埋点代码之前,具体请参考上述链接的说明。

就本文来说,_gaq的机制不是重点,重点是后面匿名函数的代码,这才是埋点代码真正要做的。这段代码的主要目的就是引入一个外部的js文件(ga.js),方式是通过document.createElement方法创建一个script并根据协议(http或https)将src指向对应的ga.js,最后将这个element插入页面的dom树上。

注意ga.async = true的意思是异步调用外部js文件,即不阻塞浏览器的解析,待外部js下载完成后异步执行。这个属性是HTML5新引入的。

数据收集脚本执行阶段

数据收集脚本(ga.js)被请求后会被执行,这个脚本一般要做如下几件事:

1、通过浏览器内置javascript对象收集信息,如页面title(通过document.title)、referrer(上一跳url,通过document.referrer)、用户显示器分辨率(通过windows.screen)、cookie信息(通过document.cookie)等等一些信息。

2、解析_gaq收集配置信息。这里面可能会包括用户自定义的事件跟踪、业务数据(如电子商务网站的商品编号等)等。

3、将上面两步收集的数据按预定义格式解析并拼接。

4、请求一个后端脚本,将信息放在http request参数中携带给后端脚本。

这里唯一的问题是步骤4,javascript请求后端脚本常用的方法是ajax,但是ajax是不能跨域请求的。这里ga.js在被统计网站的域内执行,而后端脚本在另外的域(GA的后端统计脚本是http://www.google-analytics.com/__utm.gif),ajax行不通。一种通用的方法是js脚本创建一个Image对象,将Image对象的src属性指向后端脚本并携带参数,此时即实现了跨域请求后端。这也是后端脚本为什么通常伪装成gif文件的原因。通过http抓包可以看到ga.js对__utm.gif的请求:

图3. 后端脚本请求的http包

可以看到ga.js在请求__utm.gif时带了很多信息,例如utmsr=1280×1024是屏幕分辨率,utmac=UA-35712773-1是_gaq中解析出的我的GA标识ID等等。

值得注意的是,__utm.gif未必只会在埋点代码执行时被请求,如果用_trackEvent配置了事件跟踪,则在事件发生时也会请求这个脚本。

由于ga.js经过了压缩和混淆,可读性很差,我们就不分析了,具体后面实现阶段我会实现一个功能类似的脚本。

后端脚本执行阶段

GA的__utm.gif是一个伪装成gif的脚本。这种后端脚本一般要完成以下几件事情:

1、解析http请求参数的到信息。

2、从服务器(WebServer)中获取一些客户端无法获取的信息,如访客ip等。

3、将信息按格式写入log。

5、生成一副1×1的空gif图片作为响应内容并将响应头的Content-type设为image/gif。

5、在响应头中通过Set-cookie设置一些需要的cookie信息。

之所以要设置cookie是因为如果要跟踪唯一访客,通常做法是如果在请求时发现客户端没有指定的跟踪cookie,则根据规则生成一个全局唯一的cookie并种植给用户,否则Set-cookie中放置获取到的跟踪cookie以保持同一用户cookie不变(见图4)。

图4. 通过cookie跟踪唯一用户的原理

这种做法虽然不是完美的(例如用户清掉cookie或更换浏览器会被认为是两个用户),但是是目前被广泛使用的手段。注意,如果没有跨站跟踪同一用户的需求,可以通过js将cookie种植在被统计站点的域下(GA是这么做的),如果要全网统一定位,则通过后端脚本种植在服务端域下(我们待会的实现会这么做)。

系统的设计实现

根据上述原理,我自己搭建了一个访问日志收集系统。总体来说,搭建这个系统要做如下的事:

图5. 访问数据收集系统工作分解

下面详述每一步的实现。我将这个系统叫做MyAnalytics。

确定收集的信息

为了简单起见,我不打算实现GA的完整数据收集模型,而是收集以下信息。


埋点代码

埋点代码我将借鉴GA的模式,但是目前不会将配置对象作为一个FIFO队列用。一个埋点代码的模板如下:

1 <script type="text/javascript">
2 var _maq = _maq || [];
3 _maq.push(['_setAccount''网站标识']);
4 
5 (function() {
6     var ma = document.createElement('script'); ma.type ='text/javascript'; ma.async = true;
7     ma.src = ('https:' == document.location.protocol ?'https://analytics' 'http://analytics') + '.codinglabs.org/ma.js';
8     var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ma, s);
9})();
10</script>

这里我启用了二级域名analytics.codinglabs.org,统计脚本的名称为ma.js。当然这里有一点小问题,因为我并没有https的服务器,所以如果一个https站点部署了代码会有问题,不过这里我们先忽略吧。

前端统计脚本

我写了一个不是很完善但能完成基本工作的统计脚本ma.js:

1 (function () {
2     var params = {};
3     //Document对象数据
4     if(document) {
5         params.domain = document.domain || '';
6         params.url = document.URL || '';
7         params.title = document.title || '';
8         params.referrer = document.referrer || '';
9     
10     //Window对象数据
11     if(window && window.screen) {
12         params.sh = window.screen.height || 0;
13         params.sw = window.screen.width || 0;
14         params.cd = window.screen.colorDepth || 0;
15     
16     //navigator对象数据
17     if(navigator) {
18         params.lang = navigator.language || '';
19     
20     //解析_maq配置
21     if(_maq) {
22         for(var in _maq) {
23             switch(_maq[i][0]) {
24                 case '_setAccount':
25                     params.account = _maq[i][1];
26                     break;
27                 default:
28                     break;
29             
30         
31     
32     //拼接参数串
33     var args = '';
34     for(var in params) {
35         if(args != '') {
36             args += '&';
37         
38         args += i + '=' + encodeURIComponent(params[i]);
39     
40 
41     //通过Image对象请求后端脚本
42     var img = new Image(1, 1);
43     img.src = 'http://analytics.codinglabs.org/1.gif?' + args;
44})();

整个脚本放在匿名函数里,确保不会污染全局环境。功能在原理一节已经说明,不再赘述。其中1.gif是后端脚本。

日志格式

日志采用每行一条记录的方式,采用不可见字符^A(ascii码0×01,Linux下可通过ctrl + v ctrl + a输入,下文均用“^A”表示不可见字符0×01),具体格式如下:

时间^AIP^A域名^AURL^A页面标题^AReferrer^A分辨率高^A分辨率宽^A颜色深度^A语言^A客户端信息^A用户标识^A网站标识

后端脚本

为了简单和效率考虑,我打算直接使用nginx的access_log做日志收集,不过有个问题就是nginx配置本身的逻辑表达能力有限,所以我选用了OpenResty做这个事情。OpenResty是一个基于Nginx扩展出的高性能应用开发平台,内部集成了诸多有用的模块,其中的核心是通过ngx_lua模块集成了Lua,从而在nginx配置文件中可以通过Lua来表述业务。关于这个平台我这里不做过多介绍,感兴趣的同学可以参考其官方网站http://openresty.org/,或者这里有其作者章亦春(agentzh)做的一个非常有爱的介绍OpenResty的slide:http://agentzh.org/misc/slides/ngx-openresty-ecosystem/,关于ngx_lua可以参考:https://github.com/chaoslawful/lua-nginx-module。

首先,需要在nginx的配置文件中定义日志格式:

1log_format tick
2"$msec^A$remote_addr^A$u_domain^A$u_url^A$u_title^A$u_referrer^A$u_sh^A$u_sw
3^A$u_cd^A$u_lang^A$http_user_agent^A$u_utrace^A$u_account";

注意这里以u_开头的是我们待会会自己定义的变量,其它的是nginx内置变量。

然后是核心的两个location:

1location /1.gif {
2#伪装成gif文件
3     default_type image/gif; 
4#本身关闭access_log,通过subrequest记录log
5     access_log off;
6 
7     access_by_lua "
8         -- 用户跟踪cookie名为__utrace
9         local uid = ngx.var.cookie___utrace      
10         if not uid then
11             -- 如果没有则生成一个跟踪cookie,算法为md5(时间戳+IP+客户端信息)
12             uid = ngx.md5(ngx.now() .. ngx.var.remote_addr .. ngx.var.http_user_agent)
13         end
14         ngx.header['Set-Cookie'] = {'__utrace=' .. uid .. '; path=/'}
15         if ngx.var.arg_domain then
16         -- 通过subrequest到/i-log记录日志,将参数和用户跟踪cookie带过去
17             ngx.location.capture('/i-log?' .. ngx.var.args .. '&utrace=' .. uid)
18         end
19     ";
20 
21     #此请求不缓存
22     add_header Expires "Fri, 01 Jan 1980 00:00:00 GMT";
23     add_header Pragma "no-cache";
24     add_header Cache-Control "no-cache, max-age=0, must-revalidate";
25 
26     #返回一个1×1的空gif图片
27     empty_gif;
28
29 
30location /i-log {
31     #内部location,不允许外部直接访问
32     internal;
33 
34     #设置变量,注意需要unescape
35     set_unescape_uri $u_domain $arg_domain;
36     set_unescape_uri $u_url $arg_url;
37     set_unescape_uri $u_title $arg_title;
38     set_unescape_uri $u_referrer $arg_referrer;
39     set_unescape_uri $u_sh $arg_sh;
40     set_unescape_uri $u_sw $arg_sw;
41     set_unescape_uri $u_cd $arg_cd;
42     set_unescape_uri $u_lang $arg_lang;
43     set_unescape_uri $u_utrace $arg_utrace;
44     set_unescape_uri $u_account $arg_account;
45 
46     #打开日志
47     log_subrequest on;
48     #记录日志到ma.log,实际应用中最好加buffer,格式为tick
49     access_log /path/to/logs/directory/ma.log tick;
50 
51     #输出空字符串
52     echo '';
53}</pre>
54 <pre class="c">

要完全解释这段脚本的每一个细节有点超出本文的范围,而且用到了诸多第三方ngxin模块(全都包含在OpenResty中了),重点的地方我都用注释标出来了,可以不用完全理解每一行的意义,只要大约知道这个配置完成了我们在原理一节提到的后端逻辑就可以了。

日志轮转

真正的日志收集系统访问日志会非常多,时间一长文件变得很大,而且日志放在一个文件不便于管理。所以通常要按时间段将日志切分,例如每天或每小时切分一个日志。我这里为了效果明显,每一小时切分一个日志。我是通过crontab定时调用一个shell脚本实现的,shell脚本如下:

1 _prefix="/path/to/nginx"
2 time=`date +%Y%m%d%H`
3 
4 mv ${_prefix}/logs/ma.log ${_prefix}/logs/ma/ma-${time}.log
5 kill -USR1 `cat ${_prefix}/logs/nginx.pid`</pre>
6 <pre class="c">[/sehll]</pre>
7</div>
8这个脚本将ma.log移动到指定文件夹并重命名为ma-{yyyymmddhh}.log,然后向nginx发送USR1信号令其重新打开日志文件。
9 
10 然后再/etc/crontab里加入一行:
11 
121
1359**** root /path/to/directory/rotatelog.sh

在每个小时的59分启动这个脚本进行日志轮转操作。

测试

下面可以测试这个系统是否能正常运行了。我昨天就在我的博客中埋了相关的点,通过http抓包可以看到ma.js和1.gif已经被正确请求:

图6. http包分析ma.js和1.gif的请求

同时可以看一下1.gif的请求参数:

图7. 1.gif的请求参数

相关信息确实也放在了请求参数中。

然后我tail打开日志文件,然后刷新一下页面,因为没有设access log buffer, 我立即得到了一条新日志:

11351060731.360^A0.0.0.0^Awww.codinglabs.org^Ahttp://www.codinglabs.org/^ACodingLabs^A^A1024^A1280^A24^Azh-CN^AMozilla/5.0 (Macintosh; Intel Mac OS X 10_8_2) AppleWebKit/537.4 (KHTML, like Gecko) Chrome/22.0.1229.94 Safari/537.4^A4d612be64366768d32e623d594e82678^AU-1-1</pre>
2 <pre class="c">[/sehll]</pre>
3</div>
4注意实际上原日志中的^A是不可见的,这里我用可见的^A替换为方便阅读,另外IP由于涉及隐私我替换为了0.0.0.0。
5 
6看一眼日志轮转目录,由于我之前已经埋了点,所以已经生成了很多轮转文件:
7 
8 <img alt="" src="http://blog.codinglabs.org/uploads/pictures/how-web-analytics-data-collection-system-work/8.png" />
9 
10<strong>图8. 轮转日志</strong>
11<h3>关于分析</h3>
12通过上面的分析和开发可以大致理解一个网站统计的日志收集系统是如何工作的。有了这些日志,就可以进行后续的分析了。本文只注重日志收集,所以不会写太多关于分析的东西。
13 
14注意,原始日志最好尽量多的保留信息而不要做过多过滤和处理。例如上面的MyAnalytics保留了毫秒级时间戳而不是格式化后的时间,时间的格式化是后面的系统做的事而不是日志收集系统的责任。后面的系统根据原始日志可以分析出很多东西,例如通过IP库可以定位访问者的地域、user agent中可以得到访问者的操作系统、浏览器等信息,再结合复杂的分析模型,就可以做流量、来源、访客、地域、路径等分析了。当然,一般不会直接对原始日志分析,而是会将其清洗格式化后转存到其它地方,如MySQL或HBase中再做分析。
15 
16 分析部分的工作有很多开源的基础设施可以使用,例如实时分析可以使用<a href="https://github.com/nathanmarz/storm">Storm</a>,而离线分析可以使用<a href="http://hadoop.apache.org/">Hadoop</a>。当然,在日志比较小的情况下,也可以通过shell命令做一些简单的分析,例如,下面三条命令可以分别得出我的博客在今天上午8点到9点的访问量(PV),访客数(UV)和独立IP数(IP):
17 <div class="wlWriterEditableSmartContent" id="scid:812469c5-0cb0-4c63-8c15-c81123a09de7:21550f92-f0c2-45bd-a9ff-521038b53714" style="margin: 0px; display: inline; float: none; padding: 0px;">
18 <pre class="c">1
19 awk -F^A '{print $1}' ma-2012102409.log | wc -l
20 awk -F^A '{print $12}' ma-2012102409.log | uniq | wc -l
21 awk -F^A '{print $2}' ma-2012102409.log | uniq | wc -l</pre>
22 <pre class="c">

其它好玩的东西朋友们可以慢慢挖掘。

参考

GA的开发者文档:https://developers.google.com/analytics/devguides/collection/gajs/

一篇关于实现nginx收日志的文章:http://blog.linezing.com/2011/11/%E4%BD%BF%E7%94%A8nginx%E8%AE%B0%E6%97%A5%E5%BF%97

关于Nginx可以参考:http://wiki.nginx.org/Main

OpenResty的官方网站为:http://openresty.org

ngx_lua模块可参考:https://github.com/chaoslawful/lua-nginx-module

本文http抓包使用Chrome浏览器开发者工具,绘制思维导图使用Xmind,流程和结构图使用Tikz PGF

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_768100.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何阻止ajax自动重定向_技巧:IE访问不兼容网站时如何不重定向到Edge中打开...

微软正有条不紊地推进 Edge 迁移工作。首先自 Edge 85 开始&#xff0c;微软整合了 IE 模式&#xff0c;以便于用户兼容使用&#xff1b;对外正式公布了 IE 和经典版 Edge 的停止支持时间表&#xff0c;而现在当用户使用 IE 11 访问某些不兼容的网站时自动重定向到 Edge 浏览器…

在线学习Java的资源网站

CodeGym&#xff08;https://codegym.cc/&#xff09;&#xff1a;一个在线Java编程课程&#xff0c;80%的内容是练习&#xff0c;适合一窍不通的入门者。 CodeAcademy&#xff08;https://www.codecademy.com/&#xff09;&#xff1a;该课程注重的是在找工作时非常有用的技术…

网站服务器宕机,B站服务器宕机惊动上海消防,官微致歉

7月13日晚间&#xff0c;“b站崩了”冲上微博热搜榜第三位。消息称&#xff0c;B站官网疑似出现服务器宕机事故&#xff0c;页面提示称“非常抱歉&#xff0c;该页面暂时无法访问”。7月14日凌晨2点&#xff0c;哔哩哔哩弹幕官微更新动态称“昨晚&#xff0c;B站的部分服务器机…

想要导航首页提示页_网站建设|网站首页这么设计,用户体验更好

这是【建站百科】专栏第18篇原创内容&#xff0c;由我在建站行业从业10年、给上万公司搭建过网站的经验总结而来。hello&#xff0c;艾瑞巴蒂&#xff0c;大梦又来了&#xff0c;今天要说的是作为网站“门面”的网站首页设计。一、 网站首页的重要性作为网站全貌及重要信息、产…

基于LNMP的实验之电子商务网站

实验开始之前的环境检查&#xff1a;iptables ,selinux&#xff08;要处于关闭状态&#xff09; 实验工具&#xff1a;centos7虚拟主机一台 实验步骤如下&#xff1a; 一、安装 ①安装实验所需包 [rootcentos7 ~]# yum install mariadb mariadb-server php php-mysql php-fpm &…

alevel aqa business_学习干货 | ALevel商科学习网站总结

学生小编&#xff0c;有什么方法我可以在日常中锻炼自己的商科思维呀&#xff1f;有很多呀&#xff0c;最简单的就是浏览一些商业资讯或者观看训练商科思维的视频~英联教育学生那小编有没有一些推荐的网站&#xff1f;有有有&#xff0c;小编已经帮你整理好啦&#xff01;就等你…

SpringCloud系列(一)网站架构演变过程—什么是微服务?SpringCloud是什么?

网站架构演变过程 1、传统架构模式&#xff08;单点应用&#xff09; 一般只适合一个人或者是小团队开发 缺点&#xff1a;耦合度太高&#xff0c;一旦某个模块出问题&#xff0c;可能会影响整个服务不可用 2、分布式架构模式&#xff08;对项目进行拆分&#xff09; 由传…

软件测试必学:电子商务网站测试经验总结

有开发就有测试&#xff0c;现在软件测试行业真的很不错。测试网站也是一项很重要的工作。今天我总结了一下如何测试电子商务网站&#xff0c;总体按照两种模式进行划分总结&#xff0c;请往下看哦&#xff01; 一、按照测试类型来划分 1.兼容性1.1主要是在浏览器兼容&#x…

给你一个网站,你如何来做自动化测试的?Web网站测试流程及方法

给你一个网站&#xff0c;你如何来做自动化测试的&#xff1f;今天小编来给大家科普一下Web网站测试流程及方法。 首先&#xff0c;查找需求说明、网站设计等相关文档&#xff0c;分析测试需求。制定测试计划&#xff0c;确定测试范围和测试策略。一般包括以下几个部分&#x…

网站静态化处理

动静分离是让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开来&#xff0c;动静资源做好了拆分以后&#xff0c;我们就可以根据静态资源的特点将其做缓存操作&#xff0c;这就是网站静态化处理的核心思路。由此可见&#xff0c;网站静态化处理的核心就是动…

微软正式发布Azure Storage上的静态网站

微软正式宣布了Azure Storage上的静态网站&#xff0c;提供了从托管在Azure Storage上的HTML、CSS和JavaScript文件提供内容的能力。静态网站包含内容固定的Web页面&#xff0c;同时仍然允许利用JavaScript等客户端代码来创建丰富的用户体验。 有了这个新功能&#xff0c;继用于…

使用Nginx + Node.js部署你的网站(转)

转自&#xff1a;https://www.jianshu.com/p/717f2b88d057 Nginx是一个高性能的HTTP和反向代理服务器&#xff08;反向代理就是通常所说的web服务器加速&#xff0c;它是一种通过在繁忙的web服务器和internet之间增加一个高速的web缓冲服务器来降低实际的web服务器的负载&#…

phpcms网站搬家 至 服务器 完整并且详细过程

想要自己的网站让人们看到那就要上传服务器空间后&#xff0c;这样才会通过搜索域名进行网页访问。 但是在上传的过程中肯定会有很多东西要修改&#xff0c;例如数据库怎么上传、路径怎么修改等。。。。。这些对于生手可能会慌乱&#xff0c;不用害怕&#xff01; 这就让大家看…

制作chrome插件/扩展程序,禁止谷歌浏览器访问某些网站

简单地说&#xff0c;浏览器插件&#xff0c;可以大大的扩展你的浏览器的功能。包括但不仅限于这些功能&#xff1a; 捕捉特定网页的内容捕捉HTTP报文捕捉用户浏览动作&#xff0c;改变浏览器地址栏/起始页/书签/Tab等界面元素的行为与别的站点通信&#xff0c;修改网页内容………

把你开发的网站免费发布到互联网上

2019独角兽企业重金招聘Python工程师标准>>> 0. 前言 之前我们写过很多代码&#xff0c;但几乎都是在自己的电脑上运行的。如果别人要看&#xff0c;也只能在电脑上演示&#xff0c;或者把代码发给他运行。 而在学习 web 开发&#xff0c;比如 Django、Flask、webpy…

营销运作百科:全国公安机关互联网网站安全服务平台备案流程

最近速名网企业建站网站备案完成了。当然&#xff0c;作为一家合法经营的企业网站&#xff0c;建站之后肯定是要去公安系统备案的。现在国家也强制使用国内服务器的用于需要在规定时间30天内在全国互联网安全管理服务平台进行备案&#xff0c;理由其实很简单&#xff0c;因为防…

茶陵SEO优化网站关键词排名如何做才能上首页

今天速名网的主要话题就是围绕如何做好关键词“茶陵SEO”、“茶陵SEO优化”、“茶陵网站关键词排名”、“茶陵SEO关键词排名”、“茶陵关键词排名”的排名而设定的。你是否注意到从标题上&#xff0c;速名网就对关键词进行了拆分与组合&#xff0c;这就是SEO的魅力所在。它不具…

SEO网络营销培训机构都是如何给新手SEO培训的,新手SEO看完就知道套路,以后就不会上当受骗

SEO网络营销培训机构都是如何给新手SEO培训的&#xff1f;如题&#xff0c;今天速名网就来给大家聊聊SEO培训这个话题。诚然&#xff0c;SEO网络营销听起来就很高大上&#xff0c;但是在如今各大平台圈流量形成闭环的情况对于SEO行业来说都是一个寒冬。尤其是短视频营销&#x…

新开网站不收录的原因及解决方法有哪些

新开一个网站发现一个月了收录很少&#xff0c;那么新开网站不收录的原因及解决方法有哪些呢&#xff1f;速名网长期研究SEO优化&#xff0c;尤其是百度SEO关键词排名技术与算法&#xff0c;在实战中&#xff0c;我们总结了这样一条经验。在等待中爆发&#xff0c;做好原创内容…

网站域名对SEO优化的重要性分析

域名重要吗&#xff1f;绝对地。选择正确的域名是您营销策略的重要组成部分。您应该选择一个适合您公司品牌并且不太复杂的域名。名称本身也不是URL中唯一的考虑因素。公司应该考虑TLD&#xff08;顶级域&#xff09;部分。如果您的域是.com、.org或.computers&#xff08;或其…