WO2008069540A1 - Client system and method for managing a software version thereof - Google Patents

Client system and method for managing a software version thereof Download PDF

Info

Publication number
WO2008069540A1
WO2008069540A1 PCT/KR2007/006231 KR2007006231W WO2008069540A1 WO 2008069540 A1 WO2008069540 A1 WO 2008069540A1 KR 2007006231 W KR2007006231 W KR 2007006231W WO 2008069540 A1 WO2008069540 A1 WO 2008069540A1
Authority
WO
WIPO (PCT)
Prior art keywords
executable
version
pages
streaming
page
Prior art date
Application number
PCT/KR2007/006231
Other languages
French (fr)
Inventor
Won-Young Kim
Jeong-Min Shim
Wan Choi
Gyu Hyun Seo
Original Assignee
Electronics And Telecommunications Research Institute
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
Priority claimed from KR1020070107264A external-priority patent/KR100942695B1/en
Application filed by Electronics And Telecommunications Research Institute filed Critical Electronics And Telecommunications Research Institute
Publication of WO2008069540A1 publication Critical patent/WO2008069540A1/en
Priority to US12/477,128 priority Critical patent/US20090241101A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44521Dynamic linking or loading; Link editing at or after load time, e.g. Java class loading
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/70Software maintenance or management
    • G06F8/71Version control; Configuration management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44557Code layout in executable memory
    • G06F9/44563Sharing

