CN108156022A - 一种服务调用方法、装置及电子设备 - Google Patents

一种服务调用方法、装置及电子设备 Download PDF

Info

Publication number
CN108156022A
CN108156022A CN201711261116.0A CN201711261116A CN108156022A CN 108156022 A CN108156022 A CN 108156022A CN 201711261116 A CN201711261116 A CN 201711261116A CN 108156022 A CN108156022 A CN 108156022A
Authority
CN
China
Prior art keywords
micro services
code
interface
configuration
configuration result
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.)
Granted
Application number
CN201711261116.0A
Other languages
English (en)
Other versions
CN108156022B (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 QIYI Century Science and Technology Co Ltd
Original Assignee
Beijing QIYI Century 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 QIYI Century Science and Technology Co Ltd filed Critical Beijing QIYI Century Science and Technology Co Ltd
Priority to CN201711261116.0A priority Critical patent/CN108156022B/zh
Publication of CN108156022A publication Critical patent/CN108156022A/zh
Application granted granted Critical
Publication of CN108156022B publication Critical patent/CN108156022B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L41/00Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
    • H04L41/08Configuration management of networks or network elements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]

Abstract

本发明实施例提供了一种服务调用方法、装置及电子设备,应用于互联网技术领域,所述方法包括:根据本地存储的各微服务的接口,通过配置页面对各微服务进行配置,得到各微服务的配置结果;根据各微服务的接口以及各微服务的配置结果,通过代码生成工具,自动生成各微服务代码;在调用各微服务时,通过接口注解方式自动调用各微服务代码,得到各微服务对应的返回值。本发明实施例通过对微服务进行配置,并自动生成微服务代码,减少了代码的开发量,并且生成的微服务代码逻辑统一,可以提高系统的稳定性;通过接口注解方式自动调用各微服务代码,代码调用过程简单。

Description

