CN109254778B - 用于部署信息流系统的方法和装置 - Google Patents

用于部署信息流系统的方法和装置 Download PDF

Info

Publication number
CN109254778B
CN109254778B CN201811014614.XA CN201811014614A CN109254778B CN 109254778 B CN109254778 B CN 109254778B CN 201811014614 A CN201811014614 A CN 201811014614A CN 109254778 B CN109254778 B CN 109254778B
Authority
CN
China
Prior art keywords
information flow
flow system
historical version
information
terminal
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN201811014614.XA
Other languages
English (en)
Other versions
CN109254778A (zh
Inventor
孙敬云
郭慧
姚旭晨
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing Baidu Netcom Science and Technology Co Ltd
Shanghai Xiaodu Technology Co Ltd
Original Assignee
Beijing Baidu Netcom Science and Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Beijing Baidu Netcom Science and Technology Co Ltd filed Critical Beijing Baidu Netcom Science and Technology Co Ltd
Priority to CN201811014614.XA priority Critical patent/CN109254778B/zh
Publication of CN109254778A publication Critical patent/CN109254778A/zh
Application granted granted Critical
Publication of CN109254778B publication Critical patent/CN109254778B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/70Software maintenance or management
    • G06F8/71Version control; Configuration management

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Security & Cryptography (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

本申请实施例公开了用于部署信息流系统的方法和装置。该方法的一具体实施方式包括:接收终端发送的信息流系统的第一部署指令,其中,上述第一部署指令包括信息流系统的版本标识和部署环境信息;根据上述版本标识,从历史版本信息流系统集合中确定历史版本信息流系统作为目标历史版本信息流系统;根据上述部署环境信息,确定信息流在信息流系统中运行所需的目标环境;将上述目标历史版本信息流系统部署到上述目标环境中。该实施方式实现了历史版本信息流系统集合中的历史版本信息流系统的快速部署。

Description

用于部署信息流系统的方法和装置
技术领域
本申请实施例涉及计算机技术领域,具体涉及用于部署信息流系统的方法和装置。
背景技术
随着人工智能的发展,聊天机器人越来越受到关注。例如,可以通过智能在线客服机器人、手机助手等智能交互机器人为使用者提供服务。例如,使用者在聊天窗口输入信息之后,智能在线客服机器人会基于使用者的输入信息,按照一定的逻辑自动在聊天窗口给出相关的语句。又例如,手机助手可以基于使用者的语音信息为使用者提供服务。
实践中,针对每一种智能交互机器人都需要预先定义信息流系统来支撑使用者输入信息后给予正确的反馈。信息流系统一旦被智能交互机器人正式使用,再次调整信息流系统就会对使用者产生影响,尤其是对信息流系统进行大量的调整。
发明内容
本申请实施例提出了用于部署信息流系统的方法和装置。
第一方面,本申请实施例提供了一种用于部署信息流系统的方法,包括:接收终端发送的信息流系统的第一部署指令,其中,上述第一部署指令包括信息流系统的版本标识和部署环境信息,信息流系统包括用于对信息流进行处理的信息流处理节点集合,信息流从上述信息流处理节点集合中的、作为入口的输入节点流入以及在流经上述信息流处理节点集合中的至少一个信息流处理节点之后流出信息流系统;根据上述版本标识,从历史版本信息流系统集合中确定历史版本信息流系统作为目标历史版本信息流系统;根据上述部署环境信息,确定信息流在信息流系统中运行所需的目标环境;将上述目标历史版本信息流系统部署到上述目标环境中。
在一些实施例中,上述历史版本信息流系统集合中的历史版本信息流系统是通过如下步骤生成的:接收上述终端创建的信息流系统;将接收到的信息流系统存储为历史版本信息流系统。
在一些实施例中,在接收上述终端创建的信息流系统之后,上述方法还包括:配置信息流在信息流系统中运行所需的沙盒环境;响应于接收到上述终端发送的第二部署指令,将接收到的信息流系统部署到上述沙盒环境,其中,上述第二部署指令用于指示将接收到的信息流系统部署到上述沙盒环境。
在一些实施例中,上述目标环境为生产环境和/或沙盒环境;以及在将上述目标历史版本信息流系统部署到上述目标环境之前,上述方法还包括:接收上述终端发送的、针对上述目标历史版本信息流系统中输入节点的访问配置信息,其中,上述访问配置信息包括自定义地址;根据上述自定义地址,生成用于访问上述生产环境的第一访问地址和用于访问上述沙盒环境的第二访问地址;将上述第一访问地址和上述第二访问地址发送到上述终端。
在一些实施例中,上述方法还包括:接收上述终端发送的、针对上述历史版本信息流系统集合中的历史版本信息流系统的操作信息,其中,上述操作信息包括历史版本信息流系统的版本标识和以下之一:删除操作指令、编辑操作指令、重命名操作指令;对上述操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统执行相应的操作。
在一些实施例中,当上述操作信息包括编辑操作指令时,上述对上述操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统执行相应的操作,包括:确定上述操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统为待编辑历史版本信息流系统;将上述待编辑历史版本信息流系统发送给上述终端,以供上述终端进行呈现;将上述终端发送的、针对上述待编辑历史版本信息流系统进行编辑后的版本作为历史版本信息流系统存储到上述历史版本信息流系统集合。
在一些实施例中,上述方法还包括:响应于接收到上述终端创建的信息流系统以及部署到生产环境的部署指令,将所接收到的信息流系统部署到信息流在上述信息流系统中运行所需的生产环境。
第二方面,本申请实施例提供了一种用于部署信息流系统的装置,包括:接收单元,被配置成接收终端发送的信息流系统的第一部署指令,其中,上述第一部署指令包括信息流系统的版本标识和部署环境信息,信息流系统包括用于对信息流进行处理的信息流处理节点集合,信息流从上述信息流处理节点集合中的、作为入口的输入节点流入以及在流经上述信息流处理节点集合中的至少一个信息流处理节点之后流出信息流系统;第一确定单元,被配置成根据上述版本标识,从历史版本信息流系统集合中确定历史版本信息流系统作为目标历史版本信息流系统;第二确定单元,被配置成根据上述部署环境信息,确定信息流在信息流系统中运行所需的目标环境;部署单元,被配置成将上述目标历史版本信息流系统部署到上述目标环境中。
在一些实施例中,上述装置还包括:信息流系统接收单元,被配置成接收上述终端创建的信息流系统;存储单元,被配置成将接收到的信息流系统存储为历史版本信息流系统。
在一些实施例中,上述装置还包括第二部署单元,上述第二部署单元被配置成:配置信息流在信息流系统中运行所需的沙盒环境;响应于接收到上述终端发送的第二部署指令,将接收到的信息流系统部署到上述沙盒环境,其中,上述第二部署指令用于指示将接收到的信息流系统部署到上述沙盒环境。
在一些实施例中,上述目标环境为生产环境和/或沙盒环境;以及上述装置还包括地址发送单元,上述地址发送单元被配置成:接收上述终端发送的、针对上述目标历史版本信息流系统中输入节点的访问配置信息,其中,上述访问配置信息包括自定义地址;根据上述自定义地址,生成用于访问上述生产环境的第一访问地址和用于访问上述沙盒环境的第二访问地址;将上述第一访问地址和上述第二访问地址发送到上述终端。
在一些实施例中,上述装置还包括:操作信息接收单元,被配置成接收上述终端发送的、针对上述历史版本信息流系统集合中的历史版本信息流系统的操作信息,其中,上述操作信息包括历史版本信息流系统的版本标识和以下之一:删除操作指令、编辑操作指令、重命名操作指令;执行单元,被配置成对上述操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统执行相应的操作。
在一些实施例中,当上述操作信息包括编辑操作指令时,上述执行单元进一步被配置成:确定上述操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统为待编辑历史版本信息流系统;将上述待编辑历史版本信息流系统发送给上述终端,以供上述终端进行呈现;将上述终端发送的、针对上述待编辑历史版本信息流系统进行编辑后的版本作为历史版本信息流系统存储到上述历史版本信息流系统集合。
在一些实施例中,上述装置还包括:部署指令接收单元,被配置成响应于接收到上述终端创建的信息流系统以及部署到生产环境的部署指令,将所接收到的信息流系统部署到信息流在上述信息流系统中运行所需的生产环境。
第三方面,本申请实施例提供了一种服务器,该服务器包括:一个或多个处理器;存储装置,其上存储有一个或多个程序,当上述一个或多个程序被上述一个或多个处理器执行时,使得上述一个或多个处理器实现如第一方面中任一实现方式描述的方法。
第四方面,本申请实施例提供了一种计算机可读介质,其上存储有计算机程序,其中,该计算机程序被处理器执行时实现如第一方面中任一实现方式描述的方法。
本申请实施例提供的用于部署信息流系统的方法和装置,首先接收终端发送的信息流系统的第一部署指令,而后根据版本标识从历史版本信息流系统集合中确定历史版本信息流系统作为目标历史版本信息流系统,然后根据部署环境信息确定信息流在信息流系统中运行所需要的目标环境,最后将目标历史版本信息流系统部署到目标环境中,从而实现了历史版本信息流系统集合中的历史版本信息流系统的快速部署。尤其是当目标环境为生产环境时,一旦生产环境中的信息流系统发生故障,不能正常工作,可以通过上述实施例提供的方法快速部署可以正常工作的历史版本信息流系统到生产环境中,从而提高了生产环境的稳定性。
附图说明
通过阅读参照以下附图所作的对非限制性实施例所作的详细描述,本申请的其它特征、目的和优点将会变得更明显:
图1是本申请可以应用于其中的示例性系统架构图;
图2是根据本申请的用于部署信息流系统的方法的一个实施例的流程图;
图3是信息流系统的一个示例的结构示意图;
图4是根据本申请的用于部署信息流系统的方法的一个应用场景的示意图;
图5是历史版本信息流系统集合中的历史版本信息流系统的生成方法的一个实施例的流程图;
图6是根据本申请的用于部署信息流系统的装置的一个实施例的结构示意图;
图7是适于用来实现本申请实施例的服务器的计算机系统的结构示意图。
具体实施方式
下面结合附图和实施例对本申请作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释相关发明,而非对该发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与有关发明相关的部分。
需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。下面将参考附图并结合实施例来详细说明本申请。
图1示出了可以应用本申请的用于部署信息流系统的方法或用于部署信息流系统的装置的实施例的示例性系统架构100。
如图1所示,系统架构100可以包括终端设备101、102、103,网络104和服务器105。网络104用以在终端设备101、102、103和服务器105之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备101、102、103通过网络104与服务器105交互,以接收或发送消息等。终端设备101、102、103上可以安装有各种客户端应用,例如网页浏览器应用、购物类应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等。
终端设备101、102、103可以是具有显示屏并且支持通过聊天机器人(chatbot)开发页面接收和发送信息的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。
服务器105可以是提供各种服务的服务器,例如对终端设备101、102、103上显示的聊天机器人(chatbot)开发页面提供支持的后台服务器。后台服务器可以接收用户通过聊天机器人(chatbot)开发页面发送的各种开发信息,并根据开发信息创建信息流系统,以及可以根据用户发送的部署指令将信息流系统部署到运行所需的环境,从而实现用户对聊天机器人的开发。
需要说明的是,服务器105可以是硬件,也可以是软件。当服务器为硬件时,可以实现成多个服务器组成的分布式服务器集群,也可以实现成单个服务器。当服务器为软件时,可以实现成多个软件或软件模块(例如用来提供分布式服务),也可以实现成单个软件或软件模块。在此不做具体限定。
应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
需要说明的是,本申请实施例所提供的用于部署信息流系统的方法一般由服务器105执行,相应地,用于部署信息流系统的装置一般设置于服务器105中。
继续参考图2,其示出了根据本申请的用于部署信息流系统的方法的一个实施例的流程200。该用于部署信息流系统的方法,包括以下步骤:
步骤201,接收终端发送的信息流系统的第一部署指令。
在本实施例中,用于部署信息流系统的方法运行于其上的执行主体(例如图1所示的服务器105)可以通过有线连接方式或者无线连接方式从用户利用其进行聊天机器人(chatbot)开发平台访问的终端(例如图1所示的终端设备101、102、103)接收第一部署指令。其中,上述第一部署指令可以包括信息流系统的版本标识和部署环境信息。此处,信息流系统的版本标识可以用于唯一标识信息流系统的版本。作为示例,信息流系统的版本标识可以为版本名称,例如,版本(version)0.1、版本0.2等等。部署环境信息可以用于表示信息流系统所要部署到的环境。实践中,上述执行主体可以在聊天机器人开发平台的可视化界面的预定区域中显示历史版本信息流系统的版本信息。其中,版本信息可以包括版本标识、版本创建时间等等。针对该区域显示的每一条历史版本信息流系统的版本信息,可以设置一个或多个按钮,从而使用户通过点击按钮发送第一部署指令。为方便用户使用,可以设置按钮的显示标签以提示用户点击该按钮所能实现的功能。例如,对于该区域所显示的版本标识“版本0.0.1”,可以设置标签为“部署到生产环境”、“部署到沙盒环境”两个按钮。这样,用户可以通过点击标签为“部署到生产环境”的按钮发送第一部署指令,该第一部署指令可以包括版本标识“版本0.0.1”和部署环境信息“生产环境”,用于指示将版本标识为“版本0.0.1”的信息流系统部署到生产环境中。
在这里,信息流系统可以包括用于对信息流进行处理的信息流处理节点集合,信息流可以从信息流处理节点集合中的、作为入口的输入节点流入以及在流经上述信息流处理节点集合中的至少一个信息流处理节点之后流出信息流系统。其中,信息流处理节点集合中的各个信息流处理节点之间可以存在连接关系,一个节点的输出可以作为下一个节点的输入。实践中,信息流处理节点可以是硬件,也可以是软件,此处不做限定。作为示例,信息流系统可以包括一个作为入口的输入节点、至少一个用于对信息进行处理的处理节点和一个作为出口的输出节点。信息流在经过这些节点时,信息流系统会通过这些节点对流经的信息流进行处理并将处理后的信息流作为下个节点的输入,直到最后一个节点(例如输出节点)将最终的信息流输出信息流系统为止。
举例来说,假设某一个信息流系统(如图3所示)用于提供智能在线客服服务,则该信息流系统可以包括用于接收客户输入信息的聊天输入(Chat in)节点。聊天输入(Chatin)节点对客户输入信息进行预定的处理之后可以将结果按照连接关系发送给自然语言理解(Natural Language Understanding,简称NLU)节点,NLU节点对输入的数据进行自然语言解析后,可以将解析结果发送给路由(router)节点。路由节点可以根据接收的解析结果以及预先设定的选取规则,从多个处理节点中选取一个处理节点,并将解析结果发送给所选取的处理节点。该处理节点对解析结果处理完成之后,可以将处理结果发送给状态(state)节点,由状态节点进行相应的处理之后将结果发送给路由节点,并最终由路由节点将处理结果(例如反馈信息)发送给聊天输出(Chat out)节点。需要说明的是,图3中虽然未示出路由节点与处理节点、状态节点之间的连线,但是路由节点与处理节点、状态节点之间存在连接关系。需要说明的是,本例中信息流系统的节点数量以及各个节点所拥有的功能、使用方式等仅仅是示例性的,实践中,可以根据实际需要进行设定,此处不做限定。
步骤202,根据版本标识,从历史版本信息流系统集合中确定历史版本信息流系统作为目标历史版本信息流系统。
在本实施例中,上述执行主体中可以预先存储有历史版本信息流系统集合,该历史版本信息流系统集合中可以包括至少一个历史版本信息流系统。这样,上述执行主体可以从历史版本信息流系统集合中选取版本标识与步骤201中接收到的版本标识相同的历史版本信息流系统作为目标历史版本信息流系统。
步骤203,根据部署环境信息,确定信息流在信息流系统中运行所需的目标环境。
在本实施例中,上述执行主体可以根据步骤201中接收到的部署环境信息确定信息流在信息流系统中运行所需的目标环境。作为示例,上述目标环境可以是生产环境,也可以是沙盒环境。生产环境可以是指信息流系统上线后正式使用的运营环境,是指正式提供对外服务的环境。沙盒环境又称为测试环境,可以是指提供给开发者(例如,使用上述终端的用户)开发和测试用的环境。举例来说,如果开发者想要使用信息流系统对外提供服务,则可以将生产环境作为目标环境;如果开发者想要对信息流系统进行测试,则可以将沙盒环境作为目标环境。
步骤204,将目标历史版本信息流系统部署到目标环境中。
在本实施例中,上述执行主体可以将上述目标历史版本信息流系统部署到目标环境中。作为示例,上述执行主体可以通过各种部署策略将目标历史版本信息流系统部署到目标环境中。例如,重建部署,即将目标环境中运行的信息流系统下线后,目标历史版本信息流系统上线。又例如,滚动部署,即目标历史版本信息流系统缓慢更新并替代目标环境中的版本信息流系统。
在本实施例的一些可选的实现方式中,上述目标环境可以为生产环境和/或沙盒环境。以及在步骤204之前,上述方法还可以包括以下内容:
首先,上述执行主体可以接收上述终端发送的、针对目标历史版本信息流系统中输入节点的访问配置信息,其中,访问配置信息可以包括自定义地址。在这里,上述自定义地址可以是指使用上述终端的用户根据实际需要或个人习惯自己定义的地址,例如,“/a”、“/a/b/c”、“/aaa/bbb/ccc”等等。
然后,上述执行主体可以根据上述自定义地址,生成用于访问上述生成环境的第一访问地址和用于访问上述沙盒环境的第二访问地址。作为示例,上述执行主体可以“前缀+自定义地址+后缀”的形式生成第一访问地址和第二访问地址,其中,前缀可以用于表示上述执行主体的统一入口,后缀可以用于区分沙盒环境地址和生产环境地址。
实践中,生产环境和沙盒环境可以是两个独立运行的环境,两个环境内部运行的信息流系统可以一模一样。然而,这两个环境内部运行的信息流系统的输入节点的访问地址并不相同。例如,可以设置沙盒环境的地址比生产环境的地址多一个后缀,例如,?source=editor,这样,通过后缀可以区分沙盒环境和生产环境。举例来说,假设前缀为http://xxx.com/,自定义地址为users/xx/apps/xx/api/xx,则上述执行主体可以生成用于访问生产环境的第一访问地址http://xxx.com/users/xx/apps/xx/api/xx,以及用于访问沙盒环境的第二访问地址http://xxx.com/users/xx/apps/xx/api/xx?source=editor。
最后,上述执行主体可以将上述第一访问地址和上述第二访问地址发送到上述终端。这样,使用上述终端的用户可以将上述第一访问地址发布给线上访客,通过第一访问地址可以使线上访客的输入信息流入信息流系统,从而实现对线上访客的输入信息的处理和反馈。使用上述终端的用户还可以通过第二访问地址实现对信息流系统的测试,通过第二访问地址可以使测试数据流入信息流系统,从而实现对信息流系统的测试。
在本实施例的一些可选的实现方式中,上述方法还可以包括以下内容:
步骤S1,上述执行主体可以接收上述终端发送的、针对上述历史版本信息流系统集合中的历史版本信息流系统的操作信息。其中,上述操作信息可以包括历史版本信息流系统的版本标识和以下之一:删除操作指令、编辑操作指令、重命名操作指令。
步骤S2,上述执行主体可以对上述操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统执行相应的操作。作为示例,当操作信息包括删除指令时,可以将操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统进行删除。当操作信息包括重命名指令时,可以对操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统进行重命名。应当理解,重命名过程中需要终端发送新的版本名称。
在一些可选的实现方式中,当上述操作信息包括编辑操作指令时,上述步骤S2可以具体包括以下内容:
首先,上述执行主体可以确定上述操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统为待编辑历史版本信息流系统。
然后,上述执行主体可以将上述待编辑历史版本信息流系统发送给上述终端,以供上述终端进行呈现。这样,使用上述终端的用户可以对待编辑历史版本信息流系统进行编辑操作,例如,增加节点、删除节点、重定义节点功能等等。
最后,上述执行主体可以将上述终端发送的、针对上述待编辑历史版本信息流系统进行编辑后的版本作为历史版本信息流系统存储到上述历史版本信息流系统集合。作为示例,假设待编辑历史版本信息流系统为版本1,则上述执行主体可以将版本1发送给终端,以供用户进行编辑。用户编辑完成之后可以进行版本命名和保存,用户点击保存后,上述执行主体可以接收到终端发送的编辑后的版本,并将该版本命名后进行保存,从而得到不同与版本1的版本。
继续参见图4,图4是根据本实施例的用于部署信息流系统的方法的应用场景的一个示意图。在图4的应用场景中,服务器401首先接收终端402发送的信息流系统的第一部署指令,该第一部署指令包括信息流系统的版本标识“版本1.0”和部署环境信息“生产环境”。之后,服务器401根据版本标识“版本1.0”从历史版本信息流系统集合中确定版本标识为“版本1.0”的历史版本信息流系统作为目标历史版本信息流系统。然后,服务器401根据部署环境信息“生产环境”确定信息流在信息流系统中运行所需的目标环境为“生产环境”。最后,服务器401将目标历史版本信息流系统部署到生产环境中。
本申请的上述实施例提供的方法实现了历史版本信息流系统集合中的历史版本信息流系统的快速部署。尤其是当目标环境为生产环境时,一旦生产环境中的信息流系统发生故障,不能正常工作,可以通过上述实施例提供的方法快速部署可以正常工作的历史版本信息流系统到生产环境中,从而提高了生产环境的稳定性。
进一步参考图5,其示出了上述历史版本信息流系统集合中的历史版本信息流系统的生成方法的一个实施例的流程图500。该方法的流程500包括以下步骤:
步骤501,接收终端创建的信息流系统。
在本实施例中,上述执行主体可以接收终端(例如图1所示的终端设备101、102、103)创建的信息流系统。作为示例,上述执行主体可以是为聊天机器人开发平台提供支持的后台服务器,用户可以通过所使用的终端登录聊天机器人开发平台的可视化开发界面,并通过该可视化开发界面创建信息流系统。
举例来说,聊天机器人开发平台可以为ChatFlow,ChatFlow是一个提供开发聊天机器人(chatbot)的各种模块(或节点)的软件平台,同时具有多轮对话追踪能力。用户通过终端设备登录ChatFlow之后可以在可视化开发界面上通过拖拽的方式自由地选择需要用到的模块,像画流程图一样将各个模块串好,辅以对应的代码,完成信息流系统的创建。完成信息流系统的创建之后,用户可以通过点击上述可视化开发界面中预先设定的“保存”按钮,从而将创建的信息流系统发送到后端服务器。
步骤502,将接收到的信息流系统存储为历史版本信息流系统。
在本实施例中,响应于接收到终端发送的信息流系统,上述执行主体可以将接收到的信息流系统存储为历史版本信息流系统。
步骤503,配置信息流在信息流系统中运行所需的沙盒环境。
在本实施例中,上述执行主体在接收到终端创建的信息流系统之后,可以配置信息流在该信息流系统中运行所需的沙盒环境。作为示例,上述执行主体可以使用预先设定的配置规则配置沙盒环境,其中,上述预先设定的配置规则可以是用户根据实际需要进行设定的,此处不做限定。
步骤504,响应于接收到终端发送的第二部署指令,将接收到的信息流系统部署到沙盒环境。
在本实施例中,响应于接收到上述终端发送的第二部署指令,上述执行主体可以信息流系统部署到上述沙盒环境中,以供用户对信息流系统进行测试。其中,上述第二部署指令可以用于指示将接收到的信息流系统部署到上述沙盒环境。作为示例,上述第二部署指令可以是用户通过点击上述可视化开发界面中预先设定的“部署到沙盒环境”按钮发送的。
在本实施例的一些可选的实现方式中,上述方法还可以包括流程500未示出的以下内容:响应于接收到上述终端创建的信息流系统以及部署到生产环境的部署指令,上述执行主体可以将所接收到的信息流系统部署到信息流在信息流系统中运行所需的生产环境。实践中,上述执行主体可以在聊天机器人开发平台的可视化界面的预定区域中设置并显示“保存并部署到生产环境”按钮,用户通过点击该按钮可以将创建的信息流系统以及部署指令发送到后端服务器,后端服务器接收到信息流系统以及部署指令之后,可以将信息流系统部署到生产环境。通过本实现方式,可以直接将用户最新创建的信息流系统部署到生产环境中,从而使信息流系统的部署更加方便、快捷。
本实施例所描述的历史版本信息流系统集合中的历史版本信息流系统的生成方法,可以实现将最新生成的信息流系统部署到沙盒环境,从而方便了用户对信息流系统的测试。
进一步参考图6,作为对上述各图所示方法的实现,本申请提供了一种用于部署信息流系统的装置的一个实施例,该装置实施例与图2所示的方法实施例相对应,该装置具体可以应用于各种电子设备中。
如图6所示,本实施例的用于部署信息流系统的装置600包括:接收单元601、第一确定单元602、第二确定单元603和部署单元604。其中,接收单元601被配置成接收终端发送的信息流系统的第一部署指令,其中,上述第一部署指令包括信息流系统的版本标识和部署环境信息,信息流系统包括用于对信息流进行处理的信息流处理节点集合,信息流从上述信息流处理节点集合中的、作为入口的输入节点流入以及在流经上述信息流处理节点集合中的至少一个信息流处理节点之后流出信息流系统;第一确定单元602被配置成根据上述版本标识,从历史版本信息流系统集合中确定历史版本信息流系统作为目标历史版本信息流系统;第二确定单元603被配置成根据上述部署环境信息,确定信息流在信息流系统中运行所需的目标环境;部署单元604被配置成将上述目标历史版本信息流系统部署到上述目标环境中。
在本实施例中,用于部署信息流系统的装置600的接收单元601、第一确定单元602、第二确定单元603和部署单元604的具体处理及其所带来的技术效果可分别参考图2对应实施例中步骤201、步骤202、步骤203和步骤204的相关说明,在此不再赘述。
在本实施例的一些可选的实现方式中,上述装置600还包括:信息流系统接收单元(图中未示出),被配置成接收上述终端创建的信息流系统;存储单元(图中未示出),被配置成将接收到的信息流系统存储为历史版本信息流系统。
在本实施例的一些可选的实现方式中,上述装置600还包括第二部署单元(图中未示出),上述第二部署单元被配置成:配置信息流在信息流系统中运行所需的沙盒环境;响应于接收到上述终端发送的第二部署指令,将接收到的信息流系统部署到上述沙盒环境,其中,上述第二部署指令用于指示将接收到的信息流系统部署到上述沙盒环境。
在本实施例的一些可选的实现方式中,上述目标环境为生产环境和/或沙盒环境;以及上述装置600还包括地址发送单元(图中未示出),上述地址发送单元被配置成:接收上述终端发送的、针对上述目标历史版本信息流系统中输入节点的访问配置信息,其中,上述访问配置信息包括自定义地址;根据上述自定义地址,生成用于访问上述生产环境的第一访问地址和用于访问上述沙盒环境的第二访问地址;将上述第一访问地址和上述第二访问地址发送到上述终端。
在本实施例的一些可选的实现方式中,上述装置600还包括:操作信息接收单元(图中未示出),被配置成接收上述终端发送的、针对上述历史版本信息流系统集合中的历史版本信息流系统的操作信息,其中,上述操作信息包括历史版本信息流系统的版本标识和以下之一:删除操作指令、编辑操作指令、重命名操作指令;执行单元(图中未示出),被配置成对上述操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统执行相应的操作。
在本实施例的一些可选的实现方式中,当上述操作信息包括编辑操作指令时,上述执行单元进一步被配置成:确定上述操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统为待编辑历史版本信息流系统;将上述待编辑历史版本信息流系统发送给上述终端,以供上述终端进行呈现;将上述终端发送的、针对上述待编辑历史版本信息流系统进行编辑后的版本作为历史版本信息流系统存储到上述历史版本信息流系统集合。
在本实施例的一些可选的实现方式中,上述装置600还包括:部署指令接收单元(图中未示出),被配置成响应于接收到上述终端创建的信息流系统以及部署到生产环境的部署指令,将所接收到的信息流系统部署到信息流在上述信息流系统中运行所需的生产环境。
下面参考图7,其示出了适于用来实现本申请实施例的服务器的计算机系统700的结构示意图。图7示出的服务器仅仅是一个示例,不应对本申请实施例的功能和使用范围带来任何限制。
如图7所示,计算机系统700包括中央处理单元(CPU,Central Processing Unit)701,其可以根据存储在只读存储器(ROM,Read Only Memory)702中的程序或者从存储部分706加载到随机访问存储器(RAM,Random Access Memory)703中的程序而执行各种适当的动作和处理。在RAM 703中,还存储有系统700操作所需的各种程序和数据。CPU 701、ROM702以及RAM 703通过总线704彼此相连。输入/输出(I/O,Input/Output)接口705也连接至总线704。
以下部件连接至I/O接口705:包括硬盘等的存储部分706;以及包括诸如LAN(局域网,Local Area Network)卡、调制解调器等的网络接口卡的通信部分707。通信部分707经由诸如因特网的网络执行通信处理。驱动器708也根据需要连接至I/O接口705。可拆卸介质709,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器708上,以便于从其上读出的计算机程序根据需要被安装入存储部分706。
特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分707从网络上被下载和安装,和/或从可拆卸介质709被安装。在该计算机程序被中央处理单元(CPU)701执行时,执行本申请的方法中限定的上述功能。
需要说明的是,本申请所述的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本申请中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本申请中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言或其组合来编写用于执行本申请的操作的计算机程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
附图中的流程图和框图,图示了按照本申请各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本申请实施例中所涉及到的单元可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的单元也可以设置在处理器中,例如,可以描述为:一种处理器包括接收单元、第一确定单元、第二确定单元和部署单元。其中,这些单元的名称在某种情况下并不构成对该单元本身的限定,例如,接收单元还可以被描述为“接收终端发送的信息流系统的第一部署指令的单元”。
作为另一方面,本申请还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的装置中所包含的;也可以是单独存在,而未装配入该装置中。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该装置执行时,使得该装置:接收终端发送的信息流系统的第一部署指令,其中,上述第一部署指令包括信息流系统的版本标识和部署环境信息,信息流系统包括用于对信息流进行处理的信息流处理节点集合,信息流从上述信息流处理节点集合中的、作为入口的输入节点流入以及在流经上述信息流处理节点集合中的至少一个信息流处理节点之后流出信息流系统;根据上述版本标识,从历史版本信息流系统集合中确定历史版本信息流系统作为目标历史版本信息流系统;根据上述部署环境信息,确定信息流在信息流系统中运行所需的目标环境;将上述目标历史版本信息流系统部署到上述目标环境中。
以上描述仅为本申请的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本申请中所涉及的发明范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述发明构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本申请中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。

Claims (16)

1.一种用于部署信息流系统的方法,包括:
接收终端发送的信息流系统的第一部署指令,其中,所述第一部署指令包括信息流系统的版本标识和部署环境信息,信息流系统包括用于对信息流进行处理的信息流处理节点集合,信息流从所述信息流处理节点集合中的、作为入口的输入节点流入以及在流经所述信息流处理节点集合中的至少一个信息流处理节点之后流出信息流系统,其中,信息流系统用于智能交互机器人来支撑使用者输入信息后给予正确的反馈;
根据所述版本标识,从历史版本信息流系统集合中确定历史版本信息流系统作为目标历史版本信息流系统,包括:从所述历史版本信息流系统集合中选取版本标识与所述第一部署指令中的版本标识相同的历史版本信息流系统作为目标历史版本信息流系统;
根据所述部署环境信息,确定信息流在信息流系统中运行所需的目标环境;
将所述目标历史版本信息流系统部署到所述目标环境中。
2.根据权利要求1所述的方法,其中,所述历史版本信息流系统集合中的历史版本信息流系统是通过如下步骤生成的:
接收所述终端创建的信息流系统;
将接收到的信息流系统存储为历史版本信息流系统。
3.根据权利要求2所述的方法,其中,在接收所述终端创建的信息流系统之后,所述方法还包括:
配置信息流在信息流系统中运行所需的沙盒环境;
响应于接收到所述终端发送的第二部署指令,将接收到的信息流系统部署到所述沙盒环境,其中,所述第二部署指令用于指示将接收到的信息流系统部署到所述沙盒环境。
4.根据权利要求1所述的方法,其中,所述目标环境为生产环境和/或沙盒环境;以及
在将所述目标历史版本信息流系统部署到所述目标环境之前,所述方法还包括:
接收所述终端发送的、针对所述目标历史版本信息流系统中输入节点的访问配置信息,其中,所述访问配置信息包括自定义地址;
根据所述自定义地址,生成用于访问所述生产环境的第一访问地址和用于访问所述沙盒环境的第二访问地址;
将所述第一访问地址和所述第二访问地址发送到所述终端。
5.根据权利要求1所述的方法,其中,所述方法还包括:
接收所述终端发送的、针对所述历史版本信息流系统集合中的历史版本信息流系统的操作信息,其中,所述操作信息包括历史版本信息流系统的版本标识和以下之一:删除操作指令、编辑操作指令、重命名操作指令;
对所述操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统执行相应的操作。
6.根据权利要求5所述的方法,其中,当所述操作信息包括编辑操作指令时,所述对所述操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统执行相应的操作,包括:
确定所述操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统为待编辑历史版本信息流系统;
将所述待编辑历史版本信息流系统发送给所述终端,以供所述终端进行呈现;
将所述终端发送的、针对所述待编辑历史版本信息流系统进行编辑后的版本作为历史版本信息流系统存储到所述历史版本信息流系统集合。
7.根据权利要求2所述的方法,其中,所述方法还包括:
响应于接收到所述终端创建的信息流系统以及部署到生产环境的部署指令,将所接收到的信息流系统部署到信息流在所述信息流系统中运行所需的生产环境。
8.一种用于部署信息流系统的装置,包括:
接收单元,被配置成接收终端发送的信息流系统的第一部署指令,其中,所述第一部署指令包括信息流系统的版本标识和部署环境信息,信息流系统包括用于对信息流进行处理的信息流处理节点集合,信息流从所述信息流处理节点集合中的、作为入口的输入节点流入以及在流经所述信息流处理节点集合中的至少一个信息流处理节点之后流出信息流系统,其中,信息流系统用于智能交互机器人来支撑使用者输入信息后给予正确的反馈;
第一确定单元,被配置成根据所述版本标识,从历史版本信息流系统集合中确定历史版本信息流系统作为目标历史版本信息流系统,所述第一确定单元进一步被配置成:从所述历史版本信息流系统集合中选取版本标识与所述第一部署指令中的版本标识相同的历史版本信息流系统作为目标历史版本信息流系统;
第二确定单元,被配置成根据所述部署环境信息,确定信息流在信息流系统中运行所需的目标环境;
部署单元,被配置成将所述目标历史版本信息流系统部署到所述目标环境中。
9.根据权利要求8所述的装置,其中,所述装置还包括:
信息流系统接收单元,被配置成接收所述终端创建的信息流系统;
存储单元,被配置成将接收到的信息流系统存储为历史版本信息流系统。
10.根据权利要求9所述的装置,其中,所述装置还包括第二部署单元,所述第二部署单元被配置成:
配置信息流在信息流系统中运行所需的沙盒环境;
响应于接收到所述终端发送的第二部署指令,将接收到的信息流系统部署到所述沙盒环境,其中,所述第二部署指令用于指示将接收到的信息流系统部署到所述沙盒环境。
11.根据权利要求8所述的装置,其中,所述目标环境为生产环境和/或沙盒环境;以及
所述装置还包括地址发送单元,所述地址发送单元被配置成:
接收所述终端发送的、针对所述目标历史版本信息流系统中输入节点的访问配置信息,其中,所述访问配置信息包括自定义地址;
根据所述自定义地址,生成用于访问所述生产环境的第一访问地址和用于访问所述沙盒环境的第二访问地址;
将所述第一访问地址和所述第二访问地址发送到所述终端。
12.根据权利要求8所述的装置,其中,所述装置还包括:
操作信息接收单元,被配置成接收所述终端发送的、针对所述历史版本信息流系统集合中的历史版本信息流系统的操作信息,其中,所述操作信息包括历史版本信息流系统的版本标识和以下之一:删除操作指令、编辑操作指令、重命名操作指令;
执行单元,被配置成对所述操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统执行相应的操作。
13.根据权利要求12所述的装置,其中,当所述操作信息包括编辑操作指令时,所述执行单元进一步被配置成:
确定所述操作信息中的历史版本信息流系统的版本标识所对应的历史版本信息流系统为待编辑历史版本信息流系统;
将所述待编辑历史版本信息流系统发送给所述终端,以供所述终端进行呈现;
将所述终端发送的、针对所述待编辑历史版本信息流系统进行编辑后的版本作为历史版本信息流系统存储到所述历史版本信息流系统集合。
14.根据权利要求9所述的装置,其中,所述装置还包括:
部署指令接收单元,被配置成响应于接收到所述终端创建的信息流系统以及部署到生产环境的部署指令,将所接收到的信息流系统部署到信息流在所述信息流系统中运行所需的生产环境。
15.一种服务器,包括:
一个或多个处理器;
存储装置,其上存储有一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行时,使得所述一个或多个处理器实现如权利要求1-7中任一所述的方法。
16.一种计算机可读介质,其上存储有计算机程序,其中,该计算机程序被处理器执行时实现如权利要求1-7中任一所述的方法。
CN201811014614.XA 2018-08-31 2018-08-31 用于部署信息流系统的方法和装置 Active CN109254778B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201811014614.XA CN109254778B (zh) 2018-08-31 2018-08-31 用于部署信息流系统的方法和装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811014614.XA CN109254778B (zh) 2018-08-31 2018-08-31 用于部署信息流系统的方法和装置

Publications (2)

Publication Number Publication Date
CN109254778A CN109254778A (zh) 2019-01-22
CN109254778B true CN109254778B (zh) 2020-06-16

Family

ID=65050466

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201811014614.XA Active CN109254778B (zh) 2018-08-31 2018-08-31 用于部署信息流系统的方法和装置

Country Status (1)

Country Link
CN (1) CN109254778B (zh)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111176830B (zh) * 2019-12-03 2024-04-26 先进新星技术(新加坡)控股有限公司 信息流的分配方法、装置及服务器系统
CN114443057B (zh) * 2022-01-25 2023-03-24 北京百度网讯科技有限公司 对话模型的部署和对话方法、装置、电子设备及存储介质

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104090799A (zh) * 2014-07-11 2014-10-08 百度在线网络技术(北京)有限公司 一种环境部署方法及装置
CN107463432A (zh) * 2017-08-17 2017-12-12 福建中金在线信息科技有限公司 服务器生产环境部署方法、装置、电子设备及存储介质
CN107908421A (zh) * 2017-09-29 2018-04-13 北京创鑫旅程网络技术有限公司 软件代码版本管理与发布的方法及装置
CN108416151A (zh) * 2018-03-16 2018-08-17 中国空间技术研究院 一种基于模型的卫星测控信息流智能化设计系统及故障信息快速定位方法

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9798916B2 (en) * 2015-09-15 2017-10-24 Kimberly Anne Fish Symbolic print to electronic media bridge

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104090799A (zh) * 2014-07-11 2014-10-08 百度在线网络技术(北京)有限公司 一种环境部署方法及装置
CN107463432A (zh) * 2017-08-17 2017-12-12 福建中金在线信息科技有限公司 服务器生产环境部署方法、装置、电子设备及存储介质
CN107908421A (zh) * 2017-09-29 2018-04-13 北京创鑫旅程网络技术有限公司 软件代码版本管理与发布的方法及装置
CN108416151A (zh) * 2018-03-16 2018-08-17 中国空间技术研究院 一种基于模型的卫星测控信息流智能化设计系统及故障信息快速定位方法

Also Published As

Publication number Publication date
CN109254778A (zh) 2019-01-22

Similar Documents

Publication Publication Date Title
US11132114B2 (en) Method and apparatus for generating customized visualization component
CN109117378B (zh) 用于显示信息的方法和装置
CN111090423B (zh) 一种webhook框架系统和实现主动调用、实现事件触发的方法
CN112015654A (zh) 用于测试的方法和装置
CN111340220A (zh) 用于训练预测模型的方法和装置
CN110543297A (zh) 用于生成源码的方法和装置
WO2019029451A1 (zh) 发布移动应用的方法和电子设备
CN113010405A (zh) 一种应用程序的测试方法和装置
CN111368973A (zh) 用于训练超网络的方法和装置
CN112187488A (zh) 网络沟通方法和设备
CN109254778B (zh) 用于部署信息流系统的方法和装置
CN113296828A (zh) 一种发布应用的方法、服务器和系统
JP2021114278A (ja) 情報を生成するための方法及び装置
CN111382953A (zh) 一种动态流程生成方法和装置
CN111124523A (zh) 用于初始化应用的方法和装置
CN114157658A (zh) 镜像仓库部署方法、装置、电子设备和计算机可读介质
CN114661274A (zh) 用于生成智能合约的方法和装置
CN113095060A (zh) 处理数据的方法、装置、设备和计算机可读介质
US20210096919A1 (en) Identifying recurring actions in a hybrid integration platform to control resource usage
CN112395194A (zh) 一种接入测试平台的方法和装置
CN112099841A (zh) 一种生成配置文件的方法和系统
US20190373110A1 (en) Predicting 'usefullness' of a call by analysing digital footprint of a person
CN111767447A (zh) 用于确定用户流量路径的方法和装置
US11880668B2 (en) Dynamically altering a code execution workflow during development using augmented reality
CN111131354A (zh) 用于生成信息的方法和装置

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant
TR01 Transfer of patent right
TR01 Transfer of patent right

Effective date of registration: 20210508

Address after: 100085 Baidu Building, 10 Shangdi Tenth Street, Haidian District, Beijing

Patentee after: BEIJING BAIDU NETCOM SCIENCE AND TECHNOLOGY Co.,Ltd.

Patentee after: Shanghai Xiaodu Technology Co.,Ltd.

Address before: 100085 Baidu Building, 10 Shangdi Tenth Street, Haidian District, Beijing

Patentee before: BEIJING BAIDU NETCOM SCIENCE AND TECHNOLOGY Co.,Ltd.