CN109766080A - 微服务注册方法、装置、电子设备及可读存储介质 - Google Patents

微服务注册方法、装置、电子设备及可读存储介质 Download PDF

Info

Publication number
CN109766080A
CN109766080A CN201910057515.8A CN201910057515A CN109766080A CN 109766080 A CN109766080 A CN 109766080A CN 201910057515 A CN201910057515 A CN 201910057515A CN 109766080 A CN109766080 A CN 109766080A
Authority
CN
China
Prior art keywords
class
registration
client
configuration
micro services
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
CN201910057515.8A
Other languages
English (en)
Other versions
CN109766080B (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.)
Xizang Liansa Intelligent Technology Co ltd
Original Assignee
Nubia 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 Nubia Technology Co Ltd filed Critical Nubia Technology Co Ltd
Priority to CN201910057515.8A priority Critical patent/CN109766080B/zh
Publication of CN109766080A publication Critical patent/CN109766080A/zh
Application granted granted Critical
Publication of CN109766080B publication Critical patent/CN109766080B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Stored Programmes (AREA)

Abstract

本发明公开了一种微服务注册方法、装置、电子设备及可读存储介质,涉及通讯技术领域,该方法包括:创建注册服务模块管理类,所述注册服务模块管理类包括客户端配置类和实例配置类;对所述客户端配置类和实例配置类进行实例化,创建对应的客户端配置对象和实例配置对象;根据所述实例配置对象创建实例信息对象和应用信息管理对象;通过所述客户端配置对象和应用信息管理对象完成注册中心的注册;通过注册服务模块完成基于spring mvc的框架自动注册服务,且该注册服务模块对旧代码无侵入性,对开发人员是透明的,适用于任何基于spring mvc的框架的系统,具有普适性,提高了系统重构的安全性,减少了开发人员的工作量。

Description

