[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

KR20150057383A - Method of providing cloud service for managing remote simulation processes by file system commands - Google Patents

Method of providing cloud service for managing remote simulation processes by file system commands Download PDF

Info

Publication number
KR20150057383A
KR20150057383A KR1020130140700A KR20130140700A KR20150057383A KR 20150057383 A KR20150057383 A KR 20150057383A KR 1020130140700 A KR1020130140700 A KR 1020130140700A KR 20130140700 A KR20130140700 A KR 20130140700A KR 20150057383 A KR20150057383 A KR 20150057383A
Authority
KR
South Korea
Prior art keywords
simulation
active folder
activity
folder
server
Prior art date
Application number
KR1020130140700A
Other languages
Korean (ko)
Other versions
KR102205651B1 (en
Inventor
황선태
허대영
Original Assignee
국민대학교산학협력단
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 국민대학교산학협력단 filed Critical 국민대학교산학협력단
Priority to KR1020130140700A priority Critical patent/KR102205651B1/en
Publication of KR20150057383A publication Critical patent/KR20150057383A/en
Priority to KR1020210003916A priority patent/KR102348354B1/en
Application granted granted Critical
Publication of KR102205651B1 publication Critical patent/KR102205651B1/en

Links

Images

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/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • G06F30/20Design optimisation, verification or simulation
    • 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/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/30076Arrangements for executing specific machine instructions to perform miscellaneous control operations, e.g. NOP
    • G06F9/30087Synchronisation or serialisation instructions
    • 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/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5061Partitioning or combining of resources
    • G06F9/5072Grid computing
    • 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/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/45591Monitoring or debugging support

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Computer Hardware Design (AREA)
  • Evolutionary Computation (AREA)
  • Geometry (AREA)
  • Mathematical Physics (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

A method for providing a cloud service for managing remote simulation processes is executed in an active folder system in which a user terminal, an active folder server, and a cloud server are connected to each other. The method includes the steps of: (a) registering metadata, related to simulation, in an active folder, which maps a metadata model into a folder and a file of a file system, of the active folder server, after receiving the metadata from the user terminal; (b) generating activity, which defines a simulation plan, by manipulating the received metadata according to a file system command received by the terminal user; and (c) executing the generated activity in the cloud server assigned by the active folder server. Accordingly, a user of the cloud service can focus more on generating, utilizing, and managing research data instead of calculating data.

Description

원격 시뮬레이션 과정을 관리하는 클라우드 서비스 제공 방법{METHOD OF PROVIDING CLOUD SERVICE FOR MANAGING REMOTE SIMULATION PROCESSES BY FILE SYSTEM COMMANDS}TECHNICAL FIELD [0001] The present invention relates to a method of providing a cloud service for managing a remote simulation process,

본 발명은 클라우드 서비스 제공 기술에 관한 것으로, 보다 상세하게는, 파일 시스템 명령으로 원격 시뮬레이션 과정을 관리할 수 있는 클라우드 서비스 제공 방법에 관한 것이다.
The present invention relates to a cloud service providing technology, and more particularly, to a cloud service providing method capable of managing a remote simulation process by a file system command.

컴퓨터의 성능의 발전으로 데이터가 양적, 질적으로 팽창함에 따라 과학자는 문제를 해결하는 것뿐만 아니라, 연구 데이터의 신뢰성과 안정성을 확보하는 노력이 중요해졌다. 그러나 기존의 문제 해결 환경은 문제를 해결하는 알고리즘이나 모델을 적용하는 방법에 있어서 절차 중심적 관점으로 구현되어 왔다. 즉, 기존의 연구에서 데이터는 계산 결과와 그 계산을 위해 필요한 입력 정보로만 인식되어 왔다. 하지만 과학자에게 가장 중요한 것은 계산 자체 보다는 데이터이다.
As the performance of computers has been expanding both quantitatively and qualitatively, it has become important for scientists not only to solve problems, but also to ensure the reliability and stability of research data. However, the existing problem solving environment has been implemented from the procedural viewpoint in the problem solving algorithm and the method of applying the model. In other words, in the existing research, data has been recognized only as calculation information and input information necessary for its calculation. But the most important thing for a scientist is data rather than computation itself.

도 1은 종래의 문제 해결 환경에 대한 개념도이다.1 is a conceptual diagram of a conventional problem solving environment.

도 1을 참조하면, 기존의 과학 계산을 이용한 연구는 “어떤 문제를 어떤 알고리즘이나 모델을 적용하여 풀 것인가?”에 사고가 중심이 되어 있다. 따라서 종래의 문제 해결 환경(100)은 문제를 풀기 위한 절차적인 관점에서 구축되어 왔다.Referring to FIG. 1, the existing research using scientific computation is centered on "what problem is solved by applying an algorithm or a model?". Thus, the prior art problem solving environment 100 has been constructed from a procedural point of view to solve the problem.

문제를 풀기 위해서 사용했던 알고리즘이나 모델들은 데이터를 생성하기 위한 도구이다. 문제 해결 환경은 이러한 도구들과 데이터 생성을 자동화할 수 있는 기획 기능들을 제공해야 한다.
The algorithms and models used to solve the problem are tools for generating data. The troubleshooting environment should provide these tools and planning functions to automate data generation.

퓨즈(FUSE : Filesystem in userspace)는 유닉스(Unix)와 같은 컴퓨터 운영 시스템을 위한 운영 시스템 매커니즘에 해당한다. 보다 구체적으로, 퓨즈는 운영 체제의 가상 파일 시스템으로 들어온 요청을 사용자 영역의 프로세스에 돌려주는 방식으로, 운영체제의 사용자 영역에서 파일 시스템의 기능을 구현할 수 있도록 한다. 퓨즈는 FTP(File transfer protocol), HTTP(Hypertext transfer protocol) 등과 같은 프로토콜로 제공되는 데이터도 운영체제의 사용자 영역에서 파일 시스템으로 전환하여 일반 파일처럼 접근이 가능하도록 한다. 즉, 레거시 소프트웨어(legacy software, 과거에 개발되어 현재에도 사용 중인 낡은 소프트웨어)가 소프트웨어 수정 없이 원격지에 있는 데이터를 직접 읽고 쓰는 것이 가능하다.FUSE (Filesystem in userspace) corresponds to the operating system mechanism for computer operating systems such as Unix. More specifically, the fuse allows the functionality of the file system to be implemented in the user area of the operating system, in a manner that returns requests to the operating system's virtual file system to the process of the user area. The fuse transfers data provided by protocols such as FTP (file transfer protocol) and HTTP (Hypertext transfer protocol) from the user area of the operating system to the file system so that it can be accessed like a normal file. In other words, legacy software (legacy software developed in the past and still in use today) can read and write data remotely without software modifications.

웹데브(WebDAV: Web-based Distributed Authoring and Versioning)는 인터넷 상에서 광범위하고 다양한 콘텐츠의 비동기적인 분산 저작 활동을 지원하기 위한 표준 프로토콜에 해당한다. 웹데브는 HTTP/1.1 프로토콜의 확장을 통하여 원거리에 있는 웹상의 자원을 편집하고 관리할 수 있는 하부 구조를 제공한다. 웹데브 접근 제어 프로토콜(WebDAV Access Control Protocol)은 웹데브 서버에 의해 관리되는 자원과 이들에 대한 속성/정보에 대한 접근을 임의적으로 제어할 수 있는 기능을 표준적으로 제공한다.Web-based Distributed Authoring and Versioning (WebDAV) is a standard protocol for supporting asynchronous distributed authoring of a wide variety of content over the Internet. WebDev provides an infrastructure for editing and managing resources on the web over the web through the extension of the HTTP / 1.1 protocol. The WebDAV Access Control Protocol provides a standard for arbitrarily controlling access to resources and their properties / information managed by the WebDAV server.

퓨즈는 네트워크 프로토콜을 파일시스템으로 변경하여 레거시 소프트웨어로 하여금 접근하게 할 수 있게 하고, 웹 데브는 원격지의 데이터들을 파일 개념으로 관리할 수 있게 한다. 그러나, 퓨즈와 웹데브는 데이터를 관리하기 위한 연산 외에 데이터를 생산하기 위한 계산 등의 복잡한 연산을 로컬 파일 시스템에서 표현하기에는 적합하지 않은 문제점이 있다.
The fuse changes the network protocol to a file system so that legacy software can be accessed, and the WebDev can manage the remote data in the file concept. However, there is a problem that fuses and web devs are not suitable for expressing complex operations such as calculation for producing data in a local file system in addition to operations for managing data.

“MGrid: 분자 시뮬레이션 그리드 시스템”, 정보과학회논문지, 시스템 및 이론 제33권 제7호, 2006.7, 380-389"MGrid: Molecular Simulation Grid System", Journal of the Institute of Information Science and Technology, 33 (7), 2006.7, 380-389 “시뮬레이션 데이터 공유 및 재 실험을 위한 Glyco-MGrid시스템”, 정보과학회 한국컴퓨터종합학술대회 논문집 제34권 제1호(B), 2007.6,"Glyco-MGrid System for Simulation Data Sharing and Re-experimentation", Journal of Korea Information Science Society, Vol.34 No. 1 (2007), 2007.6, “The anatomy of the grid” in International Journal of High Performance Computing Applications, Mar. 2001.&Quot; The anatomy of the grid &quot; in International Journal of High Performance Computing Applications, Mar. 2001. “Why and Where: A Characterization of Data Provenance” in 8th International Conference, Jan. 4-6, 2001."Why and Where: A Characterization of Data Provenance" in 8th International Conference, Jan. 4-6, 2001. “A Survey of Data Provenance in e-Science” in Journal of ACM Sigmod Record, Volume 34 Issue 3, Sep. 2005, 31-36"A Survey of Data Provenance in e-Science" in Journal of ACM Sigmod Record, Volume 34 Issue 3, Sep. 2005, 31-36 “Cloud Computing: Distributed Internet Computing for IT and Scientific Research”, in Internet Computing, IEEE, Sept. 2009,&Quot; Cloud Computing: Distributed Internet Computing for IT and Scientific Research &quot;, in Internet Computing, IEEE, Sept. 2009, "FUSE: Filesystem in Userspace," <http://fuse.sourceforge.net/>"FUSE: Filesystem in Userspace," <http://fuse.sourceforge.net/> "File Transfer Protocol," IETF RFC 959, 1985."File Transfer Protocol," IETF RFC 959, 1985. "Hypertext Transfer Protocol - HTTP/1.1," IETF RFC 2616, Standards"Hypertext Transfer Protocol - HTTP / 1.1," IETF RFC 2616, Standards Track, Jun. 1999.Track, Jun. 1999. "WEBDAV: IETF Standard for Collaborative Authoring on the Web," IEEE Internet Computing, pp.34-40, Sep./Oct. 1998."WEBDAV: IETF Standard for Collaborative Authoring on the Web," IEEE Internet Computing, pp. 34-40, Sep./Oct. 1998. "HTTP Extensions for Distributed Authoring - WEBDAV," IETF RFC 2518, Standards Track, Feb. 1999."HTTP Extensions for Distributed Authoring - WEBDAV," IETF RFC 2518, Standards Track, Feb. 1999. "Versioning extensions to WebDAV," IETF Internet Draft, Jan. 1999."Versioning extensions to WebDAV," IETF Internet Draft, Jan. 1999. "WebDAV Access Control Protocol," IETF WebDAV Working Group, Oct. 2003."WebDAV Access Control Protocol," IETF WebDAV Working Group, Oct. 2003. "Web Distributed Authoring and Versioning (WebDAV) Access Control Protocol," IETF RFC 3744, Standards Track, May 2004."Web Distributed Authoring and Versioning (WebDAV) Access Control Protocol," IETF RFC 3744, Standards Track, May 2004. "Cloud Computing: Distributed Internet Computing for IT and Scientific Research," in Internet Computing, IEEE, Sep. 2009."Cloud Computing: Distributed Internet Computing for IT and Scientific Research," in Internet Computing, IEEE, Sep. 2009. "The anatomy of the grid," in International Journal of High Performance Computing Applications, Mar. 2001."The anatomy of the grid, " in International Journal of High Performance Computing Applications, Mar. 2001. Dropbox <http://www.dropbox.com>Dropbox <http://www.dropbox.com> Google Drive <http://drive.google.com>Google Drive <http://drive.google.com>

본 발명은 사용자가 계산 보다는 연구 데이터를 생성, 활용, 관리하는 측면에 더욱 집중할 수 있는 데이터 중심의 문제 해결 환경을 위한 클라우드 서비스 제공 기술을 제공하고자 한다.The present invention intends to provide a cloud service providing technology for a data-based problem solving environment in which a user can concentrate more on the creation, utilization, and management of research data than calculation.

본 발명은 사용자가 문제 해결 환경을 새로 학습하고 사용하는 데 필요한 오버헤드를 최소화하기 위해서 문제 해결 환경 원격지에 있는 데이터를 관리할 수 있는 클라우드 서비스 제공 기술을 제공하고자 한다. The present invention intends to provide a cloud service providing technology capable of managing data in a remotely located troubleshooting environment in order to minimize the overhead required for a user to newly learn and use a problem solving environment.

실시예들 중에서 클라우드 서비스 제공 방법은 네트워크를 통해 상호 연결된 사용자 단말, 액티브 폴더 서버 및 클라우드 서버를 포함하는 액티브 폴더 시스템에서 수행된다. 클라우드 서비스 제공 방법은 네트워크를 통해 상호 연결된 사용자 단말, 액티브 폴더 서버 및 클라우드 서버를 포함하는 액티브 폴더 시스템에서 수행된다. 클라우드 서비스 제공 방법은 (a) 상기 사용자 단말을 통해 시뮬레이션과 연관된 메타데이터를 수신하여 액티브 폴더 서버의 액티브 폴더에 등록하는 단계 -상기 액티브 폴더는 메타데이터 모델을 파일 시스템의 폴더와 파일로 사상함-, (b) 상기 사용자 단말에서 수신된 파일 시스템 명령에 따라 상기 수신한 메타데이터를 조작하여 액티비티를 생성하는 단계 -상기 액티비티는 시뮬레이션 계획을 정의함- 및 (c) 상기 액티브 폴더 서버를 통해 할당된 클라우드 서버에서 상기 생성된 액티비티를 실행하는 단계를 포함한다.Among the embodiments, a method of providing a cloud service is performed in an active folder system including a user terminal, an active folder server, and a cloud server interconnected through a network. A cloud service providing method is performed in an active folder system including a user terminal, an active folder server, and a cloud server interconnected through a network. A method for providing a cloud service includes the steps of: (a) receiving metadata associated with a simulation through the user terminal and registering the metadata in an active folder of an active folder server, the active folder mapping a metadata model to a folder and a file in a file system, (b) generating an activity by manipulating the received metadata according to a file system command received at the user terminal, the activity defining a simulation plan; and (c) And executing the generated activity on the cloud server.

여기에서, 상기 액티비티는 폴더 형태로 나타나고, 스크립트를 포함하는 적어도 하나의 시뮬레이션 작업을 포함할 수 있다.Here, the activity may appear in a folder form and may include at least one simulation task that includes a script.

일 실시예에서, 상기 클라우드 서비스 제공 방법은 (d) 상기 액티비티의 실행이 종료되면, 결과 파일을 액티브 폴더에 프로덕트로 출력하는 단계를 더 포함할 수 있다. 여기에서, 상기 프로덕트는 상기 시뮬레이션과 연관된 메타데이터를 속성 정보로 포함할 수 있다. In one embodiment, the cloud service providing method may further include (d) outputting the result file as a product to an active folder when the execution of the activity is terminated. Here, the product may include metadata associated with the simulation as attribute information.

일 실시예에서, 상기 액티브 폴더는 상기 액티비티의 실행과 상기 생성된 프로덕트를 감시하는 모니터링 에이전트를 포함할 수 있다. 또한, 상기 액티브 폴더는 상기 시뮬레이션의 실행 과정을 상기 프로덕트의 상태 전이로 나타내고, 상기 프로덕트의 상태 전이는 액티비티가 생성되는 준비 상태, 시뮬레이션 진행 중을 나타내는 생성 상태, 시뮬레이션의 종료를 나타내는 완료 상태 및 손상 상태 중 적어도 하나를 포함할 수 있다.In one embodiment, the active folder may include a monitoring agent monitoring the execution of the activity and the generated product. In addition, the active folder indicates the execution process of the simulation by the state transition of the product, and the state transition of the product includes a preparation state in which the activity is generated, a generation state indicating that the simulation is in progress, a completion state indicating the end of the simulation, Or a state.

일 실시예에서, 상기 클라우드 서비스 제공 방법은 (e) 상기 사용자 단말에 상주하는 액티브 폴더 클라이언트를 통해 상기 사용자 단말과 상기 액티브 폴더간의 동기화를 수행하고, 사용자 단말에 상기 프로덕트를 제공하는 단계를 더 포함할 수 있다.In one embodiment, the cloud service providing method further includes: (e) performing synchronization between the user terminal and the active folder through an active folder client residing in the user terminal, and providing the product to the user terminal can do.

개시된 기술은 다음의 효과를 가질 수 있다. 다만, 특정 실시예가 다음의 효과를 전부 포함하여야 한다거나 다음의 효과만을 포함하여야 한다는 의미는 아니므로, 개시된 기술의 권리범위는 이에 의하여 제한되는 것으로 이해되어서는 아니 될 것이다.The disclosed technique may have the following effects. It is to be understood, however, that the scope of the disclosed technology is not to be construed as limited thereby, as it is not meant to imply that a particular embodiment should include all of the following effects or only the following effects.

본 발명의 일 실시예에 따른 클라우드 서비스 제공 방법은 데이터 액티브 폴더를 통해 사용자가 계산 보다는 연구 데이터를 생성, 활용, 관리하는 측면에 더욱 집중하도록 할 수 있다.The cloud service providing method according to an embodiment of the present invention allows the user to concentrate more on the aspect of creating, utilizing, and managing research data than computing through a data active folder.

본 발명의 일 실시예에 따른 클라우드 서비스 제공 방법은 액티브 폴더를 통해 사용자가 문제 해결 환경을 새로 학습하고 사용하는 데 필요한 오버헤드를 최소화할 수 있다.The cloud service providing method according to an exemplary embodiment of the present invention minimizes the overhead required for the user to newly learn and use the troubleshooting environment through the active folder.

도 1은 종래의 문제 해결 환경의 개념도이다.
도 2는 데이터 중심의 문제 해결 환경의 개념도이다.
도 3은 본 발명의 일 실시예에 따른 액티브 폴더 시스템의 블록도이다.
도 4는 본 발명의 일 실시예에 따른 액티브 폴더 시스템의 개요도이다.
도 5는 도 4에 있는 스크립트를 설명하는 예시도이다.
도 6은 도 4에 있는 프로덕트를 설명하는 예시도이다.
도 7은 본 발명의 일 실시예에 따른 원격 시뮬레이션 과정을 관리하는 클라우드 서비스 제공 방법의 흐름도이다.
1 is a conceptual diagram of a conventional problem solving environment.
2 is a conceptual diagram of a data-driven problem-solving environment.
3 is a block diagram of an active folder system in accordance with an embodiment of the present invention.
4 is a schematic diagram of an active folder system according to an embodiment of the present invention.
5 is an exemplary diagram illustrating the script shown in FIG.
6 is an exemplary view illustrating the product in Fig.
7 is a flowchart illustrating a method of providing a cloud service for managing a remote simulation process according to an embodiment of the present invention.

본 발명에 관한 설명은 구조적 내지 기능적 설명을 위한 실시예에 불과하므로, 개시된 기술의 권리범위는 본문에 설명된 실시예에 의하여 제한되는 것으로 해석되어서는 아니 된다. 즉, 실시예는 다양한 변경이 가능하고 여러 가지 형태를 가질 수 있으므로 개시된 기술의 권리범위는 기술적 사상을 실현할 수 있는 균등물들을 포함하는 것으로 이해되어야 한다.The description of the present invention is merely an example for structural or functional explanation, and thus the scope of the right of the disclosed technology should not be construed as being limited by the embodiments described in the text. That is, the embodiments are to be construed as being variously embodied and having various forms, so that the scope of the disclosed technology should be understood to include equivalents capable of realizing technical ideas.

한편, 본 출원에서 서술되는 용어의 의미는 다음과 같이 이해되어야 할 것이다.Meanwhile, the meaning of the terms described in the present application should be understood as follows.

"제1", "제2" 등의 용어는 하나의 구성요소를 다른 구성요소로부터 구별하기 위한 것으로 이들 용어들에 의해 권리범위가 한정되어서는 아니 된다. 예를 들어, 제1 구성요소는 제2 구성요소로 명명될 수 있고, 유사하게 제2 구성요소도 제1 구성요소로 명명될 수 있다.The terms "first "," second ", and the like are used to distinguish one element from another and should not be limited by these terms. For example, the first component may be referred to as a second component, and similarly, the second component may also be referred to as a first component.

어떤 구성요소가 다른 구성요소에 "연결되어" 있다고 언급된 때에는, 그 다른 구성요소에 직접적으로 연결될 수도 있지만, 중간에 다른 구성요소가 존재할 수도 있다고 이해되어야 할 것이다. 반면에, 어떤 구성요소가 다른 구성요소에 "직접 연결되어" 있다고 언급된 때에는, 중간에 다른 구성요소가 존재하지 않는 것으로 이해되어야 할 것이다. 한편, 구성요소들 간의 관계를 설명하는 다른 표현들, 즉 "~사이에"와 "바로 ~사이에" 또는 "~에 이웃하는"과 "~에 직접 이웃하는" 등도 마찬가지로 해석되어야 한다.It is to be understood that when an element is referred to as being "connected" to another element, it may be directly connected to the other element, but there may be other elements in between. On the other hand, when an element is referred to as being "directly connected" to another element, it should be understood that there are no other elements in between. On the other hand, other expressions that describe the relationship between components, such as "between" and "between" or "neighboring to" and "directly adjacent to" should be interpreted as well.

단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한 복수의 표현을 포함하는 것으로 이해되어야 하고, "포함하다" 또는 "가지다" 등의 용어는 설시된 특징, 숫자, 단계, 동작, 구성요소, 부분품 또는 이들을 조합한 것이 존재함을 지정하려는 것이지, 하나 또는 그 이상의 다른 특징들이나 숫자, 단계, 동작, 구성요소, 부분품 또는 이들을 조합한 것들의 존재 또는 부가 가능성을 미리 배제하지 않는 것으로 이해되어야 한다.It should be understood that the singular " include "or" have "are to be construed as including a stated feature, number, step, operation, component, It is to be understood that the combination is intended to specify that it is present and not to preclude the presence or addition of one or more other features, numbers, steps, operations, components, parts or combinations thereof.

각 단계들에 있어 식별부호(예를 들어, a, b, c, ...)는 설명의 편의를 위하여 사용되는 것으로 식별부호는 각 단계들의 순서를 설명하는 것이 아니며, 각 단계들은 문맥상 명백하게 특정 순서를 기재하지 않은 이상 명기된 순서와 다르게 일어날 수 있다. 즉, 각 단계들은 명기된 순서와 동일하게 일어날 수도 있고 실질적으로 동시에 수행될 수도 있으며 반대의 순서대로 수행될 수도 있다.In each step, the identification codes (e.g., a, b, c, ...) are used for convenience of explanation, and the identification codes do not describe the order of each step, Unless the specific order is described, it may occur differently from the order specified. That is, each step may occur in the same order as described, may be performed substantially concurrently, or may be performed in reverse order.

본 발명은 컴퓨터가 읽을 수 있는 기록매체에 컴퓨터가 읽을 수 있는 코드로서 구현될 수 있고, 컴퓨터가 읽을 수 있는 기록 매체는 컴퓨터 시스템에 의하여 읽혀질 수 있는 데이터가 저장되는 모든 종류의 기록 장치를 포함한다. 컴퓨터가 읽을 수 있는 기록 매체의 예로는 ROM, RAM, CD-ROM, 자기 테이프, 플로피 디스크, 광 데이터 저장 장치 등이 있으며, 또한, 캐리어 웨이브(예를 들어 인터넷을 통한 전송)의 형태로 구현되는 것도 포함한다. 또한, 컴퓨터가 읽을 수 있는 기록 매체는 네트워크로 연결된 컴퓨터 시스템에 분산되어, 분산 방식으로 컴퓨터가 읽을 수 있는 코드가 저장되고 실행될 수 있다.The present invention can be embodied as computer-readable code on a computer-readable recording medium, and the computer-readable recording medium includes all kinds of recording devices for storing data that can be read by a computer system . Examples of the computer-readable recording medium include a ROM, a RAM, a CD-ROM, a magnetic tape, a floppy disk, an optical data storage device, and the like, and also implemented in the form of a carrier wave (for example, transmission over the Internet) . In addition, the computer-readable recording medium may be distributed over network-connected computer systems so that computer readable codes can be stored and executed in a distributed manner.

여기서 사용되는 모든 용어들은 다르게 정의되지 않는 한, 개시된 기술이 속하는 분야에서 통상의 지식을 가진 자에 의해 일반적으로 이해되는 것과 동일한 의미를 가진다. 일반적으로 사용되는 사전에 정의되어 용어들은 관련 기술의 문맥상 가지는 의미와 일치하는 것으로 해석되어야 하며, 본 출원에서 명백하게 정의하지 않는 한 이상적이거나 과도하게 형식적인 의미를 지니는 것으로 해석될 수 없다.
All terms used herein have the same meaning as commonly understood by one of ordinary skill in the art to which the disclosed technology belongs, unless otherwise defined. Terms defined in commonly used dictionaries should be interpreted to be consistent with meaning in the context of the relevant art and can not be construed as having ideal or overly formal meaning unless expressly defined in the present application.

도 2는 데이터 중심의 문제 해결 환경의 개념도이다.2 is a conceptual diagram of a data-driven problem-solving environment.

종래의 문제 해결 환경(100)에서 문제를 풀기 위해서 사용했던 알고리즘이나 모델들은 데이터를 생성하기 위한 도구에 해당한다. 문제 해결 환경(200)은 이러한 도구들과 데이터 생성을 자동화할 수 있는 기획 기능들을 제공하여야 한다.The algorithms and models used to solve the problem in the conventional problem solving environment 100 correspond to a tool for generating data. The troubleshooting environment 200 should provide planning tools to automate these tools and data generation.

도 2를 참조하면, 본 발명의 일 실시예에 따른 데이터 중심의 문제 해결 환경(200)은 데이터 중심으로 과학 계산 연구를 관리하는 방법을 분류화 하고. 보다 구체적으로, 데이터의 보관(store), 보관된 데이터의 활용(usage), 시스템에 데이터를 확보하는 생산(product), 이러한 생산을 자동화할 수 있는 기획(plan), 다른 사용자와 협력하기 위한 공유(sharing)로 분류한다.Referring to FIG. 2, a data-driven problem solving environment 200 according to an embodiment of the present invention classifies a method for managing scientific computation research as a data center. More specifically, the present invention relates to a system for storing data, usage of archived data, product securing data in the system, plan for automating such production, sharing for cooperation with other users, (sharing).

이하에서는 분류된 방법들 각각의 기능을 상세히 설명한다.Hereinafter, the function of each of the classified methods will be described in detail.

·데이터 보관: 데이터는 임시 혹은 영구적으로 보관된다. 특정 시점에서 과거에 생산한 데이터에 접근할 수 있다. 또한 지리적으로 분산된 환경에서도 똑같은 방법으로 데이터에 접근할 수 있다. 보관된 데이터를 분류 및 정리하는 것에 제한이 없다.· Data archiving: Data is stored temporarily or permanently. You can access data produced in the past at a specific point in time. Data can also be accessed in the same way in a geographically dispersed environment. There is no restriction to sort and organize the archived data.

·데이터 활용: 데이터는 소프트웨어의 의해서 접근이 가능하다. 데이터를 수정하거나, 데이터를 분석하거나 혹은 계산의 입력 자료로 사용하기 위해 소프트웨어 의한 접근이 허용된다. 사용자가 주로 활용하는 레거시 소프트웨어를 새로운 데이터 시스템을 위한 수정 없이 활용할 수 있다.· Data utilization: Data is accessible by software. Software access is allowed to modify the data, analyze the data, or use it as input to the calculation. Legacy software that is primarily used by users can be utilized without modification for new data systems.

·데이터 생산: 문제 해결 환경(200)은 다양한 방법으로 데이터를 생성할 수 있는 수단을 제공한다. 외부 시스템에 의해서 작성되어진 데이터의 등록, 사용자가 직접 시스템에서 데이터를 작성하는 편집, 시스템에 연결된 로컬이나 원격의 컴퓨팅 자원을 이용한 계산을 통해서 데이터를 생성할 수 있다.Data production: The troubleshooting environment 200 provides a means of generating data in a variety of ways. Data can be generated through registration of data created by an external system, editing by the user to create data directly in the system, or calculation using local or remote computing resources connected to the system.

·데이터 기획: 문제 해결 환경(200)은 반복적이거나 프로그래밍 규칙으로 데이터를 생산할 수 있다. 사용자가 데이터를 생산하는 방법을 기획하고, 기획된 내용을 규칙으로 정의할 수 있다. 규칙은 사용자가 재활용할 수 있도록 매개 변수를 적용할 수 있다. 시스템은 사용자가 정의할 수 있는 규칙과 규칙의 작성 방법, 일괄처리 등의 규칙을 실행하는 방법을 통해서 데이터 생산을 자동화할 수 있다.Data planning: The troubleshooting environment 200 can produce data in repetitive or programming rules. You can plan how the user will produce the data and define the planned content as rules. Rules can apply parameters so that users can recycle them. The system can automate the production of data through user-defined rules, how to create rules, and how to execute rules such as batch processing.

·데이터 공유: 사용자는 다른 사용자와 공동으로 데이터를 분석이나 계산하는 연구할 수 있다. 따라서 사용자간에 연구에 필요한 데이터를 같이 공유할 수 있다.
· Data sharing: Users can collaborate with other users to analyze or calculate data. Therefore, the data necessary for research can be shared among users.

도 3은 본 발명의 일 실시예에 따른 액티브 폴더 시스템의 블록도이다.3 is a block diagram of an active folder system in accordance with an embodiment of the present invention.

도 3을 참조하면, 액티브 폴더 시스템(300)은 사용자 단말(310), 액티브 폴더 서버(320) 및 클라우드 서버(330)를 포함한다. 여기에서, 사용자 단말(310), 액티브 폴더 서버(320) 및 클라우드 서버(330)는 네트워크(특히, 인터넷)을 통해 연결될 수 있다.Referring to FIG. 3, the active folder system 300 includes a user terminal 310, an active folder server 320, and a cloud server 330. Here, the user terminal 310, the active folder server 320, and the cloud server 330 may be connected through a network (in particular, the Internet).

사용자 단말(310)은 클라이언트를 통해 사용자 단말(310)의 상태를 감시하여 변화를 탐지하고, 사용자에게 특수 명령을 제공한다. 여기에서, 클라이언트는 컴퓨터가 읽을 수 있는 기록매체로 구현될 수 있고, 액티브 폴더 서버(320)에서 제공될 수 있다. 여기에서, 제공은 컴퓨터 프로그램의 배포, 가상 또는 클라우드 컴퓨팅 환경에서의 컴퓨터 프로그램 실행을 포함할 수 있다.The user terminal 310 monitors the status of the user terminal 310 through the client and detects a change and provides a special command to the user. Here, the client may be implemented as a computer-readable recording medium, and may be provided in the active folder server 320. [ Here, the provision may include distribution of a computer program, and execution of a computer program in a virtual or cloud computing environment.

보다 구체적으로, 클라이언트는 사용자 단말(310)에 상주하며 설정된 사용자 디스크 영역 일부를 할당받아 후술할 액티브 폴더 메타데이터 모델을 파일 시스템으로 표현한다. 할당받은 디스크 공간을 주기적으로 감시하여 서비스의 메타 데이터와 사용자 디스크에 동기화하는 일을 지속적으로 수행한다.More specifically, the client resides in the user terminal 310 and allocates a part of the set user disk area to express an active folder metadata model, which will be described later, as a file system. It periodically monitors the allocated disk space and continuously performs synchronization with the service metadata and the user disk.

사용자 단말(310)은 클라우드 컴퓨팅 환경에서 동작될 수 있는 데스크톱, 노트북, 스마트폰 또는 태블릿 PC, 서버, 로컬 시스템에 해당할 수 있다.
The user terminal 310 may correspond to a desktop, laptop, smartphone or tablet PC, server, or local system that may be operated in a cloud computing environment.

액티브 폴더 서버(320)는 시뮬레이션과 관련된 메타 데이터를 관리하는 서비스를 제공한다.The active folder server 320 provides a service for managing metadata related to the simulation.

여기에서, 서비스는 크게 데이터를 관리하는 서비스와 서버로 표현되는 컴퓨팅 자원을 관리하는 서비스로 구분된다. 데이터 관리는 액티브 폴더 메타 데이터 모델과 연결된 클라우드 저장장치의 내용을 일관성 있게 유지하는 것을 주기적으로 수행한다. 서버의 관리는 후술할 액티비티 실행과 감시를 위해서 액티비티를 실행하기 위한 대기열과 클라우드 컴퓨팅이나 그리드 컴퓨팅으로 연결할 수 있는 실행 컴포넌트, 실행된 액티비티와 액티비티가 생성하는 프로덕트를 감시하는 모니터링 에이전트를 포함한다.Here, the service is largely divided into a service for managing data and a service for managing computing resources represented by a server. Data management periodically performs consistent maintenance of the contents of the cloud storage device associated with the Active Folder Metadata Model. The management of the server includes a queue for executing activities for executing and monitoring activities to be described later, an execution component that can be connected to cloud computing or grid computing, and a monitoring agent for monitoring the products generated by the activities and activities.

클라우드 서버(330)는 사용자의 데이터를 보관하고, 시뮬레이션을 수행한다. 클라우드 서버(330)는 사용자의 데이터를 보관하는 클라우드 저장장치, 계산을 담당하는 컴퓨팅 자원을 포함할 수 있다.
The cloud server 330 stores the user's data and performs simulation. The cloud server 330 may include a cloud storage device for storing user data, and a computing resource for computing.

도 4는 본 발명의 일 실시예에 따른 액티브 폴더 시스템의 개요도이다.4 is a schematic diagram of an active folder system according to an embodiment of the present invention.

도 4를 참조하면, 액티브 폴더 시스템(300)은 사용자의 시뮬레이션을 메타데이터 모델로 표현하고, 이를 파일 시스템의 파일로 표출한다. 이하에서는, 도 4 내지 6을 참조하여, 액티브 폴더에서 사용하는 메타데이터 모델을 상세히 설명한다. 여기에서, 액티브 폴더는 데이터 중심적 개념으로 연구 시뮬레이션과 데이터를 관리할 수 있도록 구현한 원격 파일 시스템 서비스에 해당한다.Referring to FIG. 4, the active folder system 300 expresses a simulation of a user as a meta data model and displays it as a file of a file system. Hereinafter, a metadata model used in the active folder will be described in detail with reference to FIGS. Here, the Active Folder corresponds to a remote file system service that is implemented as a data-centric concept to manage research simulation and data.

·액티비티(Activity, 410)는 사용자의 시뮬레이션 계획을 정의하는 메타데이터이다. 액티비티는 작업들과 파라미터 집합을 가지며, 액티브 폴더에서 컴퓨팅 자원을 할당하는 기본 단위에 해당한다. Activity (Activity) 410 is metadata that defines the user's simulation plan. An activity has a set of tasks and parameters, and corresponds to a basic unit for allocating computing resources in an active folder.

일 실시예에서, 액티비티는 파일 시스템에서 디렉토리 형태로 표현될 수 있다. 액티비티는 이름, 생성날짜, 마지막 수정날짜, 버전 등의 정보와 다수의 작업을 가질 수 있다.In one embodiment, the activity may be represented in directory form in the file system. An activity can have a number of operations with information such as name, creation date, last modified date, version, and so on.

·작업(Task, 420)은 하나의 컴퓨팅 노드에서 실행되는 시뮬레이션 작업에 해당한다. 작업은 같은 액티비티에 속하는 작업간의 데이터 의존성이 없다면, 동시에 실행될 수 있다. 하나의 작업은 최초에 실행되는 스크립트 외에 다수의 스크립트를 가질 수 있다.Task 420 corresponds to a simulation task executed on one computing node. Tasks can be executed concurrently, if there is no data dependency between tasks belonging to the same activity. A task can have many scripts in addition to the scripts that are executed first.

일 실시예에서, 작업은 파일 시스템에서 디렉토리 형태로 표현될 수 있다. 작업은 이름, 생성 날짜, 마지막 수정날짜 등의 정보와 다수의 스크립트를 가질 수 있다.In one embodiment, the job may be represented in the form of a directory in the file system. Tasks can have multiple scripts with information such as name, creation date, last modified date, and so on.

·스크립트(Script, 430)는 컴퓨팅 노드에서 실제 시뮬레이션을 수행하는 소프트웨어 실행 루틴에 해당한다. A script (Script, 430) corresponds to a software execution routine that performs an actual simulation at a computing node.

도 5는 도 4에 있는 스크립트를 설명하는 예시도이다.5 is an exemplary diagram illustrating the script shown in FIG.

도 5를 참조하면, 스크립트 표현 규칙을 사용하여 스크립트에서 사용해야 하는 파일과 생성할 파일을 정의할 수 있다. 여기에서, 사용한 파일 이름은 액티비티 내에서 유일하다.Referring to FIG. 5, a script expression rule can be used to define a file to be used in a script and a file to be generated. Here, the filenames used are unique within the activity.

일 실시예에서, 스크립트는 파일 시스템에서 파일로 표현될 수 있다.In one embodiment, the script may be represented as a file in the file system.

·파라미터 집합(Parameter-set, 440)은 액티비티에 속한 모든 스크립트에서 정의한 파라미터의 집합이다. 파라미터 집합은 액티비티에서 오직 하나만 존재한다.A parameter set (parameter-set, 440) is a set of parameters defined in all scripts belonging to an activity. There is only one parameter set in an activity.

일 실시예에서, 파라미터 집합은 파일 시스템에서 폴더로 표현하며 각각의 파라미터는 파일로 표현될 수 있다. 여기에서, 파일로 표현된 파라미터는 각각의 파라미터가 가지는 기본 값을 포함할 수 있다. 예를 들어, 도 3에서 도시된 입력 파일 파라미터의 경우에는 후술할 프로덕트의 경로를 포함할 수 있다.In one embodiment, the parameter set is represented as a folder in the file system and each parameter can be represented as a file. Here, the parameter expressed in the file may include a basic value of each parameter. For example, in the case of the input file parameter shown in FIG. 3, it may include a path of a product to be described later.

·프로덕트(Product, 450)는 액티브 폴더에서 시뮬레이션 수행에 필요한 원시 데이터 혹은 연산 결과 데이터에 해당한다. 프로덕트는 외부 시스템으로부터 업로드 한 결과뿐만 아니라, 시뮬레이션 수행의 결과로 얻은 결과들을 포함한다.Product (Product, 450) corresponds to primitive data or operation result data required to perform simulation in the active folder. The product includes the results obtained from the simulation as well as the results uploaded from the external system.

도 6은 도 4에 있는 프로덕트를 설명하는 예시도이다.6 is an exemplary view illustrating the product in Fig.

도 6을 참조하면, 프로덕트는 생성시 연관된 프로덕트를 비롯한 메타데이터들을 속성 정보로 관리한다. 이를 통해, 지정된 프로덕트와 같은 방법으로 생성된 프로덕트, 프로덕트 생성에 사용한 액티비티, 적용된 파라미터 집합 등을 추적할 수 있다. 또한, 프로덕트는 데이터 생성 중, 즉, 시뮬레이션이 실행되면서 결과 파일을 점진적으로 기록하는 상황을 프로덕트의 상태 전이로 표현할 수 있다.Referring to FIG. 6, a product manages metadata including attributed products as attribute information at the time of creation. This allows you to keep track of the products created in the same way as the specified products, the activities used to create the products, and the set of applied parameters. In addition, a product can represent a state transition of a product during data generation, that is, a situation in which a result file is progressively recorded while a simulation is executed.

일 실시예에서, 프로덕트는 액티브 폴더 시스템(300)에서 데이터의 관리 이력에 대한 정보를 관리한다. 사용자가 시뮬레이션에 필요한 파일을 액티브 폴더 시스템(300) 외부에서 수입(Import)하거나, 액티비티의 전송(Send) 혹은 프로덕트를 복제(Copy)하여 프로덕트를 생성할 수 있다. 프로덕트는 수입에 의한 생성, 전송에 의한 생성, 생성할 때 사용된 액티비티 정보, 파라미터 정보를 관리하여 추적할 수 있다. 전송에 의해 생성된 프로덕트는 프로덕트 생성에 관여한 액티비티에 대한 메타데이터를 가지고 있어, 액티비티를 추출 및 재현하는 것이 가능하다. 이러한 관리 이력은 프로덕트 복제 시 같이 복제되어진다.In one embodiment, the product manages information about the history of management of data in the active folder system 300. A user can import a file necessary for simulation outside the active folder system 300 or create a product by transmitting an activity or copying a product. The product can be managed by tracking the generation of income, the generation by transmission, the activity information used at the time of generation, and the parameter information. The product created by the transfer has metadata about the activity involved in the product creation, so it is possible to extract and reproduce the activity. These management histories are replicated at the time of product replication.

시뮬레이션 실행을 의미하는 액티비티 전송을 통해서 프로덕트를 생성할 때에, 시뮬레이션이 장기간 수행되면서 점진적으로 생성할 수 있다. 액티브 폴더에서는 장기간 수행되는 시뮬레이션의 중간 결과를 확인할 수 있도록 하기 위하여 도 5에서 도시한 바와 같이 상태 전이를 가진다. 여기에서, 상태 전이는 준비(Dormant) 상태, 시뮬레이션 중간의 상태인 생성(Creating) 상태, 시뮬레이션이 종료되어 생성이 완료(Completed) 상태, 시뮬레이션이 아닌 다른 도구에 의해 내용이 손상(Damaged) 상태에 해당한다. 프로덕트 수입의 경우에도 파일의 크기에 따라 전송시간이 길어질 수 있으므로, 전송중인 상태를 생성 상태로 정의할 수 있다.When creating a product through activity transfer, which means execution of the simulation, the simulation can be performed for a long time and gradually generated. The active folder has a state transition as shown in FIG. 5 in order to be able to confirm the intermediate result of the simulation performed for a long time. Here, the state transition can be classified into a dormant state, a creation state in the middle of the simulation, a completed state in which the simulation is terminated, and a state in which the content is damaged by a tool other than the simulation . In the case of the product import, since the transmission time may be longer depending on the size of the file, the state of transmission can be defined as the generation state.

프로덕트 상태에 따라 액티비티에서 참조할 수 있는 여부가 결정된다. 아직 파일이 존재하지 않거나 생성중인 상태에서는 참조할 수 없고, 프로덕트가 완료되거나 손상 상태에서만 참조할 수 있다. 만약, 손상 상태의 프로덕트를 참조하여 시뮬레이션을 수행하여 얻은 프로덕트는 관리 이력에서 손상된 프로덕트를 참조하여 얻었음을 확인 할 수 있다.Depending on the state of the product, it is determined whether the activity can be referenced. The file can not be referenced when the file does not exist yet or is being created, and can be referenced only when the product is complete or damaged. If a product obtained by performing a simulation with reference to a damaged product is confirmed by referring to a damaged product in the management history,

프로덕트의 이력 관리를 통해서 액티브 폴더는 사용자에게 결과 데이터에 대한 안전장치를 제공한다.Through the history management of the product, the Active Folder provides the user with a safeguard against the resulting data.

·런(Run, 460)은 액티비티를 실제 서버에서 수행중인 상태 정보를 포함한다. 예를 들어, 도 3에 도시된 바와 같이, 런은 수행 요청 당시의 액티비티에 대한 정보(activity.dat)와 할당된 서버(server.rsc), 액티비티의 진행상태(activity.status), 액티비티의 연관 파일 정보(@stage-xxx/*)를 포함할 수 있다. 런은 파일 시스템에서 "/execute"로 시작하는 경로 아래에 표현될 수 있고, 각 정보는 파일 형태로 표현될 수 있다.Run (Run) 460 contains state information that the activity is performing on the real server. For example, as shown in FIG. 3, a run includes information (activity.dat) about an activity at the time of execution request, an allocated server (server.rsc), an activity status (activity.status) File information (@ stage-xxx / *). The run can be represented in the file system under a path starting with "/ execute", and each piece of information can be represented in a file.

·서버(Server, 470)는 시뮬레이션을 수행할 수 있는 컴퓨팅 자원 정보(예를 들어, server.rsc)와 컴퓨팅 자원 상태 정보(예를 들어, server.status)를 포함한다. 여기에서, 컴퓨팅 자원 정보는 실행 가능한 소프트웨어, 최대 CPU 노드 수, 병렬 시스템 지원 여부 및 병렬 라이브러리에 대한 정보 등을 포함한다. 액티비티가 서버에서 실행될 때 정보를 참조한다. 서버는 파일 시스템에서 "/server"로 시작하는 경로 아래에 표현될 수 있다.The server 470 includes computing resource information (e.g., server.rsc) and computing resource status information (e.g., server.status) that can perform simulation. Here, the computing resource information includes executable software, a maximum number of CPU nodes, whether or not a parallel system is supported, and information on a parallel library. Refer to the information when the activity is executed on the server. The server can be represented in the file system under the path starting with "/ server".

·레이블(Label, 480)은 사용자가 액티비티와 프로덕트를 효과적으로 분류하고 검색할 수 있는 역할을 수행한다. 레이블은 파일 시스템 표현을 위한 것과 검색을 위한 키워드로 나뉜다. 레이블은 액티비티와 프로덕트 모델에 하나 이상 연관될 수 있다.
The label (Label, 480) serves to allow the user to effectively classify and search activities and products. Labels are divided into two parts, one for the file system representation and one for the search. A label can be associated with one or more activities and product models.

액티브 폴더는 레거시 소프트웨어가 액티브 폴더의 메타데이터를 별도의 수정 없이 접근할 수 있도록 하기 위해서, 모든 메타데이터 모델을 파일 시스템의 폴더와 파일 형태로 사상(abstract)한다. The Active Folder abstracts all metadata models into folders and files in the file system so that legacy software can access the Active Folder's metadata without further modification.

Data ModelData Model File SystemFile System ActivityActivity sub folders in "/activities/"sub folders in "/ activities /" JobJob folder in Activityfolder in Activity ScriptScript file in Jobfile in Job Parameter setParameter set folder called "Parameters" in ActivityActivity in folder called "Parameters" ProductProduct files in "/products/"files in "/ products /" RunRun sub folders in "/apps/execute/" and files in those folderssub folders in "/ apps / execute /" and files in those folders ServerServer sub folders in "/apps/server/" and files in those folderssub folders in "/ apps / server /" and files in those folders LabelLabel showed by file path from "/activities/" or "/products/". label of key word type is not shown in the path in file system"/ products /" or "/ products /". label of key word type is not shown in the file system

표 1은 파일 시스템의 폴더와 파일로 표현된 메타데이터 모델(Mapping to File System)을 나타낸다.
Table 1 shows the metadata model (Mapping to File System) represented by the folders and files of the file system.

한편, 액티비티의 구조는 도 4에 도시된 바와 같이, 하나 이상의 작업과 하나의 파라미터 집합으로 구성된 폴더에 해당한다. 액티비티가 사상된 폴더는 파일의 생성을 허가하지 않는다.On the other hand, the structure of the activity corresponds to a folder composed of one or more tasks and one parameter set as shown in Fig. Folders whose activities are mapped do not allow creation of files.

런은 확정된 액티비티 실행 문맥 정보와 실행 상태, 수행 중인 서버 정보, 입/출력에 사용되는 파일 정보들을 폴더로 묶고, 각각의 정보를 파일로 제공한다. 서버는 구성 정보와 서버 상태를 폴더로 묶고, 각 정보를 파일로 제공한다.
The run bundles the confirmed activity execution context information, the execution status, the server information being executed, and the file information used for input / output into a folder, and provides each information as a file. The server bundles the configuration information and the server status into folders, and provides each information to a file.

일 실시예에서, 액티브 폴더의 메타데이터를 조작하기 위한 연산은 레거시 파일 시스템에 사상된 형태로도 연산될 수 있다.In one embodiment, the operation for manipulating the metadata of the active folder may also be computed in a mapped form in a legacy file system.

ModelModel OperationOperation command / function in file systemcommand / function in file system ActivityActivity createcreate use a new command called mkactivityuse a new command called mkactivity deletedelete delete activity folddelete activity fold modifymodify changing folder's name to change
activity's name
changing folder's name to change
activity's name
executeexecute 1. use a command called submit
2. Drag&Drop in file explorer in GUI
1. use a command called submit
2. Drag & Drop in file explorer in GUI
JobJob CreateCreate create a new folder in activitycreate a new folder in activity deletedelete delete job folderdelete job folder modifymodify changing folder's name to change job's namechanging folder's name to change job's name ScriptScript createcreate create a new file in Jobcreate a new file in Job deletedelete delete script filedelete script file modifymodify edit and save fileedit and save file Parameter SetParameter Set createcreate created automatically by editing scriptcreated automatically by editing script deletedelete delete either all parameter files or"Parameters" folder.delete all parameter files or "Parameters" folder. modifymodify parameter values are replaced by modifying parameter fileparameter values are replaced by modifying parameter file ProductProduct ** same as regular file systemsame as regular file system RunRun -- read onlyread only stopstop delete the file called "activity.status" in run folderdelete the file called "activity.status" in run folder ServerServer -- read onlyread only stop
stop
write STOP in the file "server.status" or delete the file "server.status"write STOP in the file "server.status" or delete the file "server.status"
startstart write START in the file "server.status" or create emty file "server.status"write START in the file "server.status" or create emty file "server.status" unregisterunregister delete either the file "server.rsc" or the
server folder
delete either the file "server.rsc" or the
server folder
Label
Label
create/
delete
create /
delete
create or delete folders in /activities/ or /products/create / delete folders in / activities / or / products /
taggingtagging move model (activity or product) to the
folder named by the label
move model (activity or product) to the
folder named by the label

표 2는 액티브 폴더의 메타데이터 연산을 파일 시스템 연산으로 수행할 수 있는 방법을 나타낸다(action mapping to file system).Table 2 shows how the metadata operations of the active folder can be performed by file system operations (action mapping to file system).

표 2를 참조하면, 액티비티는 레이블의 생성 방법과 구분하기 위해서 mkactivity 라는 별도의 명령어를 사용한다. 액티비티의 하위 모델은 기본적인 파일 연산을 통해서 생성, 수정, 변경이 가능하다. 액티비티는 일반 데이터와는 달리 실행할 수 있는 데이터 모델로, "submit" 이라는 명령어를 사용하여 다음과 같이 실행하거나, GUI 환경에서는 액티비티를 서버 디렉토리로 드래그-앤-드롭(Drag & Drop)하여 실행할 수 있다.Referring to Table 2, the activity uses a separate command called mkactivity to distinguish it from the label generation method. A sub-model of an activity can be created, modified, and changed through basic file operations. An activity is a data model that can be executed differently from general data and can be executed by using the command "submit" as follows, or by dragging and dropping an activity to a server directory in GUI environment .

"submit activity/ [ apps/server/server-name-1/ ]""submit activity / [apps / server / server-name-1 /]"

프로덕트는 일반 파일 시스템과 동일하게 처리된다. 반면에 런과 서버는 특수한 폴더로써, 대부분의 파일은 읽기 전용으로 변경할 수 없다. 런은 액티비티의 실행을 표현하는 것으로 액티비티 실행의 의해 생성되어진다. 실행을 중단하기 위해서는 런의 수행 상태 파일(activity.status)을 삭제한다. 서버는 정해진 웹 서비스를 통해서만 등록하여 생성할 수 있다. 파일 시스템 명령으로는 서버의 연결을 중단하거나 시작하는 것과 등록을 취소하는 연산만 실행 가능하다.
The product is treated the same as a regular file system. Runs and servers, on the other hand, are special folders, and most files can not be changed to read-only. A run is a representation of the execution of an activity and is generated by the execution of an activity. To stop the execution, delete the execution status file (activity.status) of the run. The server can be created by registering only through the specified web service. File system commands can only be used to stop or start the connection to the server and to cancel the registration.

도 7은 본 발명의 일 실시예에 따른 원격 시뮬레이션 과정을 관리하는 클라우드 서비스 제공 방법의 흐름도이다.7 is a flowchart illustrating a method of providing a cloud service for managing a remote simulation process according to an embodiment of the present invention.

앞서 설명한 바와 같이, 액티브 폴더는 사용자가 사용하고 있는 레거시 소프트웨어만을 이용해서 데이터 중심의 문제 해결 환경(200)을 구현할 수 있다. 예를 들어, 드롭박스를 통해 구현한 액티브 폴더를 사용해서 클라우드 컴퓨팅 자원에 시뮬레이션을 실행하고 그 결과를 얻는 과정을 보여준다. 이를 통해, 사용자는 시뮬레이션을 수행하고 결과를 얻을 수 있다.As described above, the active folder can implement the data-based problem solving environment 200 using only the legacy software that the user is using. For example, we show the process of running a simulation on a cloud computing resource using an active folder implemented through a drop box and obtaining the result. This allows the user to perform the simulation and obtain the results.

도 7을 참조하면, 액티브 폴더 시스템(300)은 사용자 단말(310)에서 선택되고 시뮬레이션에 사용될 파일을 액티브 폴더에 등록한다(S710).Referring to FIG. 7, the active folder system 300 registers a file selected in the user terminal 310 and used in a simulation in an active folder (S710).

액티브 폴더 시스템(300)은 파일 시스템 명령(표 2 참조)을 사용해서 사용자 단말(310)에서 액티비티를 생성한다(S720).The active folder system 300 generates an activity at the user terminal 310 using a file system command (see Table 2) (S720).

일 실시예에서, 드롭박스나 구글드라이브처럼 사용자가 액티브 폴더에 할당된 디스크 공간의 내용이나 구조를 변경하면, 클라이언트(액티브 폴더 클라이언트)가 액티브 폴더 서버(320)와 클라우드 서버(330, 특히, 클라우드 저장소)에 동기화할 수 있다.In one embodiment, when a user changes the content or structure of disk space allocated to an active folder, such as a drop box or a Google Drive, a client (an active folder client) may access the active folder server 320 and the cloud server 330, Storage).

사용자로부터 submit 혹은 드래그&드롭을 통해 시뮬레이션의 실행이 요청되면, 액티브 폴더 시스템(300)은 액티비티를 컴퓨팅 자원에 실행한다(S730).When execution of the simulation is requested by the user through submit or drag & drop, the active folder system 300 executes the activity on the computing resource (S730).

보다 구체적으로, submit은 액티브 폴더 서버(320)에 요청하고, 액티브 폴더 서버(320)는 해당 액티비티를 실행할 수 있도록 클라우드 서버(330)에 맞게 변환한 후 실행한다.More specifically, submit requests the active folder server 320, and the active folder server 320 converts the contents into the cloud server 330 so that the active folder server 320 can execute the activity.

시뮬레이션의 실행이 종료되면, 액티브 폴더 시스템(300)은 결과 파일을 액티브 폴더에 프로덕트로 출력한다(S740).When execution of the simulation is finished, the active folder system 300 outputs the result file as a product to the active folder (S740).

이를 통해, 사용자는 최종적으로 디스크 공간에 동기화된 프로덕트를 얻게 되고, 친숙한 레거시 소프트웨어를 사용하여 이를 분석하거나 또 다른 데이터를 생성할 수 있다(S750).
This allows the user to finally obtain a synchronized product in disk space, analyze it using familiar legacy software or generate another data (S750).

사용자가 과학 계산 방법과 관련된 일 보다 데이터의 생성과 활용 측면에 더 집중할 수 있도록 하기 위해서, 본 발명에서는 데이터 중심의 문제 해결 환경(200)을 제공한다. 데이터 중심의 문제 해결 환경(200)은 데이터를 얻기 위한 방법과 데이터를 활용하는 방법 그리고 데이터를 관리하는 방법을 기획, 생성, 활용, 보관, 공유로 분류하고 각각의 기능을 정의하였다.The present invention provides a data-driven problem solving environment 200 in order to allow the user to focus more on the creation and utilization of data than on a science computing method. The data-driven problem solving environment 200 classifies the methods for obtaining data, how to utilize the data, and how to manage the data into planning, creating, utilizing, storing, and sharing, and defining the respective functions.

데이터 중심의 문제 해결 환경(200)을 구현하기 위해서 본 발명은 시뮬레이션을 지원하는 원격 파일 시스템 서비스인 액티브 폴더를 제공한다. 액티브 폴더는 데이터 생성 및 분석을 위한 계산과 이를 위한 컴퓨팅 자원의 표현을 데이터 중심으로 바꾸는 모델을 정의하고, 이를 레거시 파일 시스템에 사상된 형태로 나타낼 수 있다. 원격지인 클라우드 서버(330, 특히, 클라우드 저장소)와 액티브 폴더 서버(320)에 데이터를 저장하지만, 레거시 프로그램이 바로 접근 가능하도록 액티브 폴더의 모델에 필요한 액션을 모두 레거시 파일 시스템 명령으로 사상시켰다.
In order to implement a data-driven problem solving environment 200, the present invention provides an active folder, which is a remote file system service supporting simulation. The Active Folder defines a model that transforms the computation for data generation and analysis, the representation of computing resources for that data into a data center, and displays it in a mapped form in a legacy file system. Stores data in the remote cloud server 330 (in particular, the cloud storage) and the active folder server 320, but maps all actions necessary for the model of the active folder to the legacy program as legacy file system commands so that the legacy program can be accessed immediately.

상기에서는 본 출원의 바람직한 실시예를 참조하여 설명하였지만, 해당 기술 분야의 숙련된 당업자는 하기의 특허 청구의 범위에 기재된 본 발명의 사상 및 영역으로부터 벗어나지 않는 범위 내에서 본 발명을 다양하게 수정 및 변경시킬 수 있음을 이해할 수 있을 것이다.It will be apparent to those skilled in the art that various modifications and variations can be made in the present invention without departing from the spirit or scope of the present invention as defined by the following claims It can be understood that

100 : 종래의 문제 해결 환경
200 : 데이터 중심의 문제 해결 환경
300 : 액티브 폴더 시스템
310 : 사용자 단말 320 : 액티브 폴더 서버
330 : 클라우드 서버
100: Conventional troubleshooting environment
200: Data-driven troubleshooting environment
300: Active Folder System
310: user terminal 320: active folder server
330: Cloud server

Claims (7)

네트워크를 통해 상호 연결된 사용자 단말, 액티브 폴더 서버 및 클라우드 서버를 포함하는 액티브 폴더 시스템에서 수행되는 클라우드 서비스 제공 방법에 있어서,
(a) 상기 사용자 단말을 통해 시뮬레이션과 연관된 메타데이터를 수신하여 액티브 폴더 서버의 액티브 폴더에 등록하는 단계 -상기 액티브 폴더는 메타데이터 모델을 파일 시스템의 폴더와 파일로 사상함-;
(b) 상기 사용자 단말에서 수신된 파일 시스템 명령에 따라 상기 수신한 메타데이터를 조작하여 액티비티를 생성하는 단계 -상기 액티비티는 시뮬레이션 계획을 정의함-; 및
(c) 상기 액티브 폴더 서버를 통해 할당된 클라우드 서버에서 상기 생성된 액티비티를 실행하는 단계를 포함하는 클라우드 서비스 제공 방법.
A method for providing a cloud service performed in an active folder system including a user terminal, an active folder server, and a cloud server interconnected through a network,
(a) receiving metadata associated with a simulation through the user terminal and registering the metadata in an active folder of an active folder server, the active folder mapping a metadata model to a folder and a file in a file system;
(b) generating an activity by manipulating the received metadata according to a file system command received at the user terminal, the activity defining a simulation plan; And
and (c) executing the generated activity from a cloud server allocated through the active folder server.
제1항에 있어서, 상기 액티비티는
스크립트를 포함하는 적어도 하나의 시뮬레이션 작업을 포함하는 것을 특징으로 하는 클라우드 서비스 제공 방법
2. The method of claim 1,
Wherein the at least one simulation job includes a script.
제1항에 있어서,
(d) 상기 액티비티의 실행이 종료되면 결과 파일을 액티브 폴더에 프로덕트로 출력하는 단계를 더 포함하는 클라우드 서비스 제공 방법.
The method according to claim 1,
(d) outputting the result file as a product to an active folder when execution of the activity is terminated.
제3항에 있어서, 상기 프로덕트는
상기 시뮬레이션과 연관된 메타데이터를 속성 정보로 포함하는 것을 특징으로 하는 클라우드 서비스 제공 방법.
4. The method of claim 3,
And the metadata associated with the simulation is included as attribute information.
제3항에 있어서, 상기 액티브 폴더는
상기 액티비티의 실행과 상기 프로덕트를 감시하는 모니터링 에이전트를 포함하는 것을 특징으로 하는 클라우드 서비스 제공 방법.
4. The method of claim 3, wherein the active folder
And a monitoring agent for monitoring the execution of the activity and the product.
제5항에 있어서, 상기 액티브 폴더는
상기 시뮬레이션의 실행 과정을 상기 프로덕트의 상태 전이로 나타내고,
상기 프로덕트의 상태 전이는 액티비티가 생성되는 준비 상태, 시뮬레이션 진행 중을 나타내는 생성 상태, 시뮬레이션의 종료를 나타내는 완료 상태 및 손상 상태 중 적어도 하나를 포함하는 것을 특징으로 하는 클라우드 서비스 제공 방법.
The method of claim 5, wherein the active folder
The execution process of the simulation is represented by a state transition of the product,
Wherein the state transition of the product includes at least one of a preparation state in which an activity is generated, a generation state indicating that simulation is in progress, a completion state indicating completion of simulation, and a damaged state.
제3항에 있어서,
(e) 상기 사용자 단말에 상주하는 액티브 폴더 클라이언트를 통해 상기 사용자 단말과 상기 액티브 폴더간의 동기화를 수행하고, 사용자 단말에 상기 프로덕트를 제공하는 단계를 더 포함하는 클라우드 서비스 제공 방법.
The method of claim 3,
(e) performing synchronization between the user terminal and the active folder through an active folder client residing in the user terminal, and providing the product to the user terminal.
KR1020130140700A 2013-11-19 2013-11-19 Method of providing cloud service for managing remote simulation processes by file system commands KR102205651B1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
KR1020130140700A KR102205651B1 (en) 2013-11-19 2013-11-19 Method of providing cloud service for managing remote simulation processes by file system commands
KR1020210003916A KR102348354B1 (en) 2013-11-19 2021-01-12 Method of providing cloud service for managing remote simulation processes by file system commands

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020130140700A KR102205651B1 (en) 2013-11-19 2013-11-19 Method of providing cloud service for managing remote simulation processes by file system commands

Related Child Applications (1)

Application Number Title Priority Date Filing Date
KR1020210003916A Division KR102348354B1 (en) 2013-11-19 2021-01-12 Method of providing cloud service for managing remote simulation processes by file system commands

Publications (2)

Publication Number Publication Date
KR20150057383A true KR20150057383A (en) 2015-05-28
KR102205651B1 KR102205651B1 (en) 2021-01-21

Family

ID=53392263

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020130140700A KR102205651B1 (en) 2013-11-19 2013-11-19 Method of providing cloud service for managing remote simulation processes by file system commands

Country Status (1)

Country Link
KR (1) KR102205651B1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101645689B1 (en) * 2015-06-26 2016-08-05 (주)네모파트너즈엔이씨 The apparatus and method of cloud application moudule in public tender with smartphone

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20060063349A (en) * 2004-12-07 2006-06-12 한국전자통신연구원 System and method for support of embedded software development methodology with quantitative process management
JP2007148739A (en) * 2005-10-25 2007-06-14 Mitsubishi Materials Corp File management system and its program
KR20080087804A (en) * 2005-12-29 2008-10-01 마이크로소프트 코포레이션 Modeling user input and interaction in workflow based applications
KR20130089349A (en) * 2012-02-02 2013-08-12 (주)레이풀시스템 Virtual disk drive system and method thereof

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20060063349A (en) * 2004-12-07 2006-06-12 한국전자통신연구원 System and method for support of embedded software development methodology with quantitative process management
JP2007148739A (en) * 2005-10-25 2007-06-14 Mitsubishi Materials Corp File management system and its program
KR20080087804A (en) * 2005-12-29 2008-10-01 마이크로소프트 코포레이션 Modeling user input and interaction in workflow based applications
KR20130089349A (en) * 2012-02-02 2013-08-12 (주)레이풀시스템 Virtual disk drive system and method thereof

Non-Patent Citations (19)

* Cited by examiner, † Cited by third party
Title
"Cloud Computing: Distributed Internet Computing for IT and Scientific Research," in Internet Computing, IEEE, Sep. 2009.
"File Transfer Protocol," IETF RFC 959, 1985.
"FUSE: Filesystem in Userspace," <http://fuse.sourceforge.net/>
"HTTP Extensions for Distributed Authoring - WEBDAV," IETF RFC 2518, Standards Track, Feb. 1999.
"Hypertext Transfer Protocol - HTTP/1.1," IETF RFC 2616, Standards
"The anatomy of the grid," in International Journal of High Performance Computing Applications, Mar. 2001.
"Versioning extensions to WebDAV," IETF Internet Draft, Jan. 1999.
"Web Distributed Authoring and Versioning (WebDAV) Access Control Protocol," IETF RFC 3744, Standards Track, May 2004.
"WebDAV Access Control Protocol," IETF WebDAV Working Group, Oct. 2003.
"WEBDAV: IETF Standard for Collaborative Authoring on the Web," IEEE Internet Computing, pp.34-40, Sep./Oct. 1998.
"A Survey of Data Provenance in e-Science" in Journal of ACM Sigmod Record, Volume 34 Issue 3, Sep. 2005, 31-36
"Cloud Computing: Distributed Internet Computing for IT and Scientific Research", in Internet Computing, IEEE, Sept. 2009,
"MGrid: 분자 시뮬레이션 그리드 시스템", 정보과학회논문지, 시스템 및 이론 제33권 제7호, 2006.7, 380-389
"The anatomy of the grid" in International Journal of High Performance Computing Applications, Mar. 2001.
"Why and Where: A Characterization of Data Provenance" in 8th International Conference, Jan. 4-6, 2001.
"시뮬레이션 데이터 공유 및 재 실험을 위한 Glyco-MGrid시스템", 정보과학회 한국컴퓨터종합학술대회 논문집 제34권 제1호(B), 2007.6,
Dropbox <http://www.dropbox.com>
Google Drive <http://drive.google.com>
Track, Jun. 1999.

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101645689B1 (en) * 2015-06-26 2016-08-05 (주)네모파트너즈엔이씨 The apparatus and method of cloud application moudule in public tender with smartphone

Also Published As

Publication number Publication date
KR102205651B1 (en) 2021-01-21

Similar Documents

Publication Publication Date Title
US20210334301A1 (en) Design-time information based on run-time artifacts in transient cloud-based distributed computing clusters
Deelman et al. Data management challenges of data-intensive scientific workflows
US10275221B2 (en) Systems and methods for generating data visualization applications
US9336288B2 (en) Workflow controller compatibility
US7895156B2 (en) Method, system, and computer program product for implementing a model exchange framework generating a synchronization record in response to a model exchange request using fusion technology
US20200065136A1 (en) Design-time information based on run-time artifacts in a distributed computing cluster
WO2018133578A1 (en) Method and device for migrating virtual machine, computer storage medium, and electronic apparatus
US10282494B2 (en) Modeling and simulation of infrastructure architecture for big data
JP2022505216A (en) Dependency Graph Control Objects and Computation Pipeline Migration
Barreiro et al. The ATLAS production system evolution: new data processing and analysis paradigm for the LHC Run2 and high-luminosity
CN105227672B (en) The method and system that data are stored and accessed
Ahad et al. Comparing and analyzing the characteristics of hadoop, cassandra and quantcast file systems for handling big data
Lee et al. Implementation and performance of distributed text processing system using hadoop for e-discovery cloud service
Vergadia Visualizing Google Cloud: 101 Illustrated References for Cloud Engineers and Architects
KR102205651B1 (en) Method of providing cloud service for managing remote simulation processes by file system commands
KR102348354B1 (en) Method of providing cloud service for managing remote simulation processes by file system commands
Nagdive et al. A review of Hadoop ecosystem for bigdata
KR20170041713A (en) Method for unifying tool and information coming from multiple information sources, and computer program product and device using same
Parekh et al. Analytical modelling of distributed file systems (GlusterFS and CephFS)
Jamal et al. Performance Comparison between S3, HDFS and RDS storage technologies for real-time big-data applications
Rana Integration of big data analytics and the cloud environment in harnessing valuable business insights
Ma et al. Energy Big Data Storage and Parallel Processing Method Based on ODPs
Dos Anjos et al. BIGhybrid--A Toolkit for Simulating MapReduce in Hybrid Infrastructures
Choudhry HBase High Performance Cookbook
Kong Design and Implementation of the Big Data Management Decision System Based on the Hadoop Technology

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
E90F Notification of reason for final refusal
E701 Decision to grant or registration of patent right
A107 Divisional application of patent