蜂巢(已更名为网易云计算基础服务)计费系统架构升级之路网易数帆

该项目在人员上已经几经易手,就我所知,已经换过两拨完整的开发和测试团队了,而且已经全部离职。不得不说,该项目已经变得令人谈之色变,让人敬而远之。在这样的背景下,后期接手的开发和QA不得不硬着头皮上,踩着雷过河,小心翼翼的应对着不断涌来的业务需求。随之而来的是高居不下的bug率,越来越难以维护的代码,无法扩展的架构问题,我们开始意识到这样下去是不行的。于是我们从8月份开始了漫漫的架构升级之路。

在我们开始优化架构之前,我们重新梳理了计费系统完整的业务,得到了如下图所示的业务领域:

梳理以后发现,计费系统承载了太多非计费的业务,包含订单、账单、结算和代金券等,这些业务代码散落在各处,没有严格地业务边界划分,而是“奇迹般”的融合在了一个工程里面。造成这个局面的原因在于计费系统初版设计时,根本没有考虑到这些问题,当然也不可能考虑到,而在后面逐步地迭代过程中,也未能去及时地调整架构,架构腐化不是一天内完成的。当然,这方面有部分技术的原因,也有部分人为的原因所在,因为当时负责计费系统的开发就只有一人,还是刚毕业的同学。目前看来,也是难为这位同学了。

技术债务的问题不是小事,千里之堤毁于蚁穴。既然我们找到了问题的症结所在,那么解决的方式也就显而易见了,一个字:拆!我们分析了所有的业务,订单是最大也是最复杂的一个业务,而结算和账单考虑到后期有可能迁移到云支付团队,我们决定优先把订单系统拆分出去!

订单拆分说起来容易,做起来难。套用一句业界常说的话,就是开着飞机换轮胎。因为在我们拆分的同时,不断地有新的业务需求进来,还有一些bug需要处理,所以不太可能让我们专门进行拆分的工作。因此,为了不影响正常的业务迭代,我们决定拉出独立分支进行开发。我们分出两人专门处理拆分的工作。

为了最小化风险,订单拆分我们分了两步进行:一,模块独立;二:系统独立。

模块独立是将订单的代码首先在工程内部独立出来,我们采用独立Module的形式,将订单独立成了一个Order的模块。它拥有完全独立的服务层、业务层以及持久化层。其他模块可以依赖Order,而Order不能依赖除公共模块外的其他业务模块。整体的模块划分如下图所示。模块的拆分过程中我们也发现了原先很多不合理的地方,例如:其他服务直接操作订单的持久化层(DAO)、模块直接依赖关系混乱、Service所在的Pacakge不合理、存在大量无用的代码和逻辑、随意的命名等。我们边拆分边重构,虽然进度比预期要缓慢一些,但整体上在向着合理的方向进行。

模块独立的过程中我们遇到了业务层级关系的问题。由于订单模块不再依赖于其他业务模块,而又有一些业务逻辑是由订单触发的,需要在计费模块完成,我们又不能直接调用计费模块的Service。针对这个问题,我们采用了领域事件的方式来解耦,简单来说就是订单通过发布事件的方式来与其他模块进行通信,当时实现的代码其实也相当简单。

我们并没有独立拆分web层,因为系统还没有独立,web层作为统一的打包入口也承载着订单的流量。而且,Controller层的逻辑相对比较简单,完全可以在系统独立时再做。通过大家的努力,8月底订单已独立模块的方式上线了,一切正常。

模块拆分完成后,仅接着就是系统独立,此时我们需要将订单系统独立部署。这里一个关键的问题是,独立部署意味着单独提供服务,而依赖订单系统的业务方非常之多,包含前端、主站、大部分的PaaS业务和计费,都有需要直接依赖订单接口的地方,冒然独立风险很大。针对这个问题,我们采用使用haproxy七层转发代理来将流量分发到不同的vip来解决。虽然,在上线过程中遇到了一些坎坷,但最终还是成功了。现在看来这个选择是非常对的,因为这样可以在业务方无感知的情况下平滑升级。但长远来看,最终我们还是以独立的vip对外保留服务。