微服务注册方法、装置、电子设备及可读存储介质
技术领域
本发明涉及通讯技术领域,尤其涉及一种微服务注册方法、装置、电子设备及可读存储介质。
背景技术
许多系统进行重构的时候会考虑到使用微服务化,而微服务化的重点就是服务质量,目前eureka是一个很完善的服务注册中心,只需接入的系统按照一定的规则既可以注册服务,而市场上开源的视线有spring cloud结合spring boot框架可以自动完成微服务注册,而一般我们需要重构的代码绝大部分都是基于spring mvc,而对代码的框架进行改动,涉及到的范围比较大,特别针对线上已经稳定的核心功能进行底层框架改动,承担的风险巨大,且开发人员重新开发的工作量也非常大。
发明内容
本发明的主要目的在于提出一种微服务注册方法、装置、电子设备及可读存储介质,旨在解决系统进行微服务注册时,安全性不足、工作量大的问题。
为实现上述目的,本发明提供的一种微服务注册方法,包括:
创建注册服务模块管理类,所述注册服务模块管理类包括客户端配置类和实例配置类;
对所述客户端配置类和实例配置类进行实例化,创建对应的客户端配置对象和实例配置对象;
根据所述实例配置对象创建实例信息对象和应用信息管理对象;
通过所述客户端配置对象和应用信息管理对象完成注册中心的注册。
可选地,还包括:
在所述注册服务模块管理类的程序中添加身份注解。
可选地,所述注册服务模块管理类包括还包括框架配置类,相应地,所述对所述客户端配置类和实例配置类进行实例化之后还包括:
对所述框架配置类进行实例化,创建框架配置对象。
可选地,所述框架配置对象用于读取用户配置的配置文件信息,所述配置文件信息包括:注册中心的地址、本系统的应用名称和本系统启动的端口号;所述客户端配置对象用于配置客户端的配置信息,所述客户端的配置信息包括:从所述框架配置对象中获取的注册中心的地址和连接注册中心的超时时间;所述实例配置对象用于获取实例的配置信息,所述实例的配置信息包括从所述框架配置对象中获取的实例的名称。
可选地,所述根据所述实例配置对象创建实例信息对象和应用信息管理对象包括:
根据所述实例配置对象创建实例信息对象;
根据所述实例配置对象和所述实例信息对象创建应用信息管理对象。
可选地,所述通过所述客户端配置对象和应用信息管理对象完成注册中心的注册包括:
传递所述客户端配置对象和应用信息管理对象,创建发现服务对象;
通过所述发现服务对象完成注册中心的注册。
可选地,所述通过所述实例信息对象和应用信息管理对象完成注册中心的注册之后还包括:
通过所述发现服务对象创建心跳检查模块,用于获取客户端在所述注册中心的状态信息。
此外,为实现上述目的,本发明还提出一种微服务注册装置,包括:
管理模块,用于创建注册服务模块管理类,所述注册服务模块管理类包括客户端配置类和实例配置类;
实例化模块,用于对所述客户端配置类和实例配置类进行实例化,创建对应的客户端配置对象和实例配置对象;
创建模块,用于根据所述实例配置对象创建实例信息对象和应用信息管理对象;
注册模块,用于通过所述客户端配置对象和应用信息管理对象完成注册中心的注册。
此外,为实现上述目的,本发明还提出一种电子设备,包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的微服务注册程序,所述微服务注册程序被所述处理器执行时实现上述的微服务注册方法的步骤。
此外,为实现上述目的,本发明还提出一种计算机可读存储介质,所述计算机可读存储介质存储有微服务注册程序,所述微服务注册程序被处理器执行时实现上述的微服务注册方法的步骤。
本发明提出的一种微服务注册方法、装置、电子设备及可读存储介质,该方法包括:创建注册服务模块管理类,所述注册服务模块管理类包括客户端配置类和实例配置类;对所述客户端配置类和实例配置类进行实例化,创建对应的客户端配置对象和实例配置对象;根据所述实例配置对象创建实例信息对象和应用信息管理对象;通过所述客户端配置对象和应用信息管理对象完成注册中心的注册;通过注册服务模块完成基于spring mvc的框架自动注册服务,且该注册服务模块对旧代码无侵入性,对开发人员是透明的,适用于任何基于spring mvc的框架的系统,具有普适性,提高了系统重构的安全性,减少了开发人员的工作量。
附图说明
图1为实现本发明各个实施例的移动终端的硬件结构示意图;
图2为如图1所示的移动终端的无线通信系统示意图;
图3为本发明实施例一提供的一种微服务注册方法的流程图;
图4为本发明实施例一提供的一种微服务注册方法的功能实现示意图;
图5为本发明实施例一提供的另一种微服务注册方法的流程图;
图6为图3中步骤S30的一种方法流程图;
图7为图3中步骤S40的一种方法流程图;
图8为本发明实施例一提供的再一种微服务注册方法的流程图;
图9为本发明实施例二提供的一种微服务注册装置的示范性结构框图;
图10为本发明实施例三提供的一种电子设备的模块示意图。
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。
终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、个人数字助理(PersonalDigital Assistant,PDA)、便捷式媒体播放器(Portable Media Player,PMP)、导航装置、可穿戴设备、智能手环、计步器等移动终端,以及诸如数字TV、台式计算机等固定终端。
后续描述中将以移动终端为例进行说明,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。
请参阅图1,其为实现本发明各个实施例的一种移动终端的硬件结构示意图,该移动终端100可以包括:RF(Radio Frequency,射频)单元101、WiFi模块102、音频输出单元103、A/V(音频/视频)输入单元104、传感器105、显示单元106、用户输入单元107、接口单元108、存储器109、处理器110、以及电源111等部件。本领域技术人员可以理解,图1中示出的移动终端结构并不构成对移动终端的限定,移动终端可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
下面结合图1对移动终端的各个部件进行具体的介绍:
射频单元101可用于收发信息或通话过程中,信号的接收和发送,具体的,将基站的下行信息接收后,给处理器110处理;另外,将上行的数据发送给基站。通常,射频单元101包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器、双工器等。此外,射频单元101还可以通过无线通信与网络和其他设备通信。上述无线通信可以使用任一通信标准或协议,包括但不限于GSM(Global System of Mobile communication,全球移动通讯系统)、GPRS(General Packet Radio Service,通用分组无线服务)、CDMA2000(CodeDivision Multiple Access 2000,码分多址2000)、WCDMA(Wideband Code DivisionMultiple Access,宽带码分多址)、TD-SCDMA(Time Division-Synchronous CodeDivision Multiple Access,时分同步码分多址)、FDD-LTE(Frequency DivisionDuplexing-Long Term Evolution,频分双工长期演进)和TDD-LTE(Time DivisionDuplexing-Long Term Evolution,分时双工长期演进)等。
WiFi属于短距离无线传输技术,移动终端通过WiFi模块102可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图1示出了WiFi模块102,但是可以理解的是,其并不属于移动终端的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。
音频输出单元103可以在移动终端100处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将射频单元101或WiFi模块102接收的或者在存储器109中存储的音频数据转换成音频信号并且输出为声音。而且,音频输出单元103还可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出单元103可以包括扬声器、蜂鸣器等等。
A/V输入单元104用于接收音频或视频信号。A/V输入单元104可以包括图形处理器(Graphics Processing Unit,GPU)1041和麦克风1042,图形处理器1041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元106上。经图形处理器1041处理后的图像帧可以存储在存储器109(或其它存储介质)中或者经由射频单元101或WiFi模块102进行发送。麦克风1042可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风1042接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由射频单元101发送到移动通信基站的格式输出。麦克风1042可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。
移动终端100还包括至少一种传感器105,比如光传感器、运动传感器以及其他传感器。具体地,光传感器包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板1061的亮度,接近传感器可在移动终端100移动到耳边时,关闭显示面板1061和/或背光。作为运动传感器的一种,加速计传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别手机姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于手机还可配置的指纹传感器、压力传感器、虹膜传感器、分子传感器、陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。
显示单元106用于显示由用户输入的信息或提供给用户的信息。显示单元106可包括显示面板1061,可以采用液晶显示器(Liquid Crystal Display,LCD)、有机发光二极管(Organic Light-Emitting Diode,OLED)等形式来配置显示面板1061。
用户输入单元107可用于接收输入的数字或字符信息,以及产生与移动终端的用户设置以及功能控制有关的键信号输入。具体地,用户输入单元107可包括触控面板1071以及其他输入设备1072。触控面板1071,也称为触摸屏,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触控面板1071上或在触控面板1071附近的操作),并根据预先设定的程式驱动相应的连接装置。触控面板1071可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器110,并能接收处理器110发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触控面板1071。除了触控面板1071,用户输入单元107还可以包括其他输入设备1072。具体地,其他输入设备1072可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的一种或多种,具体此处不做限定。
进一步的,触控面板1071可覆盖显示面板1061,当触控面板1071检测到在其上或附近的触摸操作后,传送给处理器110以确定触摸事件的类型,随后处理器110根据触摸事件的类型在显示面板1061上提供相应的视觉输出。虽然在图1中,触控面板1071与显示面板1061是作为两个独立的部件来实现移动终端的输入和输出功能,但是在某些实施例中,可以将触控面板1071与显示面板1061集成而实现移动终端的输入和输出功能,具体此处不做限定。
接口单元108用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(I/O)端口、视频I/O端口、耳机端口等等。接口单元108可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端100和外部装置之间传输数据。
存储器109可用于存储软件程序以及各种数据。存储器109可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据手机的使用所创建的数据(比如音频数据、电话本等)等。此外,存储器109可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
处理器110是移动终端的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器109内的软件程序和/或模块,以及调用存储在存储器109内的数据,执行移动终端的各种功能和处理数据,从而对移动终端进行整体监控。处理器110可包括一个或多个处理单元;优选的,处理器110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器110中。
移动终端100还可以包括给各个部件供电的电源111(比如电池),优选的,电源111可以通过电源管理系统与处理器110逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。
尽管图1未示出,移动终端100还可以包括蓝牙模块等,在此不再赘述。
为了便于理解本发明实施例,下面对本发明的移动终端所基于的通信网络系统进行描述。
请参阅图2,图2为本发明实施例提供的一种通信网络系统架构图,该通信网络系统为通用移动通信技术的LTE系统,该LTE系统包括依次通讯连接的UE(User Equipment,用户设备)201,E-UTRAN(Evolved UMTS Terrestrial Radio Access Network,演进式UMTS陆地无线接入网)202,EPC(Evolved Packet Core,演进式分组核心网)203和运营商的IP业务204。
具体地,UE201可以是上述终端100,此处不再赘述。
E-UTRAN202包括eNodeB2021和其它eNodeB2022等。其中,eNodeB2021可以通过回程(backhaul)(例如X2接口)与其它eNodeB2022连接,eNodeB2021连接到EPC203,eNodeB2021可以提供UE201到EPC203的接入。
EPC203可以包括MME(Mobility Management Entity,移动性管理实体)2031,HSS(Home Subscriber Server,归属用户服务器)2032,其它MME2033,SGW(Serving Gate Way,服务网关)2034,PGW(PDN Gate Way,分组数据网络网关)2035和PCRF(Policy andCharging Rules Function,政策和资费功能实体)2036等。其中,MME2031是处理UE201和EPC203之间信令的控制节点,提供承载和连接管理。HSS2032用于提供一些寄存器来管理诸如归属位置寄存器(图中未示)之类的功能,并且保存有一些有关服务特征、数据速率等用户专用的信息。所有用户数据都可以通过SGW2034进行发送,PGW2035可以提供UE 201的IP地址分配以及其它功能,PCRF2036是业务数据流和IP承载资源的策略与计费控制策略决策点,它为策略与计费执行功能单元(图中未示)选择及提供可用的策略和计费控制决策。
IP业务204可以包括因特网、内联网、IMS(IP Multimedia Subsystem,IP多媒体子系统)或其它IP业务等。
虽然上述以LTE系统为例进行了介绍,但本领域技术人员应当知晓,本发明不仅仅适用于LTE系统,也可以适用于其他无线通信系统,例如GSM、CDMA2000、WCDMA、TD-SCDMA以及未来新的网络系统等,此处不做限定。
基于上述移动终端硬件结构以及通信网络系统,提出本发明方法各个实施例。
实施例一
如图3所示,在本实施例中,一种微服务注册方法,包括:
S10、创建注册服务模块管理类,所述注册服务模块管理类包括客户端配置类和实例配置类;
S20、对所述客户端配置类和实例配置类进行实例化,创建对应的客户端配置对象和实例配置对象;
S30、根据所述实例配置对象创建实例信息对象和应用信息管理对象;
S40、通过所述客户端配置对象和应用信息管理对象完成注册中心的注册。
在本实施例中,通过注册服务模块完成基于spring mvc的框架自动注册服务,且该注册服务模块对旧代码无侵入性,对开发人员是透明的,适用于任何基于spring mvc的框架的系统,具有普适性,提高了系统重构的安全性,减少了开发人员的工作量。
在本实施例中,Spring是一个开源框架,Spring是于2003年兴起的一个轻量级的Java开发框架,它是为了解决企业应用开发的复杂性而创建的,框架的主要优势之一就是其分层架构,分层架构允许使用者选择使用哪一个组件,同时为J2EE应用程序开发提供集成的框架。Spring使用基本的JavaBean来完成以前只可能由EJB完成的事情。然而,Spring的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度而言,任何Java应用都可以从Spring中受益。Spring的核心是控制反转(IoC)和面向切面(AOP)。简单来说,Spring是一个分层的JavaSE/EEfull-stack(一站式)轻量级开源框架。
在本实施例中,Eureka是Netflix开发的服务发现框架,SpringCloud将它集成在自己的子项目spring-cloud-netflix中,实现SpringCloud的服务发现功能。在一个完整的系统架构中,任何单点的服务都不能保证不会中断,因此我们需要服务发现机制,在某个节点中断后,其它的节点能够继续提供服务,从而保证整个系统是高可用的。服务发现有两种模式:一种是客户端发现模式,一种是服务端发现模式。Erueka采用的是客户端发现模式。
在本实施例中,注册服务模块管理类NubiaEurekaAutoConfiguration属于注册服务模块的核心管理类,要在声明此类的开头添加一个@Configuration的注解,表示其是一个spring bean的管理配置项,这样在程序启动的时候就会去识别这个@Configuration注解,然后会对此类中声明的bean进行操作。关于该声明及注解的代码如下所示:
在本实施例中,Spring将容器中的一切对象称为Bean,Spring通过XML配置文件(beans.xml)来管理Bean。
在本实施例中,所述注册服务模块管理类包括:框架配置类NubiaEurekaProperties、客户端配置类NubiaEurekaClientConfig和实例配置类NubiaEurekaInstanceConfig;NubiaEurekaProperties是一个配置类,管理了配置中心需要的所有配置信息,它会读取用户配置的配置文件信息,诸如注册中心的地址、本系统的应用名称、本系统启动的端口号等等信息。NubiaEurekaClientConfig是一个配置eureka客户端的所有信息,诸如它需要从NubiaEurekaProperties对象中获取注册中心的地址以及连接注册中心的超时时间等诸多配置信息。NubiaEurekaInstanceConfig是一个客户端实例的配置对象,它会从NubiaEurekaProperties对象中获取实例的名称等信息。注:此步骤的重点不在于哪些配置信息,只会罗列必须要更改的配置信息。上述三个类都是由NubiaEurekaAutoConfiguration进行管理,对它们实例化后交由spring bean的容器进行管理。
在本实施例中,把用类创建对象的过程称为实例化,在步骤S20中对所述框架配置类、客户端配置类和实例配置类进行实例化的代码如下所示:
在本实施例中,创建eureka注册中心需要的实例信息对象InstanceInfo和应用信息管理对象ApplicationInfoManager,首先,根据所述实例配置对象NubiaEurekaInstanceConfig创建实例信息对象InstanceInfo;然后再根据NubiaEurekaInstanceConfig和InstanceInfo创建eureka需要的应用信息管理对象ApplicationInfoManager。其中InstanceInfo和ApplicationInfoManager为eureka规定要求的对象,只需构造生成这两个对象的参数即可,客户端配置对象和实例配置对象即是用来生成这两个对象的必要属性。其中创建这两个对象的代码如下:
InstanceInfo instanceInfo=create(nubiaEurekaInstanceConfig);
ApplicationInfoManager appManeger=new ApplicationInfoManager(nubiaEurekaInstanceConfig,
|instanceInfo);
在本实施例中,使用NubiaEurekaClientConfig和ApplicationInfoManager即可以完成注册中心的注册,完成该注册操作的核心代码如下:
由以上代码可知,本实施例通过发现服务对象DiscoveryClient来进行注册服务的操作,一般来说,DiscoveryClient是用作服务发现的,而本实施例中,使用DiscoveryClient注册服务是利用了LifeCycle机制,在容器启动时会执行ServiceRegistry的register()方法;且使用DiscoveryClient要比EnableEurekaClient与EnableEurekaServer更灵活,因为它屏蔽了对服务注册的实现,甚至可以自定义注册中心。
如图4所示,为本实施例中微服务注册方法的功能实现示意图,完成注册并不代表所有工作已完成,还有很重要的一步是需要为此添加一个心跳检查机制,保证服务高可用,知道是否服务器宕机以及进行一些续约的操作。此检查机制它的核心功能会获取当前客户端在注册中心的状态,会将自己的状态切换为UP,eureka是用UP来标识当前客户端是否正常。
如图5所示,在本实施例中,步骤S10之后还包括:
S11、在所述注册服务模块管理类的程序中添加身份注解。
在声明此类的开头添加一个@Configuration的注解,表示其是一个spring bean的管理配置项,这样在程序启动的时候就会去识别这个@Configuration注解,然后会对此类中声明的bean进行操作。
在本实施例中,所述框架配置对象用于读取用户配置的配置文件信息,所述配置文件信息包括:注册中心的地址、本系统的应用名称和本系统启动的端口号;所述客户端配置对象用于配置客户端的配置信息,所述客户端的配置信息包括:从所述框架配置对象中获取的注册中心的地址和连接注册中心的超时时间;所述实例配置对象用于获取实例的配置信息,所述实例的配置信息包括从所述框架配置对象中获取的实例的名称。
如图6所示,在本实施例中,所述步骤S30包括:
S31、根据所述实例配置对象创建实例信息对象;
S32、根据所述实例配置对象和所述实例信息对象创建应用信息管理对象。
在本实施例中,创建eureka注册中心需要的实例信息对象InstanceInfo和应用信息管理对象ApplicationInfoManager,首先,根据所述实例配置对象NubiaEurekaInstanceConfig创建实例信息对象InstanceInfo;然后再根据NubiaEurekaInstanceConfig和InstanceInfo创建eureka需要的应用信息管理对象ApplicationInfoManager。其中InstanceInfo和ApplicationInfoManager为eureka规定要求的对象,只需构造生成这两个对象的参数即可,客户端配置对象和实例配置对象即是用来生成这两个对象的必要属性。
如图7所示,在本实施例中,所述步骤S40包括:
S41、传递所述客户端配置对象和应用信息管理对象,创建发现服务对象;
S42、通过所述发现服务对象完成注册中心的注册。
本实施例通过发现服务对象DiscoveryClient来进行注册服务的操作,一般来说,DiscoveryClient是用作服务发现的,而本实施例中,使用DiscoveryClient注册服务是利用了LifeCycle机制,在容器启动时会执行ServiceRegistry的register()方法;且使用DiscoveryClient要比EnableEurekaClient与EnableEurekaServer更灵活,因为它屏蔽了对服务注册的实现,甚至可以自定义注册中心。
如图8所示,在本实施例中,所述步骤S40之后还包括:
S50、通过所述发现服务对象创建心跳检查模块,用于获取客户端在所述注册中心的状态信息。
在本实施例中,完成注册并不代表所有工作已完成,还有很重要的一步是需要为此添加一个心跳检查机制,保证服务高可用,知道是否服务器宕机以及进行一些续约的操作。此检查机制它的核心功能会获取当前客户端在注册中心的状态,会将自己的状态切换为UP,eureka是用UP来标识当前客户端是否正常。
实施例二
如图9所示,在本实施例中,一种微服务注册装置,包括:
管理模块31,用于创建注册服务模块管理类,所述注册服务模块管理类包括客户端配置类和实例配置类;
实例化模块32,用于对所述客户端配置类和实例配置类进行实例化,创建对应的客户端配置对象和实例配置对象;
创建模块33,用于根据所述实例配置对象创建实例信息对象和应用信息管理对象;
注册模块34,用于通过所述客户端配置对象和应用信息管理对象完成注册中心的注册。
在本实施例中,通过注册服务模块完成基于spring mvc的框架自动注册服务,且该注册服务模块对旧代码无侵入性,对开发人员是透明的,适用于任何基于spring mvc的框架的系统,具有普适性,提高了系统重构的安全性,减少了开发人员的工作量。
在本实施例中,Spring是一个开源框架,Spring是于2003年兴起的一个轻量级的Java开发框架,它是为了解决企业应用开发的复杂性而创建的,框架的主要优势之一就是其分层架构,分层架构允许使用者选择使用哪一个组件,同时为J2EE应用程序开发提供集成的框架。Spring使用基本的JavaBean来完成以前只可能由EJB完成的事情。然而,Spring的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度而言,任何Java应用都可以从Spring中受益。Spring的核心是控制反转(IoC)和面向切面(AOP)。简单来说,Spring是一个分层的JavaSE/EEfull-stack(一站式)轻量级开源框架。
在本实施例中,Eureka是Netflix开发的服务发现框架,SpringCloud将它集成在自己的子项目spring-cloud-netflix中,实现SpringCloud的服务发现功能。在一个完整的系统架构中,任何单点的服务都不能保证不会中断,因此我们需要服务发现机制,在某个节点中断后,其它的节点能够继续提供服务,从而保证整个系统是高可用的。服务发现有两种模式:一种是客户端发现模式,一种是服务端发现模式。Erueka采用的是客户端发现模式。
在本实施例中,注册服务模块管理类NubiaEurekaAutoConfiguration属于注册服务模块的核心管理类,要在声明此类的开头添加一个@Configuration的注解,表示其是一个spring bean的管理配置项,这样在程序启动的时候就会去识别这个@Configuration注解,然后会对此类中声明的bean进行操作。关于该声明及注解的代码如下所示:
在本实施例中,Spring将容器中的一切对象称为Bean,Spring通过XML配置文件(beans.xml)来管理Bean。
在本实施例中,所述注册服务模块管理类包括:框架配置类NubiaEurekaProperties、客户端配置类NubiaEurekaClientConfig和实例配置类NubiaEurekaInstanceConfig;NubiaEurekaProperties是一个配置类,管理了配置中心需要的所有配置信息,它会读取用户配置的配置文件信息,诸如注册中心的地址、本系统的应用名称、本系统启动的端口号等等信息。NubiaEurekaClientConfig是一个配置eureka客户端的所有信息,诸如它需要从NubiaEurekaProperties对象中获取注册中心的地址以及连接注册中心的超时时间等诸多配置信息。NubiaEurekaInstanceConfig是一个客户端实例的配置对象,它会从NubiaEurekaProperties对象中获取实例的名称等信息。注:此步骤的重点不在于哪些配置信息,只会罗列必须要更改的配置信息。上述三个类都是由NubiaEurekaAutoConfiguration进行管理,对它们实例化后交由spring bean的容器进行管理。
在本实施例中,把用类创建对象的过程称为实例化,在步骤S20中对所述框架配置类、客户端配置类和实例配置类进行实例化的代码如下所示:
在本实施例中,创建eureka注册中心需要的实例信息对象InstanceInfo和应用信息管理对象ApplicationInfoManager,首先,根据所述实例配置对象NubiaEurekaInstanceConfig创建实例信息对象InstanceInfo;然后再根据NubiaEurekaInstanceConfig和InstanceInfo创建eureka需要的应用信息管理对象ApplicationInfoManager。其中InstanceInfo和ApplicationInfoManager为eureka规定要求的对象,只需构造生成这两个对象的参数即可,客户端配置对象和实例配置对象即是用来生成这两个对象的必要属性。其中创建这两个对象的代码如下:
InstanceInfo instanceInfo=create(nubiaEurekaInstanceConfig);
ApplicationInfoManager appManeger=new ApplicationInfoManager(nubiaEurekaInstanceConfig,
|instanceInfo);
在本实施例中,使用NubiaEurekaClientConfig和ApplicationInfoManager即可以完成注册中心的注册,完成该注册操作的核心代码如下:
由以上代码可知,本实施例通过发现服务对象DiscoveryClient来进行注册服务的操作,一般来说,DiscoveryClient是用作服务发现的,而本实施例中,使用DiscoveryClient注册服务是利用了LifeCycle机制,在容器启动时会执行ServiceRegistry的register()方法;且使用DiscoveryClient要比EnableEurekaClient与EnableEurekaServer更灵活,因为它屏蔽了对服务注册的实现,甚至可以自定义注册中心。
如图4所示,为本实施例中微服务注册方法的功能实现示意图,完成注册并不代表所有工作已完成,还有很重要的一步是需要为此添加一个心跳检查机制,保证服务高可用,知道是否服务器宕机以及进行一些续约的操作。此检查机制它的核心功能会获取当前客户端在注册中心的状态,会将自己的状态切换为UP,eureka是用UP来标识当前客户端是否正常。
实施例三
如图10所示,在本实施例中,一种电子设备,包括:存储器10、处理器20及存储在所述存储器上并可在所述处理器上运行的微服务注册装置30,所述微服务注册装置被所述处理器执行时实现实施例一的微服务注册方法的步骤。
在本实施例中,所述存储器至少包括一种类型的可读存储介质,用于存储安装于所述电子设备的操作系统和各类应用软件,例如微服务注册装置的程序代码等,此外,所述存储器还可以用于暂时地存储已经输出或者将要输出的各类数据。
在本实施例中,所述处理器在一些实施例中可以是中央处理器(CentralProcessing Unit,CPU)、控制器、微控制器、微处理器或者其他数据处理芯片。该处理器通常用于控制所述电子设备的总体操作,在本实施例中,所述处理器用于运行所述存储器中存储的程序代码或者处理数据,例如运行所述微服务注册装置等。
在本实施例中,微服务注册装置,包括:
管理模块31,用于创建注册服务模块管理类,所述注册服务模块管理类包括客户端配置类和实例配置类;
实例化模块32,用于对所述客户端配置类和实例配置类进行实例化,创建对应的客户端配置对象和实例配置对象;
创建模块33,用于根据所述实例配置对象创建实例信息对象和应用信息管理对象;
注册模块34,用于通过所述客户端配置对象和应用信息管理对象完成注册中心的注册。
在本实施例中,通过注册服务模块完成基于spring mvc的框架自动注册服务,且该注册服务模块对旧代码无侵入性,对开发人员是透明的,适用于任何基于spring mvc的框架的系统,具有普适性,提高了系统重构的安全性,减少了开发人员的工作量。
在本实施例中,Spring是一个开源框架,Spring是于2003年兴起的一个轻量级的Java开发框架,它是为了解决企业应用开发的复杂性而创建的,框架的主要优势之一就是其分层架构,分层架构允许使用者选择使用哪一个组件,同时为J2EE应用程序开发提供集成的框架。Spring使用基本的JavaBean来完成以前只可能由EJB完成的事情。然而,Spring的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度而言,任何Java应用都可以从Spring中受益。Spring的核心是控制反转(IoC)和面向切面(AOP)。简单来说,Spring是一个分层的JavaSE/EEfull-stack(一站式)轻量级开源框架。
在本实施例中,Eureka是Netflix开发的服务发现框架,SpringCloud将它集成在自己的子项目spring-cloud-netflix中,实现SpringCloud的服务发现功能。在一个完整的系统架构中,任何单点的服务都不能保证不会中断,因此我们需要服务发现机制,在某个节点中断后,其它的节点能够继续提供服务,从而保证整个系统是高可用的。服务发现有两种模式:一种是客户端发现模式,一种是服务端发现模式。Erueka采用的是客户端发现模式。
在本实施例中,注册服务模块管理类NubiaEurekaAutoConfiguration属于注册服务模块的核心管理类,要在声明此类的开头添加一个@Configuration的注解,表示其是一个spring bean的管理配置项,这样在程序启动的时候就会去识别这个@Configuration注解,然后会对此类中声明的bean进行操作。关于该声明及注解的代码如下所示:
在本实施例中,Spring将容器中的一切对象称为Bean,Spring通过XML配置文件(beans.xml)来管理Bean。
在本实施例中,所述注册服务模块管理类包括:框架配置类NubiaEurekaProperties、客户端配置类NubiaEurekaClientConfig和实例配置类NubiaEurekaInstanceConfig;NubiaEurekaProperties是一个配置类,管理了配置中心需要的所有配置信息,它会读取用户配置的配置文件信息,诸如注册中心的地址、本系统的应用名称、本系统启动的端口号等等信息。NubiaEurekaClientConfig是一个配置eureka客户端的所有信息,诸如它需要从NubiaEurekaProperties对象中获取注册中心的地址以及连接注册中心的超时时间等诸多配置信息。NubiaEurekaInstanceConfig是一个客户端实例的配置对象,它会从NubiaEurekaProperties对象中获取实例的名称等信息。注:此步骤的重点不在于哪些配置信息,只会罗列必须要更改的配置信息。上述三个类都是由NubiaEurekaAutoConfiguration进行管理,对它们实例化后交由spring bean的容器进行管理。
在本实施例中,把用类创建对象的过程称为实例化,在步骤S20中对所述框架配置类、客户端配置类和实例配置类进行实例化的代码如下所示:
在本实施例中,创建eureka注册中心需要的实例信息对象InstanceInfo和应用信息管理对象ApplicationInfoManager,首先,根据所述实例配置对象NubiaEurekaInstanceConfig创建实例信息对象InstanceInfo;然后再根据NubiaEurekaInstanceConfig和InstanceInfo创建eureka需要的应用信息管理对象ApplicationInfoManager。其中InstanceInfo和ApplicationInfoManager为eureka规定要求的对象,只需构造生成这两个对象的参数即可,客户端配置对象和实例配置对象即是用来生成这两个对象的必要属性。其中创建这两个对象的代码如下:
InstanceInfo instanceInfo=create(nubiaEurekaInstanceConfig);
ApplicationInfoManager appManeger=new ApplicationInfoManager(nubiaEurekaInstanceConfig,
|instanceInfo);
在本实施例中,使用NubiaEurekaClientConfig和ApplicationInfoManager即可以完成注册中心的注册,完成该注册操作的核心代码如下:
由以上代码可知,本实施例通过发现服务对象DiscoveryClient来进行注册服务的操作,一般来说,DiscoveryClient是用作服务发现的,而本实施例中,使用DiscoveryClient注册服务是利用了LifeCycle机制,在容器启动时会执行ServiceRegistry的register()方法;且使用DiscoveryClient要比EnableEurekaClient与EnableEurekaServer更灵活,因为它屏蔽了对服务注册的实现,甚至可以自定义注册中心。
如图4所示,为本实施例中微服务注册方法的功能实现示意图,完成注册并不代表所有工作已完成,还有很重要的一步是需要为此添加一个心跳检查机制,保证服务高可用,知道是否服务器宕机以及进行一些续约的操作。此检查机制它的核心功能会获取当前客户端在注册中心的状态,会将自己的状态切换为UP,eureka是用UP来标识当前客户端是否正常。
实施例四
在本实施例中,一种计算机可读存储介质,所述计算机可读存储介质存储有微服务注册程序,所述微服务注册程序被处理器执行时实现实施例一的微服务注册方法的步骤。
本发明提供的计算机可读存储介质,通过注册服务模块完成基于spring mvc的框架自动注册服务,且该注册服务模块对旧代码无侵入性,对开发人员是透明的,适用于任何基于spring mvc的框架的系统,具有普适性,提高了系统重构的安全性,减少了开发人员的工作量。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
上面结合附图对本发明的实施例进行了描述,但是本发明并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本发明的启示下,在不脱离本发明宗旨和权利要求所保护的范围情况下,还可做出很多形式,这些均属于本发明的保护之内。

