大型即时通讯系统微信、陌陌架构分析全记录!

点击蓝色“架构文摘”关注我哟

加个“星标”,每天上午 09:25,干货推送!

作者:肉眼品世界

出处:转载自微信公众号:肉眼品世界(ID:find_world_fine)

导读: 像QQ,微信,陌陌这样大的im,即时通讯量很大的,这个是长链接实现,一个长链接一个文件描述符,一台机器的长连接又有限,当然你可以一台机器划分成多个虚拟机,就让一台机器一个65535个的限制,一台机器的资源可以更好的得到复用,也可以调整一些内核参数快速释放一些同时一些wait状态的socket fd;单台机器达到物理上限,自然少不了分布式。

对微信、陌陌等进行了分析的一些资料的分析,发出来分享一下。

电量:对于移动设备最大的瓶颈就是电量了。因为用户不可能随时携带电源,充电宝。所以必须考虑到电量问题。那就要检查我们工程是不是有后台运行,心跳包发送时间是不是合理。

流量:对于好多国内大部分屌丝用户来说可能还是包月100M,现在4g,5g了虽然很多用户好几个g,在那个3g的时代,屌丝们还是很节约的,那么我们必须站在广大用户角度来考虑问题了。一个包可以解决的就一个包。


网络:

这个也是IM最核心的内容了,我们要做到在任何网络下等顺畅聊天那就不容易了,好多公司都用的xmpp框架,如果在强网络环境下,xmpp完全没有问题。但是那种弱网络环境下xmpp就束手无策啦,用户体验就很垃圾了。

个人觉得xmpp 可以玩玩,但是用来真正的产品就差远了。如果遇到一个做IM 的朋友张口闭口都说xmpp 的话,那么不用沟通了,肯定不是什么好产品。微信、QQ以前也曾用过xmpp,但是最后也放弃了xmpp,就知道xmpp有很多弊端了,还有就是报文太大,好臃肿,浪费流量,这玩意儿笔者自己玩过一段时间,显得比较慢,大。为了保证稳定,微信用了长链接和短链接相结合,例如:

1 、两个域名

微信划分了http模式(short链接)和 tcp 模式(long 链接),分别应对状态协议和数据传输协议

long.weixin.qq.com  dns check (112.64.237.188 112.64.200.218)

short.weixin.qq.com  dns check  ( 112.64.237.186 112.64.200.240)

2 说明

2.1 short.weixin.qq.com  

是HTTP协议扩展,运行8080 端口,http body为二进制(protobuf)。

主要用途(接口):

  • 用户登录验证;

  • 好友关系(获取,添加);

  • 消息sync (newsync),自有sync机制;

  • 获取用户图像;

  • 用户注销;

  • 行为日志上报。

  • 朋友圈发表刷新

2.2  long.weixin.qq.com  

tcp 长连接, 端口为8080,类似微软activesync的二进制协议。

主要用途(接口):

  • 接受/发送文本消息;

  • 接受/发送语音;

  • 接受/发送图片;

  • 接受/发送视频文件等。

所有上面请求都是基于tcp长连接。在发送图片和视频文件等时,分为两个请求;第一个请求是缩略图的方式,第二个请求是全数据的方式。

2.2.1 数据报文方面

增量上传策略:

每次8k左右大小数据上传,服务器确认;在继续传输。

图片上传:

先传缩略图,传文本消息,再传具体文件

下载:

先下载缩略图, 在下载原图

下载的时候,全部一次推送。

3 附录

3.1  用户登录验证

POST /cgi-bin/micromsg-bin/auth HTTP/1.1

Accept: **

User-Agent: Mozilla/4.0

Content-Type: application/x-www-form-urlencoded

Host: short.weixin.qq.com

Content-Length: 174

3.3 消息sync (newsync)

POST /cgi-bin/micromsg-bin/newsync HTTP/1.1

Host: short.weixin.qq.com

User-Agent: Android QQMail HTTP Client

Cache-Control: no-cache

Connection: Keep-Alive

Content-Type: application/octet-stream

accept: **

Content-Length:  206

3.5 用户注销

POST /cgi-bin/micromsg-bin/iphoneunreg HTTP/1.1