订单和计费直接我们采用RabbitMQ来完成主体通信,关于采用MQ还是HTTP调用我们内部还进行了一番争论。之所以最终还是采用MQ来进行通信,是因为我们发现很多业务流程并不需要计费系统立即响应(大部分流程都是订单触发的),也就是我们常说的弱依赖。另外,职责上计费系统的响应的质量也不应影响到订单的主体流程,举个例子:用户支付了一个云主机的订单,如果计费系统此时无法响应,业务上相对来说可以接受过一小会儿计费再处理,而不是把订单直接退款给用户。MQ的引入在技术和职责层面都将订单和计费分的更开了。当然,强依赖的服务是我们无法避免的,其中之一就是结算模块还留在计费中,订单需要通过接口调用结算服务来完成支付。

前期,我们在模块独立时采用事件解耦的方式,在此时也获得了收获。我们通过一个统一的转化层,将那些事件直接转化层RabbitMQ可以识别的消息,这样代码的改造工作就大大减少了。

系统独立后一个直接的表象就是每个系统的代码行数大大降低了。独立前,整体的代码行数已经达到了12W行以上(包含配置文件),独立后,计费系统降低到了10W以下,订单维持在4W以下。代码行数的降低将直接提高系统的可维护性。个人认为如果一个工程里的代码超过10W行,那么维护性将大大降低,除非是那些有着严格自律意识的团队,否则,我建议还是尽量降低代码行数。

经过大家一个月的努力,订单系统终于已独立的姿态提供服务了。过程很艰辛,但是收获良多。

公有云产商面临的一大挑战就是多Region环境的支持。普通的互联网行业出于高可用的考虑,往往会把核心系统部署到多个机房,然后根据自己的实际应用场景选择冷备、双活甚至三活。我们经常听到的“两地三中心”、“三地五中心”等等高大上的名词就是代多机房高可用的缩影。这些行业做多机房部署的主要目的是为了提高系统的可用性,不是其业务的必须属性。换句话说,他们不做多机房部署也可以,做了当然更好。而公有云产商不一样,多Region部署就是其行业属性之一。如果哪个云产商不提供多region产品的支持,那么它肯定是不完整的。不得不承认,我们在这方面的经验是比较欠缺的,在多Region的支持上走了一些弯路。

在这种情况下,我们“胆战心惊”的给出了第一版的多Region设计方案,主体架构如下所示:

因为当时计费系统还没有拆分,所有的业务都在一个系统中完成的,就是我们常说的“大泥球”系统。这种情况下我们很难做到多Region部署,订单和账单其实只有在一个Region部署就可以了,而计费的数据采集和请求分发是要下沉到各个Region的,而计算过程可以集中完成。采用"双主"同步复制的方案实则是无奈之举。数据库的同步只能基于实例级别,而无法细分到表,我们各Region中计费数据库中存在资源的计量表,这个数据需要同步到杭州Region来完成。为了避免“脑裂”的问题,我们特别将该表的主键采用UUID的形式。存量表因为无法做大规模修改,我们通过限制北京MySQL用户的权限来避免写入和修改全局表。

这个设计很糟糕,但是当时的条件限制,我们也拿不出更好的设计了。虽然上线的过程有些曲折,当这个架构还是成功运行了,这是令我们最为欣慰的事情。因为为了适配这个架构,团队的小伙伴做了很多工作。不可否认,这个架构存在诸多弊端,其中最大的隐患就在于数据库的“双主”同步,这就像一颗随时会爆的炸弹萦绕在我们心头。当时专线还没有搭建好,所有的流量均通过外网隧道代理,糟糕的网络质量无疑放大了这个风险。为此,DBA们向我们吐槽了好久,幸好我们抗打击能力很强。

在做完双Region的支持以后,计费团队就继续做产品需求了,因为架构调整导致需求列表已经很长了。而且当时也说的是,短期内(至少今年)不会再有第三个Region了,我们也想着快点做完,多花点精力投入到重构中。但是计划赶不上变化,9月底我们被通知到第三个Region来了,而且已经被提高到第一优先级支持了。

其实多Region的支持的问题我们总结出主要表现在一下两个方面,一是应用层面的接口互通;二是底层数据库的同步。

我们先说底层数据库的同步,对计费系统而言,数据的一致性是至关重要的,但多机房部署是在挑战CAP定律。是不是就没有了这样的数据库方案了呢,有,那就是Google的Spanner,号称可以在全球做到强一致的数据库。但是我们没有这样的数据库。其实我们也考虑使用NoSQL数据库——Cassandra,但是这个数据库运维起来太复杂,我们也没有这方面的经验,也就放弃了。还是回归到MySQL,受限于传统关系型数据库在扩展性方面的问题,我们不可能把整个库在各个Region都同步一份。但是计费原始数据又必须在各个Region内收集,于是我们决定——拆,把计费拆层两个部分,分为bill-agent(数据采集)和bill-central(数据计算)两个部分。