Claims (10)

1.一种微服务注册方法,其特征在于,包括:
创建注册服务模块管理类,所述注册服务模块管理类包括客户端配置类和实例配置类;
对所述客户端配置类和实例配置类进行实例化,创建对应的客户端配置对象和实例配置对象;
根据所述实例配置对象创建实例信息对象和应用信息管理对象;
通过所述客户端配置对象和应用信息管理对象完成注册中心的注册。
2.根据权利要求1所述的一种微服务注册方法,其特征在于,还包括:
在所述注册服务模块管理类的程序中添加身份注解。
3.根据权利要求1所述的一种微服务注册方法,其特征在于,所述注册服务模块管理类包括还包括框架配置类,相应地,所述对所述客户端配置类和实例配置类进行实例化之后还包括:
对所述框架配置类进行实例化,创建框架配置对象。
4.根据权利要求3所述的一种微服务注册方法,其特征在于,所述框架配置对象用于读取用户配置的配置文件信息,所述配置文件信息包括:注册中心的地址、本系统的应用名称和本系统启动的端口号;所述客户端配置对象用于配置客户端的配置信息,所述客户端的配置信息包括:从所述框架配置对象中获取的注册中心的地址和连接注册中心的超时时间;所述实例配置对象用于获取实例的配置信息,所述实例的配置信息包括从所述框架配置对象中获取的实例的名称。
5.根据权利要求1所述的一种微服务注册方法,其特征在于,所述根据所述实例配置对象创建实例信息对象和应用信息管理对象包括:
根据所述实例配置对象创建实例信息对象;
根据所述实例配置对象和所述实例信息对象创建应用信息管理对象。
6.根据权利要求1所述的一种微服务注册方法,其特征在于,所述通过所述客户端配置对象和应用信息管理对象完成注册中心的注册包括:
传递所述客户端配置对象和应用信息管理对象,创建发现服务对象;
通过所述发现服务对象完成注册中心的注册。
7.根据权利要求6所述的一种微服务注册方法,其特征在于,所述通过所述实例信息对象和应用信息管理对象完成注册中心的注册之后还包括:
通过所述发现服务对象创建心跳检查模块,用于获取客户端在所述注册中心的状态信息。
8.一种微服务注册装置,其特征在于,包括:
管理模块,用于创建注册服务模块管理类,所述注册服务模块管理类包括客户端配置类和实例配置类;
实例化模块,用于对所述客户端配置类和实例配置类进行实例化,创建对应的客户端配置对象和实例配置对象;
创建模块,用于根据所述实例配置对象创建实例信息对象和应用信息管理对象;
注册模块,用于通过所述客户端配置对象和应用信息管理对象完成注册中心的注册。
9.一种电子设备,其特征在于,包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的微服务注册程序,所述微服务注册程序被所述处理器执行时实现如权利要求1-7任一项所述的微服务注册方法的步骤。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有微服务注册程序,所述微服务注册程序被处理器执行时实现如权利要求1-7任一项所述的微服务注册方法的步骤。
CN201910057515.8A 2019-01-22 2019-01-22 微服务注册方法、装置、电子设备及可读存储介质 Active CN109766080B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201910057515.8A CN109766080B (zh) 2019-01-22 2019-01-22 微服务注册方法、装置、电子设备及可读存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201910057515.8A CN109766080B (zh) 2019-01-22 2019-01-22 微服务注册方法、装置、电子设备及可读存储介质