Accept: */*

User-Agent: Mozilla/4.0

Cotent-Type: application/x-www-form-urlencoded

Host: short.weixin.qq.com

Content-Length: 271

3.6 行为日志上报

POST /cgi-bin/stackreport?version=240000a7&filelength=1258&sum=7eda777ee26a76a5c93b233eed504c7d&reporttype=1&username=jolestar HTTP/1.1

Content-Length: 736

Content-Type: binary/octet-stream

Host: weixin.qq.com

Connection: Keep-Alive

User-Agent: Apache-HttpClient/UNAVAILABLE (java 1.4)

从现在互联网的发展而言,IM和视频(包括IM里面视频通话)是一个方向,这些都应该成为互联网的基础设施,就像浏览器一样。现在IM还没有一个很好的解决方案,XMPP并不能很好地做到业务逻辑独立开来。从IM的本质来看,IM其实就是将一条消息从一个地方传输到另外一个地方,这个和TCP很像,为什么不实现一个高级点的TCP协议了,只是将TCP/IP里面的IP地址换成了一个类似XMPP的唯一ID而已,其他的很多细节都可以照搬TCP协议。有了这个协议之后,将业务逻辑在现有HTTP server的基础上做,例如发送语音和图片就相当于上传一个文件,服务器在处理完这个文件后就发一条特殊的IM消息。客户端收到这个IM消息后,按照IM消息里面url去HTTP server取语音文件和图片文件。将HTTP server和IM server打通之后,可以做很多事情。但将这个两个server合并在一块并不是一个好事,不然腾讯也不会有2005年的战略转型了。从现在的情况来看,应用除了游戏,都没怎么赚钱,现在能够承载赚钱业务的还是以web为主。IM不可以赚钱,但没有却是不行的,就像一个地方要致富,不修路是不行的道理一样。

上面说到了protobuf ,就简单介绍下:

JSON相信大家都知道是什么东西,如果不知道,那可就真的OUT了,GOOGLE一下去。这里就不介绍啥的了。

Protobuffer大家估计就很少听说了,但如果说到是GOOGLE搞的,相信大家都会有兴趣去试一下,毕竟GOOGLE出口,多属精品。

Protobuffer是一个类似JSON的一个传输协议,其实也不能说是协议,只是一个数据传输的东西罢了。

那它跟JSON有什么区别呢?

跨语言,这是它的一个优点。它自带了一个编译器,protoc,只需要用它进行编译,可以编译成JAVA、python、C++代码,暂时只有这三个,其他就暂时不要想了,然后就可以直接使用,不需要再写任何其他代码。连解析的那些都已经自带有的。JSON当然也是跨语言的,但这个跨语言是建立在编写代码的基础上。

陌陌设计:


陌陌发展刚开始由于规模小,30-40W的连接数(包括Android后台长连接用户),也使用XMPP;由于XMPP的缺点:流量大(基于XML),不可靠(为传统固定网络设计,没有考虑WIFI/2G/3G/地铁/电梯等复杂网络场景),交互复杂(登陆需5-6次,尤其是TLS握手);XMPP丢消息的根本原因:服务端和客户端处于“半关闭”状态,客户端假连接状态,服务端有收不到回执;Server端连接层和逻辑层代码没有解耦分离,常常重启导致不可用;


消息中转:


连接层:


逻辑层:


通讯协议设计:


高效:弱网络快速的收发

可靠:不会丢消息

易于扩展

协议格式:


Redis协议:



优化

  • 连接层(参见通讯服务器组成):只做消息转发,允许随时重启更新,设计原则简单/异步;单台压测试连接数70W;现状:1.5亿用户,月活5000W+,连接数1200W+;

  • 逻辑层(参见通讯服务器组成):用户会话验证即登陆、消息存取、异步队列

  • 采用私有通讯协议,目标:高效,弱网络快速收发;可靠:不会丢消息;易于扩展;参考协议格式:REDIS协议;参见协议格式、基于队列的消息协议、基于队列的交互、基于版本号的消息协议、基于版本号的交互等;

  • 核心的长连接只用于传输轻量的实时数据,图片、语音等都开新的TCP或HTTP连接;一切就绪后,最重要的就是监控,写一个APP查看所有的运营状态,每天观察;

  • 如何选择最优路线,即智能路由;

二、智能路由、连接策略:

多端口、双协议支持

应对移动网关代理的端口限制

  • 支持TCP、HTTP两种协议

  • 根据备选IP列表进行并发测速(IP+端口+协议)

  • 后端根据终端连接情况,定时更新终端的备选IP列表

  • 终端在连接空闲时上报测速数据,便于后端决策

  • TCP协议不通,自动切换到http

  • 优先使用最近可用IP

  • 并发测速,根据终端所处的位置下发多组IP、PORT,只用IP,不用域名,手机上的DNS50%不准

负载均衡器(LVS...)的问题– 单点失效

  • 单点性能瓶颈

  • 负载均衡从客户端开始做起• 域名负载的问题

  • 域名系统不可靠– 更新延迟大  

WNS(wireless network services)


1解决移动互联网开发常见问题:

通道:数据交互、大数据上传、push

网络连接:大量长链接管理、链接不上、慢、多地分布

运营支撑:海量监控、简化问题定位

登录&安全:登录鉴权、频率控制



移动互联网特点:

1、高延时: 信道建立耗时( 高RTT)

2、低宽带、高丢包

3、多运营商(电信,移动,联通等)

4、复杂网络  

   -2G,3G,4G,wifi。cmwap,cmnet。。

   -网关限制:协议,端口

5、用户流动性大,上网环境复杂

WNS 性能指标:





1、开发时间:历史一年半

2、链接成功率-99.9%

3、极端网络环境下成功率-由于常见app

4、crash率 -0.02%(crash次数/登录用户数)

微信后台系统架构


背景:

A、分布式问题收敛

 后台逻辑模块专注逻辑,快速开发

可能读取到过时的数据是个痛点

需要看到一致的数据

B、内部定义

 数据拥有两个以上的副本

如果成功提交了变更,那么不会再返回旧数据

推演:

1增加一个数据

2 序列号发生器,偏序

约束:只能有一个client操作

client有解决冲突的能力

问题转移:client如何分布?

3 修改集群中一个制定的key的value

1)覆盖他

2)根据value的内容做修改

if value = 1 then value :=2

通用解法:

1)paxos算法

工程难度

一切可控

分布式算法设计:

2)quorum算法(2011)

再单个key上面运算

真是系统约束

类paxos方案,简化

为每次变更选举(by key)

算法过程

提议/变更/同步/广播

系统架构


写流程


Replication & Sharding

权衡点

 自治,负载均衡,扩散控制

replication->relation

容灾抵消

同城(上海)多数派存活

三园区(独立供电,独立)

Sharding

一组KV6 为一个单位

1、人工阶段

局部扩容,影响收敛9

2均匀分布 制定分段hash32 (string)

翻倍扩容

3一致性哈希

具体实现?

1、业务侧快速开发

存储需要提供强一致性

丰富的数据模型支持(结构化、类SQL/KV)

条件读,条件写

2 业务增长迅速,系统要能够方便的横向扩容

3设备故障/短时节点实效便成为常态,容灾自动化,主碑可写无需人工介入

4小数据


存储模型

纯内存

Bitcask

小表系统

LSM-tree


小表系统

1、解决放大问题

2、数据按变更聚集存储

3、Affected1

  ChangeTable

(1+2+。。。。+n-1+total)/n

4、分裂与合并

数据流动

1、自动化迁移

2、节点同时做代理

3、合并磁盘io

同步流量

1、数据vs 操作

2、幂等

3、保底策略

通信包量

1、动态合并

   100K qps

   200% -10%

3、权衡与估算

设计要点

1、吞吐量

2、异步化

3、复杂度

4、libco

自动修复系统

1、不要让错误累计

2、全量扫描

bitcask 的一些变化

1、内存限制

2、全内存

推荐阅读:


如有收获,点个在看,诚挚感谢
架构文摘
关注 关注
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信语音技术原理_微信语音电话是如何实现的?
weixin_39925350的博客
12-24 8016
贴个我之前的回答吧,一个原理微信电话本上线了!对运营商的冲击有多大?这个问题先放一放。作为一个通信工程师,我想从技术的角度去分析一下两者区别?我的结论是:VoLTE完胜!但是,技术不一定换得来市场,未来几何?仍然是个未知数。乍一看,两者没有什么区别。VoLTE就是无线语音技术的下一代,看起来很像无线连接的VoIP业务。一定程度上说,它就是的,将语音通过IP包来传输。但从技术上说,它又不完全是的。首...
仿QQ,仿陌陌即时通讯带服务器端
01-15
仿QQ,仿陌陌即时通讯带服务器端
从0到10亿,微信后台架构及基础设施设计与实践
Java程序员的知识博客
03-23 1037
摘要:微信后台业务类型众多,包括即时通信,社交网络,金融支付等等。本次分享着重讨论如何在海量用户场景下,后台架构设计中的共性部分如高可用、强一致、快速迭代等等,微信是如何在不断变化的背景下设计统一的架构与基础设施来解决核心难题。 本文根据许家滔老师在2018年10月17日【第十届中国系统架构师大会(SACC2018)】现场演讲内容整理而成。 回顾微信发展历程 2011年,我们发布了第一版微信,2012年,推出视频聊天功能。如今,微信的活跃用户数已经达到10亿。后台涉及到的技术很多,我这边主要
微信团队分享:来看看微信十年前的IM消息收发架构,你做到了吗
最新发布
hellojackjiang2011的博客
04-11 58
好的架构是迭代出来的,却也少不了良好的设计,本文将带大家回顾微信背后最初的也是最核心的IM消息收发技术架构,愿各位读者能从中获得启发。
wifidog添加URL白名单[放行微信]
liuzheng081的博客
06-27 5783
通读wifidog的源码可以发现wifidog的各种策略都是通过iptables实现的 而wifidog本身并没有实现URL白名单,通过修改代码实现也可以,通过外在的iptables命令实现也可以 iptables实现的原理是把白名单URL当成认证服务器一样的来处理,策略中如何处理认证服务器,就如何处理白名单! 下面是实现放行微信的命令 iptables -I WiFiDo
微信消息传输机制
热门推荐
洋葱专栏-有灵魂的程序员
07-28 3万+
微信消息是一种即时通讯;消息即时传递和用户交互性。 即时通信原理 即时通信是一种基于网络的通信技术,涉及到IP/TCP/UDP/Sockets、P2P、C/S、多媒体音视频编解码/传送、WebService等多种技术手段。无论即时通信系统的功能如何复杂,它们大都基于相同的技术原理,主要包括客户/服务器(C/S)通信模式和对等通信(P2P)模式。(来自百度文库)这里主要说说C/S架构的通讯...
微信陌陌 架构方案分析
06-05 978
近两年、手机应用,莫过于微信陌陌之类最受欢迎;但实现原理,分享文章甚少。 故,提出两种方案,供分享;不对之处,敬请留言学习。 目标 解决大型应用(微信陌陌级别)中,用户经纬度在不断更新,用户查找频繁的问题。(每分钟1000W级) =========================================================================
通信架构
weixin_30377461的博客
07-22 36
1.纯走http https 2.DUBBO是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,使用RPC远程调度 DUBBO是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案 DUBBO是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案 DUBBO是一个分布式服务框架,致力于提供高性能和透明化的RPC...
即时通讯架构之路
zhaoyang0429的博客
04-02 2463
前言 即时通信是指能够实时发送和接收互联网消息等的业务通信系统,允许两人或多人使用网络实时的传递文字消息、文件、语音与视频交流,其主要的功能核心是收发消息。即时通信发展至今,已是非常重要的互联网应用形态之一,尤其移动互联网时代,它正以无与论比的优势降低了沟通成本和交流门槛,对各种应用形态产生了深远影响。 做为即时通信开发者或即将成为即时通信开发者的技术人员,即时通信的价值和重要性不言自明。但从技术实现来说,即时通信系统的开发(尤其是移动端即时通信)还是存在许多技术难点和坑点的。也正因如此,优质的即时通信开发
php业务关系结构图,一套亿级用户的IM架构技术干货(上篇):整体架构、服务拆分等...
weixin_29099217的博客
03-27 439
具体解释就是:1)高可靠:确保不丢消息;2)高可用:任意机房或者服务器挂掉,不影响服务;3)实时性:不管用户在哪里,在线用户消息在1秒内达到(我们实际是75%消息可以做到120ms);4)有序性:确保用户消息的有序性,不会出现发送和接受的乱序。5、架构拆分从整体架构上来说,亿级用户量的IM架构整体上偏复杂。传统开源的IM服务喜欢把所有服务做到1-2个服务里(Connector+Service模型...
许家滔 - 微信后台架构与基础设施简介
11-17
微信后台架构 数据存储与微服务框架 PaxosStore架构简介
即时通讯APP源码 IM原生APP高仿微信全源码无加密
09-28
高仿微信即时通讯 APP源码,IM 原生 APP源码,全源码开源无加密。
微信陌陌等著名IM软件设计架构详解
02-20
微信陌陌等进行了分析,发出来分享一下(时间有些久了)电量:对于移动设备最大的瓶颈就是电量了。因为用户不可能随时携带电源,充电宝。所以必须考虑到电量问题。那就要检查我们工程是不是有后台运行,心跳包...
基于Python的微信聊天记录提取与分析系统设计源码
04-08
微信聊天记录提取与分析系统 - 基于Python开发,包含247个文件,如PY、PNG、SVG、HTML、MD、JSON、YML、PYD、JPG和TXT等。该系统可提取微信聊天记录,并将其导出为HTML、Word、CSV文档进行永久保存,同时提供聊天...
2021仿PC微信即时通讯聊天系统
12-16
带前端和服务端源码,含群聊+私聊+朋友圈+钱包等模块
25页PPT带你吃透微信陌陌等著名IM软件设计架构(值得珍藏)
02-24 604
微信陌陌等进行了分析,发出来分享一下。电量:对于移动设备最大的瓶颈就是电量了。因为用户不可能随时携带电源,充电宝。所以必须考虑到电量问题。那就要检查我们工程是不是有后台运行,心跳包发送...
微信陌陌等著名im软件设计架构详解
09-06
微信陌陌是两个著名的即时通讯软件,它们的设计架构具有以下特点。 首先,微信架构可以分为客户端和服务器端两部分。客户端采用C++语言开发,支持主流的移动操作系统,包括iOS和Android。服务器端主要分为消息中心、用户管理、资源存储和推送服务等模块,通过分布式架构实现高可用性和高性能。 其次,微信客户端的架构采用MVC(Model-View-Controller)模式。模型(Model)层负责处理数据请求和数据存储,视图(View)层负责界面的展示,控制器(Controller)层负责处理用户操作和业务逻辑。这样的分层结构使得代码更加清晰、易于维护。 再次,微信的核心功能包括即时通信、社交、支付、公众号等。在即时通信方面,微信通过建立长连接,并采用自定义通信协议和加密算法,保证了消息的安全和可靠传输。在社交方面,微信实现了好友关系、群聊等功能,同时提供了朋友圈等社交媒体功能。支付方面,微信集成了多种支付方式,方便用户进行在线交易。公众号则为企业和个人提供了内容推送、客服等服务。 与微信相比,陌陌架构设计更加简洁。陌陌也分为客户端和服务器端两部分。客户端采用Objective-C和Java语言开发,同样支持主流的移动操作系统。服务器端采用分布式架构,包括用户服务器、消息服务器和推送服务器等模块,以满足大规模用户访问的需求。 陌陌的核心功能是附近的人和短信。附近的人通过获取用户的地理位置信息,将附近的其他用户展示给用户,并提供了聊天、发动态等功能。短信则是陌陌提供的一种语音通讯方式,用户可以发送语音消息给好友。同时,陌陌还提供了社交游戏、红包等功能,丰富了用户的交互体验。 总的来说,微信陌陌都是基于分布式架构设计的著名IM软件,它们在安全性、性能、功能丰富等方面都具备优势,为用户提供了便捷的即时通讯和社交功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
写文章

热门文章

  • 史上最全的Ceph介绍、原理、架构 67691
  • 服务发现框架选型,Consul还是Zookeeper还是etcd 14979
  • 哔哩哔哩(B站)的前端之路 13043
  • 聊聊自动化测试框架 12796
  • ChatGPT可以帮我们做哪些事? 12279

最新评论

  • 强力推荐一个完善的物流(WMS)管理项目(附代码)

    行走的人型机器: 1819

  • SpringBoot+SpringCloud+Mybatis+Vue电商项目实战,附视频+源码+文档,包含所有主流技术栈...

    天蓝999: 可以的,我看的另一个SpringBoot视频,从零开发,十天掌握了项目实战:https://knife.blog.csdn.net/article/details/134911141

  • 数据可视化:基于 Echarts + SpringBoot 的动态实时大屏银行监管系统【源码】

    CO₂96: 二维码在哪里

  • 《解构领域驱动设计》- DDD 设计统一过程

    量小无才: 还没有做到通俗易懂,毕竟大道至简是对表达者的考验。

  • 很全的敏感词匹配系统的设计与实践

    严简易: 博主还在用csdn吗?我想问一下这个架构在物理存储上是如何实现的?

您愿意向朋友推荐“博客详情页”吗?

  • 强烈不推荐
  • 不推荐
  • 一般般
  • 推荐
  • 强烈推荐
提交

最新文章

  • 中国电信裁减 22000 人。。。
  • 高逼格的SQL写法:行行比较
  • 再见VMware,一款更轻量级的虚拟机!
2024
06月 9篇
05月 18篇
04月 22篇
03月 24篇
02月 18篇
01月 27篇
2023年240篇
2022年262篇
2021年289篇
2020年328篇
2019年188篇
2018年223篇
2017年25篇

目录

目录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43元 前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值

深圳SEO优化公司南通百度标王价格坪地营销网站哪家好平湖网站优化按天扣费公司伊春至尊标王多少钱武汉设计公司网站推荐武威网站推广哪家好银川网页制作价格连云港百度标王哪家好北海优秀网站设计多少钱清徐seo网站优化公司开封关键词排名推荐随州网站优化按天扣费哪家好邢台关键词排名包年推广多少钱鄂州企业网站建设公司怀化模板推广报价汕头网页设计价格大同模板网站建设推荐开封品牌网站设计推荐吴忠网站制作设计公司白山网络推广哪家好黄南企业网站设计哪家好台州网站优化推广报价商丘外贸网站制作宿迁百度爱采购报价乐山seo报价南平模板网站建设公司阳江网络营销怒江关键词按天计费公司贵港建站哪家好兰州网站定制价格歼20紧急升空逼退外机英媒称团队夜以继日筹划王妃复出草木蔓发 春山在望成都发生巨响 当地回应60岁老人炒菠菜未焯水致肾病恶化男子涉嫌走私被判11年却一天牢没坐劳斯莱斯右转逼停直行车网传落水者说“没让你救”系谣言广东通报13岁男孩性侵女童不予立案贵州小伙回应在美国卖三蹦子火了淀粉肠小王子日销售额涨超10倍有个姐真把千机伞做出来了近3万元金手镯仅含足金十克呼北高速交通事故已致14人死亡杨洋拄拐现身医院国产伟哥去年销售近13亿男子给前妻转账 现任妻子起诉要回新基金只募集到26元还是员工自购男孩疑遭霸凌 家长讨说法被踢出群充个话费竟沦为间接洗钱工具新的一天从800个哈欠开始单亲妈妈陷入热恋 14岁儿子报警#春分立蛋大挑战#中国投资客涌入日本东京买房两大学生合买彩票中奖一人不认账新加坡主帅:唯一目标击败中国队月嫂回应掌掴婴儿是在赶虫子19岁小伙救下5人后溺亡 多方发声清明节放假3天调休1天张家界的山上“长”满了韩国人?开封王婆为何火了主播靠辱骂母亲走红被批捕封号代拍被何赛飞拿着魔杖追着打阿根廷将发行1万与2万面值的纸币库克现身上海为江西彩礼“减负”的“试婚人”因自嘲式简历走红的教授更新简介殡仪馆花卉高于市场价3倍还重复用网友称在豆瓣酱里吃出老鼠头315晚会后胖东来又人满为患了网友建议重庆地铁不准乘客携带菜筐特朗普谈“凯特王妃P图照”罗斯否认插足凯特王妃婚姻青海通报栏杆断裂小学生跌落住进ICU恒大被罚41.75亿到底怎么缴湖南一县政协主席疑涉刑案被控制茶百道就改标签日期致歉王树国3次鞠躬告别西交大师生张立群任西安交通大学校长杨倩无缘巴黎奥运

深圳SEO优化公司 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化