现在再来看跨Region调用的问题。在多Region的横向系统中,我们发现或多或少的存在着机房间的接口调用问题。这些问题有可能是某些Region的库不能写需要路由到主库来写导致的,也有可能是全局缓存的问题,还有就是Global业务向Region内服务发送指令。计费属于最后一种场景,我们有一些业务场景需要由杭州Region触发,然后调用各个Region内的服务的接口。在第一版的实现中,计费系统自己实现了跨Region代理部分,但是实现的不是很好,代码的可维护性比较差,加重了调试的难度。这一版的设计中,我们决定把跨Region接口代理单独拿出来重新做,结合多Region的应用场景,然后封装一些非功能性的特性,这就成了后面我们很重要的一个组件——RegionProxy。

RegionProxy最开始是为了解决跨Region调用的非功能性问题,简化应用系统处理的成本。但是设计上经历了比较大的调整。最开始的设计我们是希望Region内所有跨Region的HTTP调用都能通过RegionProxy来代理,RegionProxy之间能够发现对方并且相互通信,那么Region内的应用系统就只需要与本Region的RegionProxy通信就可以调到任意一个Region的应用系统了。但是在方案评审的过程中,我们发现如果都用RegionProxy代理,可能会导致跨Region调用多出一跳或者两跳,调试可能会比较困难。后来,我们放弃了这个方案。再后来,我们发现ServiceMesh的方案和我们最初RegionProxy的方案是十分相似的。

在RegionProxy的设计上我们进行了简化处理,我们将所有Region的业务系统录入到一个全局的配置中心(我们自己开发的ConfigCenter)中,然后通过一个自己开发的一个HttpProxy的Java库来与ConfigCenter通信来完成跨Region的调用。这样做的好处就是使用方用起来比较轻量,但是在网络连通性方面我们需要与所有Region的系统做到互通。在开发Proxy库的时候,我们不仅对跨Region的HTTP调用进行了封装,而且对普通的HTTP调用也加入了非功能性的封装,这样系统可以通过Proxy库完成所有的HTTP调用请求,极大的简化了代码的维护成本。后面,我们使用RegionProxy来代理请求后,确实删除了很多以前的无用代码,整体流程上也清晰了许多。

经过两版多Region的改造,我们确实收货了很多宝贵的经验,非常难得。实际上,在多Region的支持上,大家需要清晰地认识到为什么要支持多Region,以何种方式去支持多Region,多Region支持与高可用的关系等基本问题。如果这些问题回到不好,或者不清楚,那么很容易就会掉到陷阱中去。另外一个感悟就是结合业务的实际场景,第二版的多Region架构我们之所以能够这么设计,就在于计费系统不需要实时出账,我们完全可以把数据保存下来,离线计算以后再出账,这是可以接受的。但这并不适用与所用情况,有些性能要求很高的横向业务就不适合这种场景。

前面提过几次技术债务的问题,有些问题是可以通过工具来解决了,有些只能通过内部重构来解决。左耳朵耗子曾经说过一句话对我感触很大,大意是说有些公司在解决问题时偏流程,有些公司偏技术。我想我们既然是技术团队,在解决问题时能通过技术方式解决的就应该尽量用技术解决,流程和人都是不可靠的。

如果你要问我做蜂巢计费最困难的地方是什么?我的回答肯定是业务太复杂了。这种复杂性不是因为我们架构设计的不好导致的复杂,而是业务本身就是十分复杂的。现在计费系统需要支持十几种产品的售卖形式,涵盖IaaS、PaaS和SaaS的绝大部分产品,同时各个产品的售卖和计费模式都存在或多或少的差异,这让我们很难通过一个统一的模型就涵盖所有的场景。我们找到了一条缓解这个问题的方式——抽象化。

横向系统或者支持系统如果需要服务多个产品,那么抽象化设计是不可或缺的一个缓解。如果越早进行抽象化,那么后期对接和维护的成本也就会越低,还能把系统的边界划分得更清晰。计费系统早期的设计在抽象化方面没有过多的规划,在后期的对接方面又处于比较弱势的一方,导致计费系统出现了大量的特化代码。这些特化代码对一个服务十几个产品的支持系统无疑是伤害巨大的。现在我们已经意识到了问题的严重性,也着手在做这方面的重构工作了。但是挑战依然很大,因为业务的复杂性是无法通过技术手段就能降低的,这方面我们只有和产品、运营和销售各方面一起努力,打造一个合理、灵活、稳定的新计费。