Definitions

  • the present invention relates to a software version management method, and more particularly, to a streaming client system for managing multiple versions of software program provided undera software streaming environment, and a software version management method thereof.
  • Software streaming service is a technology to stream the code of a software program (or application program) from a streaming server and execute it on a streaming client in real-time without downloading and installation of the software program.
  • the streaming server has to perform a software program packing process for providing the software program, and the streaming client caches the streamed software program in order to improve quality of service.
  • FIG. 1 is a conceptual view illustrating the operation of a software streaming system according to the previous art, in which a streaming server 120 transmits streaming data to a streaming client 110 in order to provide a software streaming service.
  • a streaming client 110 connect with the streaming server 120 and requests executable pages (or executable codes) of a software program to be executed.
  • the streaming server 120 searches for and acquires the requested pages from the application packages 130 and provides the acquired executable pages to the streaming client 110.
  • the streaming client 110 can receive the executable pages of the software program from the streaming server 120 and execute the software program as if installed in the local system thereof without downloading and installing.
  • the streaming client 110 temporarily stores the executable page streamed from the streaming server 120 in a cache.
  • FIG. 2 is a view illustrating executable code of the previousart, which provide two versions of a software program.
  • an executable code 210 includes execution files necessary to execute a version 1.0 (SW V 1.0) of the software program, and an executable code 220 includes execution files necessary to execute another version 1.1 (SW Vl.1) of the software program.
  • V 1.0 and the executable code 220 of the SW Vl.1 are composed of the same executable files except for /sw/swl.dat 221 and /sw/config/back/dat files 222.
  • a streaming client should receive the whole executable code of a new version from a streaming server although the streaming client already received and cached the partially redundant code of the previous version.
  • the previous art not only has transmission overhead but also has storage overhead caused by the redundant code.
  • a software streaming service of the new version can be started after then that of the previous version should be stopped and/or the executable code of the previous version should be removed.
  • a streaming client system comprising: an executable page storage for sharing common executable pages of a prior version and a new version, additionally streaming and storing executable pages added or modified in the new version in order to support execution of software program having multiple versions; and an executable page searcher for searching and providing executable pages of the prior version for a necessary executable page during execution of prior version of software, and searching and providing the shared common executable pages and the added or modified executable pages for a necessary executable page during execution of a new version of software.
  • a streaming client system comprising: an executable page storage for sharing common executable pages of a prior version and a new version, additionally storing executable pages added or modified in the new version of software, and deleting part of executable pages which are used only in the prior version, in order to support only the new version; and an executable page searcher for searching the executable pages for a necessary executable page to execute the new version of software.
  • a software program version management method of a streaming client system comprising: (a) streaming executable pages of a prior version in order to service the prior version of software; (b) in response to a request for addition of a new version of software, sharing common executable pages of the prior version and the new version, additionally streaming and storing executable pages added or modified in the new version; and (c) executing the prior version of software program with reference to the executable pages of the prior version or executing the new version of software program with reference to both the shared executable pages and the added or modified executable pages.
  • a software program version management method of a streaming client system comprising: (a) streaming executable pages of a prior version of software, which are necessary for servicing the prior version; (b) sharing part of the executable pagesof the prior version which are in common with a new version of software, additionally streaming and storing added or modified executable pages of the new version; and (c) deleting part of the executable pages of the prior version which are necessary for executing only the prior version after terminating execution of the prior version of software.
  • the streaming client system and the software version management method thereof share most of the executable pages of a previous version and additionally receive only a specific part of the information of changed or added files via streaming in order to update the version of a software program program.
  • the transmission overhead can be prevented and the streaming client can use a storage area with improved efficiency. Furthermore, the software programs can be updated without interruption of the previous version program service. [31]
  • FIG. 1 is a conceptual view illustrating the operation of a software streaming system of the previous art
  • FIG. 2 is a view illustrating executable pages of the previous art, which provide two versions of a software program
  • FIG. 3 is a block diagram illustrating the architecture of a streaming client system according to the invention.
  • FIG. 4 is diagram illustrating the structures of the executable page provider according to the invention.
  • FIG. 5 is a view illustrating executable pages according to the invention, which provide two versions of a software program
  • FIG. 6 is a flowchart illustrating a software version management method according to an embodiment of the invention.
  • FIG. 7 is a flowchart illustrating a software version management method according to another embodiment of the invention.
  • FIG. 3 is a block diagram illustrating the architecture of a streaming client system
  • the streaming client system 300 includes an executable page provider 310, a software program streamer 320 and a software program processor 333.
  • the executable page provider 310 includes an executable page searcher 311 and an executable page storage 312, and inputs and outputs the executable pages using a cache technique.
  • the executable page provider 310 composes executable pages of a new version by reusing preexisting executable pages, which were streamed for a previous version of the software program.
  • the software program streamer 320 detects a user request, it connects with a streaming server and receives a program code streamed therefrom, and controls the operation of the executable page provider 310.
  • the software program streamer 320 checks whether a previous version of the software program is present in local system or not. If the previous version is not present, the software program streamer 320 receives entire first executable pages from the streaming server. On the other hand, if the previous version is present, the software program streamer 320 connects with the streaming server and confirms whether the version of the software program is updated or not. If the version of the software program is updated, the software program streamer 320 receives second executable pages which is corresponding to a new version and added or modified with respect to the previous version.
  • the software program streamer 320 When the user makes a request to delete the previous version in order to use only the new version, the software program streamer 320 notifies the delete request to the executable page provider 310, so that the executable pages corresponding to only the previous version can be deleted.
  • the software program processor 333 executes the previous version of the software program with reference to first executable pages only, and executes the new version of software program with reference to first and second executable pages.
  • FIG.4 is diagram illustrating the structures of the executable page provider according to the invention, in which (a) shows the structure in the case where only a previous version of a software program is present, (b) shows the structure in the case where the previous version is present together with a new version, and (c) shows the structure in the case where only the new version is present.
  • the executable page storage 312 of the executable page provider 310 includes first executable pages 312-1 corresponding to the previous version and first streaming state information 312-2 informing respective streaming state of the first executable pages 312-1.
  • the executable page searcher 311 comprises only a first executable page searcher 311-1, which searches the first executable pages 312-1 to be necessary for executing the previous version.
  • a second executable page searcher 311-2 and second streaming state information 312-4 which in common correspond to the first and second executable page 312-1 and 312-3, are additionally generated. And then information of the first streaming state information 312-2 and the first executable page searcher 311-1 is reflected for a corresponding one of the second executable page searcher 311-2 and the second streaming state information 312-4, respectively.
  • the first streaming state information 312-2 and the first executable page searcher 311-1 are deleted, and part of first the executable pages 312-1, which have been used by only the first executable page searcher 311-1, are also deleted. That is, a part of the executable pages, which are necessary to execute only the previous version, are deleted.
  • FIG. 6 is a flowchart illustrating a software version management method according to an embodiment of the invention, by which a streaming client can service multiple versions of software program.
  • the streaming client checks whether a previous version of software program is present in local system thereof or not, in SlOl.
  • the streaming client receives an initial streaming information including all executable pages of the previous version streamed from streaming server, in S 102. [66] And then, the streaming client generates an executable page provider 310 having a structure as shown in (a) of FIG. 4 based on the initial streaming information and initializes the executable page provider 310 in S 103. In S 106, the streaming client acquires necessary executable pages using theexecutable page provider 310 and executes the previous version of software program based on the acquired executable pages.
  • the streaming client provides the currently used version number to the streaming server and brings update information including added or modified executable pages in a new version from streaming server, in S 104.
  • the structure of the executable page provider 310 is changed as shown in
  • FIG. 7 is aflowchart illustrating a software version management method according to another embodiment of the invention, by which a streaming client can service only a new version of software program.
  • the streaming client When a user makes a request for a software program service, the streaming client notifies a previous version of software program to a streaming server and checks whether software program has been updated or not through the streaming server, in
  • the streaming client executes the previous version of software program by using an executable page provider 310 having a structure, in S207.
  • the streaming client receives update information including added or modified executable pages in a new version from streaming sever in S202, and modifies the structure of theexecutable page provider as shown in of FIG. 4Bbased on the newly-provided update information and the existing structure thereof, in S203.
  • the streaming client checks whether the previous version of software program is executing in S204, and stands by until execution of the previous version of software program terminates in S205.
  • the streaming client deletes all information of the previous version which is necessary to execute only the previous version, and then modifies the structure of the executable page provider as shown in of FIG. 4C in S206. That is, there remains only the information of the new version of software program.
  • the invention can prevent generation of transmission overhead, minimize consumption of a storage area in order to store multiple versions of software program, and add a version of software program without having to interrupt the service of the software program.