一种服务调用方法、装置及电子设备
技术领域
本发明涉及互联网技术领域,特别是涉及一种服务调用方法、装置及电子设备。
背景技术
在互联网企业中,对外提供服务的系统往往需要调用成百上千个微服务,而微服务是一个新兴的软件架构,就是把一个大型的单个应用程序和服务拆分为数十个的支持微服务。一个微服务的策略可以让工作变得更为简便,它可扩展单个组件而不是整个的应用程序堆栈,从而满足服务等级协议。
然而,调用的微服务会暴露自己的接口给其他应用,而且这些微服务的接口大部分支持HTTP(HyperText Transfer Protocol,超文本传输协议)的访问方式。通过HTTP的访问方式调用的代码一般是重复的,那么,需要开发人员编写大量的HTTP访问调用代码,并且,在调用微服务之后,对微服务的返回值进行处理也需要编写大量的代码,导致开发效率较低。
发明内容
本发明实施例的目的在于提供一种服务调用方法、装置及电子设备,以简化代码开发量、提高开发效率。具体技术方案如下:
本发明实施例提供了一种服务调用方法,所述方法包括:
根据本地存储的各微服务的接口,通过配置页面对所述各微服务进行配置,得到所述各微服务的配置结果;
根据所述各微服务的接口以及所述各微服务的配置结果,通过代码生成工具,自动生成各微服务代码;
在调用所述各微服务时,通过接口注解方式自动调用所述各微服务代码,得到所述各微服务对应的返回值。
可选的,在所述通过接口注解方式自动调用所述各微服务代码,得到所述各微服务对应的返回值之后,所述方法还包括:
根据所述各微服务对应的返回值,以及所述各微服务代码中返回参数与实体值对象参数的对应关系,得到所述各微服务对应的实体值对象。
可选的,所述根据本地存储的各微服务的接口,通过配置页面对所述各微服务进行配置,得到所述各微服务的配置结果,包括:
根据各微服务的接口,设置所述各微服务的请求字段、所述请求字段的默认值、返回字段、所述返回字段和实体值对象的对应关系、待生成的各微服务代码的名称。
可选的,所述根据所述各微服务的接口以及所述各微服务的配置结果,通过代码生成工具,自动生成各微服务代码,包括:
根据所述各微服务的接口以及所述各微服务的请求字段、返回字段,生成各微服务代码的请求参数和返回参数;
根据所述请求字段的默认值,设置所述请求参数的默认值;
根据所述返回字段和实体值对象的对应关系,建立返回参数和实体值对象参数的对应关系。
可选的,在所述根据本地存储的各微服务的接口,通过配置页面对所述各微服务进行配置,得到所述各微服务的配置结果之后,所述方法还包括:
将所述配置结果保存至配置文件中;
当接收到对所述配置结果进行修改的操作指令时,对所述配置文件中的配置结果进行修改,得到更新的配置文件。
可选的,在所述根据本地存储的各微服务的接口,通过配置页面对所述各微服务进行配置,得到所述各微服务的配置结果之前,所述方法还包括:
获取待调用的各微服务的接口,将所述各微服务的接口存储至本地。
本发明实施例提供了一种服务调用装置,所述装置包括:
配置模块,用于根据本地存储的各微服务的接口,通过配置页面对所述各微服务进行配置,得到所述各微服务的配置结果;
代码生成模块,用于根据所述各微服务的接口以及所述各微服务的配置结果,通过代码生成工具,自动生成各微服务代码;
服务调用模块,用于在调用所述各微服务时,通过接口注解方式自动调用所述各微服务代码,得到所述各微服务对应的返回值。
可选的,本发明实施例的服务调用装置,还包括:
实体值对象确定模块,用于根据所述各微服务对应的返回值,以及所述各微服务代码中返回参数与实体值对象参数的对应关系,得到所述各微服务对应的实体值对象。
可选的,所述配置模块具体用于,根据各微服务的接口,设置所述各微服务的请求字段、所述请求字段的默认值、返回字段、所述返回字段和实体值对象的对应关系、待生成的各微服务代码的名称。
可选的,所述代码生成模块具体用于,根据所述各微服务的接口以及所述各微服务的请求字段、返回字段,生成各微服务代码的请求参数和返回参数;根据所述请求字段的默认值,设置所述请求参数的默认值;根据所述返回字段和实体值对象的对应关系,建立返回参数和实体值对象参数的对应关系。
可选的,本发明实施例的服务调用装置,还包括:
配置结果保存模块,用于将所述配置结果保存至配置文件中;
配置结果修改模块,用于当接收到对所述配置结果进行修改的操作指令时,对所述配置文件中的配置结果进行修改,得到更新的配置文件。
可选的,本发明实施例的服务调用装置,还包括:
接口存储模块,用于获取待调用的各微服务的接口,将所述各微服务的接口存储至本地。
本发明实施例提供了一种电子设备,包括:处理器、通信接口、存储器和通信总线,其中,所述处理器、所述通信接口、所述存储器通过所述通信总线完成相互间的通信;
所述存储器,用于存放计算机程序;
所述处理器,用于执行所述存储器上所存放的程序时,实现上述任一所述的服务调用方法的步骤。
在本发明实施的又一方面,还提供了一种计算机可读存储介质,所述计算机可读存储介质中存储有指令,当其在计算机上运行时,使得计算机执行上述任一所述的服务调用方法的步骤。
在本发明实施的又一方面,本发明实施例还提供了一种包含指令的计算机程序产品,当其在计算机上运行时,使得计算机执行上述任一所述的服务调用方法的步骤。
本发明实施例提供的服务调用方法、装置及电子设备,根据本地存储的各微服务的接口,通过配置页面对各微服务进行配置,得到各微服务的配置结果;根据各微服务的接口以及各微服务的配置结果,通过代码生成工具,自动生成各微服务代码;在调用各微服务时,通过接口注解方式自动调用各微服务代码,得到各微服务对应的返回值。本发明实施例通过配置页面对各微服务进行配置,根据得到的配置结果自动生成微服务代码,微服务代码可以调用微服务,简化了代码的开发量,提高了代码开发的效率。另外,通过接口注解方式自动调用各微服务代码,代码调用过程简单。当然,实施本发明的任一产品或方法并不一定需要同时达到以上所述的所有优点。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍。
图1为本发明实施例的服务调用方法的一种流程图;
图2为本发明实施例的服务调用方法的另一种流程图;
图3为本发明实施例的服务调用装置的一种结构图;
图4为本发明实施例的服务调用装置的另一种结构图;
图5为本发明实施例的电子设备的结构图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行描述。
为了解决通过HTTP访问方式调用微服务时,需要开发重复的HTTP访问调用代码的问题,本发明实施例提供了一种服务调用方法、装置及电子设备,以简化代码的开发量,提高开发效率。
下面首先对本发明实施例的服务调用方法进行详细介绍。
参见图1,图1为本发明实施例的服务调用方法的一种流程图,包括以下步骤:
S101,根据本地存储的各微服务的接口,通过配置页面对各微服务进行配置,得到各微服务的配置结果。
其中,微服务是一种新兴的软件架构,就是把一个大型的单个应用程序和服务拆分为数十个的支持微服务。一个微服务的策略可以让工作变得更为简便,它可扩展单个组件而不是整个的应用程序堆栈,从而满足服务等级协议。微服务架构来源于互联网的思路,因此,组件对外发布的微服务可以通过HTTP访问的方式调用。例如,通过以HTTP访问方式请求地址http://www.test.com/test.html?p1=a可以调用微服务。微服务的接口可以是URL(Uniform Resource Locator,统一资源定位符)地址,URL是对可以从互联网上得到的资源的位置和访问方法的一种简洁的表示,是互联网上标准资源的地址。互联网上的每个文件都有一个唯一的URL,URL中包含的信息指出文件的位置以及浏览器应该怎么处理该URL。本发明实施例根据各微服务的接口,通过配置页面对各微服务进行配置,得到各微服务的配置结果,其中,对各微服务进行配置指的是,配置请求字段、返回字段以及返回字段和实体值对象的对应关系等,请求字段与微服务的输入参数相对应,返回字段与微服务的输出参数相对应。
S102,根据各微服务的接口以及各微服务的配置结果,通过代码生成工具,自动生成各微服务代码。
本发明实施例中,在通过S101得到各微服务的配置结果之后,可以根据各微服务的接口以及各微服务的配置结果,通过代码生成工具,自动生成微服务代码,各微服务代码可以调用各微服务。其中,代码生成工具包括代码生成的类库,例如,Javassist、ApacheBCEL、ASM、cglib等。根据各微服务的接口以及各微服务的配置结果,自动生成各微服务代码。
S103,在调用各微服务时,通过接口注解方式自动调用各微服务代码,得到各微服务对应的返回值。
具体的,S101中,在对各微服务进行配置时,同时根据各微服务接口配置各微服务接口对应的接口注解,而JAVA中的注解可以用于创建文档,跟踪代码中的依赖性,甚至执行基本编译时检查。注解是以‘@注解名’在代码中存在的,根据注解参数的个数,可以将注解分为:标记注解、单值注解、完整注解三类。它们都不会直接影响到程序的语义,只是作为注解(标识)存在,可以通过反射机制编程实现对这些元数据(用来描述数据的数据)的访问。在调用各微服务时,可以根据各微服务接口对应的接口注解,自动调用各微服务所对应的微服务代码,从而得到各微服务对应的返回值。
本发明实施例的服务调用方法,根据本地存储的各微服务的接口,通过配置页面对各微服务进行配置,得到各微服务的配置结果;根据各微服务的接口以及各微服务的配置结果,通过代码生成工具,自动生成各微服务代码;在调用各微服务时,通过接口注解方式自动调用各微服务代码,得到各微服务对应的返回值。本发明实施例通过配置页面对各微服务进行配置,根据得到的配置结果自动生成微服务代码,微服务代码可以调用微服务,简化了代码的开发量,提高了代码开发的效率。另外,通过接口注解方式自动调用各微服务代码,代码调用过程简单。
参见图2,图2为本发明实施例的服务调用方法的另一种流程图,包括以下步骤:
S201,获取待调用的各微服务的接口,将各微服务的接口存储至本地。
本发明实施例中,微服务可以是各互联网公司提供的微服务,那么,为了调用各互联网公司的微服务,需要获取各互联网公司提供的微服务的接口。具体的,系统管理员可以对系统进行配置,获取各公司内部的微服务swagger-url,如果是符合swagger标准定义,将自动读取微服务的接口,存储至本地,例如,可以存在本地数据库或者本地文件中。其中,Swagger是一个规范和完整的框架,用于生成、描述、调用和可视化RESTful风格的Web服务。并且,Swagger是一种和语言无关的规范和框架,用于定义服务接口,主要用于描述RESTful的API(Application Programming Interface,应用程序编程接口)。
S202,根据本地存储的各微服务的接口,通过配置页面对各微服务进行配置,得到各微服务的配置结果。
S203,根据各微服务的接口以及各微服务的配置结果,通过代码生成工具,自动生成各微服务代码。
S204,在调用各微服务时,通过接口注解方式自动调用各微服务代码,得到各微服务对应的返回值。
S205,根据各微服务对应的返回值,以及各微服务代码中返回参数与实体值对象参数的对应关系,得到各微服务对应的实体值对象。
本发明实施例中,在通过微服务代码调用微服务,得到微服务的返回值之后,还可以对微服务的返回值进行处理,得到处理后的结果,即微服务对应的实体值对象。例如,微服务的返回值为用户名,为了得到用户名的首字母,可以通过调用该微服务,根据微服务代码中返回参数与实体值对象参数的对应关系,将返回值传入返回参数,得到各微服务对应的实体值对象。
由于S202、S203、S204分别与图1实施例中的S101、S102、S103相同,S101、S102、S103的所有实现方式均适用于图2,且均能达到相同或相似的有益效果,在此不再赘述。
本发明实施例的服务调用方法,在得到各微服务对应的返回值之后,还可以根据各微服务对应的返回值,以及各微服务代码中返回参数与实体值对象参数的对应关系,得到各微服务对应的实体值对象。由于各微服务代码是通过配置的方式生成的,因此,简化了代码的开发,减少了工作量,提高了开发效率。
本发明的一种实现方式中,图1实施例S101或图2实施例S202中,根据本地存储的各微服务的接口,通过配置页面对各微服务进行配置,得到各微服务的配置结果,包括:
根据各微服务的接口,设置各微服务的请求字段、请求字段的默认值、返回字段、返回字段和实体值对象的对应关系、待生成的各微服务代码的名称。
通常,不同微服务的功能是不同的,那么,不同微服务的接口也是不同的,例如,微服务的接口可以是URL地址,互联网上的每个文件都有一个唯一的URL,URL中包含的信息指出文件的位置以及浏览器应该怎么处理该URL。因此,本发明实施例中,根据各微服务的接口,通过配置页面可以对各微服务进行配置,得到各微服务的配置结果。其中,对各微服务进行配置指的是,配置请求字段、返回字段以及返回字段和实体值对象的对应关系等,请求字段与待生成的微服务代码中的输入参数相对应,返回字段与待生成的微服务代码中的输出参数相对应。返回字段和实体值对象的对应关系用于表示待生成的微服务代码的输出参数与处理后的输出参数的对应关系,并且,返回字段和实体值对象的对应关系可以通过公式进行配置。
例如,对微服务的配置结果可以通过表一表示如下:
表一
由表一可以看出,配置结果中包括:HTTP访问的请求地址、该请求地址中包括请求字段p1,并且p1的值为a,HTTP访问的请求方式GET、返回字段r1、r2、实体值对象s1、s2,返回字段和实体值对象的对应关系,以及微服务代码的名称TestDelegate。这样,代码生成的类库可以根据该配置结果自动生成相应的微服务代码。
本发明的一种实现方式中,图1实施例S102或图2实施例S203中,根据各微服务的接口以及各微服务的配置结果,通过代码生成工具,自动生成各微服务代码,包括以下步骤:
第一步,根据各微服务的接口以及各微服务的请求字段、返回字段,生成各微服务代码的请求参数和返回参数。
本发明实施例中,请求字段和返回字段是配置页面中的字段,分别对应于微服务代码中的输入参数和输出参数,因此,代码生成的类库可以根据各微服务的接口以及请求字段、返回字段,生成各微服务代码的请求参数和返回参数。
第二步,根据请求字段的默认值,设置请求参数的默认值。
具体的,由于请求字段对应于输入参数,因此,在生成微服务代码时,可以设置请求参数的默认值,请求参数的默认值可以为请求字段的默认值。
第三步,根据返回字段和实体值对象的对应关系,建立返回参数和实体值对象参数的对应关系。
同样地,可以根据配置页面中返回字段和实体值对象的对应关系,建立微服务代码中的返回参数和实体值对象参数的对应关系。
可见,通过上述方式,可以根据配置页面自动生成微服务的接口对应的微服务代码,之后,可以根据微服务代码调用各微服务,得到各微服务的返回值。因此,本发明实施例简化了代码的开发,提高了开发效率。
本发明的一种实现方式中,在根据本地存储的各微服务的接口,通过配置页面对各微服务进行配置,得到各微服务的配置结果之后,本发明的服务调用方法还包括:
第一步,将配置结果保存至配置文件中。
第二步,当接收到对配置结果进行修改的操作指令时,对配置文件中的配置结果进行修改,得到更新的配置文件。
本发明实施例中,通过配置页面对微服务进行配置时,还可以生成对应的配置文件,通过配置页面保存配置时,同时将配置结果保存至配置文件中。当需要对配置结果进行修改时,可以通过配置文件对配置结果进行修改即可,而不需要通过配置页面进行修改。这样,可以提高对配置结果进行修改的效率。
相应于上述方法实施例,本发明实施例还提供了一种服务调用装置,参见图3,图3为本发明实施例的服务调用装置的一种结构图,包括:
配置模块301,用于根据本地存储的各微服务的接口,通过配置页面对各微服务进行配置,得到各微服务的配置结果;
代码生成模块302,用于根据各微服务的接口以及各微服务的配置结果,通过代码生成工具,自动生成各微服务代码;
服务调用模块303,用于在调用各微服务时,通过接口注解方式自动调用各微服务代码,得到各微服务对应的返回值。
本发明实施例的服务调用装置,根据本地存储的各微服务的接口,通过配置页面对各微服务进行配置,得到各微服务的配置结果;根据各微服务的接口以及各微服务的配置结果,通过代码生成工具,自动生成各微服务代码;在调用各微服务时,通过接口注解方式自动调用各微服务代码,得到各微服务对应的返回值。本发明实施例通过配置页面对各微服务进行配置,根据得到的配置结果自动生成微服务代码,微服务代码可以调用微服务,简化了代码的开发量,提高了代码开发的效率。另外,通过接口注解方式自动调用各微服务代码,代码调用过程简单。
需要说明的是,本发明实施例的装置是应用上述服务调用方法的装置,则上述服务调用方法的所有实施例均适用于该装置,且均能达到相同或相似的有益效果。
参见图4,图4为本发明实施例的服务调用装置的另一种结构图,包括:
接口存储模块401,用于获取待调用的各微服务的接口,将各微服务的接口存储至本地;
配置模块402,用于根据本地存储的各微服务的接口,通过配置页面对各微服务进行配置,得到各微服务的配置结果;
代码生成模块403,用于根据各微服务的接口以及各微服务的配置结果,通过代码生成工具,自动生成各微服务代码;
服务调用模块404,用于在调用各微服务时,通过接口注解方式自动调用各微服务代码,得到各微服务对应的返回值。
实体值对象确定模块405,用于根据各微服务对应的返回值,以及各微服务代码中返回参数与实体值对象参数的对应关系,得到各微服务对应的实体值对象。
本发明实施例的服务调用装置,在得到各微服务对应的返回值之后,还可以根据各微服务对应的返回值,以及各微服务代码中返回参数与实体值对象参数的对应关系,得到各微服务对应的实体值对象。由于各微服务代码是通过配置的方式生成的,因此,简化了代码的开发,减少了工作量,提高了开发效率。
本发明的一种实现方式中,配置模块具体用于,根据各微服务的接口,设置各微服务的请求字段、请求字段的默认值、返回字段、返回字段和实体值对象的对应关系、待生成的各微服务代码的名称。
本发明的一种实现方式中,代码生成模块具体用于,根据各微服务的接口以及各微服务的请求字段、返回字段,生成各微服务代码的请求参数和返回参数;根据请求字段的默认值,设置请求参数的默认值;根据返回字段和实体值对象的对应关系,建立返回参数和实体值对象参数的对应关系。
可选的,本发明实施例的服务调用装置,还包括:
配置结果保存模块,用于将配置结果保存至配置文件中;
配置结果修改模块,用于当接收到对配置结果进行修改的操作指令时,对配置文件中的配置结果进行修改,得到更新的配置文件。
本发明实施例还提供了一种电子设备,参见图5,图5为本发明实施例的电子设备的结构图,包括:处理器501、通信接口502、存储器503和通信总线504,其中,处理器501、通信接口502、存储器503通过通信总线504完成相互间的通信;
存储器503,用于存放计算机程序;
处理器501,用于执行存储器503上所存放的程序时,实现上述实施例中任一服务调用方法的步骤。
需要说明的是,上述电子设备提到的通信总线504可以是PCI(PeripheralComponent Interconnect,外设部件互连标准)总线或EISA(Extended Industry StandardArchitecture,扩展工业标准结构)总线等。该通信总线504可以分为地址总线、数据总线、控制总线等。为便于表示,图5中仅用一条粗线表示,但并不表示仅有一根总线或一种类型的总线。
通信接口502用于上述电子设备与其他设备之间的通信。
存储器503可以包括RAM(Random Access Memory,随机存取存储器),也可以包括非易失性存储器(non-volatile memory),例如至少一个磁盘存储器。可选的,存储器还可以是至少一个位于远离前述处理器的存储装置。
上述的处理器501可以是通用处理器,包括:CPU(Central Processing Unit,中央处理器)、NP(Network Processor,网络处理器)等;还可以是DSP(Digital SignalProcessing,数字信号处理器)、ASIC(Application Specific Integrated Circuit,专用集成电路)、FPGA(Field-Programmable Gate Array,现场可编程门阵列)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。
本发明实施例的电子设备中,处理器通过执行存储器上所存放的程序,从而根据本地存储的各微服务的接口,通过配置页面对各微服务进行配置,得到各微服务的配置结果;根据各微服务的接口以及各微服务的配置结果,通过代码生成工具,自动生成各微服务代码;在调用各微服务时,通过接口注解方式自动调用各微服务代码,得到各微服务对应的返回值。本发明实施例通过配置页面对各微服务进行配置,根据得到的配置结果自动生成微服务代码,微服务代码可以调用微服务,简化了代码的开发量,提高了代码开发的效率。另外,通过接口注解方式自动调用各微服务代码,代码调用过程简单。
在本发明提供的又一实施例中,还提供了一种计算机可读存储介质,该计算机可读存储介质中存储有指令,当其在计算机上运行时,使得计算机执行上述实施例中任一服务调用方法的步骤。
本发明实施例的计算机可读存储介质中存储的指令在计算机上运行时,可以根据本地存储的各微服务的接口,通过配置页面对各微服务进行配置,得到各微服务的配置结果;根据各微服务的接口以及各微服务的配置结果,通过代码生成工具,自动生成各微服务代码;在调用各微服务时,通过接口注解方式自动调用各微服务代码,得到各微服务对应的返回值。本发明实施例通过配置页面对各微服务进行配置,根据得到的配置结果自动生成微服务代码,微服务代码可以调用微服务,简化了代码的开发量,提高了代码开发的效率。另外,通过接口注解方式自动调用各微服务代码,代码调用过程简单。
在本发明提供的又一实施例中,还提供了一种包含指令的计算机程序产品,当其在计算机上运行时,使得计算机执行上述实施例中任一服务调用方法的步骤。
本发明实施例的计算机程序产品,当其在计算机上运行时,根据本地存储的各微服务的接口,通过配置页面对各微服务进行配置,得到各微服务的配置结果;根据各微服务的接口以及各微服务的配置结果,通过代码生成工具,自动生成各微服务代码;在调用各微服务时,通过接口注解方式自动调用各微服务代码,得到各微服务对应的返回值。本发明实施例通过配置页面对各微服务进行配置,根据得到的配置结果自动生成微服务代码,微服务代码可以调用微服务,简化了代码的开发量,提高了代码开发的效率。另外,通过接口注解方式自动调用各微服务代码,代码调用过程简单。
在上述实施例中,可以全部或部分地通过软件、硬件、固件或者其任意组合来实现。当使用软件实现时,可以全部或部分地以计算机程序产品的形式实现。所述计算机程序产品包括一个或多个计算机指令。在计算机上加载和执行所述计算机程序指令时,全部或部分地产生按照本发明实施例所述的流程或功能。所述计算机可以是通用计算机、专用计算机、计算机网络、或者其他可编程装置。所述计算机指令可以存储在计算机可读存储介质中,或者从一个计算机可读存储介质向另一个计算机可读存储介质传输,例如,所述计算机指令可以从一个网站站点、计算机、服务器或数据中心通过有线(例如同轴电缆、光纤、数字用户线(DSL))或无线(例如红外、无线、微波等)方式向另一个网站站点、计算机、服务器或数据中心进行传输。所述计算机可读存储介质可以是计算机能够存取的任何可用介质或者是包含一个或多个可用介质集成的服务器、数据中心等数据存储设备。所述可用介质可以是磁性介质,(例如,软盘、硬盘、磁带)、光介质(例如,DVD)、或者半导体介质(例如固态硬盘Solid State Disk(SSD))等。
需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
本说明书中的各个实施例均采用相关的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于服务调用装置、电子设备实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
以上所述仅为本发明的较佳实施例而已,并非用于限定本发明的保护范围。凡在本发明的精神和原则之内所作的任何修改、等同替换、改进等,均包含在本发明的保护范围内。