从八月底加入计费团队以来,收获良多,无论是在技术上,还是在对业务的理解上,都有了许多新的认识。最为给力的还是团队的小伙伴们,因为计费本身的需求非常多,处理这些需求的人都只刚刚够。后来我们又做了两版跨Region改造、订单拆分、框架替换、抽象化等优化工作,迭代周期从两周一次压缩到了一周一次,开发和QA的小伙伴也都是任劳任怨。当然,大家能在这个过程中有所收获才是最关键的。

计费系统可以说是我接触过的最为复杂的一个系统,越是复杂的系统越需要清晰的头脑和良好的设计。云计算产商的博弈已经到了白热化阶段了,大家拼的不光光是每个产品的质量和体验,还有整个云平台的内功。公有云平台本身就是一个庞大、复杂的系统,如何把这个系统建设好,用户体验做好、服务质量提高、稳定性得到保障,这本身就是极为有难度的一件事情。计费系统作为公有云平台一个重要的组成部分,可以说扮演着一个极为关键的角色。做得好可以对整个平台提供助力,而做的差则会拖慢整体的发展进程。我们已经找到了适合自己的一条道路,相信会走上正轨!

THE END
1.蜂巢SAAS.商家管理系统2024-12-12 10:50 企业文化 争做一流员工,共造一流产品,同创一流企业。 商家端 远征者 专属定制 专业为你 装酷企,用蜂巢 客服QQ:1253816961 联系电话:028-69902443 ?登录帮助下次免登录短信验证码登录 登录https://sj.fcsaas.cn/
2.丰巢用户认证中心账号登录 扫码登录 请输入丰巢工号登录 请输入丰巢域密码 验证码 登录 https://cns.fcbox.com/
3.聚水潭SaaS协同平台登录入口欢迎访问聚水潭SaaS协同平台,您可以通过此入口一键登录聚水潭SaaS协同平台下所有业务模块子系统。https://www.erp321.com/
4.FCM系统后台忘记密码? 登入http://tatake.tatanono.com/
5.首页供应商在线账单系统 用户登录 账号格式为“CW”+6位供应商编码,如“CW114093” 安全校验: 换一个 登录 忘记密码?(申请重置密码) 没收到初始化密码邮件?(申请重发邮件) 为保障供应商账户安全,新账号初始密码在一个月内有效,超过一个月需要申请重置密码。 https://vfs.vip.com/account/login
6.企趣官网员工激励工具员工激励平台企业文化落地游戏化员工此外,企趣云的客户服务团队也值得称赞,不仅响应迅速,而且非常专业,无论我们遇到什么问题,都能得到及时且有效的解决方案。 棠联科技 任女士 2024-10-25 企趣云激励是一种将游戏元素和机制融入企业管理和员工激励中的策略。通过设立积分系统,鼓励员工相互赞赏,达到了提升员工积极性、增强团队协作、促进企业文化的目的http://u002fwww.qiqucn.com/five_star
7.ModelArts准备工作ModelArts用户指南创建虚拟私有云需要登录管理员账号,IP地址段请根据现网情况合理规划。 登录管理控制台。 在左侧服务列表中,单击“网络 > 虚拟私有云 VPC“,进入虚拟私有云页面。 单击右上角“创建虚拟私有云”后,根据界面提示配置虚拟私有云参数(参数介绍可参考虚拟私有云 VPC用户指南的“通过VPC快速搭建IPv4网络”章节),然后单击“http://console.ecloud.10086.cn/op-help-center/doc/article/88681
8.方天云ERP软件解决方案企业上云,就上方天云OQC等系统化管理,有效控制并改善产品质量,溯源、去向双向追溯精准 全程质量精准追溯 快速响应工艺变更、订单变化、过程异常,保障品质,提升生产效率,缩短制造周期,构建柔性生产能力,可视化看板让车间状况一目了然 柔性制造改善交期 整合物联网、边缘计算、云计算技术,连接工业设备与云端,实时准确地将生产、环境数据发送到https://www.moldde.com/h-col-258.html
9.蜂巢云简介:蜂巢云是一家基于云端架构的一站式店铺管理专家,为用户提供会员管理、消费收银、会员营销、移动支付、大数据分析、会员充值、商家微信门户、积分营销、会员等级管理、导购提成、商品库存管理、会员互动等服务。融资历程 1 核心人员 0 关联企业 0 相关竞品 18 融资历程1 导出 序号融资日期 融资轮次 融资金额 https://www.qcc.com/product/f8a0c21e-70b3-46ee-bb2e-4bb843cde7f2.html
10.商圈云商圈云公司商圈云竞品公司信息深圳市蜂巢天使科技有限公司是一家全民帮你卖商品的集客系统。家居建材门店盈利六大系统包括:天网集客系统、拓客商城系统、精准成交系统、贴心服务系统、超级会员系统、蜂巢天使助手。 深圳市蜂巢天使科技有限公司 7 宰相办公 -2018-10-25企业服务上海 宰相办公是一款轻量级销售管理软件,覆盖整个云办公平台,信息智能快速传递https://www.tianyancha.com/brand/b93b5477696
11.2021.08.01新闻早报1、电动电池研发生产商「蜂巢能源」完成102.8亿元B轮融资,由中银投领投,联合投资机构包括国家科技成果转化引导基金子基金、碧桂园创投、深创投、建信投资、IDG、三一重工、小米集团、湖州海松、华兴资本等,国投招商、九智资本等原股东进行大额增持 2、智能制造管理系统研发商「微茗智能」完成数千万元Pre-A轮融资,由百https://maimai.cn/article/detail?fid=1647902005&efid=z-Asmx2ixrS3UV0AKjPnog
12.农小蜂数智云——农业产业的数智化引擎数字产地仓基于蜂巢引擎的数字化技术底座,聚集生产端信息,通过数字仓库管理系统、组货管理系统、品控管理系统,实现根据不同农产品分级标准,实现智能化的采收、分选、分级、包装,仓储,发货等在线协同管理,建立农产品转变成商品的高效渠道,进一步优化供应链效率,稳定商品质量,降低损耗,以产地仓作为关键节点,高效连接农产品产https://www.weihengag.com/home/article/detail/id/17579.html
13.重磅来袭丨2020(第十五届)青岛国际水大会二轮通知绿色制造系统解决方案企业经验分享 青岛水务发展论坛 ◆由青岛市水务管理局主持召开,局相关领导将发表主旨演讲,重点介绍青岛市水务发展情况。论坛将同时对青岛市水务的十四五发展规划、涉水产业发展新政策等进行介绍。 ◆邀请与会专家、水务领军企业代表进行学术交流、分享成果经验。 http://goootech.com/topics/72010276/detail-10300299.html
14.北京世纪蜂巢网络科技有限公司店铺+不仅是生态理念,也是实现店铺与消费者连接与互动的综合解决方案,通过蜂巢云提供的云端会员管理、消费收银、移动支付、会员营销、大数据分析,促进互联网+时代企业店铺的转型升级,实现店铺利润的爆发式增长。 蜂巢云携手亿智达会员管理系统和云阶梯云会员平台,10年如一日,专注做一件事,打造最好用的、最了解中国商家http://wydb.leshanvc.com/21696.html
15.企业中高层时事解读课2021第27期(总期77期)在线培训课程二是优化外资银行、保险等金融机构准入门槛要求,完善金融机构母子公司跨境往来规则。优化外资参与境内金融市场的渠道和方式。推进完善与实体经济密切相关的直接投资项目管理要求。保持人民币汇率在合理均衡水平上的基本稳定。三是完善宏观审慎政策框架,构建系统性金融风险监测、评估和预警机制,保持金融市场平稳运行。https://www.zzqyj.net/?list_89/1303.html
16.蜂巢云(山东)生物医药科技有限公司蜂巢云(山东)生物医药科技有限公司 工作地点:济南市性别要求:不限 薪酬待遇:10000元/月工作经验:三年以上 最低学历要求:硕士研究生年龄要求:28周岁--40周岁9.有一定医疗软件系统操、管理和架构设计经验者优先 岗位职责/福利待遇/工作环境 1.能够针对心血管病、糖尿病等进行诊断、跟进病出具报告,给出用药指导和https://rc.jinan.gov.cn/require/jobInfo.jsp?id=51663
17.云蜂巢iPhone版免费下载云蜂巢app的ios最新版1.2.57下载会员管理系统、会员数据分析引导诚信商家为客户提供便捷、诚信、物美价廉的服务,形成客户自有粘性,实现持续盈利。积分通历时七年打造,已具备了完善的平台资源,在2014年的“富乐资本 你就是奇迹”创新项目大赛中,获奖频频,引起业内广泛关注。 安装云蜂巢将极大的方便广大已经加盟积分通的新老商家实时动态的掌握自己的经营https://www.duote.com/ios/629295.html
18.蜂巢云物业管理系统蜂巢云物业管理系统 登录https://www.honeycombiot.cn/
19.蜂巢(已更名为网易云计算基础服务)计费系统架构升级之路蜂巢计费系统为网易云计算基础服务(网易蜂巢)提供整体的计费服务,业务范围涵盖完整的产品售卖流程,包含定价、订单、支付、计费、结算、优惠、账单等主体功能,支持十几种不同产品的售卖,产品形态上贯穿了IaaS、PaaS和SaaS类别。同时,计费方式还提供了了按量、包年包月、资源包等多种方式。该项目的业务范围之广,玩法种类https://zhuanlan.zhihu.com/p/41363986
20.企业云存储系统互联网头条产品:企业文档管理系统、文档管理中间件、开始云文件盒子、开始云SaaS平台 http://kass/ 13、 联想云存储 联想云科技,隶属于联想集团,主要业务涉及云计算服务(包括云主机,云存储和云基础设施)、技术开发及技术外包等,其中云存储业务-联想企业网盘自2006年开始产品技术研发,至今运营10余年。 https://www.300.cn/toutiao/t_208926.html
21.蜂巢(已更名为网易云计算基础服务)计费系统架构升级之路蜂巢计费系统为网易云计算基础服务(网易蜂巢)提供整体的计费服务,业务范围涵盖完整的产品售卖流程,包含定价、订单、支付、计费、结算、优惠、账单等主体功能,支持十几种不同产品的售卖,产品形态上贯穿了IaaS、PaaS和SaaS类别。同时,计费方式还提供了了按量、包年包月、资源包等多种方式。该项目的业务范围之广,玩法种类https://blog.csdn.net/jessicaiu/article/details/84337113
22.蜂巢云吧百度贴吧蜂巢云吧 关注: 37 贴子: 618 蜂巢云贴吧集合行业经验,整合会员营销管理 目录: 科技周边 看贴 图片 吧主推荐 图册精选 全部(1) 蜂巢云(1) 图片小编: 本吧暂无图片小编 蜂巢云 1个图册 3张 蜂巢云 ?2024 Baidu 贴吧协议 | 隐私政策 | 吧主制度 | 意见反馈 | 网络谣言警示 扫码http://nba.baidu.com/f?kw=%E8%9C%82%E5%B7%A2%E4%BA%91&ie=utf-8&tab=album
23.应用生态日益繁荣8月适配认证产品汇总HopeStage是基于openEuler开源社区构建的企业级Linux操作系统,具备高效、稳定、安全的特性,致力于为企业级的数据库、大数据、云计算、人工智能平台提供安全稳定的运行基础。 2 支撑软件 山东恒远智能科技有限公司 蜂巢工厂MOM平台 蜂巢工厂结合装备制造企业痛点,紧密围绕网格式效率协同、体系化质量保障、精细化成本管理三大主线https://www.zhaoxin.com/news_view.aspx?nid=2&typeid=273&id=1592
24.非凡体验戴尔平板Streak强劲升级戴尔Streak10Pro在这里笔者仅是做了一个粗略的展示,究竟戴尔平板电脑Steak 10 Pro在升级了Android3.2系统之后究竟有哪些变化,以及该机在两种模式下是如何工作的将在接下来的文章中为大家一一介绍,笔者尽量做到详细希望各位网友不要感到很罗嗦。 强劲性能:图睿蜂巢带来无比顺畅体验 https://pad.zol.com.cn/256/2569608_all.html
25.独家最全广州创业地图,看这一本就够龙硅谷正构建起庞大的创业导师系统。目前,龙硅谷第一批入驻天使投资人已有108位,天使投资人将直接入驻孵化器办公,不仅为提供资本咨询服务,更以创业导师身份为创业团队把脉战略、管理、财务规划等业务运营。 万科云工坊联创空间 成立时间:2014年4月10日 地址:广州市天河区华观路1933号万科云D栋4楼 https://www.tmtpost.com/1393712.html
26.2019中央国家机关软件协议供货项目中标公告发布都有谁?可以看到,今年中央国家机关软件协议供货采购的产品包括,财务、资产管理、舆情、杀毒、分析、事务、中间件、虚拟化、安全、邮件系统、版式、签章、地理信息、档案管理、云计算等15大类。 从所列分包来看,需求越来越细化,紧跟目前政府实际办公需求。 值得注意的是,不少投标企业因所提交资格或材料不符合招标要求,投标被拒https://it.caigou2003.com/ITcaigouyaowen/4477844.html