Abstract

A streaming client system for managing multiple versions of a software program and a software version management method thereof. An executable page storage storing executable pages of a previous version only corresponded to the previous version or shared by the previous version and a new version, and executable pages added or modified in the new version, An executable page searcher searching and providing a necessary executable page with reference to executable pages of the previous version when a software program of the previous version is executed, and searching and providing the necessary executable page with reference to both the shared executable pages and the added or modified executable pages when the software program of the new version is executed. Transmission overhead is minimized, a storage area is optimized, and software version can be updated without service interruption.

Description

Description
CLIENT SYSTEM AND METHOD FOR MANAGING A SOFTWARE VERSION THEREOF
Technical Field
[I] The present invention relates to a software version management method, and more particularly, to a streaming client system for managing multiple versions of software program provided undera software streaming environment, and a software version management method thereof.
[2] This work was supported by the ITR&D program of MIC/IITA [2005-S-007-02, A
Development of Open Software Based On-Demand Officeware Deployment Technologies].
[3]
Background Art
[4] Software streaming service is a technology to stream the code of a software program (or application program) from a streaming server and execute it on a streaming client in real-time without downloading and installation of the software program.
[5]
[6] In order to provide the software streaming service, the streaming server has to perform a software program packing process for providing the software program, and the streaming client caches the streamed software program in order to improve quality of service.
[7] FIG. 1 is a conceptual view illustrating the operation of a software streaming system according to the previous art, in which a streaming server 120 transmits streaming data to a streaming client 110 in order to provide a software streaming service.
[8] A streaming client 110 connect with the streaming server 120 and requests executable pages (or executable codes) of a software program to be executed. The streaming server 120 searches for and acquires the requested pages from the application packages 130 and provides the acquired executable pages to the streaming client 110.
[9] In this way, the streaming client 110 can receive the executable pages of the software program from the streaming server 120 and execute the software program as if installed in the local system thereof without downloading and installing.
[10]
[I I] Here, in order to speed up a software program execution, the streaming client 110 temporarily stores the executable page streamed from the streaming server 120 in a cache.
[12] Generally, since software programs are always updated, there are multiple versions for the same software program.
[13]
[14] FIG. 2 is a view illustrating executable code of the previousart, which provide two versions of a software program.
[15] Referring to FIG. 2, an executable code 210 includes execution files necessary to execute a version 1.0 (SW V 1.0) of the software program, and an executable code 220 includes execution files necessary to execute another version 1.1 (SW Vl.1) of the software program.
[16] In this case, however, it can be understood that the executable code 210 of the SW
V 1.0 and the executable code 220 of the SW Vl.1 are composed of the same executable files except for /sw/swl.dat 221 and /sw/config/back/dat files 222.
[17]
Disclosure of Invention Technical Problem
[18] According to the previousart as above, a streaming client should receive the whole executable code of a new version from a streaming server although the streaming client already received and cached the partially redundant code of the previous version. The previous art not only has transmission overhead but also has storage overhead caused by the redundant code.
[19] Furthermore, when a user attempts to replace the previous version with a new version, a software streaming service of the new version can be started after then that of the previous version should be stopped and/or the executable code of the previous version should be removed.
[20]
Technical Solution
[21] According to an aspect of the present invention, there is provided a streaming client system comprising: an executable page storage for sharing common executable pages of a prior version and a new version, additionally streaming and storing executable pages added or modified in the new version in order to support execution of software program having multiple versions; and an executable page searcher for searching and providing executable pages of the prior version for a necessary executable page during execution of prior version of software, and searching and providing the shared common executable pages and the added or modified executable pages for a necessary executable page during execution of a new version of software. [22]
[23] According to another aspect of the present invention, there is provided a streaming client system comprising: an executable page storage for sharing common executable pages of a prior version and a new version, additionally storing executable pages added or modified in the new version of software, and deleting part of executable pages which are used only in the prior version, in order to support only the new version; and an executable page searcher for searching the executable pages for a necessary executable page to execute the new version of software.
[24]
[25] According to a further aspect of the present invention, there is provided a software program version management method of a streaming client system, comprising: (a) streaming executable pages of a prior version in order to service the prior version of software; (b) in response to a request for addition of a new version of software, sharing common executable pages of the prior version and the new version, additionally streaming and storing executable pages added or modified in the new version; and (c) executing the prior version of software program with reference to the executable pages of the prior version or executing the new version of software program with reference to both the shared executable pages and the added or modified executable pages.
[26]
[27] According to yet another aspect of the present invention, there is provided a software program version management method of a streaming client system, comprising: (a) streaming executable pages of a prior version of software, which are necessary for servicing the prior version; (b) sharing part of the executable pagesof the prior version which are in common with a new version of software, additionally streaming and storing added or modified executable pages of the new version; and (c) deleting part of the executable pages of the prior version which are necessary for executing only the prior version after terminating execution of the prior version of software.
[28]
Advantageous Effects
[29] According to the invention as set forth above, the streaming client system and the software version management method thereof share most of the executable pages of a previous version and additionally receive only a specific part of the information of changed or added files via streaming in order to update the version of a software program program.
[30] Accordingly, the transmission overhead can be prevented and the streaming client can use a storage area with improved efficiency. Furthermore, the software programs can be updated without interruption of the previous version program service. [31]
Brief Description of the Drawings
[32] FIG. 1 is a conceptual view illustrating the operation of a software streaming system of the previous art;
[33] FIG. 2 is a view illustrating executable pages of the previous art, which provide two versions of a software program;
[34] FIG. 3 is a block diagram illustrating the architecture of a streaming client system according to the invention;
[35] FIG. 4 is diagram illustrating the structures of the executable page provider according to the invention;
[36] FIG. 5 is a view illustrating executable pages according to the invention, which provide two versions of a software program;
[37] FIG. 6 is a flowchart illustrating a software version management method according to an embodiment of the invention; and
[38] FIG. 7 is a flowchart illustrating a software version management method according to another embodiment of the invention.
[39]
Best Mode for Carrying Out the Invention
[40] Hereinafter the present invention will be described more fully with reference to the accompanying drawings, in which exemplary embodiments thereof are shown, so that those skilled in the art can more clearly understand the invention. In the following description of the present invention, a detailed description of known functions and components incorporated herein will be omitted when it may make the subject matter of the present invention rather unclear.
[41] Reference now should be made to the drawings, in which the same reference numerals or symbols are used throughout the different drawings to designate the same or similar components.
[42]
[43] FIG. 3 is a block diagram illustrating the architecture of a streaming client system
300 according to the invention.
[44] Referring to FIG. 3, the streaming client system 300 includes an executable page provider 310, a software program streamer 320 and a software program processor 333. The executable page provider 310 includes an executable page searcher 311 and an executable page storage 312, and inputs and outputs the executable pages using a cache technique.
[45] In the case of software program update, the executable page provider 310 composes executable pages of a new version by reusing preexisting executable pages, which were streamed for a previous version of the software program.
[46] That is, when a software program is streamed for the first time, first executable pages thereof are entirely streamed down and then stored. However, in the case of the software program is updated, entire executable pages of a new version are not streamed down. Rather, only second executable pages, having different information from the previous version of the software program, are streamed down and stored, and part of the first executable pages of the previous version in common with the new version are shared.
[47] In the case of deleting the previous version to support only the new version, part of the executable pages of the previous version, which are only necessary for executing the previous version, are deleted. That is, except for first and second executable pages, which are necessary to execute the new version, the rest of the executable pages are deleted in order to improve the efficiency of a memory.
[48] When the software program streamer 320 detects a user request, it connects with a streaming server and receives a program code streamed therefrom, and controls the operation of the executable page provider 310.
[49] More particularly, when the user requests an execution of the software program program, the software program streamer 320 checks whether a previous version of the software program is present in local system or not. If the previous version is not present, the software program streamer 320 receives entire first executable pages from the streaming server. On the other hand, if the previous version is present, the software program streamer 320 connects with the streaming server and confirms whether the version of the software program is updated or not. If the version of the software program is updated, the software program streamer 320 receives second executable pages which is corresponding to a new version and added or modified with respect to the previous version.
[50] When the user makes a request to delete the previous version in order to use only the new version, the software program streamer 320 notifies the delete request to the executable page provider 310, so that the executable pages corresponding to only the previous version can be deleted.
[51] The software program processor 333 executes the previous version of the software program with reference to first executable pages only, and executes the new version of software program with reference to first and second executable pages.
[52]
[53] FIG.4 is diagram illustrating the structures of the executable page provider according to the invention, in which (a) shows the structure in the case where only a previous version of a software program is present, (b) shows the structure in the case where the previous version is present together with a new version, and (c) shows the structure in the case where only the new version is present.
[54] First, referring to (a), when only the previous version is present, the executable page storage 312 of the executable page provider 310 includes first executable pages 312-1 corresponding to the previous version and first streaming state information 312-2 informing respective streaming state of the first executable pages 312-1. The executable page searcher 311 comprises only a first executable page searcher 311-1, which searches the first executable pages 312-1 to be necessary for executing the previous version.
[55] That is, when the software program is executed and streamed for the first time, the first executable page searcher 311-1 and the first streaming state information 312-2 are generated and then initialized.
[56] Next, when the first executable pages 312-1 are received, the first streaming state information 312-2 corresponding to the received executable pages is changed from "0" to "l,"and the received executable pages 312-1 are added through the first executable page searcher 311-1.
[57] In this state, when a new version is added and streamed, the structure of the executable page provider 310 is changed as shown in of (b).
[58] That is, when the new version is streamed, a second executable page searcher 311-2 and second streaming state information 312-4, which in common correspond to the first and second executable page 312-1 and 312-3, are additionally generated. And then information of the first streaming state information 312-2 and the first executable page searcher 311-1 is reflected for a corresponding one of the second executable page searcher 311-2 and the second streaming state information 312-4, respectively.
[59] When the executable pages 312-3 are received, the streaming state information
312-4 corresponding to the received executable pages 312-3 are changed from "0" to " 1," and the received executable pages 312-3 are added through the executable page searcher 311.
[60] In this state, when the previous version is deleted so that only the new version can be used, the structure of the executable page provider 310 is changed again as shown in
(C).
[61] When a request to delete the previous version of the software program is made, the first streaming state information 312-2 and the first executable page searcher 311-1 are deleted, and part of first the executable pages 312-1, which have been used by only the first executable page searcher 311-1, are also deleted. That is, a part of the executable pages, which are necessary to execute only the previous version, are deleted.
[62] Accordingly, there remain the second executable page searcher 311-2, the second executable pages 312-3 and the second streaming state information 312-4 of the new version and the first executable pages 312-1' of the previous version which are necessary for executing the new version. [63] FIG. 6 is a flowchart illustrating a software version management method according to an embodiment of the invention, by which a streaming client can service multiple versions of software program. [64] When a user makes a request for a software program service, the streaming client checks whether a previous version of software program is present in local system thereof or not, in SlOl. [65] If the previous version is not present in the streaming client, that is, it is the first time to execute the software program, the streaming client receives an initial streaming information including all executable pages of the previous version streamed from streaming server, in S 102. [66] And then, the streaming client generates an executable page provider 310 having a structure as shown in (a) of FIG. 4 based on the initial streaming information and initializes the executable page provider 310 in S 103. In S 106, the streaming client acquires necessary executable pages using theexecutable page provider 310 and executes the previous version of software program based on the acquired executable pages. [67] On the contrary, if the previous version of the user requested- software program is present in the streaming client, the streaming client provides the currently used version number to the streaming server and brings update information including added or modified executable pages in a new version from streaming server, in S 104. [68] In S 105, the structure of the executable page provider 310 is changed as shown in
(b) of FIG. 4 based on the executable page provider 310 generated in the step S 103 and the update information, received from the streaming server. [69] In S 106, necessary executable pages are acquired using a new page searcher 314 and the software program is executed based on the acquired executable pages. [70] Accordingly, the invention can prevent generation of transmission overhead and also minimize consumption of a storage area in order to store multiple versions of software program. [71] [72] FIG. 7 is aflowchart illustrating a software version management method according to another embodiment of the invention, by which a streaming client can service only a new version of software program. [73] When a user makes a request for a software program service, the streaming client notifies a previous version of software program to a streaming server and checks whether software program has been updated or not through the streaming server, in
S201. [74] If there is no new version, the streaming client executes the previous version of software program by using an executable page provider 310 having a structure, in S207.
[75] If there is a new version, the streaming client receives update information including added or modified executable pages in a new version from streaming sever in S202, and modifies the structure of theexecutable page provider as shown in of FIG. 4Bbased on the newly-provided update information and the existing structure thereof, in S203.
[76] Then, the streaming client checks whether the previous version of software program is executing in S204, and stands by until execution of the previous version of software program terminates in S205. When execution of the previous version of software program terminates, the streaming client deletes all information of the previous version which is necessary to execute only the previous version, and then modifies the structure of the executable page provider as shown in of FIG. 4C in S206. That is, there remains only the information of the new version of software program.
[77] Accordingly, the invention can prevent generation of transmission overhead, minimize consumption of a storage area in order to store multiple versions of software program, and add a version of software program without having to interrupt the service of the software program.
[78] While the present invention has been shown and described in connection with the exemplary embodiments and the accompanying drawings, it will be apparent to those skilled in the art that substitutions, modifications and variations can be made without departing from the spirit and scope of the invention.
[79]