Claims (13)

1.一种服务调用方法,其特征在于,所述方法包括:
根据本地存储的各微服务的接口,通过配置页面对所述各微服务进行配置,得到所述各微服务的配置结果;
根据所述各微服务的接口以及所述各微服务的配置结果,通过代码生成工具,自动生成各微服务代码;
在调用所述各微服务时,通过接口注解方式自动调用所述各微服务代码,得到所述各微服务对应的返回值。
2.根据权利要求1所述的服务调用方法,其特征在于,在所述通过接口注解方式自动调用所述各微服务代码,得到所述各微服务对应的返回值之后,所述方法还包括:
根据所述各微服务对应的返回值,以及所述各微服务代码中返回参数与实体值对象参数的对应关系,得到所述各微服务对应的实体值对象。
3.根据权利要求1所述的服务调用方法,其特征在于,所述根据本地存储的各微服务的接口,通过配置页面对所述各微服务进行配置,得到所述各微服务的配置结果,包括:
根据各微服务的接口,设置所述各微服务的请求字段、所述请求字段的默认值、返回字段、所述返回字段和实体值对象的对应关系、待生成的各微服务代码的名称。
4.根据权利要求3所述的服务调用方法,其特征在于,所述根据所述各微服务的接口以及所述各微服务的配置结果,通过代码生成工具,自动生成各微服务代码,包括:
根据所述各微服务的接口以及所述各微服务的请求字段、返回字段,生成各微服务代码的请求参数和返回参数;
根据所述请求字段的默认值,设置所述请求参数的默认值;
根据所述返回字段和实体值对象的对应关系,建立返回参数和实体值对象参数的对应关系。
5.根据权利要求1所述的服务调用方法,其特征在于,在所述根据本地存储的各微服务的接口,通过配置页面对所述各微服务进行配置,得到所述各微服务的配置结果之后,所述方法还包括:
将所述配置结果保存至配置文件中;
当接收到对所述配置结果进行修改的操作指令时,对所述配置文件中的配置结果进行修改,得到更新的配置文件。
6.根据权利要求1所述的服务调用方法,其特征在于,在所述根据本地存储的各微服务的接口,通过配置页面对所述各微服务进行配置,得到所述各微服务的配置结果之前,所述方法还包括:
获取待调用的各微服务的接口,将所述各微服务的接口存储至本地。
7.一种服务调用装置,其特征在于,所述装置包括:
配置模块,用于根据本地存储的各微服务的接口,通过配置页面对所述各微服务进行配置,得到所述各微服务的配置结果;
代码生成模块,用于根据所述各微服务的接口以及所述各微服务的配置结果,通过代码生成工具,自动生成各微服务代码;
服务调用模块,用于在调用所述各微服务时,通过接口注解方式自动调用所述各微服务代码,得到所述各微服务对应的返回值。
8.根据权利要求7所述的服务调用装置,其特征在于,所述装置还包括:
实体值对象确定模块,用于根据所述各微服务对应的返回值,以及所述各微服务代码中返回参数与实体值对象参数的对应关系,得到所述各微服务对应的实体值对象。
9.根据权利要求7所述的服务调用装置,其特征在于,所述配置模块具体用于,根据各微服务的接口,设置所述各微服务的请求字段、所述请求字段的默认值、返回字段、所述返回字段和实体值对象的对应关系、待生成的各微服务代码的名称。
10.根据权利要求9所述的服务调用装置,其特征在于,所述代码生成模块具体用于,根据所述各微服务的接口以及所述各微服务的请求字段、返回字段,生成各微服务代码的请求参数和返回参数;根据所述请求字段的默认值,设置所述请求参数的默认值;根据所述返回字段和实体值对象的对应关系,建立返回参数和实体值对象参数的对应关系。
11.根据权利要求7所述的服务调用装置,其特征在于,所述装置还包括:
配置结果保存模块,用于将所述配置结果保存至配置文件中;
配置结果修改模块,用于当接收到对所述配置结果进行修改的操作指令时,对所述配置文件中的配置结果进行修改,得到更新的配置文件。
12.根据权利要求7所述的服务调用装置,其特征在于,所述装置还包括:
接口存储模块,用于获取待调用的各微服务的接口,将所述各微服务的接口存储至本地。
13.一种电子设备,其特征在于,包括:处理器、通信接口、存储器和通信总线,其中,所述处理器、所述通信接口、所述存储器通过所述通信总线完成相互间的通信;
所述存储器,用于存放计算机程序;
所述处理器,用于执行所述存储器上所存放的程序时,实现权利要求1-6任一所述的服务调用方法的步骤。
CN201711261116.0A 2017-12-04 2017-12-04 一种服务调用方法、装置及电子设备 Active CN108156022B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201711261116.0A CN108156022B (zh) 2017-12-04 2017-12-04 一种服务调用方法、装置及电子设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201711261116.0A CN108156022B (zh) 2017-12-04 2017-12-04 一种服务调用方法、装置及电子设备

