大家好,我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啊。由于去重逻辑重构了几次,好多股东直呼看不懂,于是我
全球快消息!北京首次开展银行业知识产权金融培训 科技日报记者 华凌6月15日,北京首次银行业知识产权质押融资专项培训
福建2023养老金调整时间会提前吗?今年福建养老金调整方式有哪些? 有消息吗?福建2023养老金调整及补发时间会提前吗?23年福建养老金调整
关于女子租房一年才发现指纹锁脚都能开及女子租房一年才发现指纹锁脚都能开详情 音频解说1、6月14日,四川成都。2、小马去女友出租房处找女友,手随便
【全球报资讯】“一体两翼”腾飞!连云港港前 5 个月货物吞吐量同比增长 12.05% 现代快报讯(记者刘伟娟)2023年1-5月,连云港港完成货物吞吐量1 24亿
上交会广角镜|聚焦多元场景落地,创新技术秀出“硬实力” 全球独家 以“开放链动全球、技术赋能未来”为主题的第九届中国(上海)国际技术
“千万工程”20年 | 浙江:一枝花共富一方百姓|世界看热讯 棠棣村,是浙江绍兴一个以花闻名、因花致富的小山村,素有“春兰故乡”
东南亚房产市场调研报告 图片来源:Pixabay近年来,随着政策的逐步开放以及国内房地产环境不明
落实数字化行业标准 数字浙江引领产业转型新风向 潮新闻客户端通讯员声平当前,世界各国正经历新一轮科技革命和全球产业
假培训真带货!湖北一机构被抓现行! 注意!注意!注意!近日有人冒充消防人员高价推销消防产品被消防等多部
江淮钇为3上市:最长续航600公里、8.99万元起|短讯 江淮钇为3上市:最长续航600公里、8 99万元起
余额宝,10岁! 来源:雷科技互联网组|编辑:重嘉|排版:KIM6月13日,余额宝官方发布微
世界简讯:欧盟机构:6月初全球平均气温创纪录 6月初全球平均气温创下有记载以来最高纪录,比往年同期最高水平“高很
昇思开源社区理事会成立,基于昇思AI框架的全模态大模型“紫东.太初2.0”发布-环球播报 基于“紫东 太初”2 0,全栈国产化、低代码一站式开发的“紫东 太初”
圣龙股份:
(1)公司严格遵循会计准则相关规定进行资产减值相关处理 圣龙股份(603178)06月16日在投资者关系平台上答复了投资者关心的问题。
全球热点评!编写“秒杀”抢购软件,非法获利近百万获刑3年8个月 “6·18”来临,各种抢购、秒杀等优惠活动出现在各电商平台。看着辛苦
环球热点评!康师傅冰红茶兑奖官网 康师傅冰红茶兑奖 1、很多地方都可以换!说俩个我常去的吧:1 宣化街大润发超市一楼服务
即时看!最新粽子专项抽检情况公布 不合格样品均为超范围使用食品添加剂 最新粽子专项抽检情况公布不合格样品均为超范围使用食品添加剂
技塑股份股东赵新春拟以特定事项协议转让的方式将其直接持有的553.27万股公司股份... 技塑股份股东赵新春拟以特定事项协议转让的方式将其直接持有的553 27万
全球热推荐:圈套漫画韩国灿旭 圈套漫画韩国 今天来聊聊套漫画韩国灿旭,圈套漫画韩国的文章,现在就为大家来简单介
基蛋生物:
公司积极推进各款仪器的装机进度,具体装机情况请关注公司披露的定期报告 基蛋生物(603387)06月16日在投资者关系平台上答复了投资者关心的问题。
甘州区党寨镇:“蔬果飘香”话振兴 甘州融媒讯近年来,甘州区党寨镇持续做优做强设施农业产业,不断提升果
2023年06月16日股市盘中盘后重要消息 截止2023年06月16日收盘,上证指数报收3273 33点,上涨0 63%;深证成指
环球看热讯:南山控股为全资下属公司西安雅致6500万元贷款提供担保 6月16日,南山控股(SZ002314)发布关于对外担保的进展公告。近日,南山
世界快看:dotnetframework4.0下载(dotnet) 1、 net是一个微软开发的编程环境,里面可以使用C ,VB等几种语言,java
波纹唇鱼全人工繁育技术在海南取得突破 波纹唇鱼全人工繁育技术在海南取得突破---海南省海洋与渔业科学院联合
世界快报:合肥经开区莲花社区再添一楼宇党建工作指导站 日前,合肥经开区莲花社区凤凰国际楼宇党建工作指导站召开月度工作例会
环球热点!天房发展拟为子公司天蓟房地产3.4亿元融资提供担保 天蓟公司因经营发展需要,拟向天津银行股份有限公司第一中心支行申请融
三局激战逆转未果!何冰娇苦战不敌2号种子,无缘会师陈雨菲 北京时间6月16日,印尼羽毛球公开赛继续进行。在女单1 4决赛的一场较量
乐游碾子山 赴夏日之约-天天实时 明媚的六月,微风徐徐,草长莺飞,赏花、摘果、登山、烤肉……一个个快
天天看点:莫奈名画被瑞典环保主义者涂红漆 2人被捕 本文转自【中国新闻网】;中新网6月16日电综合外媒消息,14日,两名瑞
12岁以下男孩过生日应该送什么 根据年龄和兴趣爱好,以下是一些适合12岁以下男孩的礼物建议:1
长沙东马社区:党员宣讲微党课 情真意切话初心 新湖南客户端6月16日讯(通讯员陈亭)今日,长沙市望城区大泽湖街道东
高端电商,快手向往 高端电商,快手向往,电商,辛巴,手机,小红书,客单价,百亿补贴,快手(软体)
全球滚动:重逢加州,英杰电气亮相第36届世界电动汽车大会及展览会 6月11日,第36届世界电动汽车大会及展览会在美国加州萨克拉门托SAFECre
anticipate单词记忆(anticipate) 世界今热点 anticipate单词记忆,anticipate这个很多人还不知道,现在让我们一起来
还海还岸还景于民 大连长兴岛清理海域近2万亩 央广网大连6月16日消息(记者王松)5月24日大连市全面开展非法违规占用
国内塑料管材行业发展分析 塑料管材市场供需状况2023 随着技术的发展,管材也经历了普通铸铁管→水泥管→钢筋混凝土管、石棉
英特尔(INTC.US)将投资46亿美元在波兰建设芯片工厂-天天快讯 英特尔周五表示,将在波兰Wrocław附近投资46亿美元新建半导体封装和测
看图学习·乡村之美丨让农民就地过上现代文明生活 2003年6月,在时任浙江省委书记习近平同志的亲自谋划、亲自部署和亲自
16.98-20.68 万元 2023 款长城越野炮上市 [爱卡汽车国内新车原创]2023年6月16日,2023粤港澳大湾区车展上,长城
墨西哥大量野鸟死亡 或与厄尔尼诺有关|今日热文 墨西哥农业部说,依据兽医和生物学家对死鸟的尸检结果,这些鸟“死于饥
每日快讯!“发现不一样的泰安”泰山+惠游套票上线 6月16日,山东省泰安市人民政府新闻办公室召开新闻发布会,介绍“发现
“要么倒闭,要么成为巨头”,余承东最新发言:未来车市洗牌会非常惨烈,比亚迪是... 6月16日,在2023未来汽车先行者大会暨全球智能网联汽车商业化创新大会
叶县张永定:吃苦耐劳“老黄牛” 坚守环境整治一线 大河网讯“你们看,去年还是脏乱差的角落,经过这样一整理,是不是好看
简讯:机械行业:制造业产需两端增速放缓 挖机设备出口持续强劲 机械行业:制造业产需两端增速放缓挖机设备出口持续强劲
4小时直达大美新疆!乌鲁木齐—洛阳—福州航线首航-焦点快报 16日上午,由乌鲁木齐航空执飞的UQ2523航班,在洛阳机场平稳降落。这标
提升部门工作效率方法 提升部门工作效率|天天快资讯 1、第一、几个基本的工作准则一、组织协同,避免缺乏组织,让事情放任
俄罗斯经济学家:美国借债“成瘾”将危及全球经济复苏 新华社莫斯科6月15日电(记者黄河)俄罗斯经济学家、新社会研究所所长
拿破仑全面战争汉化补丁 拿破仑全面战争中文版下载好一点不要太卡|全球热消息 1、下载地址已经用私信发送,请注意查收~拿战的优化是不错的了,要是卡
世界要闻:宣传暑假防溺水 做到安全“不放假” 大江网 大江新闻客户端讯通讯员曹思敏报道:随着炎热暑假的到来,为加
每日热议!长城炮越野双雄王者焕新 23款越野炮&火炮正式上市 6月16日,“全球智能豪华越野皮卡”2023款越野炮,携手“沙漠之王”202
官宣:奉贤明天入梅!_焦点速讯 奉贤入梅2023•6•17本区明天(17日)入梅,较常年略偏早,今年梅雨前
2023一建什么时候报名考试 2023一建什么时候报名考试由一级建造师考试栏目提供,查找更多考试报名
这...孙国文右路前插准单刀,右脚打门向右远远偏出... 友谊赛中国男足vs缅甸。第52分钟,艾克森得球倚住后卫送出精准直塞,孙
乌鲁木齐经开区(头区)“大盘菜”培训班开到家门口 用技术赋能就业 为进一步提高居民技能水平和就业能力,促进辖区居民通过多种方式实现就
假培训真带货!湖北一机构被抓现行! 注意!注意!注意!近日有人冒充消...
天天观速讯丨国足5分钟2球被吹!艾克森破门被判无效,边裁示意越位在先 国足5分钟2球被吹!艾克森破门被判...
莲湖区红庙坡街道召开重点项目·企业招商推介大会 奏响地区高质量发展强音 每日视点 6月15日,莲湖区红庙坡街道重点项...
我国棉花产业韧性强助推行业高质量发展_焦点报道 中华全国供销合作总社理事会副主任...
“千万工程”20年 | 浙江:一枝花共富一方百姓|世界看热讯 棠棣村,是浙江绍兴一个以花闻名、...
澳大利亚修订鱼内脏和鱼油进口条件 今日要闻 2023年6月13日,澳大利亚农业、渔...
乐游碾子山 赴夏日之约-天天实时 明媚的六月,微风徐徐,草长莺飞,...
美股掘金 | 强者恒强!微软、苹果、甲骨文等科技巨头刷新高;中概汽车股接力狂飙... 《美股掘金》每日紧跟市场动态,洞...
更便捷 华西二院妇科肿瘤多科综合管理诊治平台上线_世界观速讯 红星新闻网(记者李慧颖实习生胡佳...
[路演]冠农股份:棉籽蛋白项目预计第四季度投产 天番食品2.5万吨番茄丁汁项目已达... 6月16日下午,冠农股份(600251 S...
当前热门:录取通知书比拿奥运金牌容易?苏翊鸣拟保送清华大学,遭网友质疑 对于高考来讲可以说是学生人生中最...
当前速讯:高淳淳溪:多措并举助推人居环境整治工作 乡村要宜居,环境是底色。近期,高...
利率周记(6月第2周):复盘10年 跨半年资金是否值得担忧?_全球最资讯 利率周记(6月第2周):复盘10年跨半...
记者:皇马想下周完成何塞卢转会,原则上这是最后一笔引援 直播吧6月16日讯科贝电台记者Melch...
全球即时:跨越伶仃洋 一桥连三地:这座世界最长跨海大桥为大湾区带来新机遇 【“粤”升湾区阔 潮涌看中国】跨...
讯景8800gts(8800gts) 1、确实非常非常尴尬,也非常非常...
全球观速讯丨现恒建筑(01500)预期年度由盈转亏至多1900万港元 现恒建筑(01500)发布公告,集团预...
首个干细胞合成人类胚胎样结构诞生 有望打开早期胚胎发育的“黑匣子” 在本周举行的波士顿国际干细胞研究...
当前报道:美职篮总冠军庆祝活动意外不断 2人遭枪击1名警察被车撞倒 本文转自【央视新闻客户端】;
据...
莲湖区红庙坡街道召开重点项目·企业招商推介大会 奏响地区高质量发展强音 每日视点 6月15日,莲湖区红庙坡街道重点项...
天天观速讯丨政策利率为何“接力”下调?了解一下→ 政策利率为何“接力”下调?了解一...
通胀持续高位运行 欧洲央行或将继续加息 欧洲中央银行15日召开货币政策会议...
老人迷路误上高速公路,好心的哥停车带其驶离并报了警……-焦点日报 扬子晚报网6月16日讯(通讯员秦公...
记者:米兰球探关注尼日利亚前锋伊克乌梅西,认为他未来可期 直播吧6月16日讯记者SachaTavolier...
ghost win8系统镜像包_ghost win8系统镜像文件 全球球精选 1、可能不行。2、因为Win8使用的是...
概念动态|成都先导新增“腾讯概念”|环球热讯 同花顺F10数据显示,2023年6月16日...
Mysteel数据:全国建筑钢材钢厂周生产情况调查统计(2023年6月16日)-热讯 想了解更多精彩内容,快来关注我的...
读书小报资料_关于读书小报资料-精选 欢迎观看本篇文章,小升来为大家解...
世界简讯:怎么查询医保卡号是多少 医保卡号码查询方法分别是哪些 医保卡号码怎么查,医保卡号码怎么...
海航控股:5月本集团收入客公里环比上升0.11% 旅客运输量环比上升0.10% 南方财经6月16日电,海航控股公告...
环球播报:金牌厨柜:拟在红安县经济开发区投资建设定制家居项目 金牌厨柜(603180):拟在红安县经济...
海南:加快推进全省义务教育阶段学校内午餐午休工作 海南:加快推进全省义务教育阶段学...
久腾网络科技有限公司(久腾网)-播报 1、久腾网的信誉很好,卖的都是行货...
新任国防部新闻发言人张晓刚亮相 6月16日下午,国防部新闻局副局长...
中国汽车流通协会:5月汽车经销商库存系数为1.74 库存水平在警戒线以上 智通财经APP获悉,6月10日,中国汽...
2017年考研英语二阅读理解第二篇重点单词汇总+翻译_天天快资讯 2017年考研英语二阅读理解第二篇重...
万通发展:参股公司北京CBD核心区Z3项目开发还处于建设阶段 万通发展:参股公司北京CBD核心区Z...
“缩水版”土拍成交1幅宅地 溧水安置房地块底价拍出 “缩水版”土拍成交1幅宅地溧水安...
抖音里的密友是什么意思(密友是什么意思)_环球新要闻 1、就是说你和a1a2是好友bc和他们...
世界短讯!董事长在内14名高管被罚,凸显茅台旗下华贵人寿内控漏洞巨大 作者宋涵出品全球财说包括董事长在...
《无尽地牢》公开新英雄角色:草本医师“菇姆” 世嘉股份有限公司宣布,由SEGA®Eu...
中国首台(套)大孔径磁共振功能创新应用成果发布 中新网合肥6月16日电 (方雯 方萍...
环球焦点!亚马逊拟以17亿美元收购iRobot交易获英国反垄断机构批准 电商报快讯:6月16日消息,亚马逊...
高考后来宁夜游夫子庙丢手机,南京秦淮警方不到10分钟找回 扬子晚报网6月16日讯(通讯员秦公...
天天快资讯:必须严惩!掘金夺冠游行突遭意外,约基奇被酒瓶砸脸,素质在哪? 在约基奇的带领下,掘金拿下了建队...
深圳市会计管理综合平台(信息采集) 天天观速讯 深圳市会计管理综合平台(信息采集...
延庆8个融媒工作站挂牌,与怀来、赤城签订“融媒联盟”协议_全球焦点 北京日报客户端|记者李瑶6月16日,...
全球百事通!瓠瓜的类型和品种有哪些? 瓠瓜别名瓠子、扁蒲、葫芦,葫芦科...
宝宝上火吃什么降火的食物 宝宝上火吃什么去火 1、孩子上火总是咳嗽、流鼻涕,通...
招募400名!江苏启动实施2023年高校毕业生“三支一扶”计划 扬子晚报讯(记者王赟)6月16日下...
世界要闻:凯顺控股(08203):建议采纳新购股权计划及新股份奖励计划 凯顺控股(08203)发布公告,公司董...
【焦点热闻】学无止境!“高龄高知”老年人如何养老?探访高校家属院 在老龄化日益严峻的背景下,高知老...
Vidda三色激光朋友圈扩大 光峰再次发布ALPD 5.0三色激光技术 随着投影仪市场的大火,众多厂商投...
山东青岛:喜分回迁房 圆了“安居梦”-环球观热点 山东青岛:喜分回迁房圆了“安居梦...
全国主流媒体山西行丨看山看水看那路!不登王莽岭,岂识太行山 海报新闻记者张琨晋城报道神奇壮观...
今日精选:央行等五部门:加大货币政策工具支持力度 全面推进乡村振兴 各金融机构要主动对接粮食生产主体...
“低头族”庞大,颈椎病发病显著增加,小心这种病不重视治疗可能会瘫痪|天天快看 三湘都市报·新湖南客户端6月16日...
全国首条穿越长江高铁隧道正式进入盾构掘进施工阶段_全球看点 6月16日,渝湘高铁重庆长江隧道“...