Claims

Claims
[1] A streaming client system comprising: an executable page storage for sharing common executable pages of a prior version and a new version, additionally streaming and storing executable pages added or modified in the new version in order to support execution of software program having multiple versions; and an executable page searcher for searching and providing executable pages of the prior version for a necessary executable page during execution of prior version of software, and searching and providing the shared common executable pages and the added or modified executable pages for a necessary executable page during execution of a new version of software.
[2] the streaming client system of claim 1, wherein the executable page storage includes: the executable pages of the prior version, which is corresponding to the prior version of software; streaming state information of the prior version, which informs streaming state of each of the executable pages of the prior version; the added or modified executable pages of the new version, information of which is corresponding to the new version of software program and added or modified with respect to the prior version; and streaming state information of the new version, which informs streaming state of each of the shared executable pages and the added or modified executable pages.
[3] the streaming client system of claim 1, wherein the executable page searcher includes: a prior version executable page searcher for searching the executable pages of the prior version for the necessary executable page to execute the prior version of software; and a new version executable page searcher for searching the shared executable pages and the added or modified executable pages for the necessary executable page to execute the new version of software.
[4] A streaming client system comprising: an executable page storage for sharing common executable pages of a prior version and a new version, additionally storing executable pages added or modified in the new version of software, and deleting part of executable pages which are used only in the prior version, in order to support only the new version; and an executable page searcher for searching the executable pages for a necessary executable page to execute the new version of software.
[5] the streaming client system of claim 4, wherein the executable page storage includes: the executable pages being shared by the prior version and the new version or added or modified in the new version; and streaming state information informing respective streaming state of executable pages in the executable page storage.
[6] the streaming client system of claim 4, wherein the executable page storage deletes the executable pages which are used only in the prior version after execution of the prior version of software program is terminated.
[7] A software program version management method of a streaming client system, comprising:
(a) streaming executable pages of a prior version in order to service the prior version of software;
(b) in response to a request for addition of a new version of software, sharing common executable pages of the prior version and the new version, additionally streaming and storing executable pages added or modified in the new version; and
(c) executing the prior version of software program with reference to the executable pages of the prior version or executing the new version of software program with reference to both the shared executable pages and the added or modified executable pages.
[8] the software program version management method of claim 7, wherein the step
(a) comprises: generating and initializing an executable page searcher and executable page streaming information of the prior version corresponding to the executable pages of the prior version; connecting with a streaming server and receiving the executable pages of the prior version, streamed from the streaming server; and registering the executable pages of the prior version in the executable page searcher of the prior version.
[9] the software program version management method of claim 8, wherein the step
(b) comprises: generating and initializing an executable page searcher and executable page streaming information of the new version corresponding to both the shared executable pages and the added or modified executable pages, and reflecting information of the executable page searcher and executable page streaming information of the prior version to the initialized executable page searcher and executable page streaming information of the new version; receiving only the added or modified executable pages, streamed from the streaming server; and registering the added or modified executable pages in the executable page searcher of the prior version.
[10] A software program version management method of a streaming client system, comprising:
(a) streaming executable pages of a prior version of software, which are necessary for servicing the prior version;
(b) sharing part of the executable pagesof the prior version which are in common with a new version of software, additionally streaming and storing added or modified executable pages of the new version; and
(c) deleting part of the executable pages of the prior version which are necessary for executing only the prior version after terminating execution of the prior version of software.
[11] the software program version management method of claim 10, wherein the step
(a) comprises: generating and initializing an executable page searcher and executable page streaming information of the prior version corresponding to the executable pages of the prior version; receiving the executable pages of the prior version, streamed from a software program streaming server; and adding the executable pages of the prior version through the executable page searcher of the prior version.
[12] the software program version management method of claim 11, wherein the step
(b) comprises: generating and initializing an executable page searcher and executable page streaming information of the new version corresponding to both the shared executable pages and the added or modified executable pages, and the n reflecting the executable page searcher and executable page streaming information of the prior version to the initialized executable page searcher and executable page streaming information of new version; receiving only the added or modified executable pages, streamed from the streaming server; and adding the added or modified executable pages through the executable page searcher of the new version.
[13] the software program version management method of claim 10 or 11, wherein the step (c) comprises: when the prior version of software program is executing, stand ing by until execution of software program is terminated; and when the execution of software program is terminated, deleting the executable page searcher and executable page streaming information of the prior version which are necessary to execute only the prior version.
PCT/KR2007/006231 2006-12-04 2007-12-04 Client system and method for managing a software version thereof WO2008069540A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US12/477,128 US20090241101A1 (en) 2006-12-04 2009-06-03 Client system and method for managing a software version thereof

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
KR10-2006-0121313 2006-12-04
KR20060121313 2006-12-04
KR1020070107264A KR100942695B1 (en) 2006-12-04 2007-10-24 Client system and method for managing a software version thereof
KR10-2007-0107264 2007-10-24

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US12/477,128 Continuation US20090241101A1 (en) 2006-12-04 2009-06-03 Client system and method for managing a software version thereof

