CN110262818A - The hot update method of Java code, device, electronic equipment and storage medium - Google Patents
The hot update method of Java code, device, electronic equipment and storage medium Download PDFInfo
- Publication number
- CN110262818A CN110262818A CN201910455888.0A CN201910455888A CN110262818A CN 110262818 A CN110262818 A CN 110262818A CN 201910455888 A CN201910455888 A CN 201910455888A CN 110262818 A CN110262818 A CN 110262818A
- Authority
- CN
- China
- Prior art keywords
- application program
- target class
- class file
- java code
- file
- 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.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims abstract description 139
- 230000008569 process Effects 0.000 claims abstract description 84
- 238000012546 transfer Methods 0.000 claims description 27
- 230000006870 function Effects 0.000 claims description 13
- 230000008859 change Effects 0.000 claims description 10
- 238000004458 analytical method Methods 0.000 claims description 7
- 230000005611 electricity Effects 0.000 claims 1
- 230000000875 corresponding effect Effects 0.000 description 73
- 238000012360 testing method Methods 0.000 description 42
- 238000012986 modification Methods 0.000 description 13
- 230000004048 modification Effects 0.000 description 13
- 238000012545 processing Methods 0.000 description 12
- 238000004891 communication Methods 0.000 description 10
- 238000010586 diagram Methods 0.000 description 10
- 238000005516 engineering process Methods 0.000 description 8
- 230000000694 effects Effects 0.000 description 7
- 238000004590 computer program Methods 0.000 description 5
- 238000011161 development Methods 0.000 description 5
- 238000004364 calculation method Methods 0.000 description 4
- 239000003795 chemical substances by application Substances 0.000 description 4
- 230000003287 optical effect Effects 0.000 description 4
- 230000005236 sound signal Effects 0.000 description 4
- 238000007726 management method Methods 0.000 description 3
- 230000001133 acceleration Effects 0.000 description 2
- 230000000712 assembly Effects 0.000 description 2
- 238000000429 assembly Methods 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- 230000002093 peripheral effect Effects 0.000 description 2
- 230000001360 synchronised effect Effects 0.000 description 2
- KLDZYURQCUYZBL-UHFFFAOYSA-N 2-[3-[(2-hydroxyphenyl)methylideneamino]propyliminomethyl]phenol Chemical compound OC1=CC=CC=C1C=NCCCN=CC1=CC=CC=C1O KLDZYURQCUYZBL-UHFFFAOYSA-N 0.000 description 1
- 230000009471 action Effects 0.000 description 1
- 230000006978 adaptation Effects 0.000 description 1
- 230000003044 adaptive effect Effects 0.000 description 1
- 238000006243 chemical reaction Methods 0.000 description 1
- 238000007796 conventional method Methods 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 201000001098 delayed sleep phase syndrome Diseases 0.000 description 1
- 208000033921 delayed sleep phase type circadian rhythm sleep disease Diseases 0.000 description 1
- 238000000151 deposition Methods 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 238000005538 encapsulation Methods 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 239000012092 media component Substances 0.000 description 1
- 238000011017 operating method Methods 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/65—Updates
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Stored Programmes (AREA)
Abstract
The disclosure is about a kind of hot update method of Java code, device, electronic equipment and storage medium.The hot update method of Java code includes: to receive at least one target class the file information of the application program of operating status, wherein, the target class the file information includes: the unique identification of Java code compiling the target class file generated and the application program of the application program;According to the unique identification, connection is established with the process of the application program;And according at least one described target class the file information, call redefineclasses interface, at least one described target class file is replaced at least one corresponding original class file respectively, to realize that the Java code heat of the application program updates.The hot update method of the Java code can execute the .class file that modified Java code is obtained by compiling in jvm without restarting corresponding application program, shorten the time-consuming of Java code update, improve the update efficiency of Java code.
Description
Technical field
This disclosure relates to software technology field more particularly to the hot update method of Java code, device, electronic equipment and storage
Medium.
Background technique
In the development process of java application, in order to constantly improve the function of java application, developer's warp
Often need repeatedly to modify Java code.In the related technology, it when modifying to the method in java class, needs again
Start relevant application program to realize the update of Java code, for example, building in tomcat container to each application program
An individual classLoader (Classloader) is stood to load the class file of the application program.When the class of some application program
When file updates, all loading classes of original classLoader load are destroyed first, then create one
ClassLoader loads updated class file.It is complex and time-consuming to restart relevant application program operating process,
It reduce the update efficiency of Java code.Meanwhile when modifying to the method in java class, need to recompilate modification
Whole Java codes of related application afterwards, and then updated Java code is executed in jvm (Java Virtual Machine).Frequently
The whole Java codes for recompilating modified related application numerously increase memory requirements, occupy more multi -CPU money
Source, This further reduces the update efficiency of Java code.
Summary of the invention
The disclosure provides a kind of hot update method of Java code, device, electronic equipment and storage medium, at least to solve phase
Need to restart relevant application program in the technology of pass to realize that the update of Java code leads to the update efficiency of Java code
Low problem.The technical solution of the disclosure is as follows:
According to the first aspect of the embodiments of the present disclosure, a kind of hot update method of Java code is provided, comprising:
Receive at least one target class the file information of the application program of operating status, wherein the target class file letter
Breath includes: the unique identification of Java code compiling the target class file generated and the application program of the application program;
According to the unique identification, connection is established with the process of the application program;
According at least one described target class the file information, call redefineclasses interface, will it is described at least one
Target class file replaces at least one corresponding original class file respectively, to realize the Java code heat of the application program more
Newly.
Optionally, before at least one target class the file information of the application program for receiving operating status, comprising:
The Java code for modifying the application program obtains the transfer portion of the Java code;
The transfer portion for compiling the Java code obtains at least one described target class file.
Optionally, the unique identification includes: the process ID of the application program,
It is then described according to the unique identification, connection is established with the process of the application program, comprising:
According to the process ID of the application program, the corresponding service processes of the application program are obtained;
Service processes corresponding with the application program establish connection.
Optionally, after at least one target class the file information of the application program for receiving operating status, comprising:
Obtain the filename of at least one target class file;
Store at least one described target class file;And
The store path of at least one target class file and the filename are combined into parameter.
Optionally, described at least one target class the file information according to calls redefineclasses interface, will
At least one described target class file replaces at least one corresponding original class file respectively, to realize the application program
Java code heat updates, comprising:
The parameter of at least one target class file is transmitted to the process of the application program;
By the Parameter analysis of electrochemical of at least one target class file at the file of at least one target class file
Name and store path;
The content of at least one target class file is read according to the store path of at least one target class file;
And
From all class files that virtual machine has loaded, at least one of the same name at least one described target class file is searched
A original class file.
Optionally, described at least one target class the file information according to calls redefineclasses interface, will
At least one described target class file replaces at least one corresponding original class file respectively, to realize the application program
Java code heat updates, further includes:
Redefineclasses interface is called, at least one described target class file is replaced corresponding at least one respectively
A original class file reloads and executes at least one described target class file, to realize that Java code heat updates.
Optionally, after the Java code heat of the application program updates, if the function of the application program is not perfect,
By further modifying the Java code of the application program, the further heat of the Java code of the application program is realized more
Newly.
According to the second aspect of an embodiment of the present disclosure, a kind of hot updating device of Java code is provided, comprising:
Receiving unit is configured as executing at least one the target class the file information for the application program for receiving operating status,
Wherein, the target class the file information includes: the target class file and described that generates of Java code compiling of the application program
The unique identification of application program;
Connection unit is configured as executing establishing connection with the process of the application program according to the unique identification;
Hot updating unit is configured as executing according at least one described target class the file information, call
At least one described target class file is replaced at least one corresponding original class file by redefineclasses interface respectively,
To realize that the Java code heat of the application program updates.
Optionally, the hot updating device of the Java code, further includes:
Unit is modified, is configured as executing the Java code for modifying the application program, obtains changing for the Java code
Dynamic part, compiles the transfer portion of the Java code, obtains at least one described target class file.
Optionally, the unique identification includes: the process ID of the application program,
It is then described according to the unique identification, connection is established with the process of the application program, comprising:
According to the process ID of the application program, the corresponding service processes of the application program are obtained;
Service processes corresponding with the application program establish connection.
Optionally, the hot updating device of the Java code, further includes:
Storage unit is configured as executing the filename for obtaining at least one target class file, and storage is described at least
One target class file;
Assembled unit is configured as executing the store path of at least one target class file and the filename group
Synthetic parameters.
Optionally, described at least one target class the file information according to calls redefineclasses interface, will
At least one described target class file replaces at least one corresponding original class file respectively, to realize the application program
Java code heat updates, comprising:
The parameter of at least one target class file is transmitted to the process of the application program;
By the Parameter analysis of electrochemical of at least one target class file at the file of at least one target class file
Name and store path;
The content of at least one target class file is read according to the store path of at least one target class file;
And
From all class files that virtual machine has loaded, at least one of the same name at least one described target class file is searched
A original class file.
Optionally, described at least one target class the file information according to calls redefineclasses interface, will
At least one described target class file replaces at least one corresponding original class file respectively, to realize the application program
Java code heat updates, further includes:
Redefineclasses interface is called, at least one described target class file is replaced corresponding at least one respectively
A original class file reloads and executes at least one described target class file, to realize that Java code heat updates.
Optionally, after the Java code heat of the application program updates, if the function of the application program is not perfect,
By further modifying the Java code of the application program, the further heat of the Java code of the application program is realized more
Newly.
According to the third aspect of an embodiment of the present disclosure, a kind of electronic equipment is provided, comprising:
Processor;
For storing the memory of the processor-executable instruction;
Wherein, the processor is configured to described instruction is executed, to realize Java code heat as described above update side
Method.
According to a fourth aspect of embodiments of the present disclosure, a kind of storage medium is provided, when the instruction in the storage medium by
When the processor of electronic equipment executes, so that the electronic equipment is able to carry out the hot update method of Java code as described above.
According to a fifth aspect of the embodiments of the present disclosure, a kind of computer program product, including computer program product are provided,
The computer program includes program instruction, when described program is instructed by mobile terminal execution, makes the mobile terminal execution
The step of above-mentioned Java code hot update method.
The technical scheme provided by this disclosed embodiment at least bring it is following the utility model has the advantages that
1) redefineclasses interface is called by agency service program agent, by least one target class file point
At least one corresponding original class file is not replaced.One is obtained in the broker program of agency service program agent
Instrumentation example, by the example by least one primitive class text before at least one original class file load
Part replaces at least one corresponding target class file to change the byte of the .class file of at least one original class file
Code reloads at least one target class file after the bytecode of .class file changes.Reload this at least one
At least one target class file is executed after target class file, in jvm to realize that Java code heat updates.Java code modification
Afterwards, it can execute what modified Java code was obtained by compiling in jvm without restarting corresponding application program
.class file, it is seen that the final implementation effect of modified code shortens the time-consuming of Java code update, improves Java
The update efficiency of code;
2) in Java code renewal process, without restarting corresponding application program, thus during code update, phase
The application program answered realizes online updating, can continue to provide external service, to improve the corresponding application of Java code
The service quality and user experience of program;
3) in the hot update method of the Java code, target class file is the Java code that developer modifies application program
Afterwards, the transfer portion of Java code is recompilated into generation.When modifying to Java code, it is only necessary to recompilate phase
The Java code transfer portion for closing application program, reduces the compiling calculation amount of Java code, thereby reduces memory requirements, account for
With less cpu resource, which further improves the update efficiency of Java code.
It should be understood that above general description and following detailed description be only it is exemplary and explanatory, not
The disclosure can be limited.
Detailed description of the invention
The drawings herein are incorporated into the specification and forms part of this specification, and shows the implementation for meeting the disclosure
Example, and together with specification for explaining the principles of this disclosure, do not constitute the improper restriction to the disclosure.
Fig. 1 is the flow chart of the hot update method of Java code shown according to an exemplary embodiment;
Fig. 2 is the application scenario diagram of the hot update method of Java code shown according to an exemplary embodiment;
Fig. 3 is the flow chart of the hot update method of Java code shown according to an exemplary embodiment;
Fig. 4 is the hot updating device block diagram of Java code shown according to an exemplary embodiment;
Fig. 5 is the hot updating device block diagram of Java code shown according to an exemplary embodiment;
Fig. 6 is a kind of block diagram of device for executing the hot update method of Java code shown according to an exemplary embodiment;
Fig. 7 is a kind of block diagram of device for executing the hot update method of Java code shown according to an exemplary embodiment.
Specific embodiment
In order to make ordinary people in the field more fully understand the technical solution of the disclosure, below in conjunction with attached drawing, to this public affairs
The technical solution opened in embodiment is clearly and completely described.
It should be noted that the specification and claims of the disclosure and term " first " in above-mentioned attached drawing, "
Two " etc. be to be used to distinguish similar objects, without being used to describe a particular order or precedence order.It should be understood that using in this way
Data be interchangeable under appropriate circumstances, so as to embodiment of the disclosure described herein can in addition to illustrating herein or
Sequence other than those of description is implemented.Embodiment described in following exemplary embodiment does not represent and disclosure phase
Consistent all embodiments.On the contrary, they are only and as detailed in the attached claim, the disclosure some aspects
The example of consistent device and method.
In the development process of java application, developer needs to recompilate code simultaneously after modifying code every time
It is encapsulated as application program, then restarts application program, can just see the final implementation effect of modified code.It is certain to answer
After routine recompilation, restarting needs the long period, for example, the web layer exploitation etc. of web application can not be divided into module
The application program of exploitation.For such application program, though every time modify minimal amount of code require recompilate encapsulation it is whole
A application program, also, restart web application server.
In the exploitation of enterprise-level, common application program is usually modified, from modification code to closing and restart web
Server, this process need about 5 minutes time-consuming.For biggish application program, this process may need about 10 points time-consuming
Clock or more time.However, developer needs periodically to check the operation result of current code simultaneously during programming
It revises accordingly, to guarantee that corresponding effect is presented according to the wish of developer in code.Therefore, it is necessary to constantly close to lay equal stress on
New starting web server, this greatly promotes the time of code compilation and re-launching applications.In addition, being serviced for large size
Property application program for, during code update, generally require recompilate code and restart application program, restarting
During service, need to interrupt external service, to influence the service quality of corresponding application programs.
For this purpose, the present invention provides a kind of hot update method of Java code, Fig. 1 is shown according to an exemplary embodiment
The flow chart of the hot update method of Java code.
In step s 110, at least one target class the file information of the application program of operating status is received, wherein described
Target class the file information includes: the target class file and the application program that the Java code compiling of the application program generates
Unique identification.
In this step, at least one target class the file information of application program in operating status is received, wherein should
Target class the file information includes: unique mark of Java code compiling the target class file generated and application program of application program
Know.The unique identification of application program is used to the service processes of the corresponding application program of unique identification.Goal class file can
Be developer modify application program Java code after, by whole Java codes recompilate generate.
Preferably, after target class file can also be the Java code that developer modifies application program, by Java code
Transfer portion recompilate generate.
Specifically, firstly, developer searches the Java code for needing to modify function.Then, the Java code is modified.By
It is based on jvm in java applications all at present to run on the server, so developer also needs Java code
Transfer portion be compiled as the format that jvm can be identified, i.e. .class file.
Different from ordinary procedure .class file is not the executable program of local server.When needing to run
.class when file, jvm should be run first, then .class file is loaded into jvm again and is run, and be responsible for load in jvm
.class the tool of file is called classLoader, and the interface that jvm is used during loading is known as jvmti interface.
In addition, receiving at least one target class the file information of the application program of operating status.It is understood that receiving
At least one target class the file information can come from an application program, for an application program A, if using journey
The Java code of sequence A has many places modification, then this many places Java code transfer portion of application program A can be compiled as a mesh
Class file is marked, this many places Java code transfer portion of application program A can also be compiled as multiple target class files.
Optionally, the multiple target class the file informations for receiving multiple application programs of operating status, for application program B and
It, can be respectively by this many places of application program B if the Java code of application program B and C have many places modification respectively for C
Java code transfer portion is compiled as a target class file, can also respectively change this many places Java code of application program B
Dynamic partial compilation is multiple target class files;This many places Java code transfer portion of application program C can be compiled as one
This many places Java code transfer portion of application program C can also be compiled as multiple target class files by target class file.
It is understood that the transfer portion of the Java code of the number of application program and each application program is compiled into
Target class file number can be arbitrary value, should not to the embodiment of the present disclosure constitute any restrictions.
In the step s 120, according to the unique identification, connection is established with the process of the application program.
In this step, according to the unique identification of application program, connection is established with the process of corresponding application program.
The unique identification of each application program includes: the process ID of application program, then according to the unique identification of application program,
Connection is established with the process of corresponding application program, comprising: according to the process ID of application program, it is corresponding to obtain the application program
Service processes.Service processes corresponding with the application program establish connection.
VirtualMachine class in the com.sun.tools.attach packet of Java allows by attach method
The pid (process id) of an incoming jvm, be connected remotely on jvm, for example, by the corresponding application program of target class file into
Journey ID is passed to attach method, where being connected remotely to corresponding application program on the jvm of server.It can pass through
LoadAgent method registers an agency service program agent to jvm, and one can be obtained in the broker program of the agent
Instrumentation example, the example can change the bytecode of .class file before .class file loads, can be with
It is reloaded after the bytecode of .class file changes.When calling the method for Instrumentation example, attach,
The methods of loadAgent will use the method provided in ClassFileTransformer interface and be handled.
In step s 130, according at least one described target class the file information, redefineclasses interface is called,
At least one described target class file is replaced at least one corresponding original class file respectively, to realize the application program
Java code heat updates.
In this step, according at least one target class the file information, redefineclasses interface is called, using extremely
A few target class file replaces at least one corresponding original class file respectively, to realize at least one target class file pair
The Java code heat for the application program answered updates.
Specifically, the storage information according at least one target class file in test machine local is called
At least one target class file is replaced at least one corresponding original class file by redefineclasses interface respectively.In generation
Manage service routine agent broker program in obtain an Instrumentation example, by the example at this at least one
The bytecode for changing .class file before original class file load reloads at least after the bytecode of .class file changes
One target class file will at least one original class file replace at least one corresponding target class file.It reloads
At least one target class file is executed after at least one target class file, in jvm to realize that Java code heat updates.
In embodiment of the disclosure, redefineclasses interface is called by agency service program agent, it is near
A few target class file replaces at least one corresponding original class file respectively.Journey is acted on behalf of in agency service program agent
An Instrumentation example is obtained in sequence, by the example before at least one original class file load by this at least
One original class file replaces at least one corresponding target class file to change at least one original class file
.class the bytecode of file reloads at least one target class file after the bytecode of .class file changes.Weight
At least one target class file is executed in jvm after newly loading at least one target class file, to realize Java code heat more
Newly.After Java code modification, modified Java code process can be executed in jvm without restarting corresponding application program
Compiling obtained .class file, it is seen that the final implementation effect of modified code shortens the time-consuming of Java code update,
Improve the update efficiency of Java code.Meanwhile in Java code renewal process, without restarting corresponding application program, because
And during code update, corresponding application program realizes online updating, can continue to provide external service, to improve
The service quality and user experience of the corresponding application program of Java code.
Preferably, target class file be developer modify application program Java code after, by the change of Java code
Recompilate generation in part.When modifying to Java code, it is only necessary to recompilate the Java generation of related application
Code transfer portion, reduces the compiling calculation amount of Java code, thereby reduces memory requirements, occupy less cpu resource, this
Further improve the update efficiency of Java code.
Code tester is reproduction application failure, positioning failure root, and finally solves the failure problems of application program
Process.When testing an item code, when single step goes to erroneous point, need to modify code, the code of modification may be
Various types.If it is intended to code after test modifications is to check the implementation effect of application program after code revision, phase
Scheme in the technology of pass is re-launching applications, and then single step goes to a test site again, this can consume many times,
Increase many duplicate operating procedures, so that the development efficiency of application program reduces.So being realized during code tester
The heat of code, which updates, to be of great significance.
Fig. 2 is the application scenario diagram of the hot update method of Java code shown according to an exemplary embodiment.Developer
The Java code of application program is modified in locally exploitation machine 210, the transfer portion of Java code is recompilated the jvm generated can
With the .class file of identification.The .class file synchronization that compiling is generated is to test machine with the Java code of test application program
Whether according to the wish of developer corresponding effect is showed after modified.Test machine includes: test machine agency 220 and test
Machine service 230.During code tester, application program is in test machine continuous service.It can shift to an earlier date and pass through in test machine
LoadAgent method registers an agency service program agent to the jvm of test machine.Developer passes through agency service program
Agent realizes that the remote thermal of the application program run on a testing machine updates.
Fig. 3 is the flow chart of the hot update method of Java code shown according to an exemplary embodiment.
Below with reference to code tester application scenarios shown in Fig. 2, Java code heat shown in Fig. 3 update side is described in detail
Method.
Specific steps include:
In step S301, the multiple application program to be tested is run in test machine.
In this step, the multiple application programs to be tested in 230 operation of test machine service.For example, in test machine service
Application program D, application program E and application program F are run on 230.
In step s 201, the process ID that the multiple application program is run on a testing machine is obtained.
In this step, the process ID that multiple application programs are run on a testing machine is obtained.It is taken for example, obtaining in test machine
The process ID 3 of the process ID 1 of application program D, the process ID 2 of application program E and application program F that are run in business 230.
In step s101, the Java code of the multiple application program of operating status is respectively modified, obtains described more
The transfer portion of the Java code of a application program.
In step s 102, the transfer portion for compiling the Java code of the multiple application program respectively obtains described more
A target class file.
In step s 103, the multiple target class file is uploaded.
In step S101- step S103, developer is respectively modified in local exploitation machine 210 and runs on a testing machine
The Java code of multiple application programs, for example, the method body of modification Java code, by the Java code of multiple application programs
Transfer portion recompilates the multiple target class files for generating the .class file format that jvm can be identified respectively.
The multiple target class files and step of generation will be compiled in multiple target class the file informations, that is, step S101- step S103
The process ID of the corresponding multiple application programs obtained in rapid S201 is synchronized to test machine to test multiple application programs respectively
Whether according to the wish of developer corresponding effect is showed after Java code is modified.
For example, application program D, application program E and application program F is respectively modified in local exploitation machine 210 in developer
Java code.And the transfer portion for compiling the Java code of application program D, application program E and application program F respectively, obtains
Multiple target class text of multiple target class files of application program D, multiple target class files of application program E and application program F
Part.By the multiple target class files and process ID 1 of application program D, multiple target class files of application program E and process ID 2 with
And the multiple target class files and process ID 3 of application program F upload to test machine by web page or quick plug-in unit respectively
Test machine agency 220.
In step S202, the class name of the multiple target class file is obtained.
In step S203, the multiple target class file is stored.
In step S204, the class name of the multiple target class file and store path are combined into parameter.
In step S202- step S204, after receiving multiple target class the file informations, test machine agency 220 is obtained
The class name of this multiple target class file and store path are combined into parameter by the class name of multiple target class files.
For example, using ASM frame, (java bytecode is grasped after being respectively received three target class files of application program D
Vertical frame) under classReader class parse the .class files of these three target class files, obtain these three target class text
The content of part.The class name of these three target class files is obtained by className class.These three the target class files that will acquire
After class name is converted to the class name that jvm can be identified, stored using these three class files of class star after conversion.For example, will apply
The target class file 1 of program D, the class name " a1/b1/c1 " of target class file 2 and target class file 3, " a2/b2/c2 " and " a3/
B3/c3 " is converted to " a1.b1.c1 ", " a2.b2.c2 " and " a3.b3.c3 ".Respectively using class name " a1.b1.c1 ",
" a2.b2.c2 " and " a3.b3.c3 " deposits the target class file 1, target class file 2 and target class file 3 of application program D respectively
Storage is in store path 1, store path 2 and store path 3.
Class name " a1.b1.c1 " and store path 1 are combined into the parameter agentArgs1 of target class file 1, by class name
" a2.b2.c2 " and store path 2 are combined into the parameter agentArgs2 of target class file 2, by class name " a3.b3.c3 " and storage
Path 3 is combined into the parameter agentArgs3 of target class file 3.
In step S205, according to the process ID of the multiple application program, respectively with the multiple application program into
Cheng Jianli connection.
In this step, test machine agency 220 respectively obtains multiple application programs according to the process ID of multiple application programs
Corresponding service processes.For example, being passed through according to the process ID of application program D, application program E and application program F
FindProcess method searches all process lists of the jvm run on test machine, finds application program D, application program
The specific process of E and application program F.
Service processes corresponding with multiple application programs establish connection respectively.For example, for application program D, application program E
With application program F, agency service program 220 is by being passed to process ID 1 to VirtualMachine.attach method, with operation
Connection is established in the specific process of the application program D of jvm;Agency service program 220 is by giving VirtualMachine.attach
Method is passed to process ID 2, establishes connection with the specific process for the application program E for operating in jvm;Agency service program 220 passes through
It is passed to process ID 3 to VirtualMachine.attach method, establishes and connects with the specific process for the application program F for operating in jvm
It connects.
In step S206, by the parameter of the multiple target class file be transmitted to the multiple application program into
Journey.
In step s 302, by the Parameter analysis of electrochemical of the multiple target class file at the class name of the multiple target class file
And store path.
In step S206 and step S302, by the parameter of multiple target class files be transmitted to multiple application programs into
Journey.By the Parameter analysis of electrochemical of multiple target class files at the class name and store path of multiple target class files.
For example, by the parameter agentArgs1 of target class file 1, the parameter agentArgs2 of target class file 2 and target
The parameter agentArgs3 of class file 3 is transmitted to the service processes of application program D, application program E and application program F respectively.
Java class is generally packaged in the compressed package of jar format.In the embodiment of the present disclosure, pass through in advance in test machine
Agency service program agent can be packaged in by loadAgent method to the jvm trade mark agency service routine agent of test machine
In the compressed package of jar format.The path of the compressed package of the jar format of agency service program agent is agentPath.By for
Attach.loadAgent method uploads parameter agentArgs1 and agentPath, the target class file of target class file 1 respectively
2 parameter agentArgs2 and agentPath and the parameter agentArgs3 and agentPath of target class file 3, respectively
To target class file 1, the class name of target class file 2 and target class file 3.Target class file 1, mesh are obtained by Paths.get
Mark the store path of class file 2 and target class file 3.
In step S303, the multiple target class file is read according to the store path of the multiple target class file
Content.
In step s 304, it from all class files that virtual machine has loaded, searches same with the multiple target class file
Multiple original class files of name.
In step S303 and step S304, multiple target class text is read according to the store path of multiple target class files
The content of part.From all class files that virtual machine has loaded, search and multiple target class files class object of the same name.
For example, reading the content of multiple target class file according to the store path of multiple target class files.
It is traversed in the jvm run on test machine and has been loaded by instrumentation.getAllLoadedClasses
.class file (the .class file loaded can store in the buffer), find the file with multiple target class file
The original class file of the identical class object of name, that is, to be replaced.
In step S305, redefineclasses interface is called respectively, multiple target class files are replaced respectively
Corresponding multiple original class files, to realize that the Java code heat of the multiple application program updates respectively.
In this step, redefineclasses interface is called in test machine service 230 respectively, respectively applies each
At least one target class file of program replaces at least one corresponding original class file respectively.
For example, calling redefineclasses interface respectively, obtained in the broker program of agency service program agent
One Instrumentation example, through the example before at least one original class file load of each application program
By this, at least one original class file replaces at least one corresponding target class file to change at least one primitive class text
The bytecode of the .class file of part reloads at least one target class text after the bytecode of .class file changes
Part.
For example, calling java.lang.instrument.Instrumentation class by Java agent mechanism
The class that redefineClasses method completes at least one original class file of each application program redefines, and realization will be each
The original class file of at least one of application program replaces at least one corresponding target class file.
Pass through classLoader respectively at least one target class file of each application program of .class file format
It is loaded into the jvm run on test machine and runs, to realize that the Java code heat of corresponding application program updates.
During running in the jvm that multiple target class files are run on a testing machine, test machine test is corresponding multiple
The no wish according to developer of the function of application program shows corresponding effect.By code tester, if corresponding multiple
The function of application program does not show corresponding effect according to the wish of developer, then executes step S101 further with into one
Step heat updates the Java code of corresponding multiple application programs.
In accordance with an embodiment of the present disclosure, when the function to multiple application programs is tested, developer opens locally
The Java code of the multiple application programs of operation on a testing machine is respectively modified in hair machine 210, by the Java generation of multiple application programs
The transfer portion of code recompilates the multiple target class files for generating the .class file format that jvm can be identified respectively.It will be more
A target class the file information is that multiple target class files of compiling generation and the process ID of corresponding multiple application programs are synchronized to
Test machine with the Java code for testing multiple application programs respectively it is modified after whether showed according to the wish of developer
Corresponding effect.The transfer portion for only needing to recompilate the Java code of related application in test process, reduces Java
The compiling calculation amount of code, thereby reduces memory requirements, occupies less cpu resource, which further improves Java codes
Update efficiency, and then improve the development efficiency of application program.
In addition, redefineclasses interface is called in test machine service 230 respectively, at least by each application program
One target class file replaces at least one corresponding original class file respectively.It is by classLoader that .class is literary respectively
At least one target class file of each application program of part format, which is loaded into the jvm run on test machine, to be run, with reality
The Java code heat of existing corresponding application program updates.At least one target class file of each application program is on a testing machine
The no wish according to developer of function that corresponding application program is tested during running in the jvm of operation shows accordingly
Effect.By code tester, if the function of corresponding multiple application programs does not show phase according to the wish of developer
Effect is answered, then further executes the Java code that step S310 updates corresponding multiple application programs with further heat.It tested
The redefine function that java.lang.instrument.Instrumentation class is utilized in journey, is answered accordingly without restarting
It is updated with the heat that Java code can be realized in program, shortens the time-consuming of Java code update, improve the update of Java code
Efficiency, and then improve the development efficiency of application program.
Fig. 4 is the hot updating device block diagram of Java code shown according to an exemplary embodiment.Include: receiving unit 410,
Connection unit 420 and hot updating unit 430.
Receiving unit 410 is configured as executing at least one the target class file letter for the application program for receiving operating status
Breath, wherein the target class the file information includes: the target class file and institute that the Java code compiling of the application program generates
State the unique identification of application program.
Connection unit 420 is configured as executing according to the unique identification, establishes and connect with the process of the application program
It connects.
Hot updating unit 430 is configured as executing according at least one described target class the file information, call
At least one described target class file is replaced at least one corresponding original class file by redefineclasses interface respectively,
To realize that the Java code heat of the application program updates.
In embodiment of the disclosure, the hot updating device of the Java code receives application program in operating status extremely
A few target class the file information, wherein the target class the file information includes: the mesh that the Java code compiling of application program generates
Mark the unique identification of class file and application program.Goal class file can be the Java that developer modifies application program
After code, whole Java codes are recompilated into generation.Target class file can also be that developer modifies application program
After Java code, the transfer portion of Java code is recompilated into generation.The unique identification of each application program includes: application
The process ID of program, according to the process ID of application program, the corresponding service processes of the program that is applied.It is corresponding with application program
Service processes establish connection.According at least one target class the file information, redefineclasses interface is called, using at least
One target class file replaces at least one corresponding original class file respectively, to realize that at least one target class file is corresponding
The Java code heat of application program updates.After Java code modification, hot updating unit 430 is corresponding using journey without restarting
Sequence can execute modified Java code in jvm and pass through the .class file that compiling obtains, it is seen that modified code is most
Whole implementation effect shortens the time-consuming of Java code update, improves the update efficiency of Java code.
Fig. 5 is the hot updating device block diagram of Java code shown according to an exemplary embodiment.Include: modification unit 510,
Receiving unit 520, connection unit 530, storage unit 540, assembled unit 550 and hot updating unit 560.
Unit 510 is modified, is configured as executing the Java code for modifying the application program, obtains the Java code
Transfer portion compiles the transfer portion of the Java code, obtains at least one described target class file.
Receiving unit 520 is configured as executing at least one the target class file letter for the application program for receiving operating status
Breath, wherein the target class the file information includes: the target class file and institute that the Java code compiling of the application program generates
State the unique identification of application program.
Connection unit 530 is configured as executing according to the unique identification, establishes and connect with the process of the application program
It connects.
Optionally, the unique identification includes: the process ID of the application program, then described according to the unique identification,
Connection is established with the application program, comprising:
According to the process ID of the application program, the corresponding service processes of the application program are obtained;Journey is applied with described
The corresponding service processes of sequence establish connection.
Storage unit 540 is configured as executing the filename for obtaining at least one target class file, and storage is described extremely
A few target class file;
Assembled unit 550 is configured as executing the store path and the file of at least one target class file
Name is combined into parameter.
Hot updating unit 560 is configured as executing according at least one described target class the file information, call
At least one described target class file is replaced at least one corresponding original class file by redefineclasses interface respectively,
To realize that the Java code heat of the application program updates.
Optionally, the parameter of at least one target class file is transmitted to the process of the application program;It will
Filename and storage road of the Parameter analysis of electrochemical of at least one target class file at least one target class file
Diameter;The content of at least one target class file is read according to the store path of at least one target class file;And
From all class files that virtual machine loads, at least one primitive class text of the same name at least one described target class file is searched
Part.
Redefineclasses interface is called, at least one described target class file is replaced corresponding at least one respectively
A original class file reloads and executes at least one described target class file, to realize that Java code heat updates.
In embodiment of the disclosure, according at least one described target class the file information, redefineclasses is called
Interface replaces at least one corresponding original class file using at least one target class file, to realize at least one mesh respectively
The Java code heat for marking the corresponding application program of class file updates.Corresponding application program operation when being updated to Java code heat
There is no limit also there is no limit for the type externally serviced provided corresponding application program for container.No matter held using tomcat
Device still can realize that the Java code heat of the embodiment of the present disclosure updates using containers such as similar jetty.
In an optional embodiment of the disclosure, after the Java code heat of the application program updates, if described
The function of application program is not perfect, then by further modifying the Java code of the application program, realizes the application program
Java code it is further heat update.
Fig. 6 is a kind of Java code for the hot update method of above-mentioned Java code shown according to an exemplary embodiment
The block diagram of hot updating device 600.For example, the hot updating device 600 of Java code can be mobile phone, computer, digital broadcasting
Terminal, messaging devices, game console, tablet device, Medical Devices, body-building equipment, personal digital assistant etc..
Referring to Fig. 6, device 600 may include following one or more components: processing component 610, memory 620, power supply
Component 630, multimedia component 640, audio component 650, the interface 660 of input/output (I/O), sensor module 670, and
Communication component 680.
The integrated operation of the usual control device 600 of processing component 610, such as with display, telephone call, data communication, phase
Machine operation and record operate associated operation.Processing component 610 may include that one or more processors 690 refer to execute
It enables, to perform all or part of the steps of the methods described above.In addition, processing component 610 may include one or more modules, just
Interaction between processing component 610 and other assemblies.For example, processing component 610 may include multi-media module, it is more to facilitate
Interaction between media component 540 and processing component 610.
Memory 620 is configured as storing various types of data to support the operation in equipment 600.These data are shown
Example includes the instruction of any application or method for operating on device 600, contact data, and telephone book data disappears
Breath, picture, video etc..Memory 620 can be by any kind of volatibility or non-volatile memory device or their group
It closes and realizes, such as static random access memory (SRAM), electrically erasable programmable read-only memory (EEPROM) is erasable to compile
Journey read-only memory (EPROM), programmable read only memory (PROM), read-only memory (ROM), magnetic memory, flash
Device, disk or CD.
Power supply module 630 provides electric power for the various assemblies of device 600.Power supply module 630 may include power management system
System, one or more power supplys and other with for device 600 generate, manage, and distribute the associated component of electric power.
Multimedia component 640 includes the screen of one output interface of offer between described device 600 and user.One
In a little embodiments, screen may include liquid crystal display (LCD) and touch panel (TP).If screen includes touch panel, screen
Curtain may be implemented as touch screen, to receive input signal from the user.Touch panel includes one or more touch sensings
Device is to sense the gesture on touch, slide, and touch panel.The touch sensor can not only sense touch or sliding action
Boundary, but also detect duration and pressure associated with the touch or slide operation.In some embodiments, more matchmakers
Body component 640 includes a front camera and/or rear camera.When equipment 600 is in operation mode, such as screening-mode or
When video mode, front camera and/or rear camera can receive external multi-medium data.Each front camera and
Rear camera can be a fixed optical lens system or have focusing and optical zoom capabilities.
Audio component 650 is configured as output and/or input audio signal.For example, audio component 650 includes a Mike
Wind (MIC), when device 600 is in operation mode, when such as call mode, recording mode, and voice recognition mode, microphone is matched
It is set to reception external audio signal.The received audio signal can be further stored in memory 620 or via communication set
Part 680 is sent.In some embodiments, audio component 650 further includes a loudspeaker, is used for output audio signal.
I/O interface 660 provides interface between processing component 610 and peripheral interface module, and above-mentioned peripheral interface module can
To be keyboard, click wheel, button etc..These buttons may include, but are not limited to: home button, enables button and lock at volume button
Determine button.
Sensor module 670 includes one or more sensors, and the state for providing various aspects for device 600 is commented
Estimate.For example, sensor module 670 can detecte the state that opens/closes of equipment 600, and the relative positioning of component, for example, it is described
Component is the display and keypad of device 600, and sensor module 670 can be with 600 1 components of detection device 600 or device
Position change, the existence or non-existence that user contacts with device 600,600 orientation of device or acceleration/deceleration and device 600
Temperature change.Sensor module 670 may include proximity sensor, be configured to detect without any physical contact
Presence of nearby objects.Sensor module 670 can also include optical sensor, such as CMOS or ccd image sensor, at
As being used in application.In some embodiments, which can also include acceleration transducer, gyro sensors
Device, Magnetic Sensor, pressure sensor or temperature sensor.
Communication component 680 is configured to facilitate the communication of wired or wireless way between device 600 and other equipment.Device
600 can access the wireless network based on communication standard, such as WiFi, carrier network (such as 2G, 3G, 4G or 5G) or them
Combination.In one exemplary embodiment, communication component 680 is received via broadcast channel from the wide of external broadcasting management system
Broadcast signal or broadcast related information.In one exemplary embodiment, the communication component 680 further includes near-field communication (NFC)
Module, to promote short range communication.For example, radio frequency identification (RFID) technology, Infrared Data Association (IrDA) can be based in NFC module
Technology, ultra wide band (UWB) technology, bluetooth (BT) technology and other technologies are realized.
In the exemplary embodiment, device 600 can be believed by one or more application specific integrated circuit (ASIC), number
Number processor (DSP), digital signal processing appts (DSPD), programmable logic device (PLD), field programmable gate array
(FPGA), controller, microcontroller, microprocessor or other electronic components are realized, for executing the above method.
In the exemplary embodiment, a kind of storage medium including instruction, the memory for example including instruction are additionally provided
620, above-metioned instruction can be executed by the processor 690 of device 600 to complete the above method.Optionally, storage medium can be with right and wrong
Provisional computer readable storage medium, for example, the non-transitorycomputer readable storage medium can be ROM, deposit at random
Access to memory (RAM), CD-ROM, tape, floppy disk and optical data storage devices etc..
In the exemplary embodiment, a kind of computer program product, including computer program product, the meter are additionally provided
Calculation machine program includes program instruction, when described program is instructed by mobile terminal execution, keeps the mobile terminal execution above-mentioned
The step of Java code hot update method: at least one target class the file information of the application program of operating status is received, wherein
The target class the file information includes: the target class file that the Java code compiling of the application program generates and described using journey
The unique identification of sequence;According to the unique identification, connection is established with the process of the application program;According at least one described mesh
Mark class file information, call redefineclasses interface, by least one described target class file replace respectively it is corresponding extremely
A few original class file, to realize that the Java code heat of the application program updates.
Fig. 7 is a kind of Java code for the hot update method of above-mentioned Java code shown according to an exemplary embodiment
The block diagram of hot updating device 700.For example, device 700 may be provided as a server.Referring to Fig. 7, device 700 includes processing
Component 710 further comprises one or more processors, and the memory resource as representated by memory 720, for depositing
Storage can be by the instruction of the execution of processing component 710, such as application program.The application program stored in memory 720 may include
It is one or more each correspond to one group of instruction module.In addition, processing component 710 is configured as executing instruction,
To execute the hot update method of above-mentioned Java code.
Device 700 can also include the power management that a power supply module 730 is configured as executive device 700, and one has
Line or radio network interface 740 are configured as device 700 being connected to network and input and output (I/O) interface 750.Dress
Setting 700 can operate based on the operating system for being stored in memory 720, such as Windows ServerTM, Mac OS XTM,
UnixTM, LinuxTM, FreeBSDTM or similar.
Those skilled in the art after considering the specification and implementing the invention disclosed here, will readily occur to its of the disclosure
Its embodiment.The disclosure is intended to cover any variations, uses, or adaptations of the disclosure, these modifications, purposes or
Person's adaptive change follows the general principles of this disclosure and including the undocumented common knowledge in the art of the disclosure
Or conventional techniques.The description and examples are only to be considered as illustrative, and the true scope and spirit of the disclosure are by following
Claim is pointed out.
It should be understood that the present disclosure is not limited to the precise structures that have been described above and shown in the drawings, and
And various modifications and changes may be made without departing from the scope thereof.The scope of the present disclosure is only limited by the accompanying claims.
Claims (10)
1. a kind of hot update method of Java code characterized by comprising
Receive at least one target class the file information of the application program of operating status, wherein the target class the file information packet
It includes: the unique identification of Java code compiling the target class file generated and the application program of the application program;
According to the unique identification, connection is established with the process of the application program;
According at least one described target class the file information, redefineclasses interface is called, it will at least one described target
Class file replaces at least one corresponding original class file respectively, to realize that the Java code heat of the application program updates.
2. the hot update method of Java code according to claim 1, which is characterized in that the application for receiving operating status
Before at least one target class the file information of program, comprising:
The Java code for modifying the application program obtains the transfer portion of the Java code;
The transfer portion for compiling the Java code obtains at least one described target class file.
3. the hot update method of Java code according to claim 1, which is characterized in that the unique identification includes: described
The process ID of application program,
It is then described according to the unique identification, connection is established with the process of the application program, comprising:
According to the process ID of the application program, the corresponding service processes of the application program are obtained;
Service processes corresponding with the application program establish connection.
4. the hot update method of Java code according to claim 3, which is characterized in that the application for receiving operating status
After at least one target class the file information of program, comprising:
Obtain the filename of at least one target class file;
Store at least one described target class file;And
The store path of at least one target class file and the filename are combined into parameter.
Preferably, described at least one target class the file information according to calls redefineclasses interface, will be described
At least one target class file replaces at least one corresponding original class file respectively, to realize the Java generation of the application program
Code heat updates, comprising:
The parameter of at least one target class file is transmitted to the process of the application program;
By the Parameter analysis of electrochemical of at least one target class file at least one target class file filename and
Store path;
The content of at least one target class file is read according to the store path of at least one target class file;And
From all class files that virtual machine has loaded, at least one original of the same name at least one described target class file is searched
Beginning class file.
Preferably, described at least one target class the file information according to calls redefineclasses interface, will be described
At least one target class file replaces at least one corresponding original class file respectively, to realize the Java generation of the application program
Code heat updates, further includes:
Redefineclasses interface is called, at least one described target class file is replaced at least one corresponding original respectively
Beginning class file reloads and executes at least one described target class file, to realize that Java code heat updates.
Preferably, after the Java code heat of the application program updates, if the function of the application program is not perfect, pass through
The Java code for further modifying the application program realizes that the further heat of the Java code of the application program updates.
5. a kind of hot updating device of Java code characterized by comprising
Receiving unit is configured as executing at least one the target class the file information for the application program for receiving operating status, wherein
The target class the file information includes: the target class file that the Java code compiling of the application program generates and described using journey
The unique identification of sequence;
Connection unit is configured as executing establishing connection with the process of the application program according to the unique identification;
Hot updating unit is configured as executing according at least one described target class the file information, calls redefineclasses
At least one described target class file is replaced at least one corresponding original class file, to realize the application by interface respectively
The Java code heat of program updates.
6. the hot updating device of Java code according to claim 5, which is characterized in that the Java code heat more new clothes
It sets, further includes:
Unit is modified, is configured as executing the Java code for modifying the application program, obtains the change portion of the Java code
Point, the transfer portion of the Java code is compiled, at least one described target class file is obtained.
7. the hot updating device of Java code according to claim 5, which is characterized in that the unique identification includes: described
The process ID of application program,
It is then described according to the unique identification, connection is established with the process of the application program, comprising:
According to the process ID of the application program, the corresponding service processes of the application program are obtained;
Service processes corresponding with the application program establish connection.
8. the hot updating device of Java code according to claim 7, which is characterized in that the Java code heat more new clothes
It sets, further includes:
Storage unit, is configured as executing the filename for obtaining at least one target class file, storage it is described at least one
Target class file;
Assembled unit, is configured as executing and is combined into the store path of at least one target class file and the filename
Parameter.
Preferably, described at least one target class the file information according to calls redefineclasses interface, will be described
At least one target class file replaces at least one corresponding original class file respectively, to realize the Java generation of the application program
Code heat updates, comprising:
The parameter of at least one target class file is transmitted to the process of the application program;
By the Parameter analysis of electrochemical of at least one target class file at least one target class file filename and
Store path;
The content of at least one target class file is read according to the store path of at least one target class file;And
From all class files that virtual machine has loaded, at least one original of the same name at least one described target class file is searched
Beginning class file.
Preferably, described at least one target class the file information according to calls redefineclasses interface, will be described
At least one target class file replaces at least one corresponding original class file respectively, to realize the Java generation of the application program
Code heat updates, further includes:
Redefineclasses interface is called, at least one described target class file is replaced at least one corresponding original respectively
Beginning class file reloads and executes at least one described target class file, to realize that Java code heat updates.
Preferably, after the Java code heat of the application program updates, if the function of the application program is not perfect, pass through
The Java code for further modifying the application program realizes that the further heat of the Java code of the application program updates.
9. a kind of electronic equipment characterized by comprising
Processor;
For storing the memory of the processor-executable instruction;
Wherein, according to any one of claims 1 to 4 to realize the processor is configured to executing described instruction
The hot update method of Java code.
10. a kind of storage medium, when the instruction in the storage medium is executed by the processor of electronic equipment, so that the electricity
Sub- equipment is able to carry out the hot update method of Java code according to any one of claims 1 to 4.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910455888.0A CN110262818A (en) | 2019-05-29 | 2019-05-29 | The hot update method of Java code, device, electronic equipment and storage medium |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910455888.0A CN110262818A (en) | 2019-05-29 | 2019-05-29 | The hot update method of Java code, device, electronic equipment and storage medium |
Publications (1)
Publication Number | Publication Date |
---|---|
CN110262818A true CN110262818A (en) | 2019-09-20 |
Family
ID=67915660
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910455888.0A Pending CN110262818A (en) | 2019-05-29 | 2019-05-29 | The hot update method of Java code, device, electronic equipment and storage medium |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110262818A (en) |
Cited By (21)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110704082A (en) * | 2019-09-25 | 2020-01-17 | 许昌许继软件技术有限公司 | Continuous integration method and system for monitoring platform |
CN110780864A (en) * | 2019-10-30 | 2020-02-11 | 网易(杭州)网络有限公司 | Control method and device for class method replacement, storage medium and electronic equipment |
CN111061486A (en) * | 2019-12-10 | 2020-04-24 | 杭州有赞科技有限公司 | Android application program increment method |
CN111580813A (en) * | 2020-03-25 | 2020-08-25 | 博雅信安科技(北京)有限公司 | Automatic management method for Java class hot update |
CN111638907A (en) * | 2020-04-20 | 2020-09-08 | 北京达佳互联信息技术有限公司 | Method, device, terminal and storage medium for replacing third-party code segment |
CN112068875A (en) * | 2020-08-04 | 2020-12-11 | 广州太平洋电脑信息咨询有限公司 | System and method for realizing thread filtering strategy based on java dynamic loading |
CN112199110A (en) * | 2020-10-16 | 2021-01-08 | 上海睿成软件有限公司 | Restart-free operation and maintenance upgrading method, system, device and medium |
CN112463303A (en) * | 2020-12-01 | 2021-03-09 | 中国工商银行股份有限公司 | JAVA virtual machine class loading method and system |
CN112596772A (en) * | 2020-12-15 | 2021-04-02 | 上海米哈游网络科技股份有限公司 | Server updating method and device, electronic equipment and storage medium |
CN112988208A (en) * | 2019-12-18 | 2021-06-18 | 腾讯科技(深圳)有限公司 | Data updating method, device, equipment and storage medium |
CN113110865A (en) * | 2021-04-21 | 2021-07-13 | 北京字跳网络技术有限公司 | Server hot updating method and device |
CN113127361A (en) * | 2021-04-23 | 2021-07-16 | 中国工商银行股份有限公司 | Application program development method and device, electronic equipment and storage medium |
CN113138787A (en) * | 2021-04-28 | 2021-07-20 | 中消云(北京)物联网科技研究院有限公司 | Program updating method and device |
CN113268242A (en) * | 2020-02-17 | 2021-08-17 | 北京达佳互联信息技术有限公司 | Code compiling time length determining method and device, electronic equipment and storage medium |
CN113342323A (en) * | 2021-06-29 | 2021-09-03 | 银清科技有限公司 | Method and device for software online development |
CN113553040A (en) * | 2021-07-20 | 2021-10-26 | 中国第一汽车股份有限公司 | Registration realization method, device, equipment and medium for visible and spoken identification function |
CN113867832A (en) * | 2021-09-15 | 2021-12-31 | 广州云徙科技有限公司 | Method, system, computer device and medium for dynamically modifying business data logic |
CN114416567A (en) * | 2022-01-20 | 2022-04-29 | 浙江吉利控股集团有限公司 | Application program access method and device |
CN114625397A (en) * | 2022-05-17 | 2022-06-14 | 山东捷瑞数字科技股份有限公司 | JAVA code hot updating device and method |
CN115576589A (en) * | 2022-12-08 | 2023-01-06 | 平安银行股份有限公司 | Program hot updating method, electronic equipment and storage medium |
CN117806688A (en) * | 2024-03-01 | 2024-04-02 | 腾讯科技(深圳)有限公司 | Thermal update detection method, thermal update detection device, computer equipment and storage medium |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6463578B1 (en) * | 1999-11-23 | 2002-10-08 | International Business Machines Corporation | Systems, methods and computer program products for debugging java server page files using compiled java class file modifications |
CN102402427A (en) * | 2010-09-09 | 2012-04-04 | 阿里巴巴集团控股有限公司 | Method and device for updating Java application program |
CN109726052A (en) * | 2018-12-29 | 2019-05-07 | 北京金山安全软件有限公司 | Method and device for realizing server thermal repair and electronic equipment |
-
2019
- 2019-05-29 CN CN201910455888.0A patent/CN110262818A/en active Pending
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6463578B1 (en) * | 1999-11-23 | 2002-10-08 | International Business Machines Corporation | Systems, methods and computer program products for debugging java server page files using compiled java class file modifications |
CN102402427A (en) * | 2010-09-09 | 2012-04-04 | 阿里巴巴集团控股有限公司 | Method and device for updating Java application program |
CN109726052A (en) * | 2018-12-29 | 2019-05-07 | 北京金山安全软件有限公司 | Method and device for realizing server thermal repair and electronic equipment |
Non-Patent Citations (3)
Title |
---|
RUANJF: "JVM INSTRUMENT使用介绍", 《HTTPS:https://WWW.RUNJF.COM/JAVA/JVM-INSTRUMENT》 * |
未分配微服务: "如何热更新线上的Java服务器代码", 《HTTPS:https://WWW.SHUZHIDUO.COM/A/PRDBGGP7ZN/》 * |
高扬: "Java动态追踪技术探究", 《HTTPS:https://TECH.MEITUAN.COM/2019/02/28/JAVA-DYNAMIC-TRACE.HTML》 * |
Cited By (32)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110704082A (en) * | 2019-09-25 | 2020-01-17 | 许昌许继软件技术有限公司 | Continuous integration method and system for monitoring platform |
CN110780864A (en) * | 2019-10-30 | 2020-02-11 | 网易(杭州)网络有限公司 | Control method and device for class method replacement, storage medium and electronic equipment |
CN111061486A (en) * | 2019-12-10 | 2020-04-24 | 杭州有赞科技有限公司 | Android application program increment method |
CN111061486B (en) * | 2019-12-10 | 2022-06-24 | 杭州有赞科技有限公司 | Android application program increment method |
CN112988208B (en) * | 2019-12-18 | 2023-06-30 | 腾讯科技(深圳)有限公司 | Data updating method, device, equipment and storage medium |
CN112988208A (en) * | 2019-12-18 | 2021-06-18 | 腾讯科技(深圳)有限公司 | Data updating method, device, equipment and storage medium |
CN113268242A (en) * | 2020-02-17 | 2021-08-17 | 北京达佳互联信息技术有限公司 | Code compiling time length determining method and device, electronic equipment and storage medium |
CN111580813B (en) * | 2020-03-25 | 2022-09-02 | 博雅信安科技(北京)有限公司 | Automatic management method for Java class hot update |
CN111580813A (en) * | 2020-03-25 | 2020-08-25 | 博雅信安科技(北京)有限公司 | Automatic management method for Java class hot update |
CN111638907A (en) * | 2020-04-20 | 2020-09-08 | 北京达佳互联信息技术有限公司 | Method, device, terminal and storage medium for replacing third-party code segment |
CN112068875A (en) * | 2020-08-04 | 2020-12-11 | 广州太平洋电脑信息咨询有限公司 | System and method for realizing thread filtering strategy based on java dynamic loading |
CN112068875B (en) * | 2020-08-04 | 2024-05-17 | 广州太平洋电脑信息咨询有限公司 | System and method for realizing thread filtering strategy based on java dynamic loading |
CN112199110A (en) * | 2020-10-16 | 2021-01-08 | 上海睿成软件有限公司 | Restart-free operation and maintenance upgrading method, system, device and medium |
CN112199110B (en) * | 2020-10-16 | 2022-05-31 | 上海睿成软件有限公司 | Restart-free operation and maintenance upgrading method, system, device and medium |
CN112463303A (en) * | 2020-12-01 | 2021-03-09 | 中国工商银行股份有限公司 | JAVA virtual machine class loading method and system |
CN112463303B (en) * | 2020-12-01 | 2023-11-24 | 中国工商银行股份有限公司 | JAVA virtual machine class loading method and system |
CN112596772A (en) * | 2020-12-15 | 2021-04-02 | 上海米哈游网络科技股份有限公司 | Server updating method and device, electronic equipment and storage medium |
CN113110865A (en) * | 2021-04-21 | 2021-07-13 | 北京字跳网络技术有限公司 | Server hot updating method and device |
CN113127361B (en) * | 2021-04-23 | 2024-02-23 | 中国工商银行股份有限公司 | Application development method and device, electronic equipment and storage medium |
CN113127361A (en) * | 2021-04-23 | 2021-07-16 | 中国工商银行股份有限公司 | Application program development method and device, electronic equipment and storage medium |
CN113138787A (en) * | 2021-04-28 | 2021-07-20 | 中消云(北京)物联网科技研究院有限公司 | Program updating method and device |
CN113342323B (en) * | 2021-06-29 | 2024-03-29 | 银清科技有限公司 | Method and device for online development of software |
CN113342323A (en) * | 2021-06-29 | 2021-09-03 | 银清科技有限公司 | Method and device for software online development |
CN113553040A (en) * | 2021-07-20 | 2021-10-26 | 中国第一汽车股份有限公司 | Registration realization method, device, equipment and medium for visible and spoken identification function |
CN113553040B (en) * | 2021-07-20 | 2022-12-02 | 中国第一汽车股份有限公司 | Registration realization method, device, equipment and medium for visible and spoken identification function |
CN113867832B (en) * | 2021-09-15 | 2024-04-02 | 广州云徙科技有限公司 | Method, system, computer equipment and medium for dynamically modifying business data logic |
CN113867832A (en) * | 2021-09-15 | 2021-12-31 | 广州云徙科技有限公司 | Method, system, computer device and medium for dynamically modifying business data logic |
CN114416567A (en) * | 2022-01-20 | 2022-04-29 | 浙江吉利控股集团有限公司 | Application program access method and device |
CN114625397A (en) * | 2022-05-17 | 2022-06-14 | 山东捷瑞数字科技股份有限公司 | JAVA code hot updating device and method |
CN115576589A (en) * | 2022-12-08 | 2023-01-06 | 平安银行股份有限公司 | Program hot updating method, electronic equipment and storage medium |
CN117806688A (en) * | 2024-03-01 | 2024-04-02 | 腾讯科技(深圳)有限公司 | Thermal update detection method, thermal update detection device, computer equipment and storage medium |
CN117806688B (en) * | 2024-03-01 | 2024-05-28 | 腾讯科技(深圳)有限公司 | Thermal update detection method, thermal update detection device, computer equipment and storage medium |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110262818A (en) | The hot update method of Java code, device, electronic equipment and storage medium | |
CN105204894B (en) | The method and apparatus for installing the plug-in unit of smart machine | |
CN104951335B (en) | The processing method and processing device of application program installation kit | |
CN104281478B (en) | The method and device of more new application | |
CN104317648B (en) | A kind of method and apparatus of monitoring advertisement | |
CN109032606A (en) | The process of compilation method, apparatus and terminal of native applications program | |
CN107423106A (en) | The method and apparatus for supporting more frame grammars | |
CN109716736A (en) | Using data sharing and decision service platform | |
CN106201610A (en) | Web application accesses the method and device of the primary function of terminal | |
CN106528255B (en) | Kind loading method and device | |
CN105094830B (en) | A kind of method and apparatus of performance objective function | |
CN113342355B (en) | Code compiling method and device, electronic equipment and storage medium | |
CN113391811B (en) | Function compiling method, function compiling device, electronic equipment and computer readable storage medium | |
CN105335200B (en) | Method for upgrading system and device | |
CN104991857B (en) | Trace debug method and device | |
CN110287100A (en) | Adjustment method, device, electronic equipment and the storage medium of shader code | |
CN110851370B (en) | Program testing method and device and storage medium | |
CN104951337B (en) | File increment update method and device | |
CN111459494A (en) | Code processing method and device | |
CN109471714A (en) | Platform deployment method, apparatus, equipment and storage medium | |
KR102188685B1 (en) | Apparatas and method for generating application packages | |
CN111338961A (en) | Application debugging method and device, electronic equipment and storage medium | |
CN109522286A (en) | The treating method and apparatus of file system | |
CN117171000A (en) | Application program APP testing method and device, electronic equipment and storage medium | |
CN114546436A (en) | Micro front-end service updating method and device, electronic equipment and storage medium |
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 | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20190920 |
|
RJ01 | Rejection of invention patent application after publication |