Publications (2)

Publication Number Publication Date
CN108156022A true CN108156022A (zh) 2018-06-12
CN108156022B CN108156022B (zh) 2021-07-09

Family

ID=62466434

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201711261116.0A Active CN108156022B (zh) 2017-12-04 2017-12-04 一种服务调用方法、装置及电子设备

Country Status (1)

Country Link
CN (1) CN108156022B (zh)

Cited By (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109062599A (zh) * 2018-09-11 2018-12-21 郑州云海信息技术有限公司 微服务架构下代码更新的管理方法和装置
CN109729149A (zh) * 2018-12-03 2019-05-07 国云科技股份有限公司 一种基于注解的微服务框架实现方法
CN109857496A (zh) * 2018-12-30 2019-06-07 贝壳技术有限公司 一种erp系统中多应用导航配置方法及系统
CN109918151A (zh) * 2019-03-14 2019-06-21 佳都新太科技股份有限公司 工作流实现方法、装置、设备及存储介质
CN109976804A (zh) * 2019-03-21 2019-07-05 平安普惠企业管理有限公司 微服务注解的应用方法、装置和计算机设备
CN110633076A (zh) * 2019-09-16 2019-12-31 杭州趣链科技有限公司 一种自动生成Solidity智能合约Java客户端程序的方法
CN110648241A (zh) * 2019-08-14 2020-01-03 中国平安财产保险股份有限公司 一种基于微服务架构的理赔处理方法及装置
CN110677475A (zh) * 2019-09-26 2020-01-10 亿企赢网络科技有限公司 一种微服务处理方法、装置、设备及存储介质
CN110764748A (zh) * 2019-10-23 2020-02-07 北京字节跳动网络技术有限公司 代码调用方法、装置、终端及存储介质
CN111221570A (zh) * 2019-12-30 2020-06-02 中国平安财产保险股份有限公司 微服务框架的迁移方法、装置、设备及存储介质
CN111399822A (zh) * 2020-03-17 2020-07-10 深圳市炎华信息技术有限公司 微服务开发方法、装置、设备及计算机存储介质
CN111556023A (zh) * 2020-03-31 2020-08-18 紫光云技术有限公司 一种基于权限的内容可配置方法
CN111625866A (zh) * 2020-05-28 2020-09-04 广东浪潮大数据研究有限公司 一种权限管理方法、系统、设备及存储介质
CN111934940A (zh) * 2020-09-24 2020-11-13 腾讯科技(深圳)有限公司 配置化的服务请求方法及装置、电子设备和存储介质
CN112118184A (zh) * 2020-08-06 2020-12-22 北京健康之家科技有限公司 网关自动路由方法及装置、存储介质、计算机设备
CN113485770A (zh) * 2021-07-26 2021-10-08 挂号网(杭州)科技有限公司 业务配置数据的确定方法、装置、电子设备及存储介质
CN117195863A (zh) * 2023-09-12 2023-12-08 蔷薇聚信(北京)科技有限公司 字典/字段的解析方法、装置、微服务系统及存储介质
CN111625866B (zh) * 2020-05-28 2024-04-19 广东浪潮大数据研究有限公司 一种权限管理方法、系统、设备及存储介质

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102609264A (zh) * 2012-02-14 2012-07-25 深圳市同洲视讯传媒有限公司 一种调用应用程序编程接口生成调用代码的方法及装置
CN103399734A (zh) * 2013-07-10 2013-11-20 北京慧点科技股份有限公司 生成rest服务和rest实现的方法及对应的设备
CN103645908A (zh) * 2013-12-29 2014-03-19 中国科学院软件研究所 网构软件全生命周期开发实现系统
US20140325336A1 (en) * 2013-04-29 2014-10-30 Sap Ag Social coding extensions
CN105843600A (zh) * 2016-02-29 2016-08-10 乐视体育文化产业发展(北京)有限公司 数据编辑方法、装置及系统

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102609264A (zh) * 2012-02-14 2012-07-25 深圳市同洲视讯传媒有限公司 一种调用应用程序编程接口生成调用代码的方法及装置
US20140325336A1 (en) * 2013-04-29 2014-10-30 Sap Ag Social coding extensions
CN103399734A (zh) * 2013-07-10 2013-11-20 北京慧点科技股份有限公司 生成rest服务和rest实现的方法及对应的设备
CN103645908A (zh) * 2013-12-29 2014-03-19 中国科学院软件研究所 网构软件全生命周期开发实现系统
CN105843600A (zh) * 2016-02-29 2016-08-10 乐视体育文化产业发展(北京)有限公司 数据编辑方法、装置及系统

Cited By (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109062599A (zh) * 2018-09-11 2018-12-21 郑州云海信息技术有限公司 微服务架构下代码更新的管理方法和装置
CN109062599B (zh) * 2018-09-11 2021-11-26 郑州云海信息技术有限公司 微服务架构下代码更新的管理方法和装置
CN109729149A (zh) * 2018-12-03 2019-05-07 国云科技股份有限公司 一种基于注解的微服务框架实现方法
CN109857496A (zh) * 2018-12-30 2019-06-07 贝壳技术有限公司 一种erp系统中多应用导航配置方法及系统
CN109918151A (zh) * 2019-03-14 2019-06-21 佳都新太科技股份有限公司 工作流实现方法、装置、设备及存储介质
CN109976804A (zh) * 2019-03-21 2019-07-05 平安普惠企业管理有限公司 微服务注解的应用方法、装置和计算机设备
CN109976804B (zh) * 2019-03-21 2024-01-23 浙江贰贰网络有限公司 微服务注解的应用方法、装置和计算机设备
CN110648241A (zh) * 2019-08-14 2020-01-03 中国平安财产保险股份有限公司 一种基于微服务架构的理赔处理方法及装置
CN110633076A (zh) * 2019-09-16 2019-12-31 杭州趣链科技有限公司 一种自动生成Solidity智能合约Java客户端程序的方法
CN110677475A (zh) * 2019-09-26 2020-01-10 亿企赢网络科技有限公司 一种微服务处理方法、装置、设备及存储介质
CN110764748A (zh) * 2019-10-23 2020-02-07 北京字节跳动网络技术有限公司 代码调用方法、装置、终端及存储介质
CN111221570A (zh) * 2019-12-30 2020-06-02 中国平安财产保险股份有限公司 微服务框架的迁移方法、装置、设备及存储介质
CN111221570B (zh) * 2019-12-30 2022-07-15 中国平安财产保险股份有限公司 微服务框架的迁移方法、装置、设备及存储介质
CN111399822A (zh) * 2020-03-17 2020-07-10 深圳市炎华信息技术有限公司 微服务开发方法、装置、设备及计算机存储介质
CN111399822B (zh) * 2020-03-17 2023-08-08 深圳市炎华信息技术有限公司 微服务开发方法、装置、设备及计算机存储介质
CN111556023A (zh) * 2020-03-31 2020-08-18 紫光云技术有限公司 一种基于权限的内容可配置方法
CN111625866A (zh) * 2020-05-28 2020-09-04 广东浪潮大数据研究有限公司 一种权限管理方法、系统、设备及存储介质
CN111625866B (zh) * 2020-05-28 2024-04-19 广东浪潮大数据研究有限公司 一种权限管理方法、系统、设备及存储介质
CN112118184A (zh) * 2020-08-06 2020-12-22 北京健康之家科技有限公司 网关自动路由方法及装置、存储介质、计算机设备
CN111934940A (zh) * 2020-09-24 2020-11-13 腾讯科技(深圳)有限公司 配置化的服务请求方法及装置、电子设备和存储介质
CN113485770A (zh) * 2021-07-26 2021-10-08 挂号网(杭州)科技有限公司 业务配置数据的确定方法、装置、电子设备及存储介质
CN113485770B (zh) * 2021-07-26 2024-03-22 挂号网(杭州)科技有限公司 业务配置数据的确定方法、装置、电子设备及存储介质
CN117195863A (zh) * 2023-09-12 2023-12-08 蔷薇聚信(北京)科技有限公司 字典/字段的解析方法、装置、微服务系统及存储介质

Also Published As

Publication number Publication date
CN108156022B (zh) 2021-07-09

Similar Documents

Publication Publication Date Title
CN108156022A (zh) 一种服务调用方法、装置及电子设备
JP6750054B2 (ja) ウェブページを構築しモデル化するためのシステム
US10942708B2 (en) Generating web API specification from online documentation
US9672140B1 (en) Processing special requests at dedicated application containers
US20200341754A1 (en) Techniques to deploy an application as a cloud computing service
CN104866383B (zh) 一种接口调用方法、装置及终端
CN109062563B (zh) 用于生成页面的方法和装置
US8543713B2 (en) Computing environment arranged to support predetermined URL patterns
TW201441829A (zh) 頁面處理方法和裝置以及頁面生成方法和裝置
CN105051687B (zh) 应用部署方法和设备
CN109213498A (zh) 一种互联网web前端的配置方法及服务器
CN106326099B (zh) 一种用于程序跟踪的方法、装置及电子设备
CN111026634A (zh) 一种接口自动化测试系统、方法、装置及存储介质
US9003433B2 (en) Off-premise and codeless process-centric business mashup to integrate BPEL based processes and web 2.0 widgets
US10310965B2 (en) Dynamic virtual testing environment for webpages
CN107205015A (zh) 开放接口的实现方法和装置
CN107193834A (zh) 用于浏览页面的计算设备、装置及方法
CN110365724A (zh) 任务处理方法、装置及电子设备
US20190087160A1 (en) System and method for creating domain specific language
CN105094857A (zh) 用于应用加载的方法和系统
US10742525B2 (en) Systems and methods for synthesizing resource templates using composable parts
CN112527459B (zh) 一种基于Kubernetes集群的日志分析方法及装置
CN110083366B (zh) 应用运行环境的生成方法、装置、计算设备及存储介质
JP7090131B2 (ja) 情報を生成するための方法及び装置
Guinard et al. Restifying real-world systems: A practical case study in rfid

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