Publications (1)

Publication Number Publication Date
WO2008069540A1 true WO2008069540A1 (en) 2008-06-12

Family

ID=39492353

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/KR2007/006231 WO2008069540A1 (en) 2006-12-04 2007-12-04 Client system and method for managing a software version thereof

Country Status (1)

Country Link
WO (1) WO2008069540A1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100942695B1 (en) 2006-12-04 2010-02-16 한국전자통신연구원 Client system and method for managing a software version thereof

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR19990001093A (en) * 1997-06-12 1999-01-15 윤종용 Operating program and database installation method of exchange system
KR20000030530A (en) * 2000-03-06 2000-06-05 신명섭 Method for providing the most recent software on internet and computer-readable medium recording the method
KR20030016984A (en) * 2001-08-23 2003-03-03 엘지전자 주식회사 Apparatus and method for updating version of system software in communication terminal
KR20050040305A (en) * 2003-10-28 2005-05-03 주식회사 팬택 Software update method of mobile station
KR20050123360A (en) * 2004-06-25 2005-12-29 주식회사 팬택 Software up-grade method for mobile handset

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR19990001093A (en) * 1997-06-12 1999-01-15 윤종용 Operating program and database installation method of exchange system
KR20000030530A (en) * 2000-03-06 2000-06-05 신명섭 Method for providing the most recent software on internet and computer-readable medium recording the method
KR20030016984A (en) * 2001-08-23 2003-03-03 엘지전자 주식회사 Apparatus and method for updating version of system software in communication terminal
KR20050040305A (en) * 2003-10-28 2005-05-03 주식회사 팬택 Software update method of mobile station
KR20050123360A (en) * 2004-06-25 2005-12-29 주식회사 팬택 Software up-grade method for mobile handset

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100942695B1 (en) 2006-12-04 2010-02-16 한국전자통신연구원 Client system and method for managing a software version thereof

