KR20050054438A - 복수의 대기 자원의 사용량 관리 방법, 장치 및 프로그램제품 - Google Patents

복수의 대기 자원의 사용량 관리 방법, 장치 및 프로그램제품 Download PDF

Info

Publication number
KR20050054438A
KR20050054438A KR1020040089126A KR20040089126A KR20050054438A KR 20050054438 A KR20050054438 A KR 20050054438A KR 1020040089126 A KR1020040089126 A KR 1020040089126A KR 20040089126 A KR20040089126 A KR 20040089126A KR 20050054438 A KR20050054438 A KR 20050054438A
Authority
KR
South Korea
Prior art keywords
availability
standby
computer
resources
program code
Prior art date
Application number
KR1020040089126A
Other languages
English (en)
Other versions
KR100843587B1 (ko
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 인터내셔널 비지네스 머신즈 코포레이션
Publication of KR20050054438A publication Critical patent/KR20050054438A/ko
Application granted granted Critical
Publication of KR100843587B1 publication Critical patent/KR100843587B1/ko

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F15/00Digital computers in general; Data processing equipment in general
    • G06F15/16Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
    • 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/5083Techniques for rebalancing the load in a distributed system
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99951File or database maintenance
    • Y10S707/99952Coherency, e.g. same view to multiple users
    • Y10S707/99953Recoverability

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Hardware Design (AREA)
  • Hardware Redundancy (AREA)

Abstract

본 발명은 각 컴퓨터 사이에서 대기 자원에 대한 자격(entitlement)을 이동시키는 장치, 프로그램 제품 및 방법에 관한 것이다. 대기 자원은 소스 컴퓨터의 대응하는 자원을 이용 가능하지 않게 함으로써 수신지 컴퓨터에서 이용 가능하게 한다. 이로써, 이용 가능한 대기 자원의 총 수는 변하지 않지만, 가용성의 분배는 사용 요구에 따라서 재분배될 수도 있다. 필요하다면, 자격의 이동이 자동으로, 동적으로 및/또는 안전한 방식으로 행해질 수도 있다.

Description

복수의 대기 자원의 사용량 관리 방법, 장치 및 프로그램 제품{SYSTEM FOR TRANSFERRING STANDBY RESOURCE ENTITLEMENT}
본 발명은 컴퓨팅 시스템에 관한 것으로, 특히 데이터 처리 환경에서 임시 자원을 관리하는 것에 관한 것이다.
상용 및 관용 애플리케이션(commercial and government application)에 대한 컴퓨터 자원 요구는 흔히 시간에 따라 증가하거나 또는 변동한다. 예를 들면, 업무를 하다보면 통상의 처리량 또는 다른 기간의 메모리 요구를 초과하는 최고 활동 기간을 경험할 수도 있다. 다른 경우에는, 판매 또는 피고용인의 증가로 인해 자원의 요구를 증가시켜 기존의 컴퓨팅 자원에 부담을 줄 수도 있다. 이러한 자원 증가 요구에 직면할 때, 사용자는 통상 증가된 컴퓨팅 요구를 감당할 수 있는 새로운 하드웨어 자원을 구매해야 할 것이다. 이러한 구매 요구는, 미리 준비하지 않으면, 급속한 증가 요구에 반응할 재정 또는 시간이 충분치 못한 사용자에게 상당한 지출을 의미할 수 있다.
이 목적을 위해, IBM사에 의해 개발된 "용량 주문형(capacity on demand)" 설계와 같은 컴퓨팅 아티텍처는 고객이 필요에 따라 프로세서와 같은 자원을 효과적으로 처리하게 한다. 특히, 고객은 처음에는 자신의 기계(machine) 내에서 작동하지 않는 대기 프로세서를 일시적으로 작동 가능하게 할 수도 있다. 필요한 경우, 대기 프로세서는 기계의 주요한 기준 비용에 포함되지 않는다. 따라서, 비교적 작은 초기 자본 투자를 위해, 고객은 필요할 때 비용을 지불하고 대기 프로세서를 활성화 및 비활성화할 수도 있다.
대기 프로세서의 이러한 선택적인 이용은 고객에게 다른 주문형 프로세서 액세스층 및 최적화된 사용을 제공한다. 역으로, 용량 주문형 시스템(capacity on demand system)의 용량은 고객의 용량 및 비용 요구 사항을 만족시키는 생산적인 방법을 제공하며, 부가적으로 수입원을 증가시킨다.
용량 주문형 애플리케이션에 의해 제공된 유연성에도 불구하고, 대기 자원과 관련된 경제성은 일반적으로 호스트 컴퓨터에만 한정된다. 즉, 대기 자원은 통상 각 컴퓨터와 통합 구성된다. 따라서, 흔히 대기 자원을 여러 컴퓨터 사이에서 물리적으로 이동시켜 재배분하기가 쉽지 않다. 그 결과, 대기 자원을 포함하는 두 컴퓨터를 구비한 사용자가 제 1 컴퓨터 상에서 부가적인 대기 자원을 활성화하여 증가된 작업 부하를 처리해야 하는 경우가 발생할 수 있다. 동시에, 제 2 컴퓨터의 활성 대기 자원이 이용되지 않은 채로 남아 있을 수도 있다. 이러한 상황은, 컴퓨터가 지리적으로 분산되어 있거나 상이한 시간에 최고 작업 부하를 갖는 경우에 발생할 수도 있다. 예를 들면, 회사의 컴퓨터가 상이한 시간 영역에서 작동할 수도 있다. 따라서, 사용자가 이론적으로는 두 컴퓨터 사이에서 충분한 활성 대기 자원을 가지고 컴퓨터의 작업 부하를 처리할 수도 있지만, 실제로는 대기 자원이 작업 요구의 불일치(discrepancy)를 처리하기 위해 각각의 작업 부하에 비례하여 컴퓨터들 사이에 물리적으로 분산될 수 없다.
그러한 환경에서, 제 1 컴퓨터 상의 부가적인 대기 자원을 활성화시키는 것은 생산 할당량(production quotas)에 부정적인 영향을 미치고, 컴퓨터에게는 혼란스럽고 낭비적인 것으로 보여질 수 있다. 비용을 덜기 위해, 가능하다면 사용자는 컴퓨터들 사이에서 작업 할당을 꼼꼼하게 계획한다. 그러나, 대부분의 애플리케이션에서 작업 요구를 예측하는 것은 통상적으로 매우 어렵다. 부가적인 대기 프로세스의 활성화를 제한하기 위한 다른 방법은 부하 균형(load balancing)을 포함한다. 부하 균형은 컴퓨터들 사이에서의 작업의 이동을 포함한다. 이상적으로는, 부담이 큰 컴퓨터의 작업 부하가 사용중인 대기 자원을 갖는 컴퓨터에 재분배될 수 있다. 그러나, 이것이 가능하다 하더라도, 데이터의 전자적 이동은 시간 소모적이고 불편하며 비효율적이다. 따라서, 사용자는, 다른 컴퓨터에서 이용가능한 활성 자원을 가짐에도 불구하고, 흔히 작업 부하가 많은 컴퓨터에서 부가적인 대기 자원을 활성화시키는 것을 담당한다. 결과적으로, 용량 주문형 시스템 내의 가변 작업 부하를 처리하기 위한 개선된 메커니즘이 요구된다.
본 발명에 따른 일실시예는 종래 기술의 한계를 해결하는 방식으로 대기 자원의 가용성에 대한 자격을 이동시키도록 구성된 장치, 방법, 프로그램 제품을 포함한다. 즉, 컴퓨터의 각 대기 자원에 대한 자격(entitlement) 또는 가용성(availability)이 재할당되거나 또는 이동되어 컴퓨터 네트워크 내의 대기 자원을 이용하는 데 큰 유연성을 허용한다. 예를 들면, 본 발명에 따른 프로세스는 소스 컴퓨터에서 대응 자원을 이용 가능하지 않게 함으로써 수신지 컴퓨터에서 대기 자원을 이용 가능하게 한다. 이와 같이, 이용 가능한 대기 자원의 총 수는 변하지 않고 유지될 수도 있지만, 가용성의 분배(distribution of availability)가 동작 요구에 따라 재배분될 수도 있다. 이 이동(transfer)은 각 컴퓨터와 관련된 작업 부하 또는 대기 자원의 물리적인 이동을 요구하지 않고 수행될 수도 있다. 따라서, 이 특징은 효율을 보다 크게 하고 비용을 더욱 절감시킨다.
필요한 경우에는, 자격의 이동이 작업 부하 요구 및 자원의 가용성 변경에 응답하여 동적으로 또는 자동으로 이루어진다. 어떠한 경우든, 본 발명에 따른 프로세스는 요금 부과를 위한 자격 데이터베이스를 갱신하고 그렇지 않으면 유지할 수도 있으며, 자격 및 기타 책임을 이동시킬 수도 있다. 신용 서명(credit signature)이 생성되어 인코딩되고, 대기 자원이 실제로 이동되었으며 또는 이용가능하다는 것이 확인될 수도 있다. 활성 코드가 각 컴퓨터에서 대기 자원에 대한 각 가용성을 자동으로 갱신할 수도 있다.
본 발명의 원리에 따른 실시예들은 다수의 상이한 환경 및 시나리로로 구현되어, 소스와 수신지 컴퓨터 사이에서 이동 프로세스를 관리하는 자격 애플리케이션/컴퓨터를 포함하는 환경 및 계획을 포함할 수도 있다. 그러한 자격 컴퓨터는 대기 자원 가용성을 팔아 재분배시키도록 구성된 웹 기반의 애플리케이션 또는 중개 수수료(brokerage)를 포함하여 부가적인 수입 및 동작의 유연성을 생성할 수도 있다.
본 발명의 상기 및 다른 목적 및 이점은 첨부한 도면 및 그 상세한 설명으로부터 명확해질 것이다.
첨부한 도면은 전술한 본 발명의 일반적인 설명과 더불어 본 발명의 실시예를 설명하며, 후술하는 실시예의 상세한 설명은 본 발명의 원리를 설명하는 역할을 한다.
본 발명의 일실시예는 각 컴퓨터 사이의 대기 자원에 자격을 이동시키는 장치, 프로그램 제품 및 방법을 포함한다. 일실시예에서, 본 발명에 따른 프로세스는 소스 컴퓨터에서 대응하는 자원을 이용 가능하게 함으로써 대기 자원을 수신지 컴퓨터에서 이용 가능하게 한다. 이에 따라, 이용 가능한 대기 자원의 총 수가 변하지 않고 유지될 수 있지만, 가용성의 분배는 동작 요구에 따라서 재배분될 수도 있다. 필요한 경우에는, 자격의 이동이 자동으로 또는 동적으로 또는 안전한 방법으로 이루어질 수도 있다. 그러한 실시예의 실행에 적합한 하드웨어 환경이 도 1 내지 도 3b에 도시되어 있다.
하드웨어 및 소프트웨어 환경
도면에서, 유사한 번호는 여러 개의 도면에 걸쳐서 유사한 부분을 나타내며, 도 1은 본 발명에 따른 방식으로 대기 자원 자격의 이동을 구현하기에 적합한 컴퓨터 시스템(10)을 도시한다. 컴퓨터 시스템(10)은 하나 이상의 수신지 컴퓨터 및 소스 컴퓨터(12, 22)(예를 들면, 데스크탑 또는 PC 기반의 컴퓨터, 워크스테이션, 프로세서를 구비한 기계 등)를 각각 포함하는 네트워크에 연결된 컴퓨터 시스템으로서 도시되어 있다. 도 1의 블록도에 도시된 바와 같이, 수신지 컴퓨터(12)는 수신지 프로그램(24)을 포함한다. 컴퓨터(16, 22)는 자격 애플리케이션(26) 또는 소스 프로그램(28)을 각각 구비하지만, 유사하게 도시되어 있다. 아래에서 상세히 논의되는 바와 같이, 그러한 프로그램 코드(24-28)는 통상 본 발명의 원리에 따르는 방법으로 자원의 자격을 이동시키는 프로세스를 개시하거나 또는 실행하도록 구성된다. 프로그램 코드(24-28)는 도 1에 도시된 소스 컴퓨터, 수신지 컴퓨터 또는 자격 컴퓨터 상에 상주할 수도 있지만, 당해 분야에 통상의 지식을 가진 자라면, 본 발명의 원리에 따른 실시예가 시스템(10) 내의 단지 하나의 위치 또는 임의의 수의 위치에서 상주하는 프로그램 코드를 이용할 수도 있음을 알 수 있을 것이다.
컴퓨터(12, 22)는 네트워크(18)를 통해 서로 및/또는 자격 컴퓨터(16)(예를 들면, PC 기반의 서버, 미니컴퓨터, 중형 컴퓨터(midrange computer), 메인프레임(mainframe) 컴퓨터 등)에 결합되거나 통신한다. 네트워크(18)는 통상 근거리 통신망, 광역 통신망, 무선 통신망, 공중망(예를 들면, 인터넷)을 포함하는 네트워킹된 상호접속부를 나타낸다. 그러나, 당해 분야에 통상의 지식을 가진 자라면 네트워크 접속부(18)가 e 메일, 우편 메일(postal mail), 전화선, 팩스 등을 포함하는 종래의 통신 메커니즘을 포함하거나 또는 이들에 의해 확대되거나 또는 이들로 교체될 수도 있음을 이해할 수 있을 것이다. 또한, 임의의 수의 컴퓨터 및 다른 장치들이 네트워크(18)를 통해 네트워킹될 수도 있다.
각각의 컴퓨터(12, 16, 22)는 실제로는 임의의 유형의 컴퓨터, 컴퓨터 시스템 또는 기타 프로그램 가능한 전자 장치를 나타낼 수도 있다. 또한, 각각의 컴퓨터(12, 16, 22)는 예를 들어 클러스터 또는 기타 분산형 컴퓨팅 시스템 내의 하나 이상의 네트워킹된 컴퓨터를 이용하여 구현될 수도 있다. 여기서 설명된 기능을 구현할 수도 있는 하나의 특정 컴퓨터의 일례로서, 도 2는 논리적으로 분할된 컴퓨터 시스템(100)으로서 도 1의 수신지 컴퓨터(12)를 구현한 것을 도시하고 있다. 도 2의 컴퓨터(100)는 일반적으로 논리적 분할을 이용하는, 예를 들어 네트워크 서버, 중형 컴퓨터, 메인프레임 컴퓨터 등과 같은 다수의 멀티 유저 컴퓨터 중 어느 하나, 예를 들면 IBM eServer iSeries 컴퓨터를 나타낸다. 그러나, 본 발명은 다른 컴퓨터 및 데이터 처리 시스템에서 구현될 수도 있으며, 따라서 이 특정 구현예에 제한되지 않는다는 점에 유의하라.
도 2의 컴퓨터(100)는 일반적으로 버스(116)를 통해 메모리(114)에 결합된 하나 이상의 프로세서(112)를 포함한다. 각각의 프로세서(112)는 단일 스레디드 프로세서(single threaded processor) 또는 복수의 하드웨어 스레드(119)를 포함하는 프로세서(112a)와 같은 멀티스레디드 프로세서(multithreaded processor)로서 구현될 수도 있다. 대부분의 경우에, 멀티스레디드 프로세서(112a) 내의 각각의 하드웨어 스레드(119)는 컴퓨터 내에 상주하는 소프트웨어에 의해 독립적인 프로세서와 같이 취급된다. 이 점에 있어서, 이 목적을 위해, 단일 스레디드 프로세서가 단일 하드웨어 스레드, 즉 단일의 독립적인 실행 유닛을 포함하는 것으로 간주될 것이다. 그러나, 소프트웨어 기반의 멀티스레딩(multithreading) 또는 멀티태스킹(multitasking)이 단일 스레디드 프로세서 및 멀티스레디드 프로세서 모두와 관련하여 사용되어 컴퓨터 내의 다수의 태스크를 병렬로 수행하는 것을 추가로 지원할 수도 있다.
또한 도 2에 도시되어 있는 바와 같이, 하나 이상의 프로세서(112)(예를 들면, 프로세서(112b)가 서비스 프로세서로서 구현될 수도 있는데, 이것은 특화된 펌웨어 코드를 실행하여 시스템의 개시 프로그램 올려놓기(IPL; initial program load)를 관리하고, 시스템 하드웨어를 감시하고 분석하고 구성하는데 사용된다. 일반적으로, 컴퓨터(100)는 하나의 서비스 프로세서와 운열 시스템 및 컴퓨터에 상주하는 애플리케이션을 실행하는데 사용되는 복수의 시스템 프로세서를 포함하지만, 본 발명은 이 특정 실시예에 한정되지 않는다. 몇몇 예에서는, 서비스 프로세서가 버스(116)를 통하지 않는 방식으로 컴퓨터 내의 다양한 다른 하드웨어 요소에 결합될 수도 있다.
도 2에 도시된 바와 같이, 시스템 프로세서는 다른 대기 자원들 외에 대기 프로세서(118)를 포함한다. 이들 대기 프로세서(118)는 활성화될 때, 컴퓨터 내에서 다른 프로세서(112)로서 기능한다. 대기 프로세서(118)에 추가로 또는 대신에 컴퓨터(100)에서 이용될 수도 있는 부가적인 유형의 대기 자원은 통합 컴퓨터(integrated computer)(133), 예를 들면 IBM의 Integrated xSeries 서버와 같은 통합 카드 기반의 컴퓨터이다. Integrated xSeries 서버는 통상적으로 PCI 카드 상에서 마이크로소프트 윈도우즈 운영 체제의 버전을 실행하는 인텔 기반의 서버를 제공하는데, 이것은 IBM iSeries 서버 내의 PCI 슬롯에 플러그되어 iSeries 서버의 시스템 관리, 통신 및 저장 자원에 영향을 줄 수 있으며, 그렇지 않으면 독립적인 윈도우즈 기반의 서버로서 동작한다. 다른 형태의 통합 컴퓨터는 카드 기반형인 지에 상관없이 본 발명에 따라 사용될 수도 있다.
여기서 논의된 바와 같이, 본 발명의 원리에 따른 적절한 대기 자원은 컴퓨팅 환경의 할당가능한 요소 또는 기능을 포함할 수도 있다. 이에 따라, 전형적인 대기 자원은 다른 요소들 중에서 프로세서, 직접 액세스 저장 장치(DASD) 또는 기타 메모리, 플러그인 카드, 입력/출력 제어기, 어댑터 또는 디바이스 및 기타 하드웨어 장치를 포함할 수도 있다. 대기 자원은 또한 예를 들어 로컬 메모리에 결합된 다수의 프로세서를 포함하는 프로세서 카드와 같은 다수의 그러한 요소들 및 예를 들어 NUMA 기반의 구조를 위한 다른 요소들을 포함한다. 본 발명의 환경에서, 당해 분야에 통상의 지식을 가진 자라면, 그러한 대기 자원이 소스 컴퓨터와 수신지 컴퓨터 상에 존재할 수도 있음을 알 수 있을 것이다.
메모리(114)는 예를 들어 DRAM 기반의 주 저장 장치와 같은 하나 이상의 메모리 장치 레벨과, 하나 이상의 데이터, 인스트럭션 및/또는 컴비네이션 케시(combination cache) 레벨을 포함할 수도 있는데, 어떤 캐시는 개별 프로세서 또는 당해 분야에 공지되어 있는 다수의 프로세서 역할을 한다. 또한, 메모리(114)는 버스(120)를 통해, 하나 이상의 네트워크 어댑터(122)(컴퓨터를 네트워크(124)와 인터페이스하기 위한), 하나 이상의 저장 제어기(126)(컴퓨터를 하나 이상의 저장 장치(128)와 인터페이스하기 위한) 및 하나 이상의 워크스테이션 제어기(130)(복수의 워크스테이션 어댑터를 통해 하나 이상의 터미널 또는 워크스테이션(132)와 인터페이스하기 위한)와 같은 많은 유형의 외부 장치에 결합된다.
도 2는 파티션 관리자(136)에 의해 관리된 복수의 논리 파티션(134)을 포함하는 컴퓨터(100) 상의 논리적으로 분할된 컴퓨팅 환경을 구현하는데 이용된 자원 및 주 소프트웨어 요소를 상세하게 도시하고 있다. 임의의 수의 논리 파티션은 당해 분야에 공지되어 있는 바와 같이 지원될 수도 있으며, 컴퓨터 내에 언제라도 상주하는 논리 파티션의 수는 파티션이 컴퓨터로부터 추가되거나 또는 제거될 때 동적으로 제거될 수도 있다.
상술한 IBM의 eServer 기반의 구현예에서, 파티션 관리자(136)는 두 개의 프로그램 코드층으로 이루어진다. 제 1 프로그램 코드층은 본 명세서에서 지정 불능부(non-dispatchable portion)(138)로 지칭되며, 컴퓨터의 펌웨어 또는 허용된 내부 코드(LIC) 내에서 구현되는데, 이것은 하드웨어 액세스의 세부(detail)로부터 운영 체제와 같은 상위 층을 격리시키면서 다양한 하드웨어 요소에 대한 저 레벨 인터페이스를 제공하는 데 이용된다. 펌웨어는 또한 서비스 프로세서(112b)와 같은 서비스 프로세서와 통신할 수도 있다. 지정 불능 부분(138)은 페이지 테이블 관리 등과 같은 컴퓨터(100)에 대한 많은 저 레벨 파티션 관리 기능을 제공한다. 지정 불능부(138)는 또한 태스크의 개념을 갖지 않고, 소프트웨어의 상위 층으로부터 주로 함수 호출을 통해 액세스 가능하다.
파티션 관리자(136) 내의 제 2 프로그램 코드층은 본 명세서에서 실행 가능부(dispatchable portion)(147)라고 지칭된다. 태스크 개념을 갖지 않고 재배치 오프(relocation off)로 실행되며 소프트웨어의 상위 층으로부터의 함수 호출을 통해 액세스 가능한 지정 불능부(138)와는 대조적으로, 실행 가능부(147)는 태스크의 개념을 가지며(운영 체제와 같이) 재배치 온(relocation on)으로 실행된다. 지정 불능부는 통상 사용자로부터 숨겨진다는 것을 제외하면, 파티션과 거의 동일한 방식으로 실행된다. 지정 불능부는 일반적으로 파티션의 생성 및 삭제, 동시 I/O 유지 보수, 프로세서, 메모리 및 기타 하드웨어 자원을 다양한 파티션(134)에 할당하는 것과 같은 상위 레벨 파티션 관리 동작을 관리한다.
각각의 논리 파티션(134)은 통상 정적으로 및/또는 동적으로 컴퓨터(100) 내의 이용 가능한 자원의 일부를 할당받는데, 이것은 전용 자원 및 대기 자원 중 어느 하나 또는 둘 모두를 포함할 수도 있다. 예를 들면, 논리 파티션은 하나 이상의 프로세서(112) 및/또는 하나 이상의 하드웨어 쓰레드(119) 및 이용 가능한 메모리 공간의 일부를 할당받을 수도 있다. 논리 파티션은 프로세서와 같은 특정 하드웨어 자원을 공유할 수 있으며, 따라서 소정의 프로세서가 하나 이상의 논리 파티션에 의해 이용될 수 있다. 한편, 하드웨어 자원들이 한번에 하나의 논리 파티션에만 할당될 수 있다.
대신에, 예를 들어, 대량 저장 장치, 백업 저장 장치, 사용자 입력, 네트워크 접속, 통합 컴퓨터 및 I/O 어댑터와 같은 부가적인 자원이 통상적으로 당해 분야에 공지되어 있는 방식으로 하나 이상의 논리 파티션에 할당된다. 자원들은 예를 들어 버스 단위 또는 자원 단위의 다수의 방식으로 할당될 수도 있어, 다수의 논리 파티션이 동일 버스에 자원을 공유한다. 일부 자원은 동시에 복수의 논리 파티션에 할당될 수도 있다.
각각의 논리 파티션(134)은 분할되지 않은(non-partitioned) 컴퓨터의 운영 체제와 동일한 방식으로 논리 파티션의 주 동작을 제어하는 운영 체제(142)를 이용한다. 예를 들면, 각각의 운영 체제(142)는 IBM 사의 OS/400 운영 체제를 이용하여 구현될 수도 있다.
각각의 논리 파티션(134)은 별개의 또는 독립적인 메모리 공간을 실행하며, 따라서 각각의 논리 파티션은 각각의 그러한 논리 파티션에서 실행되는 각각의 사용자 애플리케이션(USER APP)(144)에서 보면 독립적인 분할되지 않은 컴퓨터와 거의 동일하게 작동한다. 이로써, 사용자 애플리케이션은 통상 분할 환경에서 사용하기 위한 어떠한 특별한 구성도 요구하지 않는다.
논리 파티션(134)의 특징이 별개의 가상 컴퓨터로서 주어지면, 파티션간 통신(inter-partition communication)을 지원하여 논리 파티션이 별개의 물리적인 기계인 것처럼 논리 파티션이 서로 통신하도록 허용하는 것이 바람직하다. 이로써, 몇몇 실시예에서는 지정 불능부(138) 내의 가상 LAN(146)을 지원하여 논리 파티션(134)이 이더넷 프로토콜과 같은 네트워킹 프로토콜을 통해 서로 통신하도록 허용하는 것이 바람직할 수도 있다. 파티션 간의 통신을 지원하는 다른 방식이 또한 본 발명에 따라서 지원될 수도 있다.
다른 논리적으로 분할된 환경이 본 발명에 따른 방식에 이용될 수도 있음을 알 수 있을 것이다. 예를 들면, 임의의 파티션(134)으로부터 분리되는 실행 가능부(147)를 이용하는 대신에, 실행 가능부의 기능이 대안으로 하나 이상의 논리 파티션에 포함될 수도 있다. 또한 도 2에 도시된 특정 자원들은 단순히 예시적인 것으로, 어떠한 자원들의 조합 또는 구성이 대안으로 어떠한 논리 파티션에도 할당될 수도 있다. 또한, 몇몇 실시예에서, 자원들은 동적 기준에 따라 재배치되어 다른 논리 파티션의 요구를 서비스할 수도 있다.
일반적으로, 본 발명의 실시예를 구현하기 위해 실행된 루틴은 운영 체제 또는 특정 애플리케이션, 요소(component), 프로그램, 오브젝트, 인스트럭션의 시퀀스 또는 모듈, 또는 심지어 그 부분 집합의 일부로서 구현된다 하더라도, 여기서는 "컴퓨터 프로그램 코드" 또는 간단히 "프로그램 코드"라고 지칭된다. 프로그램 코드는, 통상 컴퓨터 내의 다양한 메모리 및 저장 장치 내에 다양한 시간에 존재하며, 컴퓨터 내의 하나 이상의 프로세서에 의해 판독 및 실행될 때 컴퓨터로 하여금 본 발명의 다양한 측면들을 구현하는 단계들 또는 요소들을 실행하는데 필요한 단계들을 수행하도록 하는 하나 이상의 인스트럭션을 포함한다.
또한, 본 발명은 컴퓨터 및 컴퓨터 시스템을 포함하며 이하에서는 이들을 완전히 기능시키는 환경에서 설명되지만, 당해 분야에 통상의 지식을 가진 자라면 본 발명의 다양한 실시예들이 다수의 형태의 프로그램 제품으로서 배포될 수 있으며, 본 발명은 실제로 배포하기 위해 사용된 특정 유형의 신호 저장 매체에 관계없이 동등하게 적용된다는 것을 알 수 있을 것이다. 신호 저장 매체의 예로는 휘발성 및 비휘발성 메모리 장치, 플로피 디스크 및 기타 이동 가능한 디스크, 하드 디스크 드라이브, 자기 테이프, 광 디스크(예를 들면, CD-ROM, DVD 등)와 같은 기록 가능한 유형의 매체와, 디지털 및 아날로그 통신 링크와 같은 전송 유형의 매체가 있지만 이들에 한정되는 것은 아니다.
또한, 이하에 설명되는 다양한 프로그램 코드는 본 발명의 특정 실시예를 구현한 애플리케이션에 기초하여 식별될 수도 있다. 그러나, 다음의 어떠한 특정 프로그램 명칭도 단순히 편의를 위해 사용될 뿐이며, 따라서 본 발명이 그러한 명칭에 의해 식별되거나 또는 암시되는 어떠한 특정 애플리케이션에만 사용하도록 제한되는 것은 아님에 유의하라. 또한, 컴퓨터 프로그램이 루틴, 절차(procedure), 방법, 모듈, 오브젝트 등으로 구성될 수도 있는 수많은 방식 및 프로그램 기능이 통상적인 컴퓨터(예를 들면, 운영 체제, 라이브러리, API, 애플리케이션, 애플릿 등) 내에 상주하는 다양한 소프트웨어층들 사이에 할당될 수도 있는 다양한 방식이 주어지므로, 본 발명은 본 명세서에 개시된 프로그램 기능의 특정한 구성 및 할당에 제한되지 않는다.
도 3a는 도 1에 도시된 컴퓨터(12, 22)와 각각 유사한 수신지 컴퓨터 및 소스 컴퓨터(212, 222)를 포함하는 컴퓨터 시스템(200)을 도시한 것이다. 도 3b는 도 3a와 동일하지만 상이한 시점에서 동작하는 컴퓨터 시스템(200)을 도시한 것이다. 도 3a 및 3b에서와 같이, 컴퓨터 시스템(200)은 통신 링크 또는 접속부(218)를 포함할 수도 있다. 예시적인 네트워크 접속부(218)는 인터넷, 케이블링(cabling), 무선 통신, 팩스, 전화선 또는 사실상 임의의 다른 링크 또는 대기 자원을 이용 가능하게 하도록 하는 요구를 전달하기 위한 통신 메커니즘을 포함할 수도 있다. 이로써, 다른 실시예와 결합하여 종래의 우편 통신 및 프로세스를 포함할 수도 있다.
이상에서와 같이, 각각의 컴퓨터(212, 222)는 프로세서 및 하나 이상의 대기 자원(224 내지 238 및 242 내지 256)을 각각 갖는 메커니즘을 포함할 수도 있다. 당해 분야에 통상의 지식을 가진 자라면, 컴퓨터(212, 222)가 대기 자원의 자격을 이동시키는 프로그램 코드와 같은 전용 자원을 추가로 포함할 수도 있다는 것을 알 수 있을 것이다. 그러나, 도 3a 및 3b에는 예증을 위해 대기 자원만이 도시되어 있다. 본 명세서의 목적을 위해, 대기 자원은 프로세서, DASD(Direct Access Storage Device), 기타 메모리, 포트 또는 인에이블 및 디스에이블될 수 있는 임의의 하드웨어 또는 소프트웨어 자원을 포함할 수도 있다. 상업적 용어로, 적절한 자원은 요금을 지불하고 사용할 수 있고 그렇지 않으면 사용할 수 없는 하드웨어 또는 소프트웨어를 포함할 수도 있다.
컴퓨터(212, 222)는 또한 도 3a에 도시된 바와 같이 각각의 작업 부하(240, 258)를 포함한다. 대기 자원(224-238)은 통상적으로 작업 부하(C240)를 처리하는데 사용된다. 예를 들어, 대기 DASD 자원(230)은 작업 부하 C(240)를 포함하는 정보를 자기 디스크에 저장할 수도 있다. 다른 예에서, 대기 프로세서(224)가 작업 C(240)를 포함하는 프로그램 작업을 실행할 수도 있다. 어떠한 경우든, 하나 이상의 컴퓨터(212, 222)의 각각의 작업 부하(240, 258)는 시간에 따라 변동할 수도 있다. 결국, 작업 부하 C(240)와 관련된 요구가 부가적인 자원을 요구할 때가 있을 수도 있다. 즉, 대기 자원(232 내지 238)을 활성화하는 것이 바람직할 때가 있다. 본 발명의 원리에 따르면, 소스 컴퓨터(222)로부터 수신지 컴퓨터(212)로 대기 자원에 자격을 이동시키는 것이 가능하다. 따라서, 작업 부하 C(240)를 보다 많은 활성 자원 가용성을 갖는 다른 컴퓨터(222)로 이동할 필요가 없다는 점에 유의하라.
도 3a 및 3b는 수신지 컴퓨터(212)가 작업 부하 C(240)를 처리하기 위해 부가적인 자원 가용성을 요구하는 경우를 나타낸다. 수신지 컴퓨터(212)는 일시적으로 비활성 또는 이용 가능하지 않은 대기 자원(232 내지 238)을 포함한다. 예를 들면, 고객 동작형(customer operating) 수신지 컴퓨터(212)는 대기 자원(232 내지 238)을 이용 가능하게 하는데 비용을 지불하지 않을 수도 있다. 그러나 작업 부하 C(240)의 요구가 증가하면, 이제 컴퓨터(212)가 이들 대기 자원(232 내지 238)이용 가능하게 되도록 하는 것이 바람직하다. 컴퓨터(222)가 또한 대기 자원(242 내지 256)을 가지며, 이 모든 자원은 이용 가능한 것으로 도시되어 있다. 도 3a 및 3b에 도시된 경우에 있어서, 작업 C(240)와 관련된 임포트(import)는 작업 부하 D(258)와 관련된 것보다 높은 우선 순위 또는 더 큰 요구를 갖는 것으로 추측된다.
도 3b는 본 발명의 원리에 따라서 자격 이동이 완료된 후의 도 3a와 동일한 시스템을 도시한 것이다. 도 3b에 도시된 바와 같이, 수신지 컴퓨터(212)의 대기 자원은 작업 부하 C(240)를 처리하는데 이용 가능하게 되었다. 역으로, 컴퓨터(222)의 대기 자원(252 내지 256)은 이용 가능하지 않게 되었다. 즉, 세 개의 대기 자원의 자격 또는 가용성의 이동이 프로그램 방식으로 소스 컴퓨터(222)로부터 수신지 컴퓨터(212)로 개시되었다. 도 3a 및 3b에 도시된 실시예에서, 증가된 작업 요구를 수용하기 위해 컴퓨터(212, 222) 사이에서 각각의 작업 부하(240, 258)를 이용시키는 것은 불필요하였다.
도 1 내지 3b에 도시된 다양한 소프트웨어 요소들, 자원 및 기본적인 기능부는 다양한 컴퓨터 소프트웨어 애플리케이션, 루틴, 요소들, 프로그램, 객체, 모듈, 데이터 구조 및 프로그램을 포함하는 다수의 방식으로 구현될 수도 있다. 당해 분야에 통상의 지식을 가진 자라면, 도 1 내지 3b에 도시된 예시적인 환경이 본 발명을 한정하고자 하는 것이 아님을 알 수 있을 것이다. 예를 들면, 본 발명의 원리는 분할되지 않은 환경에도 적용될 수 있음에 유의하라. 또한, 도 1은 컴퓨터(12, 16, 20)를 도시하고 있으나, 단지 두 개의 컴퓨터만이 본 발명의 원리에 따라서 자격 이동 프로세스를 수행할 수도 있다. 사실, 다른 대안적인 하드웨어 및/또는 소프트웨어 환경이 본 발명의 범주를 벗어나지 않으면서 사용될 수도 있다.
이동된 자격 프로세스 (Transferred Entitlement Processes)
도 4의 순서도(300)는 본 발명의 원리에 따르는 예시적인 방법을 나타내며, 도 1 내지 3b의 하드웨어 환경 내에서 실행하기에 적합하다. 순서도(300)의 방법 단계들은 둘 이상의 컴퓨터 사이에서 대기 자원을 사용하기 위해 자격을 이동시키는데 특히 적합하다. 이들 소스 컴퓨터 및 수신지 컴퓨터에 의해 취해진 각각의 단계가 도 4에 자격 애플리케이션과 함께 특별한 역할로 도시되어 있다. 도 4에 도시되어 있는 바와 같이, 그러한 자격 이동 환경은 인터넷 웹 서버 또는 다른 자격 애플리케이션 또는 컴퓨터를 부가적으로 포함할 수도 있다.
도 4의 순서도(300)를 보다 구체적으로 살펴보면, 소스 컴퓨터(222)의 액세스를 이용 가능한 대기 자원(252 내지 256)으로 제한하는 요청이 블록(302)에서 발생된다. 이 요청은 소스 컴퓨터(222)와 관련된 식별자 및 수신지 컴퓨터(212)와 관련된 식별자를 포함할 수도 있다. 예를 들면, 요청은 수신지 컴퓨터(212)에 특정한 일련 번호를 포함할 수도 있다. 블록(304)에서 송신된 요청에 포함된 다른 정보는 이동될 다수의 또는 특정한 대기 자원을 포함할 수도 있다. 블록(302)에서의 이 요청이 발생하면, 이용 가능한 대기 자원(234 내지 238)을 갖는 수신지 컴퓨터(212)에서 이용 가능한 대기 자원의 요구가 인식되었다고 가정할 수도 있다. 어떠한 경우든, 이 요청은 블록(304)에서 자격 애플리케이션으로 전송된다.
블록(306)에 도신된 바와 같이, 요청이 수신되어 처리된다. 이러한 프로세싱은 수신지 컴퓨터 또는 소스 컴퓨터가 등록되어 있는지, 대기 자원 이동에 부합하거나 또는 적합한 지를 확인하는 단계를 포함할 수도 있다. 다른 프로세싱은 블록(306)에서 이동될 대기 자원의 수를 자동으로 판단하기 위해 기계의 날짜를 판독하는 단계를 포함할 수도 있다. 또 다른 프로세싱은 블록(306)에서 요청의 해독을 포함할 수도 있다. 도 4 내지 6의 순서도에 포함된 모든 통신에 있어서, 블록(302)에서 발생된 요청은 인코딩되거나 아니면 보안 및 기타 책임 추적성(accountability) 목적을 위해 암호화될 수도 있다.
블록(308)에서 데이터베이스의 상태가 검사된다. 이러한 데이터베이스는 이용 가능한 대기 자원에 적절한 상태 정보를 포함할 수도 있다. 예를 들어, 데이터베이스는 수신지 컴퓨터(212) 및 소스 컴퓨터(222) 모두 또는 이들 중 하나와 관련된 대기 자원의 리스팅을 포함할 수도 있다.
블록(310)에서, 소스 컴퓨터(222)에 의해 제공된 대기 자원의 가용성이 실제로 데이터베이스에 따라서 이동에 이용 가능한 지의 여부가 판정된다. 데이터베이스가 대기 자원의 가용성이 이동에 이용 가능하지 않다는 것을 나타내는 경우, 블록(312)에서 이동 시도는 실패할 수도 있다. 적절한 경우, 실패한 시도는 수신지 및 소스 컴퓨터 사용자 중 하나 또는 둘 모두에게 상황을 알리는 메시지를 수반할 수도 있다.
블록(310)에서 소스 컴퓨터(222)의 대기 자원의 가용성이 구체화되는 경우에, 활성 코드가 도 4의 블록(314)에서 생성된다. 여기서 논의되는 바와 같이, 활성화 코드(activation code)는 고유하며, 암호화되거나 또는 대기 자원의 가용성을 변경하도록 구성될 수도 있다. 이로써, 본 명세서의 목적을 위한 "활성화 코드"는 필요한 경우에 다운그레이드(downgrade), 업그레이드 및/또는 비활성화(deactivation) 프로세스를 포함할 수도 있다. 도 4의 블록(316)에서, 예를 들면, 소스 컴퓨터(222)로 보내진 활성화 코드는 소스 컴퓨터(222)로 하여금 대기 자원(252 내지 256)에 대한 가용성을 이동시키도록 한다.
도 4의 블록(318 및 320)은 본 발명에 따른 소스 컴퓨터(222)에서 수행된 내부 검사를 포함한다. 보다 구체적으로는, 블록(318)에서 다운그레이드 활성화 코드가 수신되어 처리된다. 그러한 처리는 얼마나 많은 및/또는 대기 자원이 자격 이동에 포함되는지에 대한 판단을 포함할 수도 있다.
본 발명에 따른 일실시예에서는, 도 4의 블록(320)에서 실제로 포기(relinquishment)에 이용 가능한 자원이 있는 지의 여부가 판단된다. 블록(320)에서의 이러한 검사는 대기 자원이 내부적으로 임계치로 지정되는 경우를 허용하거나 또는 소스 컴퓨터(222) 내의 그 기능에 따라서 다른 사용자 또는 관리자에 의해 포기하지 않도록 할 수도 있다. 예를 들면, 관리자가 프로그램으로 소정의 순간에 컴퓨터(222) 상에서 이용 가능한 채로 유지되어야 하는 대기 자원의 최소 요구를 확립할 수도 있다. 이러한 설정은 자격 요구에 대해 관례를 취할 수도 있다. 블록(320)에서 그러한 유지되어야 할 가용성이 존재하지 않으면, 블록(322)에서 대기 자원은 소스 컴퓨터(222)에 의해 이용된다. 보다 구체적으로는, 블록(322)에서 대기 자원의 가용성은 포기된다. 본 발명의 원리에 따르면, 자원 그 자체의 이동은 필요치 않고 그 자원에 액세스만 하면 된다.
블록(322)에서 제거된 가용성에 응답하여, 블록(324)에서 암호화된 신용 서명이 소스 컴퓨터(222)에 의해 생성될 수도 있다. 원한다면, 서명이 사용자의 개입없이 자동으로 생성될 수도 있다. 서명은 수신지 컴퓨터(212)와 관련된 일련 번호 또는 다른 식별자를 지정하는 요청 내에 포함될 수도 있다. 이 요청은 블록(328 및 330)에서 웹 애플리케이션에 의해 각각 송신 및 수신된다.
신용 서명은 블록(332)에서 확인된다. 이러한 확인은 양방향 암호화 소프트웨어와 같은 공지된 메커니즘을 이용하여 수행될 수도 있다. 블록(332)에서 서명이 확인되는 경우에, 블록(334)에서 자격 데이터베이스가 갱신된다. 즉, 데이터베이스가 수정되어 수신지 컴퓨터 및 소스 컴퓨터(212, 222) 모두 또는 어느 하나의 변경된 가용성 상태를 반영할 수도 있다.
블록(336)에서 새로운 활성화 코드가 생성된다. 새로운 활성화 코드는 수신지 컴퓨터 및 소스 컴퓨터(212, 222) 중 하나 또는 둘 모두에 각각 송신되는 하나 이상의 코드를 포함할 수도 있다. 예를 들면, 도 4의 블록(338)에서 활성화 코드가 수신지 컴퓨터(212)로 송신될 수도 있다. 블록(340)에서, 수신지 컴퓨터(212)는 코드를 수신하여 처리한다. 블록(342)에서, 코드는 대기 자원(234 내지 238)의 가용성을 개시하는 내부 인스트럭션을 포함할 수도 있다.
이와 같이 구성하면, 블록(336)에서 생성된 활성화 코드는 자격 이동과 관련된 요금의 생성을 시작한다. 예를 들면, 블록(348)에서 시스템(200)이 대기 자원 사용에 대한 과금과 관련되는 경우에, 과금에 대한 기준으로 사용된 사용량 데이터베이스를 갱신하기 위해 블록(350)에서 활성화 코드가 판독될 수도 있다. 어떠한 경우든, 당해 기술 분야에서 통상의 지식을 가진 자라면 본 발명의 원리에 따라서 블록(352)에서 자격 이동이 종료하기 전에 수행될 수도 있는 실질적으로 무한한 수의 애플리케이션 시나리오가 존재한다는 것을 알 수 있을 것이다.
도 5는 도 1 내지 3B의 하드웨어 환경에 의해 실행 가능하며, 본 발명의 원리에 따라서 대기 자원의 자격 이동을 중개하는데 특히 적합한 단계들의 순서를 갖는 순서도(400)이다. 따라서 상이한 개체는 대기 자원의 자격 트랜잭션에 포함될 수도 있다. 이것은, 예를 들어 대기 자원에 액세스하는 제 1 개체가 대기 자원을 다른 사용자 또는 중개인에게 빌려주거나 중개하도록 허용한다. 이러한 구성은 부가적인 수입 및 자원 활용으로 이어질 수도 있다. 이로써, 순서도(400)의 프로세스는 마스터/중개, 또는 대기 자원에 자격을 상업적으로 재할당하도록 구성된 자격 컴퓨터(16)의 환경에서 특정 애플리케이션을 가질 수도 있다.
도 5의 블록(402)을 구체적으로 살펴보면, 중개 컴퓨터(16)는 수신지 컴퓨터(212)로부터 자원 인에이블먼트(resource enablement)에 대한 요청을 수신할 수도 있다. 이와 같이 구성되면, 중개 컴퓨터(16)는 복수의 가입 수신지 컴퓨터로부터 복수의 그러한 요청을 수신할 수도 있다. 블록(404)에서 중개 컴퓨터(16)는 요청을 기록한다. 블록(406)에서, 가입자로서의 수신지 컴퓨터(212)의 상태 또는 본 발명에 따른 자격 이동 프로세스에 참가하도록 인증된 개체가 판정된다. 블록(406)에서 수신지 컴퓨터(212)가 적합하다고 판정되면, 도 5의 블록(410)에서 중개기(16)가 자격 데이터베이스에 액세스할 수도 있다. 그러한 데이터베이스는 수신지 컴퓨터(212)에 대기 자원의 가용성을 제공하기 위해 포기될 수도 있는 대기 자원에 속하는 정보를 포함할 수도 있다. 도 5의 블록(412)에서, 이 데이터베이스는 적절한 대기 자원이 이용 가능한 지의 여부를 판정하는데 사용될 수도 있다.
본 발명의 원리에 따른 일실시예에서, 포기에 적합한 대기 자원은 블록(414)에서 선택 또는 프로그램 가능한 방안에 따라서 알아낼 수도 있다. 예를 들면, 관리자가 먼저 특정 소스 컴퓨터(222)로부터 대기 자원을 찾아내도록 중개 컴퓨터(16)를 프로그램할 수도 있다. 이것은 블록(402)에서 소스 컴퓨터(222)의 대기 자원이 통상 이용되지 않을 때 시간 프레임 동안 요청이 이루어진 경우일 수도 있다. 이 경우는 상이한 시간 영역에서 동작하는 수신지 컴퓨터와 소스 컴퓨터 사이에 발생할 수도 있다.
블록(416)에서, 본 발명의 원리에 따른 자격 이동을 수행하는 목적을 위한 하나 이상의 컴퓨터가 선택된다. 적절한 수신지 컴퓨터(212)를 찾아내기 위한 유사한 판정이 본 발명의 원리에 따른 다른 실시예의 개시에서 발생할 수도 있는데, 여기서, 블록(402)에서 이루어진 요청은 대기 자원의 가용성을 중개 컴퓨터(16)로 판매하거나 또는 포기하고자 하는 소스 컴퓨터(222)에 의한 요청이다. 어떠한 경우든, 활성화/비활성화 코드는 블록(418)에서 생성되며 블록(419)에서 찾아낸 소스 기계(212)로 송신된다.
블록(420)에서, 중개 컴퓨터(16)는 블록(418)에서 비활성화 코드 전송에 응답하여 신용 서명을 수신할 수도 있다. 중개 컴퓨터(16)는 블록(422)에서 서명의 인증을 확인할 수도 있다. 블록(422)에서의 이러한 처리는 포기된 대기 자원의 수를 확인하는 단계를 포함할 수도 있다. 이와 같이 구성된 경우, 블록(424)에서 확인이 기록된다. 블록(426)에서 수신지 컴퓨터와 소스 컴퓨터 사이에서와 같이 이용 가능한 대기 자원의 새로운 분배 및 할당을 반영하도록 자격 데이터베이스가 부가적으로 갱신될 수도 있다.
블록(428)에서, 새로운 자격 또는 활성화 코드가 생성되어 송신된다. 예시적인 자격 코드가 어떠한 및/또는 얼마나 많은 대기 자원이 작업에 이용 가능하게 되는 지를 판정하도록 수신 컴퓨터에 의해 처리된다. 예를 들면, 활성화 코드는 이용 가능한 소정의 대기 자원을 자동으로 형성하는 전자 키를 포함할 수도 있다.
블록(430)은 수신지 컴퓨터(212)에서 이용 가능한 대기 자원의 끝을 재촉하는 경우를 나타낸다. 블록(430)에서의 이러한 이벤트(event)는 계약 또는 정해진 시간의 만료를 포함할 수도 있다. 즉, 중계 컴퓨터(16) 내부의 카운트는 새로 허용된 대기 자원의 가용성이 포기되는 것을 나타낼 수도 있다. 블록(430)에서의 다른 예시적인 이벤트는 조회될 대기 자원의 가용성을 요구하는 수신지 컴퓨터 또는 소스 컴퓨터로부터의 요청을 포함할 수도 있다. 어떠한 경우든, 432에서 이벤트가 기록되고, 도 5의 블록(433)에서 새로운 활성화 코드가 생성되어 (이전의) 수신지 컴퓨터(212)로 송신된다. 그 다음에, 중개 컴퓨터(16)는 이전의 수신지 컴퓨터(212)로부터 블록(434)에서 대기 자원에 대한 가용성이 포기되었음을 확인하는 서명을 수신할 것이다. 블록(402)에서 후속 요청을 수신하는 것을 예상하여 블록(426)에서 자격 데이터베이스가 갱신된다.
도 6은 본 발명의 원리에 따른 방식으로 두 컴퓨터 사이에서 직접 대기 자원에 자격을 이동시키는데 적합한 단계들의 시퀀스를 갖는 순서도(500)이다. 즉, 순서도(500)의 단계들은 소스 컴퓨터 및 수신지 컴퓨터만 포함하는 자격 트랜잭션에 특히 적합하다. 도 4 및 5에 도시된 실시예의 경우에서와 같이, 개체를 관리 또는 중개하지 않으면 트랜잭션을 감독하거나 용이하게 한다. 이로써, 도 6의 순서도(500)의 프로세스들은 그들을 실행하는 각각의 수신지 또는 소스 컴퓨터에 따라서 분할된다.
보다 구체적으로는, 도 6의 블록(502)에서 수신지 컴퓨터(212)는 예를 들어 증가된 작업 부하를 달성하기 위해 부가적인 자원을 필요로 한다는 인식한다. 블록(504)에서 수신지 컴퓨터(212)가 이용 가능한 대기 자원을 갖는 경우, 수신지 컴퓨터(222)는 가용성 제거를 위해 블록(506)에서 활성화 코드의 생성을 초기화한다. 예시적인 활성화 또는 비활성화 코드는 소스 컴퓨터(222)에 의해 판독 가능한 인스트럭션을 포함할 수도 있다. 블록(508)에서 송신된 비활성화 코드가 수신되고, 블록(510)에서 처리된다. 이러한 처리는 수신지 컴퓨터(212)가 이용 가능하게 만든 대기 자원의 수를 판정하는 단계를 포함한다.
도 6의 블록(512)에서, 소스 컴퓨터(212)가 요청된 수의 대기 자격에 대한 가용성을 포기할 수 있다. 소스 컴퓨터(222)가 자격을 이동시킬 수 없는 경우, 수신지 컴퓨터(212)는 블록(514)에서 생성된 실패 신호를 블록(516)에서 수신할 수도 있다. 또는, 소스 컴퓨터(222)는 적절한 경우에 블록(518)에서 대기 자원에 대한 액세스를 포기할 것이다. 소스 컴퓨터(222)는 포기에 응답하여 그리고 이 포기를 증명하여, 블록(520)에서 서명을 추가로 생성할 수도 있다.
서명은, 블록(522, 524)에서 각각 수신지 컴퓨터(212)에 의해 송신 및 수신될 수도 있다. 블록(526)에서 수신지 컴퓨터(212)는 서명을 처리할 수도 있다. 이러한 프로세싱은 신호의 암호화 및 해독 단계 및/또는 소스 컴퓨터(222)가 포기된 대기 자원에 대한 액세스를 포기하였음을 프로그램으로 승인하는 단계를 포함할 수도 있다. 응답으로, 이들 대기 자원이 수신지 컴퓨터(212)에 이용 가능하게 될 도 있다. 블록(528, 530)에서, 내부 데이터베이스 또는 소스 컴퓨터 및 수신지 컴퓨터(222, 212)의 재고는 각각 대기 자원의 가용성의 새로운 분배를 반영하여 갱신될 수도 있다.
실제로는, 주문형 이동 웹사이트 애플리케이션이 소스 컴퓨터(222) 상의 액세스 용량의 다운그레이드를 요구하는데 사용되어, 다른 수신지 컴퓨터(212)로 이동될 수도 있다. 이 수신지 컴퓨터(212)는 허가되지 않은 대기 용량을 가질 수도 있다. 이로써 대기 자원에 대한 액세스는 증가된 작업 요구를 수행할 수 있게 될 수도 있다. 웹사이트 애플리케이션은 자격 데이터베이스에 액세스하여 소스 기계(222)에 포기한 액세스에 대한 대기 자원의 수와 동일한 양을 대변(credit)한다. 웹사이트 애플리케이션은 그 다음에 소스 컴퓨터의 대기 자원의 자격을 감소시키는 활성화 코드를 생성한다. 활성화 코드 또는 인에이블먼트 키는 소스 컴퓨터(222)의 대기 자원을 억제(disable)하는데 사용되며 따라서 이들은 활성화 코드의 수신 시에 자동으로 수신지 컴퓨터(212)에 사용하는 것이 가능하게 된다. 이 활성화 코드가 소스 기계(222)에 입력되면, 소스 컴퓨터에 이용 가능한 대기 자원은 감소된다. 소스 컴퓨터(222)에 의해 생성된 신용 서명은 웹사이트 애플리케이션으로 송신되어 다운그레이드가 수행되었는지를 확인한다. 그 다음에 웹사이트는 활성화 코드를 생성하여 수신지 기계(212)로 송신하여 대응하는 수의 대기 자원이 수신지 기계에 이용 가능하게 한다. 이런 방식으로, 본 발명의 실시예는 프로그램을 이용하여 상이한 컴퓨터 애플리케이션 사이의 대기 자원으로 자격을 이동시킨다.
이런 방식으로, 컴퓨터의 각 대기 자원에 대한 가용성이 재할당되거나 또는 이동되어 유연성이 더 커진다. 이용 가능한 대기 자원의 총 수는 변하지 않으며, 가용성의 분배는 동작 요구에 따라서 유연하게 재분배될 수도 있다. 이 이동은 각 컴퓨터와 관련된 대기 자원 또는 작업 부하의 물리적인 이동을 요구하지 않고 수행될 수도 있다. 따라서 이 특징은 효율성을 더욱 크게 하고 비용을 더욱 절감시킨다. 또한, 자격의 이동은 작업 부하 요구 및 자원의 가용성을 변경시키는 것에 응답하여 자동으로 및/또는 동적으로 수행될 수도 있다. 예를 들면, 자원은 상이한 시간 영역 또는 상이한 컴퓨터가 상이한 시간에 최고 작업 부하를 갖는 다른 환경에서 동작하는 동일하거나 상이한 개체들 사이에서 교환될 수도 있다. 신용 서명은 대기 자원이 실제로 포기되었거나 또는 이용 가능하게 되었다는 것을 보장하며, 활성화 코드는 자동으로 각 컴퓨터에서 각각의 가용성을 갱신한다. 이렇게 구성된 경우, 실시예는 부가적인 수입 및 운영의 유연성을 생성학 위해 대기 자원의 가용성을 판매하여 재분배하도록 구성된 중개 또는 웹 기반의 애플리케이션을 포함할 수도 있다.
이상 본 발명을 다양한 실시예로서 설명하였고, 이들 실시예는 상당히 상세하게 설명되었지만, 이러한 설명은 첨부된 청구범위를 어떠한 방법으로든 제한하고자 하는 것은 아니다. 예를 들면, 상기 예시적인 순서도의 임의의 각 단계는 본 발명의 원리에 따라서 삭제되거나 증가되거나 다른 단계와 동시에 행해지거나 또는 변경될 수도 있다.
또한, 본 발명의 원리에 따른 컴퓨터 시스템은 사실상 어떠한 수의 네트워킹된 컴퓨터도 포함할 수도 있고, 본 발명의 환경에서 이들 컴퓨터들 간의 통신이 자격 애플리케이션에 의해 용이하게 될 수도 있지만, 당해 분야에 통상의 지식을 가진 자라면, 본 발명의 프로세스가 전술한 예에서와 같이 두 개의 컴퓨터 간의 직접 통신 또는 심지어 단일 컴퓨터의 내부 프로세스에도 적용할 수 있음을 알 수 있을 것이다. 당해 분야에 통상의 지식을 가진 자라면 부가적인 이점들 및 변형들을 쉽게 알 수 있을 것이다. 따라서, 본 발명은 보다 넓은 측면에서 상술한 예, 장치 및 방법을 나타내는 특정한 부분으로 한정되지 않는다. 따라서, 본 발명의 일반적인 신규한 사상의 범위로부터 벗어나지 않고 이러한 부분으로부터 새로운 발전이 이루어질 수도 있다.
본 발명에 따르면, 컴퓨터의 각 대기 자원에 대한 자격(entitlement) 또는 가용성(availability)이 재할당되거나 또는 이동되어 유연하게 컴퓨터 네트워크 내의 대기 자원을 이용할 수 있다. 또한, 이용 가능한 대기 자원의 총 수는 변하지 않고 유지될 수 있으며, 가용성의 분배(distribution of availability)가 동작 요구에 따라 재배분될 수도 있다. 이 이동(transfer)은 각 컴퓨터와 관련된 작업 부하 또는 대기 자원의 물리적인 이동을 요구하지 않고 수행될 수도 있어, 효율이 향상되고 비용이 절감된다.
도 1은 본 발명에 따른 네트워크에 연결된 컴퓨터 시스템(networked computer system)의 블록도.
도 2는 도 1의 컴퓨터 내의 자원 및 주 소프트웨어 요소의 블록도.
도 3은 상이한 순간에 본 발명에 따른 네트워크에 연결된 컴퓨터 시스템 내의 대기 자원(standby resource)의 각각의 가용성을 도시한 블록도.
도 4는 도 1의 하드웨어 환경 내에서 대기 자원의 실행을 이용하기 위한 자격(entitlement)을 이동시키는데 적합한 예시적인 방법 단계를 포함하는 순서도.
도 5는 도 1의 하드웨어 환경 내에서 대기 자원의 자격 이동을 중개하는데 적합한 예시적인 방법 단계를 포함하는 순서도.
도 6은 도 1의 하드웨어 환경에서 두 컴퓨터 사이의 대기 자원에 직접 자격을 이동시키는데 적합한 예시적인 방법 단계를 포함하는 순서도.
도면의 주요 부분에 대한 부호의 설명
12 : 수신지 컴퓨터
16 : 자격 컴퓨터
18 : 네트워크
22 : 소스 컴퓨터
24 : 수신지 프로그램
26 : 자격 애플리케이션
28 : 소스 프로그램
112 : 시스템 프로세서
112a : 시스템 프로세서
112b : 서비스 프로세서
118 : 대기 프로세서
119 : HW 쓰레드
122 : 네트워크 어댑터
124 : 네트워크
126 : 저장 제어기
130 : 워크스테이션 제어기
133 : 통합 컴퓨터
134 : 파티션
138 : 파티션 관리자(지정 불능부)
142 : 운영 시스템
144 : 사용자 애플리케이션
146 : 가상 LAN
147 : 파티션 관리자(실행 가능부)

Claims (36)

  1. 복수의 컴퓨터 내에 포함된 복수의 대기 자원(standy resource)의 사용량(usage)을 관리하는 방법 -상기 복수의 컴퓨터의 각 컴퓨터는 상기 복수의 자원 중 적어도 하나의 대기 자원을 포함함- 에 있어서,
    상기 복수의 컴퓨터 중 소스 컴퓨터 내에 포함된 제 1 대기 자원에 대한 가용성(availability)을 제한하는 단계와,
    상기 가용성을 상기 복수의 컴퓨터 중 수신지(destination) 컴퓨터 내에 포함된 제 2 대기 자원으로 프로그램 방식으로(programmatically) 이동시키는(transferring) 단계
    를 포함하는 복수의 대기 자원의 사용량 관리 방법.
  2. 제 1 항에 있어서,
    상기 가용성을 이동시키는 단계는 상기 가용성 제한을 확인하는 단계를 더 포함하는 복수의 대기 자원의 사용량 관리 방법.
  3. 제 1 항에 있어서,
    상기 가용성을 이동시키는 단계는 상기 소스 컴퓨터와 수신지 컴퓨터 사이에서와 같이 상기 제 1 및 제 2 대기 자원의 물리적 분배를 유지하는 단계를 더 포함하는
    복수의 대기 자원의 사용량 관리 방법.
  4. 제 1 항에 있어서,
    상기 가용성을 이동시키는 단계는 상기 소스 컴퓨터와 수신지 컴퓨터 사이에서와 같이 각각의 작업 부하를 유지하는 단계를 더 포함하는
    복수의 대기 자원의 사용량 관리 방법.
  5. 제 1 항에 있어서,
    상기 가용성을 이동시키는 단계는 자격 데이터베이스를 갱신하는 단계를 더 포함하는
    복수의 대기 자원의 사용량 관리 방법.
  6. 제 1 항에 있어서,
    상기 가용성을 제한하는 단계는 상기 가용성을 다운드레이드(downgrade)하기 위한 요청을 생성하는 단계를 더 포함하는
    복수의 대기 자원의 사용량 관리 방법.
  7. 제 1 항에 있어서,
    자격 애플리케이션 컴퓨터(entitlement application computer)를 사용하여 상기 이용량을 관리하는 단계를 더 포함하는
    복수의 대기 자원의 사용량 관리 방법.
  8. 제 1 항에 있어서,
    상기 가용성을 제한하는 단계는 상기 가용성을 업그레이드(upgrade)하기 위한 요청을 생성하는 단계를 더 포함하는
    복수의 대기 자원의 사용량 관리 방법.
  9. 제 1 항에 있어서,
    상기 가용성을 제한하는 단계는 상기 가용성을 나타내는 서명을 생성하는 단계를 더 포함하는
    복수의 대기 자원의 사용량 관리 방법.
  10. 제 1 항에 있어서,
    상기 가용성을 제한하는 단계는 활성화 코드를 생성하는 단계를 더 포함하는
    복수의 대기 자원의 사용량 관리 방법.
  11. 제 1 항에 있어서,
    상기 가용성을 제한하는 단계는 상기 제 1 대기 자원을 판정하는 단계를 더 포함하는
    복수의 대기 자원의 사용량 관리 방법.
  12. 제 1 항에 있어서,
    상기 가용성을 이동시키는 단계는 상기 제 2 대기 자원을 판정하는 단계를 더 포함하는
    복수의 대기 자원의 사용량 관리 방법.
  13. 제 1 항에 있어서,
    상기 가용성을 이동시키는 단계는 활성화 코드를 생성하는 단계를 더 포함하는
    복수의 대기 자원의 사용량 관리 방법.
  14. 제 1 항에 있어서,
    상기 가용성을 이동시키는 단계는 상기 이동과 관련된 데이터를 저장하는 단계를 더 포함하는
    복수의 대기 자원의 사용량 관리 방법.
  15. 제 1 항에 있어서,
    상기 가용성을 이동시키는 단계는 자격 데이터베이스를 이용하여 가용성의 상태를 판정하는 단계를 더 포함하는
    복수의 대기 자원의 사용량 관리 방법.
  16. 제 1 대기 자원을 포함하는 소스 컴퓨터와,
    제 2 대기 자원을 포함하는 수신지(destination) 컴퓨터와,
    상기 소스 컴퓨터 및 수신지 컴퓨터 중 적어도 하나와 통신하는 프로그램 코드 -상기 프로그램 코드는 상기 제 1 대기 자원에 대한 가용성 제한을 시작하고 프로그램 방식으로 상기 가용성을 상기 제 2 대기 자원으로 이동시키도록 구성됨-
    를 포함하는 장치.
  17. 제 16 항에 있어서,
    상기 제 1 및 제 2 대기 자원의 각각의 가용성에 대한 기록(record)을 포함하는 메모리를 더 포함하는
    장치.
  18. 제 16 항에 있어서,
    상기 가용성을 관리하는 자격 컴퓨터를 더 포함하는
    장치.
  19. 제 16 항에 있어서,
    상기 프로그램 코드는 상기 가용성 확인을 시작하는
    장치.
  20. 제 16 항에 있어서,
    상기 제 1 및 제 2 대기 자원의 물리적인 분배는 상기 소스 컴퓨터와 수신지 컴퓨터 사이에서와 동일하게 되는
    장치.
  21. 제 16 항에 있어서,
    상기 소스 컴퓨터와 수신지 컴퓨터 사이에서와 같이 각각의 작업 부하는 상기 프로그램 방식의 이동에 의해 영향을 받지 않는
    장치.
  22. 제 16 항에 있어서,
    상기 프로그램 코드는 자격 데이터베이스 갱신을 시작하는
    장치.
  23. 제 16 항에 있어서,
    상기 프로그램 코드는 상기 가용성을 다운그레이드하기 위한 요청 생성을 시작하는
    장치.
  24. 제 16 항에 있어서,
    상기 프로그램 코드는 상기 가용성을 업그레이드하기 위한 요청 생성을 시작하는
    장치.
  25. 제 16 항에 있어서,
    상기 프로그램 코드는 상기 가용성을 나타내는 서명(signature) 생성을 시작하는
    장치.
  26. 제 16 항에 있어서,
    상기 프로그램 코드는 활성화 코드 생성을 시작하는
    장치.
  27. 제 16 항에 있어서,
    상기 프로그램 코드는 상기 제 1 대기 자원 판정을 시작하는
    장치.
  28. 제 16 항에 있어서,
    상기 프로그램 코드는 상기 제 2 대기 자원 판정을 시작하는
    장치.
  29. 제 16 항에 있어서,
    상기 프로그램 코드는 상기 프로그램 방식 이동과 관련된 데이터 저장을 시작하는
    장치.
  30. 제 16 항에 있어서,
    상기 프로그램 코드는 자격 데이터베이스를 사용하여 가용성 상태 판정을 시작하는
    장치.
  31. 제 1 대기 자원을 포함하는 소스 컴퓨터와 제 2 대기 자원을 포함하는 수신지 컴퓨터와 통신하는 프로세서와,
    상기 프로세서에 의해 실행 가능하며, 상기 제 1 대기 자원에 대한 가용성 제한을 시작하고 상기 가용성을 상기 제 2 대기 자원으로 프로그램 방식으로 이동시키도록 구성된 프로그램 코드
    를 포함하는 장치.
  32. 제 31 항에 있어서,
    상기 프로그램 코드는 또한 상기 프로그램 방식의 이동과 관련된 요금 생성을 시작하도록 구성되는
    장치.
  33. 프로세서와,
    상기 프로세서와 통신하는 제 1 대기 자원과,
    상기 제 1 대기 자원에 대한 가용성 -상기 가용성은 수신지 컴퓨터의 제 2 대기 자원으로 이동됨- 제한을 시작하도록 구성된 상기 프로세서에 의해 실행 가능한 프로그램 코드
    를 포함하는 장치.
  34. 프로세서와,
    상기 프로세서와 통신하는 제 1 대기 자원과,
    상기 제 1 대기 자원에 대한 가용성 -상기 가용성은 소스 컴퓨터의 제 2 대기 자원으로부터 이동됨- 증가를 시작하도록 구성된 상기 프로세서에 의해 실행 가능한 프로그램 코드
    를 포함하는 장치.
  35. (a) 제 1 및 제 2 대기 자원에 대한 액세스를 갖는 소스 컴퓨터 및 수신지 컴퓨터 중 적어도 하나와 각각 통신하는 프로그램 코드 -상기 프로그램 코드는 상기 제 1 대기 자원에 대한 가용성 제한을 시작하고 상기 가용성을 상기 제 2 대기 자원으로 프로그램 방식으로 이동시키도록 구성됨- 와,
    (b) 상기 프로그램 코드를 저장하는 신호 저장 매체
    를 포함하는 프로그램 제품.
  36. 제 35 항에 있어서,
    상기 신호 저장 매체는 기록 가능한 매체와 전송 유형의 매체 중 적어도 하나를 포함하는
    프로그램 제품.
KR1020040089126A 2003-12-04 2004-11-04 복수의 대기 자원의 이용 관리 방법, 장치 및 프로그램 제품 KR100843587B1 (ko)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US10/728,016 US7454502B2 (en) 2003-12-04 2003-12-04 System for transferring standby resource entitlement
US10/728,016 2003-12-04

Publications (2)

Publication Number Publication Date
KR20050054438A true KR20050054438A (ko) 2005-06-10
KR100843587B1 KR100843587B1 (ko) 2008-07-04

Family

ID=34633606

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020040089126A KR100843587B1 (ko) 2003-12-04 2004-11-04 복수의 대기 자원의 이용 관리 방법, 장치 및 프로그램 제품

Country Status (4)

Country Link
US (2) US7454502B2 (ko)
JP (1) JP3974913B2 (ko)
KR (1) KR100843587B1 (ko)
CN (1) CN1315076C (ko)

Families Citing this family (26)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7349904B2 (en) * 2004-09-02 2008-03-25 International Business Machines Corporation Method and apparatus for managing access to set of converged entitlement resources
US7500140B2 (en) * 2004-12-15 2009-03-03 International Business Machines Corporation System for on demand task optimization
TWI302712B (en) * 2004-12-16 2008-11-01 Japan Science & Tech Agency Nd-fe-b base magnet including modified grain boundaries and method for manufacturing the same
US7281070B2 (en) * 2005-01-28 2007-10-09 International Business Machines Corporation Multiple master inter integrated circuit bus system
US7937616B2 (en) * 2005-06-28 2011-05-03 International Business Machines Corporation Cluster availability management
US8104041B2 (en) * 2006-04-24 2012-01-24 Hewlett-Packard Development Company, L.P. Computer workload redistribution based on prediction from analysis of local resource utilization chronology data
US8650296B1 (en) * 2006-10-31 2014-02-11 Hewlett-Packard Development Company, L.P. Workload reallocation involving inter-server transfer of software license rights and intra-server transfer of hardware resources
US8386391B1 (en) * 2007-05-01 2013-02-26 Hewlett-Packard Development Company, L.P. Resource-type weighting of use rights
US20080276060A1 (en) * 2007-05-01 2008-11-06 Erik Bostrom Pre-Configured Partitions With Use-Rights Limitations
US7908610B2 (en) * 2007-07-31 2011-03-15 Microsoft Corporation Multi-threaded business programming library
WO2009072186A1 (ja) * 2007-12-04 2009-06-11 Fujitsu Limited リソース貸出制御装置、リソース貸出方法およびリソース貸出プログラム
US8005654B2 (en) * 2007-12-17 2011-08-23 Nokia Corporation Method, apparatus and computer program product for intelligent workload control of distributed storage
US8793363B2 (en) * 2008-01-15 2014-07-29 At&T Mobility Ii Llc Systems and methods for real-time service assurance
US9740640B2 (en) * 2008-09-25 2017-08-22 Dell Products L.P. System integrated teaming
WO2010046966A1 (ja) 2008-10-21 2010-04-29 富士通株式会社 情報処理システムおよび使用権一元管理方法
US20100131959A1 (en) * 2008-11-26 2010-05-27 Spiers Adam Z Proactive application workload management
US8244559B2 (en) * 2009-06-26 2012-08-14 Microsoft Corporation Cloud computing resource broker
US8838910B2 (en) 2010-06-07 2014-09-16 International Business Machines Corporation Multi-part aggregated variable in structured external storage
US8341368B2 (en) 2010-06-07 2012-12-25 International Business Machines Corporation Automatic reallocation of structured external storage structures
US8819691B2 (en) * 2011-05-04 2014-08-26 International Business Machines Corporation Logical partition defragmentation within a data processing system
US9311194B1 (en) * 2014-03-28 2016-04-12 Google Inc. Efficient resource utilization in data centers
US9923929B2 (en) 2015-11-20 2018-03-20 Nasdaq, Inc. Systems and methods for in-session refresh of entitlements associated with web applications
US10002100B2 (en) * 2016-02-02 2018-06-19 Xilinx, Inc. Active-by-active programmable device
US10701141B2 (en) * 2016-06-30 2020-06-30 International Business Machines Corporation Managing software licenses in a disaggregated environment
CN108401000A (zh) * 2017-02-07 2018-08-14 联想企业解决方案(新加坡)有限公司 用于通信网络中的权利转移的方法和装置
CN109583183B (zh) * 2018-12-03 2020-04-14 无锡华云数据技术服务有限公司 客户端管理方法及装置

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5544347A (en) * 1990-09-24 1996-08-06 Emc Corporation Data storage system controlled remote data mirroring with respectively maintained data indices
US5938732A (en) * 1996-12-09 1999-08-17 Sun Microsystems, Inc. Load balancing and failover of network services
US6260068B1 (en) * 1998-06-10 2001-07-10 Compaq Computer Corporation Method and apparatus for migrating resources in a multi-processor computer system
US6411991B1 (en) * 1998-09-25 2002-06-25 Sprint Communications Company L.P. Geographic data replication system and method for a network
KR20000054398A (ko) * 2000-06-03 2000-09-05 전준현 폐쇄형 웹 호스팅 서비스 시스템
US6651182B1 (en) * 2000-08-03 2003-11-18 International Business Machines Corporation Method for optimal system availability via resource recovery
US6957251B2 (en) * 2001-05-07 2005-10-18 Genworth Financial, Inc. System and method for providing network services using redundant resources
US7933983B2 (en) * 2002-12-17 2011-04-26 Hewlett-Packard Development Company, L.P. Method and system for performing load balancing across control planes in a data center
US7451183B2 (en) * 2003-03-21 2008-11-11 Hewlett-Packard Development Company, L.P. Assembly and method for balancing processors in a partitioned server

Also Published As

Publication number Publication date
CN1315076C (zh) 2007-05-09
KR100843587B1 (ko) 2008-07-04
US20090043877A1 (en) 2009-02-12
US20050125521A1 (en) 2005-06-09
US7720972B2 (en) 2010-05-18
US7454502B2 (en) 2008-11-18
JP2005166052A (ja) 2005-06-23
JP3974913B2 (ja) 2007-09-12
CN1624676A (zh) 2005-06-08

Similar Documents

Publication Publication Date Title
KR100843587B1 (ko) 복수의 대기 자원의 이용 관리 방법, 장치 및 프로그램 제품
US8108196B2 (en) System for yielding to a processor
JP3954774B2 (ja) 論理的に区画化されたコンピュータにおける同時使用ライセンスの管理
US8185907B2 (en) Method and system for assigning logical partitions to multiple shared processor pools
US7840965B2 (en) Selective generation of an asynchronous notification for a partition management operation in a logically-partitioned computer
US7356574B2 (en) Apparatus and method for providing dynamic and automated assignment of data logical unit numbers
US7770173B2 (en) System for dynamic processor enablement
US20040044643A1 (en) Managing multiple virtual machines
US7958218B2 (en) System for determining unreturned standby resource usage
GB2421602A (en) Managing the failure of a master workload management process
KR20030019592A (ko) 동적 호스트 서비스 관리를 제공하기 위한 방법 및 시스템
CN101118521A (zh) 跨越多个逻辑分区分布虚拟输入/输出操作的系统和方法
US5761696A (en) Parallel database serving mechanism for a single-level-store computer system
US20060168214A1 (en) System for managing logical partition preemption
WO2005098572A1 (en) System and method for licensing and distribution of i/o in partitioned computer systems
US20020116506A1 (en) Cross-MVS system serialized device control
US20050086430A1 (en) Method, system, and program for designating a storage group preference order
KR101925404B1 (ko) 인메모리 기반 이중화 지원 가상화 서비스 제공 시스템
JP5224065B2 (ja) ディスクアレイ装置、その管理方法、及びプログラム

Legal Events

Date Code Title Description
A201 Request for examination
AMND Amendment
E902 Notification of reason for refusal
AMND Amendment
E601 Decision to refuse application
J201 Request for trial against refusal decision
AMND Amendment
E902 Notification of reason for refusal
B701 Decision to grant
GRNT Written decision to grant
FPAY Annual fee payment

Payment date: 20120525

Year of fee payment: 5

FPAY Annual fee payment

Payment date: 20130524

Year of fee payment: 6

LAPS Lapse due to unpaid annual fee