Publications (2)

Publication Number Publication Date
CN109766080A true CN109766080A (zh) 2019-05-17
CN109766080B CN109766080B (zh) 2023-11-10

Family

ID=66454991

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201910057515.8A Active CN109766080B (zh) 2019-01-22 2019-01-22 微服务注册方法、装置、电子设备及可读存储介质

Country Status (1)

Country Link
CN (1) CN109766080B (zh)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111698205A (zh) * 2020-04-29 2020-09-22 中国平安财产保险股份有限公司 服务调用方法及相关设备
CN112256351A (zh) * 2020-10-26 2021-01-22 卫宁健康科技集团股份有限公司 Feign组件的实现方法、微服务调用方法及装置
CN112764723A (zh) * 2021-01-21 2021-05-07 奇秦科技(北京)股份有限公司 一种基于Spring无侵入修改标准产品业务系统和方法
CN113885873A (zh) * 2021-09-29 2022-01-04 中国科学院软件研究所 轻量级OpenHarmony操作系统应用开发对象管理系统及其应用方法
CN115102999A (zh) * 2022-06-09 2022-09-23 光大科技有限公司 DevOps系统、服务提供方法、存储介质和电子装置

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102609255A (zh) * 2012-01-19 2012-07-25 中国科学院计算机网络信息中心 一种Spring IOC配置文件的生成方法
US20160092246A1 (en) * 2014-09-26 2016-03-31 Oracle International Corporation Reverse dependency injection in a system with dynamic code loading
US20170075794A1 (en) * 2015-09-14 2017-03-16 Salesforce.Com, Inc. Methods and systems for computing code coverage using grouped/filtered source classes during testing of an application
CN108446111A (zh) * 2018-03-26 2018-08-24 国家电网公司客户服务中心 一种基于Spring cloud的微服务构建方法

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102609255A (zh) * 2012-01-19 2012-07-25 中国科学院计算机网络信息中心 一种Spring IOC配置文件的生成方法
US20160092246A1 (en) * 2014-09-26 2016-03-31 Oracle International Corporation Reverse dependency injection in a system with dynamic code loading
US20170075794A1 (en) * 2015-09-14 2017-03-16 Salesforce.Com, Inc. Methods and systems for computing code coverage using grouped/filtered source classes during testing of an application
CN108446111A (zh) * 2018-03-26 2018-08-24 国家电网公司客户服务中心 一种基于Spring cloud的微服务构建方法

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
魏文超;: "基于微服务架构的系统设计与开发" *