Similar Documents

Publication Publication Date Title
US10298670B2 (en) Real time cloud workload streaming
US7133933B2 (en) Content synchronization frameworks using dynamic attributes and file bundles for connected devices
US7721003B2 (en) System and method to synchronize OSGi bundle inventories between an OSGi bundle server and a client
CN102185928B (en) Method for creating virtual machine in cloud computing system and cloud computing system
JP5319685B2 (en) Software deployment in large networked systems
US6738801B1 (en) Master server facilitating communication between slave servers in incompatible data formats, and method for upgrading slave servers
US7680844B2 (en) Method for preserving virtual filesystem information across high availability takeover
US8838770B2 (en) Handling a service request in a hybrid computer system
US7849156B2 (en) Method, apparatus and computer program product for discovering and prioritizing patterns of component usage in a virtual application container for enhancing prefetching
JP2002536714A (en) Predefined hardware and software bundles provided for database applications
US20020184618A1 (en) Networked client-server architecture for transparently transforming and executing applications
US9122649B2 (en) Handling cross-platform system call with shared page cache in hybrid system
US20080201406A1 (en) Feature manager system for facilitating communication and shared functionality among components
US7650609B2 (en) Multi-environment document management system access
US7440971B2 (en) Context based access of files by file system to a client based on detection of related files opened by the client
JP2004533687A (en) Dynamic deployment of services in computer networks
KR100936239B1 (en) System And Method For Providing Portable SW With Streaming
US20070011274A1 (en) Data transfer in a multi-environment document management system access
WO2009117921A1 (en) Distributed network management system, network management server and method
WO2012054218A2 (en) Routing traffic in an online service with high availability
CN111158851B (en) Rapid deployment method of virtual machine
US20090241101A1 (en) Client system and method for managing a software version thereof
CN102420873A (en) Compound network brand new cloud application platform
CN101557390A (en) Method for improving system performance by flexibly using cache technology
WO2008069540A1 (en) Client system and method for managing a software version thereof

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 07851222

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

122 Ep: pct application non-entry in european phase

Ref document number: 07851222

Country of ref document: EP

Kind code of ref document: A1