大家好,我3y啊。由于去重逻辑重构了几次,好多股东直呼看不懂,于是我今天再安排一波对代码的解析吧。austin支持两种去重的类型:N分钟相同内容达到N次去重和一天内N次相同渠道频次去重。
在最开始,我的第一版实现是这样的:
publicvoidduplication(TaskInfotaskInfo){//配置示例:{"contentDeduplication":{"num":1,"time":300},"frequencyDeduplication":{"num":5}}JSONObjectproperty=JSON.parseObject(config.getProperty(DEDUPLICATION_RULE_KEY,AustinConstant.APOLLO_DEFAULT_VALUE_JSON_OBJECT));JSONObjectcontentDeduplication=property.getJSONObject(CONTENT_DEDUPLICATION);JSONObjectfrequencyDeduplication=property.getJSONObject(FREQUENCY_DEDUPLICATION);//文案去重DeduplicationParamcontentParams=DeduplicationParam.builder().deduplicationTime(contentDeduplication.getLong(TIME)).countNum(contentDeduplication.getInteger(NUM)).taskInfo(taskInfo).anchorState(AnchorState.CONTENT_DEDUPLICATION).build();contentDeduplicationService.deduplication(contentParams);//运营总规则去重(一天内用户收到最多同一个渠道的消息次数)Longseconds=(DateUtil.endOfDay(newDate()).getTime()-DateUtil.current())/1000;DeduplicationParambusinessParams=DeduplicationParam.builder().deduplicationTime(seconds).countNum(frequencyDeduplication.getInteger(NUM)).taskInfo(taskInfo).anchorState(AnchorState.RULE_DEDUPLICATION).build();frequencyDeduplicationService.deduplication(businessParams);}
(相关资料图)
那时候很简单,基本主体逻辑都写在这个入口上了,应该都能看得懂。后来,群里滴滴哥表示这种代码不行,不能一眼看出来它干了什么。于是怒提了一波pull request重构了一版,入口是这样的:
publicvoidduplication(TaskInfotaskInfo){//配置样例:{"contentDeduplication":{"num":1,"time":300},"frequencyDeduplication":{"num":5}}Stringdeduplication=config.getProperty(DeduplicationConstants.DEDUPLICATION_RULE_KEY,AustinConstant.APOLLO_DEFAULT_VALUE_JSON_OBJECT);//去重DEDUPLICATION_LIST.forEach(key->{DeduplicationParamdeduplicationParam=builderFactory.select(key).build(deduplication,key);if(deduplicationParam!=null){deduplicationParam.setTaskInfo(taskInfo);DeduplicationServicededuplicationService=findService(key+SERVICE);deduplicationService.deduplication(deduplicationParam);}});}我猜想他的思路就是把构建去重参数和选择具体的去重服务给封装起来了,在最外层的代码看起来就很简洁了。后来又跟他聊了下,他的设计思路是这样的:考虑到以后会有其他规则的去重就把去重逻辑单独封装起来了,之后用策略模版的设计模式进行了重构,重构后的代码 模版不变,支持各种不同策略的去重,扩展性更高更强更简洁
确实牛逼。
我基于上面的思路微改了下入口,代码最终演变成这样:
publicvoidduplication(TaskInfotaskInfo){//配置样例:{"deduplication_10":{"num":1,"time":300},"deduplication_20":{"num":5}}StringdeduplicationConfig=config.getProperty(DEDUPLICATION_RULE_KEY,CommonConstant.EMPTY_JSON_OBJECT);//去重ListdeduplicationList=DeduplicationType.getDeduplicationList();for(IntegerdeduplicationType:deduplicationList){DeduplicationParamdeduplicationParam=deduplicationHolder.selectBuilder(deduplicationType).build(deduplicationConfig,taskInfo);if(Objects.nonNull(deduplicationParam)){deduplicationHolder.selectService(deduplicationType).deduplication(deduplicationParam);}}} 到这,应该大多数人还能跟上吧?在讲具体的代码之前,我们先来简单看看去重功能的代码结构(这会对后面看代码有帮助)
去重的逻辑可以统一抽象为:在X时间段内达到了Y阈值,还记得我曾经说过:「去重」的本质:「业务Key」+「存储」。那么去重实现的步骤可以简单分为(我这边存储就用的Redis):
通过Key从Redis获取记录判断该Key在Redis的记录是否符合条件符合条件的则去重,不符合条件的则重新塞进Redis更新记录为了方便调整去重的参数,我把X时间段和Y阈值都放到了配置里{"deduplication_10":{"num":1,"time":300},"deduplication_20":{"num":5}}。目前有两种去重的具体实现:
1、5分钟内相同用户如果收到相同的内容,则应该被过滤掉
2、一天内相同的用户如果已经收到某渠道内容5次,则应该被过滤掉
从配置中心拿到配置信息了以后,Builder就是根据这两种类型去构建出DeduplicationParam,就是以下代码:
DeduplicationParamdeduplicationParam=deduplicationHolder.selectBuilder(deduplicationType).build(deduplicationConfig,taskInfo);
Builder和DeduplicationService都用了类似的写法(在子类初始化的时候指定类型,在父类统一接收,放到Map里管理)
而统一管理着这些服务有个中心的地方,我把这取名为DeduplicationHolder
/***@authorhuskey*@date2022/1/18*/@ServicepublicclassDeduplicationHolder{privatefinalMapbuilderHolder=newHashMap<>(4);privatefinalMapserviceHolder=newHashMap<>(4);publicBuilderselectBuilder(Integerkey){returnbuilderHolder.get(key);}publicDeduplicationServiceselectService(Integerkey){returnserviceHolder.get(key);}publicvoidputBuilder(Integerkey,Builderbuilder){builderHolder.put(key,builder);}publicvoidputService(Integerkey,DeduplicationServiceservice){serviceHolder.put(key,service);}} 前面提到的业务Key,是在AbstractDeduplicationService的子类下构建的:
而具体的去重逻辑实现则都在LimitService下,{一天内相同的用户如果已经收到某渠道内容5次}是在SimpleLimitService中处理使用mget和pipelineSetEX就完成了实现。而{5分钟内相同用户如果收到相同的内容}是在SlideWindowLimitService中处理,使用了lua脚本完成了实现。
LimitService的代码都来源于@caolongxiu的pull request,建议大家可以对比commit再学习一番:https://gitee.com/zhongfucheng/austin/pulls/19
1、频次去重采用普通的计数去重方法,限制的是每天发送的条数。
2、内容去重采用的是新开发的基于redis中zset的滑动窗口去重,可以做到严格控制单位时间内的频次。
3、redis使用lua脚本来保证原子性和减少网络io的损耗
4、redis的key增加前缀做到数据隔离(后期可能有动态更换去重方法的需求)
5、把具体限流去重方法从DeduplicationService抽取出来,DeduplicationService只需设置构造器注入时注入的AbstractLimitService(具体限流去重服务)类型即可动态更换去重的方法 6、使用雪花算法生成zset的唯一value,score使用的是当前的时间戳
针对滑动窗口去重,有会引申出新的问题:limit.lua的逻辑?为什么要移除时间窗口的之前的数据?为什么ARGV[4]参数要唯一?为什么要expire?
A: 使用滑动窗口可以保证N分钟达到N次进行去重。滑动窗口可以回顾下TCP的,也可以回顾下刷LeetCode时的一些题,那这为什么要移除,就不陌生了。
为什么ARGV[4]要唯一,具体可以看看zadd这条命令,我们只需要保证每次add进窗口内的成员是唯一的,那么就不会触发有更新的操作(我认为这样设计会更加简单些),而唯一Key用雪花算法比较方便。
为什么expire?,如果这个key只被调用一次。那就很有可能在redis内存常驻了,expire能避免这种情况。
推荐项目最后再叨叨吧,很多人可能会发一段截图,跑来问我为什么要这样写,为什么要以这种方式实现,能不能以这种方式实现。这时候,我更想看到的是:你已经实现了第二种方式了,然后探讨你写的这种方案好不好,现有的代码差在哪里。
毕竟问问题很简单,我又不是客服,总不能没诚意的问题我都得一一回答吧。
如果想学Java项目的,我还是强烈推荐我的开源项目消息推送平台Austin,可以用作毕业设计,可以用作校招,可以看看生产环境是怎么推送消息的。
仓库地址(可点击阅读原文跳转):https://gitee.com/zhongfucheng/austin
我开通了股东服务内容,感兴趣可以点击下方看看,主要针对的是项目哟
VIP服务
标签:
解剖屎山,寻觅黄金之第二弹 大家好,我3y啊。由于去重逻辑重构了几次,好多股东直呼看不懂,于是我
国际权威期刊Nature聚焦伊利益生菌,全佳益研究成果引发全球行业关注 世界观速讯 近日,全球学术界享有盛誉的国际综合性科学杂志《Nature》推出中国营养
辽篮完成重要签约!两届总决赛FMVP顶薪留队,帮助杨鸣冲击三连冠-环球速递 辽篮完成重要签约!两届总决赛FMVP顶薪留队,帮助杨鸣冲击三连冠,杨鸣,
以下哪种方法有助于猫咪消暑降温-天天即时 以下哪种方法有助于猫咪消暑降温?正确答案是【让猫咪多喝水】。天气热
看热讯:勇哥探案 | 离婚冷静期出轨、病逝后被发现生前出轨,过错方要付代价吗? 案件简介:近日,重庆市大足区法院审结一起离婚纠纷案件。男子李某与女
每日热文:海报|三晋夏收农忙“丰”景 又是一年夏收时。近日,山西省各地小麦陆续进入收获期,田间地头,处处
vivo X90 Pro+手机获推OriginOS 3 21.4:新增隐私打码、断点续传
|今日精选 IT之家6月16日消息,vivoX90Pro+获推OriginOS321 4系统更新,具体版本
当前热议!IDC概念上市公司龙头股有哪些?(2023/6/16) IDC概念上市公司龙头股有哪些?(2023 6 16),IDC概念上市公司龙头有:
新任国防部新闻发言人张晓刚亮相-环球精选 今天,新任国防部新闻发言人张晓刚亮相。(记者淳于怀涛)
科技渗透到农业生产各环节 夯实丰产基础 农业农村部小麦机收调度显示,目前,全国麦收进度已过九成,进入尾声。
天天精选!三亚传媒影视集团牵头爱心接力行动 十岁重病女孩芯芯懂事到让家长心疼 家里的凳子上,摆放着芯芯的书包和3个小玩偶,本报记者陈超全摄连日来
每年不少于50个岗位 退役军人进校园工作有三种渠道 2022年6月,我市出台并实施《厦门市实施退役军人教师培养计划工作方案
当前聚焦:泗洪县六个老旧小区改造全面启动 泗洪县六个老旧小区改造全面启动,泗洪县,住建局,老旧小区
解剖屎山,寻觅黄金之第二弹 大家好,我3y啊。由于去重逻辑重构了几次,好多股东直呼看不懂,于是我
红酒品鉴必备基础知识有哪些?_今日讯 一、葡萄酒的种类葡萄酒种类繁多,一般分为不起泡葡萄酒及起泡葡萄酒两
天天速看:近期云南多地有持续性较强降雨 6月16日,记者从省气象台获悉,6月16日至18日白天,我省东部、南部和西
受欧洲最大天然气田或将关闭的消息影响 欧洲天然气价格一度飙升30% 【亚汇网】-消息人士告诉彭博社,欧洲最大的天然气田将于10月1日关闭,
《漫长的季节》全面分析:最惨的是龚彪,最坏的女人是丽茹 婚姻,是男人第二次投胎!只不过此前的影视剧,都没有特别的说明这点但
焦点简讯:透过数据看经济“跃动” 播放暂停
【天天热闻】体验35万最值得买的家用SUV 蔚来全新ES6只有一个缺点? 在蔚来的二代车中,真正走量的ET5的销量并没有取得爆款,真说“你买我
看热讯:勇哥探案 | 离婚冷静期出轨、病逝后被发现生前出轨,过错方要付代价吗? 案件简介:近日,重庆市大足区法院审结一起离婚纠纷案件。男子李某与女
当前视点!全链条中国造,思考起来更像人!紫东太初全模态大模型发布 不光能读懂文字、图像,还能理解音频、视频,甚至3D模型、传感信号,思
集结20支乡镇队伍,海南版排球“村VA”本月底开打! 环球热讯 新海南客户端、南海网6月16日消息(记者吴岳文)久久不见“九九”见!6
美总统参选人称意识到或将被中情局枪杀:正采取措施加以预防 小罗伯特·肯尼迪(资料图)肯尼迪在当天的播客节目《乔·罗根经历》中
我国首艘海陆一体化生产运营的智能FPSO“海洋石油123”交付 人民网北京6月16日电(记者杜燕飞)记者从中国海油获悉,今日,由中国
阿特斯涨20% 机构净买入1.72亿元|每日快播 阿特斯涨20%机构净买入1 72亿元
环球微资讯!交通运输执法人员服务哈洽会 为保障第三十二届哈洽会顺利举行,按照交通运输厅的工作部署,省交通运
栗子煮多久 栗子煮多少分钟|环球观点 1、煮栗子需要15-30分钟。2、煮板栗是大火烧开之后,转小火煮,煮15-30
实时焦点:第五届中国西藏旅游文化国际博览会开幕 原标题:新华全媒+丨第五届中国西藏旅游文化国际博览会开幕这是第五届
每日快讯!一路走好!7天8位名人相继去世,有4人未满40岁,最年轻者仅21岁 广告qq售卖平台玉米QQ业务网Q超会Q会员各类QQ业务低价开通×虽说生死有
【全球播资讯】12-13岁小男孩礼物 1 电子游戏机2 体育用品(足球、篮球、乒乓球拍等)3 骑自行
滴滴租车在全国300个城市上线服务-天天看热讯 驱动中国2023年6月15日消息据滴滴官方消息,滴滴租车正式上线运营,用
艾琳科技与健康同行,与梦想为伴共创理想人生 随着国民经济和科学技术的发展,仅仅舒适安全的普通家居已经不能满足人
51岁赵文卓再现铁汉柔情,搂妻子晒玫瑰花照纪念结婚17周年,女方回应8个字秀恩爱 6月12日晚,男星赵文卓晒出一组照片,庆祝和妻子结婚17周年。广告手工
“末日博士”鲁比尼:高利率、粘性通胀、信贷紧缩三大因素叠加,美国经济注定陷入衰退 中国日报网6月16日电(党超峰)美国《商业内幕》网站15日报道,被称为
每日报道:44岁廖碧儿被曝脚踩两条船,遭质疑拜金只想嫁豪门,本人大方回应 饿了吗?戳右边关注我们,每天给您送上最新出炉的娱乐硬核大餐!6月11
禹棹焕李相二主演韩剧《猎犬》夺Netflix电视节目部门全球第一名|天天快看 搜狐韩娱讯韩剧《猎犬》夺得了Netflix电视节目部门全球第一名。流媒体
金庸小说里的大侠为什么都在报“杀父之仇”?|父亲节特辑_环球快报 金庸小说里的大侠为什么都在报“杀父之仇”?|父亲节特辑,郭靖,杨过,
新华全媒+|抓好关键期 各方助力高校毕业生就业 眼下正值高校毕业季,记者在广东、湖北、辽宁等地采访发现,各地各有关
视焦点讯!【新华500】新华500指数(989001)16日涨0.96% 新华500指数(989001)16日收盘涨0 96%,报4367 86点。指数盘中最高触
ST阳光城:重庆渝能产业以其名下部分房产提供抵押以及重庆渝能产业100%股权质押_全... 南方财经6月16日电,ST阳光城发布《关于为子公司提供担保的进展公告》
焦点快报!谷歌推出独具特色脚本编辑器:打造个性化智能家居体验 近日,谷歌为其智能家居产品GoogleHome推出了一款全新的编辑器。与其他
端午节去哪儿丨延庆全域可赏~邀你一起high翻端午小长假→|世界关注 快来延庆开启有趣好玩的全域旅游新体验!
甘肃青年公益发展大会在兰州召开 6月16日,甘肃青年公益发展大会在兰州召开,大会以“爱心甘肃益善未来
鲱鱼罐头有营养吗 鲱鱼罐头的营养高吗|每日速读 1、鲱鱼鱼肉中富含硒元素、碘元素,它可以起到抗老化以及抗癌症的效果
6月16日中大力德涨停分析:减速器,机器人,智能制造概念热股 环球滚动 中大力德涨停收盘,收盘价35 83元。该股于9点25分涨停,未打开涨停,截
数读中国 | 5月份经济运行总体延续恢复态势 本文转自【人民网】;国家统计局15日发布数据显示,2023年5月份,各地
苏翊鸣保送清华,郑钦文成为李娜学妹,王哲林张镇麟无缘上海交大-全球热头条 其中,北京冬奥会单板滑雪冠军苏翊鸣被保送清华大学。此外,女子举重奥
被控受贿2637万元,安徽省人民政府原副秘书长王诚受审 速读 6月16日上午,安徽省人民政府原副秘书长王诚涉嫌受贿罪、滥用职权罪一
天天快资讯:2023城区中考期间这些路段实施交通管制! 本周末(6月17日-19日)就要中考啦!与高考相比中考的气氛没有那么紧张
百度电商联手苏宁易购,这个618有好戏看了 每年的618无疑都是各大电商平台贴身肉搏、刺刀见红的时刻,各家为了拿
吉他最基础的6个和弦指法 吉他最基础的6个和弦 世界速看料 今天来聊聊关于吉他最基础的6个和弦指法,吉他最基础的6个和弦的文章,
全球今亮点!soy sauce(soy) 1、这是西班牙语,意思是:不知道没有你要怎么生活,没有了你我没有任
莲都开展过期食品安全专项检查 当前热议 “我们学会了分辨‘三无食品’、临期食品,还知道了酸奶和酸奶饮品的区
世界速讯:国足胜缅甸,不是聊胜于无,而是不值得一提,只能说国足是自降身份降维... 因为缅甸足球在亚洲几乎是没有什么存在感的,真的不知道国足选择缅甸热
今日四大交叉货币对多空情绪分析报告(2023/6/16) 世界今亮点 澳元 日元看多:24 39%看空:75 61%基本面情况:澳元方面,西太平洋银
字母哥紧急撤离球馆!球迷投掷烟雾弹引起骚乱 希腊豪门面临重罚 (资料图片仅供参考)北京时间6月16...
全球焦点!国电南瑞:6月16日融资买入1416.57万元,融资融券余额6.57亿元 6月16日,国电南瑞(600406)融资...
山东有哪些艺术大学排名本科一览表最新完整版_聚焦 1、山东有哪些艺术大学排名山东省...
今亮点!东方雨虹:李卫国及其一致行动人累计质押公司股份约2.82亿股 东方雨虹:李卫国及其一致行动人累...
天天精选!三亚传媒影视集团牵头爱心接力行动 十岁重病女孩芯芯懂事到让家长心疼 家里的凳子上,摆放着芯芯的书包和...
6月16日中燃上海地区燃料油报价平稳 环球通讯 生意社获悉,6月16日中燃上海地区...
2018广州车展:汉腾X5 MAX正式发布_天天播资讯 【第一新车2018广州车展】2018广州...
环球速看:火炬开花后怎么养 火炬开花后如何养护 1、花后应尽早剪除残花枝不使其结...
天天最新:我发现互联网工作的性价比还在持续走低,没看到好转的迹象 互联网行业工作的性价比,越来越低...
IWG集团签署广东首个管理项目 并首发HQ品牌 此次签署筹备的HQ中心位于广州市番...
1530亿晶体管死磕NVIDIA!AMD MIX300X加速卡功耗达750W 快科技6月16日消息,日前,AMD公布...
欧睿国际董事:关于中国酒饮新消费的三点观察 欧睿国际董事、大中华与澳洲区总监...
车展首秀!欣旺达超低温钠离子电池亮相2023粤港澳大湾区车展|快播 6月16日,第二十七届粤港澳大湾区...
河南一女子40年没睡过觉,专家连续监控48小时后,真相水落石出|环球关注 人是铁,饭是钢,一天不吃饿得慌,...
点餐先扫码?上海亮剑整治餐厅过度采集个人信息-环球热讯 去饭店吃饭,要点餐必须先扫码?对...
百事通!我为群众办实事丨广场舞噪音扰民 浐灞生态区:加强巡查频次 6月6日,有市民向华商报反映称,当...
海大集团 饲料业务竞争力强 生猪养殖成本管控优异-焦点速看 2022年全国工业饲料总产量30223 4...
美国前总统特朗普否认全部联邦刑事重罪指控,称国家“腐败” 环球资讯 当地时间6月13日,美国前总统特朗...
滴滴完善收入分配 9成司机月均抽成低于20% 三言科技6月16日消息,滴滴宣布推...
爱吵架,每次吵架都会赢的2个生肖-焦点热门 不得不说生肖鸡是一个逻辑性很强的...
宁陕秦岭山货大集将走进安康龙舟节-世界速看料 宁陕秦岭山货大集将走进安康龙舟节
独立显卡与集成显卡的区别_独立显卡与集成显卡有哪些不同 世界观速讯 欢迎观看本篇文章,小升来为大家解...
篮协公布国字号今夏主要任务 男女篮为奥运资格而战 北京时间6月16日消息,中国篮协在...
“你俩真像!”山东一男子在火车上,竟发现一人跟自己一模一样 “你俩真像!”2021年,山东一男子...
国际权威期刊Nature聚焦伊利益生菌,全佳益研究成果引发全球行业关注 世界观速讯 近日,全球学术界享有盛誉的国际综...
Dynabook推出Portégé X30L-K笔记本电脑:支持高度定制硬件配置
IT之家6月16日消息,Dynabook推出...
不惧“烤验”,坚守岗位 消防员训练不放松 今日热门 近日,天津遭遇连续高温天气,在室...
被称湖人的爹!他究竟有多不爽? 预计有70-100万人参加掘金夺冠游行...
配置更高价格更香 海豹冠军版静态体验_微速讯 比亚迪海豹冠军版上市,增配置还降...
观天象|特朗普出庭细节曝光 是时候展现表演实力了! 关注 据央视新闻客户端报道,当地时间6...
植物大战僵尸3d官网在哪下载 最新官方下载安装地址 植物大战僵尸3d怎么下载?想要比别...
被人领去贷款然后抽成_世界通讯 被人领去贷款然后抽成
2023年06月17日07时48分欧元/人民币汇率最新报价 2023年06月17日07时48分欧元 人民...
高端装备中心史家村开展“高考季”防电信诈骗宣讲活动-天天热文 鲁中网淄博6月16日讯六月即考试月...
每日热点:马云办家宴豪宅曝光,身材发福尽显憔悴,汪涵侧身赔笑尽显卑微 每日速读 置办家宴的地点选在了花园当中,在...
天天滚动:凯迪拉克ct6 凯迪拉克ct6报价 凯迪拉克ct62022款价格2022款凯迪...
环球观热点:小米 34 英寸显示器仅 1299 元,144Hz 电竞带鱼屏 小米34英寸显示器近日价格降到1499...
路由器也白菜价了?3000M 无线速率+满血 Wi-Fi 6:仅149 元! 据报道,H3CNX30Pro路由器于5月31...
财政部:1-5月累计 印花税收入1848亿元 财政部:1-5月累计,印花税收入184...
充分发挥党建引领保障作用 坚定做强做优做大国有企业 本网讯(通讯员郑言)根据中央及省...
辽篮完成重要签约!两届总决赛FMVP顶薪留队,帮助杨鸣冲击三连冠-环球速递 辽篮完成重要签约!两届总决赛FMVP...
对话MathWorks:数学软件如何帮助工程师应对AI挑战? 环球焦点 在科学研究项目中,数学软件必不可...
周五评述及下周一预测(6-16) 前日预测“周五沪市,向上关注3250...
毛利、销量下滑依旧扩产,汽车内饰龙头天富龙冲A能否成功 天天热议 近日递交招股书、冲击上交所主板的...
环球快讯:交易员看衰全球经济和需求端 原油易跌难涨 【【基本面综述】交易员主要看衰全...
银轮股份:公司已经成功研发并配套北美大客户FSD液冷产品 银轮股份在互动平台表示,公司已经...
【世界速看料】一起朗读·献给父亲节丨《挥手——怀念我的父亲》朗读者:刘欢 朗读者梅溪小学教师刘欢挥手——怀...
世界新资讯:讲案例、展风采、促提升,民族街道社区书记“擂台比武”锤炼本领 讲案例、展风采、促提升,民族街道...
啤酒禁忌与什么食物一起吃 啤酒不能和什么一起吃 1、啤酒通常不能和海鲜、腌制品一...
GAN卷土重来:10亿参数的GigaGAN效果堪比扩散模型 点蓝色字关注“机器学习算法工程师...
每日信息:重庆儿童救助基金会向永川职教中心捐赠古代名人雕塑 为弘扬古代名人精神,激活“永川工...
大兴连发多则征地公告!未来要建......|全球热讯 大兴连发多则征地公告!未来要建 ...
郭艾伦真性情!与Tatan分别时哭成泪人,一语点出人品引钦佩! 我们明显可以看到郭艾伦整个过程都...
为什么说《波斯语课》充斥着犹太人的虚伪?他们连真实历史都能改 天天播资讯 如果最近有点闹电影荒的同学,想必...
最新资讯:河北省本科批28日起集中填报志愿,省教育考试院特别提醒 我省本科批6月28日起集中填报志愿...
男孩玩氢气球砸到吹风机爆燃 妈妈被严重烧伤:画面触目惊心 男孩玩氢气球砸到吹风机爆燃妈妈被...
母乳七个月还有营养吗 宝宝七个月吃母乳有没有营养 1、七个月的母乳是有营养的,只不...
环球速看:火炬开花后怎么养 火炬开花后如何养护 1、花后应尽早剪除残花枝不使其结...