Cited By (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111698205A (zh) * 2020-04-29 2020-09-22 中国平安财产保险股份有限公司 服务调用方法及相关设备
CN111698205B (zh) * 2020-04-29 2023-09-26 中国平安财产保险股份有限公司 服务调用方法及相关设备
CN112256351A (zh) * 2020-10-26 2021-01-22 卫宁健康科技集团股份有限公司 Feign组件的实现方法、微服务调用方法及装置
CN112256351B (zh) * 2020-10-26 2023-11-17 卫宁健康科技集团股份有限公司 Feign组件的实现方法、微服务调用方法及装置
CN112764723A (zh) * 2021-01-21 2021-05-07 奇秦科技(北京)股份有限公司 一种基于Spring无侵入修改标准产品业务系统和方法
CN112764723B (zh) * 2021-01-21 2021-09-17 奇秦科技(北京)股份有限公司 一种基于Spring无侵入修改标准产品业务系统和方法
CN113885873A (zh) * 2021-09-29 2022-01-04 中国科学院软件研究所 轻量级OpenHarmony操作系统应用开发对象管理系统及其应用方法
CN113885873B (zh) * 2021-09-29 2022-09-16 中国科学院软件研究所 轻量级OpenHarmony操作系统应用开发对象管理系统及其应用方法
CN115102999A (zh) * 2022-06-09 2022-09-23 光大科技有限公司 DevOps系统、服务提供方法、存储介质和电子装置
CN115102999B (zh) * 2022-06-09 2024-02-09 光大科技有限公司 DevOps系统、服务提供方法、存储介质和电子装置

Also Published As

Publication number Publication date
CN109766080B (zh) 2023-11-10

Similar Documents

Publication Publication Date Title
CN109766080A (zh) 微服务注册方法、装置、电子设备及可读存储介质
CN108391025A (zh) 一种网络访问管理方法、移动终端及计算机可读存储介质
CN109710135A (zh) 分屏显示控制方法、终端以及计算机可读存储介质
CN108897478A (zh) 终端操作方法、移动终端及计算机可读存储介质
CN108289174A (zh) 一种拍摄方法、移动终端及计算机可读存储介质
CN109358831A (zh) 一种显示控制方法、移动终端及计算机可读存储介质
CN107247606A (zh) 应用程序管理方法、装置及计算机可读存储介质
CN109963005A (zh) 一种双屏亮度调节系统、方法及计算机存储介质
CN110064196A (zh) 移动终端控制方法、移动终端及计算机可读存储介质
CN109445660A (zh) 一种穿戴设备控制方法、移动终端及穿戴设备
CN109710159A (zh) 一种柔性屏响应方法、设备及计算机可读存储介质
CN109728952A (zh) 一种通信方法、移动终端以及计算机可读存储介质
CN109068084A (zh) 视频通话画面显示方法、移动终端及计算机可读存储介质
CN108984590A (zh) 一种页面数据展示方法、终端及计算机可读存储介质
CN108650281A (zh) 一种数据管理方法、装置及计算机可读存储介质
CN108306856A (zh) 一种接口合并方法、客户端、服务器及计算机可读存储介质
CN110167004A (zh) 一种网络注册方法、移动终端及计算机可读存储介质
CN110096173A (zh) 移动终端控制方法、移动终端及计算机可读存储介质
CN110392163A (zh) 熄屏控制方法、移动终端以及计算机可读存储介质
CN110096194A (zh) 终端解锁控制方法、装置、移动终端及可读存储介质
CN110045903A (zh) 界面操作响应方法、移动终端、装置及计算机存储介质
CN109582565A (zh) 防止应用崩溃的方法、终端及计算机存储介质
CN109714460A (zh) 按键扩展装置、终端、按键扩展方法以及存储介质
CN109743469A (zh) 一种基于volte的通信方法及移动终端
CN109151163A (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
TA01 Transfer of patent application right

Effective date of registration: 20231013

Address after: Room 3605, Floor 5, Building 3, Micro World, No. 23, Century Avenue, Liuwu New District, Lhasa, Xizang Autonomous Region, 851414

Applicant after: Xizang Liansa Intelligent Technology Co.,Ltd.

Address before: 518000 6-8 / F, 10-11 / F, 6 / F, 6-10 / F, C zone, Han's innovation building, No. 9018, Beihuan Avenue, high tech Zone, Nanshan District, Shenzhen City, Guangdong Province

Applicant before: NUBIA TECHNOLOGY Co.,Ltd.

TA01 Transfer of patent application right
GR01 Patent grant
GR01 Patent grant