CN109491855B - 管理计算设备的方法 - Google Patents
管理计算设备的方法 Download PDFInfo
- Publication number
- CN109491855B CN109491855B CN201710817399.6A CN201710817399A CN109491855B CN 109491855 B CN109491855 B CN 109491855B CN 201710817399 A CN201710817399 A CN 201710817399A CN 109491855 B CN109491855 B CN 109491855B
- Authority
- CN
- China
- Prior art keywords
- operating system
- data
- controller
- computing device
- management
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3003—Monitoring arrangements specially adapted to the computing system or computing system component being monitored
- G06F11/3031—Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system component is a motherboard or an expansion card
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3058—Monitoring arrangements for monitoring environmental properties or parameters of the computing system or of the computing system component, e.g. monitoring of power, currents, temperature, humidity, position, vibrations
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3089—Monitoring arrangements determined by the means or processing involved in sensing the monitored data, e.g. interfaces, connectors, sensors, probes, agents
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/32—Monitoring with visual or acoustical indication of the functioning of the machine
- G06F11/324—Display of status information
- G06F11/325—Display of status information by lamps or LED's
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/38—Information transfer, e.g. on bus
- G06F13/40—Bus structure
- G06F13/4004—Coupling between buses
- G06F13/4027—Coupling between buses using bus bridges
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/28—Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
- H04L12/40—Bus networks
- H04L12/40052—High-speed IEEE 1394 serial bus
- H04L12/40091—Bus bridging
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/28—Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
- H04L12/40—Bus networks
- H04L12/40052—High-speed IEEE 1394 serial bus
- H04L12/40123—Interconnection of computers and peripherals
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/02—Standardisation; Integration
- H04L41/0246—Exchanging or transporting network management information using the Internet; Embedding network management web servers in network elements; Web-services-based protocols
- H04L41/026—Exchanging or transporting network management information using the Internet; Embedding network management web servers in network elements; Web-services-based protocols using e-messaging for transporting management information, e.g. email, instant messaging or chat
Abstract
一种管理计算设备的方法包括:经由计算设备的控制器接收数据的第一步骤,该数据要被提供给计算设备的操作系统或由计算设备的操作系统用于对计算设备的管理;确定计算设备的操作系统是否准备好接收或利用来自控制器的数据的第二步骤;以及当或仅当操作系统准备好接收或利用数据时将数据从计算设备的控制器传送到操作系统的第三步骤。
Description
技术领域
本专利申请涉及管理计算设备的方法。专利申请还涉及用于管理的一个或多个计算设备。计算设备可以被称为主计算机、网络主机、计算机、网络设备或连接到计算机网络的电子设备。
背景技术
在计算机网络中,如VNC(虚拟网络计算)、SSH(安全Shell)或甚至串行端口等带内管理是基于带内连接性。相比之下,带外管理涉及使用专用信道来管理网络设备。带外管理允许网络运营商在访问网络资源的管理功能中建立信任边界。带外管理还可用于确保管理连接性,包括独立于其他带内网络组件的状态来确定任何网络组件的状态的能力。然而,与可用于带内控制的操作功能相比,带外管理通常具有非常有限的功能。
发明内容
专利申请旨在提供一种或多种新的和有用的管理计算设备的方法。该专利申请还旨在提供用于管理(managing)或管理(management)的一个或多个新的和有用的计算设备。专利申请的基本特征由一个或多个独立权利要求提供,而专利申请的有利特征分别由其从属权利要求提供。
根据一方面,本申请提供了一种管理计算设备(例如,主计算机)的方法。该方法包括:经由计算设备的控制器接收数据的第一步骤,该数据要被提供给计算设备的操作系统或由计算设备的操作系统用于对计算设备的管理;确定计算设备的操作系统是否准备好接收或利用来自控制器的数据的第二步骤;以及当或仅当操作系统准备好接收或利用数据时将数据从计算设备的控制器传送到操作系统的第三步骤。这些方法步骤中的一些步骤可以被改变顺序、被划分或被组合。
数据可以是文件或多个文件的形式,诸如可执行文件。例如,数据包括用于安装或更新硬件组件的设备驱动器。控制器可以是可选地独立于计算设备的操作系统的管理控制器或卫星控制器。例如,控制器包括经由称为智能平台管理总线/桥接器(IPMB)的系统接口的基板管理控制器(BMC),其是I2C(内部集成电路)的增强型实现。BMC经由智能平台管理控制器(IPMC)总线或桥接器连接到卫星控制器或另一机箱中的另一BMC。智能平台管理接口(IPMI)可选地由可能利用远程管理控制协议(RMCP)来管理的远程管理卡采用。
根据该方法,接收数据的步骤可以有可能独立于计算设备的CPU(中央处理单元)、固件(作为BIOS的基本输入/输出系统或作为UEFI的统一可扩展固件接口)和/或操作系统(OS)被执行。接收数据的步骤通常由网络连接或计算机端口经由一个或多个导线或者无线地进行。
接收数据的步骤可选地经由计算设备的控制器的带外管理连接被执行,而带外管理卡或远程管理卡可以使用物理上分离的网络连接器。通常,带外管理卡或远程管理卡具有部分或完全独立的电源,并且可以通过相关网络对计算设备通电和断电。
本申请的实施例提供了一种带外管理的方法。该方法包括:由连接到主计算机的外部工作站的基板管理控制器(BMC)在远程管理卡处接收文件或数据的第一步骤。BMC是远程管理卡所采用的智能平台管理接口(IPMI)的、除其他管理控制器之外的主控制器。外部工作站也称为可拆卸地连接到主计算机的管理客户端或控制节点。例如,管理客户端经由远程管理卡被远程连接到主计算机。
该方法还包括由基板管理控制器向主计算机的操作系统代理通知关于远程管理卡处的文件或数据的可用性的第二步骤。操作系统代理可选地是安装在主计算机的操作系统(OS)上的软件实现,并且能够直接或间接地通过BMC与远程管理卡通信。因此,操作系统代理由操作系统调节以执行指定的任务。更具体地,操作系统代理可操作以可选地通过采用IPMI作为计算机接口规范或通信协议来执行与BMC相关的任务。操作系统代理还被配置为协作或辅助主计算机的操作系统来提示、通知或协助由操作系统可执行的任务。例如,操作系统代理处理与主计算机的硬件和软件资源的管理相关(诸如与提供用于计算机程序或固件的公共服务相关)的任务。更具体地,操作系统代理包括驱动器更新代理或驱动器代理,其能够处理与主计算机的一个或多个设备驱动器相关的任务。设备驱动器是操作或控制附接到主计算机的特定类型的硬件设备的计算机程序。设备驱动器或仅驱动器为一个或多个硬件设备提供软件界面,使得操作系统和其他计算机程序能够访问硬件功能,而无需知道正在使用的硬件的精确细节。因此,本方法可以能够防止由BMC安装的固件和设备驱动器(由相关硬件设备的操作系统安装)之间的不匹配。主计算机的使用变得平滑、稳定且可靠。
该方法还包括由基板管理控制器、操作系统代理、操作系统或这些中的任一项的组合将文件或数据(例如,设备驱动器或驱动器映像文件)传送(例如,发送或复制)到主机的第三步骤。该方法还包括由主计算机的操作系统使文件或数据生效的第四步骤。例如,通过更新硬件和软件组件的注册表来使操作系统生效。因此,主计算机的操作系统使相关或对应记录最新。操作系统代理充当安装在操作系统上的应用软件,并且操作系统可以提示或辅助操作系统以保持主计算机最新、安全或平滑运行。例如,操作系统代理辅助操作系统维护利用应用程序和配置代码组成的库,以构建单一内核,其是可能部署到云或嵌入式环境的专用、单个地址空间的、机器映像。
操作系统代理或驱动器更新代理促进主计算机的远程管理,而不会干扰或中断主计算机的连续使用。事实上,驱动器更新代理在驱动器映像传送期间执行驱动器映像文件传送而不影响操作系统或主机。驱动器图像传送完成时,驱动器更新代理向操作系统通知就绪,并且不会干扰连续使用。相比之下,操作系统仅在相关硬件或主计算机就绪时开始安装接收到的驱动器映像文件。由于经由BMC的文件或数据传送是安全的,所以管理客户端被直接从访问主计算机的操作系统分离。防止主计算机处的敏感或机密用户数据被不必要地暴露给管理客户端。因此,主计算机具有执行与操作系统有关的任务(诸如提供驱动器更新)的自由、安全性和灵活性。
该方法还可以包括无论计算系统的操作系统是否准备好从控制器接收数据而使数据生效的步骤。例如,如果操作系统准备好接收或执行数据,则数据被生效。控制器在数据的生效之后可选地被通知。一旦操作系统对从远程管理卡接收(例如,通过采用智能平台管理接口)的文件或数据执行相关操作,则可能由操作系统代理、驱动器更新代理或操作系统通知基板管理控制器。基板管理控制器还可以通知管理客户端,使得管理客户端处的管理员能够决定主计算机的未来步骤。因此,基板管理控制器在对文件采取行动之后保持连接方(例如主计算机、远程管理客户端)被通知。
应用或方法的实施例提供计算设备的控制器在数据被生效之后由控制器接收状态更新。在由操作系统使数据生效之后,操作系统和控制器也可以在彼此之间发送状态更新。之后可以采取适当的步骤,使得计算设备的高效操作不被危害。
该方法还可以包括计算设备的控制器监视传送数据的请求。例如,控制器检查操作系统是发送请求还是准备好接收数据以由基板管理控制器从外部工作站传送文件。在一个实施例中,基板管理控制器检查(例如,通过采用智能平台管理接口或IPMI)主计算机或远程管理卡是否具有足够的存储器来存储驱动器映像文件。如果操作系统的对应或现有驱动器已经是最新的,则基板管理控制器有时会拒绝驱动器映像文件。BMC、操作系统代理或驱动器更新代理的监控或检查提高了使用基板管理控制器的可靠性、安全性和保密性。
应用或方法的其他实施例还包括计算设备的控制器发送关于数据的可用性的通知的步骤。操作系统或与操作系统相关的其他控制器在接收到关于远程管理卡处的文件的可用性的通知之后,可选地响应(例如,接受存储在主计算机的存储器中、等待或拒绝)于基板管理控制器,以用于通过主计算机的操作系统代理、驱动器更新代理或操作系统传送到主计算机。因此,管理客户端、远程管理卡和主计算机具有用于管理客户端与远程管理卡之间以及管理卡与主计算机之间的通信的规则。
由操作系统使文件或数据生效的步骤包括执行文件,如果文件单独可执行。因此,BMC促进应用程序文件、驱动器映像文件或针对BMC和管理客户端之间的安全传输所必需的任何文件的传送。例如,执行文件的步骤包括在计算设备或主计算机的操作系统内安装设备驱动器或固件。
本方法可选地包括在安装设备驱动器之前确定或检查设备驱动器的硬件组件是否就绪(例如,相关应用被关闭)的步骤。因此,驱动器更新代理、主计算机的操作系统或其他相关软件应用是智能的,以根据情况来决定必要的动作。例如,如果硬件组件正在使用,则驱动器更新代理将向操作系统停止其用于安装对应或现有驱动器或驱动器映像文件的请求。如果硬件组件就绪并且存在足够的系统资源,则主计算机将在操作系统处立即安装驱动器或驱动器映像文件,使主计算机最新。
该方法有时还包括在使文件或数据生效之后向基板管理控制器或外部工作站发送状态更新(例如消息)的步骤。例如,BMC在使文件或数据生效之后向管理客户端发送另外的消息。发送状态更新的持续时间或次数可能由BMC或管理客户端确定或影响。状态更新适用于管理客户端、BMC或操作系统。
在某些情况下,该方法还包括将文件的版本与安装在操作系统内的对应或现有文件进行比较的步骤。当尝试在主计算机的操作系统处更新驱动器时,操作系统代理或更新代理(即,驱动器更新代理)可以允许在比较步骤之后对相关文件(例如,固件、驱动器映像文件)的安装,如果操作系统处的对应或现有文件过时或损坏。
使文件或数据生效的步骤可以包括如果对应或现有文件比该文件更合适,则将对应或现有文件保持为被安装在操作系统内。因此,操作系统代理或驱动器更新代理具有执行、安装、传送、复制、转发或丢弃从管理客户端接收到的文件的自由或智能(即,预定的系统逻辑或程序)。
根据另一方面,本申请提供了一种计算设备,其包括:操作系统;以及耦合到该操作系统的控制器,该控制器被配置为接收数据,该数据要被提供给操作系统以用于对所述计算设备的管理。操作系统包括代理,其被配置为确定操作系统是否准备好从控制器接收数据,以及当或仅当操作系统准备好从控制器接收数据时从控制器接收数据。操作系统可选地可操作以请求文件或数据从控制器的传送。控制器还可选地可操作以向操作系统发送关于文件或数据的可用性的通知。
控制器可以被配置为独立于计算设备的操作系统或固件执行。控制器可以被配置为经由带外管理连接(诸如经由远程管理卡)来接收数据。控制器可以包括用于与操作系统的代理通信的板管理控制器(BMC)。
该应用的其它实施例提供了一种用于通过带外管理方法使文件生效的主计算机(例如,计算设备)。主计算机包括用于由基板管理控制器操作的远程管理卡;具有微处理器的主板;以及安装有主计算机的操作系统和操作系统的操作系统代理的存储器。远程管理卡可操作以通过基板管理控制器接收文件,并且向操作系统代理通知关于远程管理卡处的文件的可用性。微处理器、处理器或微控制器可操作以通过操作系统、可能在主计算机的存储器处使文件生效。
操作系统代理或操作系统的代理可以包括能够接收或管理来自管理客户端的驱动器映像文件的驱动器更新代理。驱动器更新代理(即,更新代理)可操作以与操作系统通信,以便更新主计算机的硬件组件的驱动器。例如,驱动器更新代理可选地被配置为确定主计算机的现有驱动器、向操作系统提示关于驱动器的新的可用性、比较驱动器的版本、或者与驱动器或硬件组件驱动器相关的任何其他任务。此外,驱动器更新代理可以可操作以在安装设备驱动器之前确定计算设备的硬件组件是否就绪。操作系统可以进一步可操作以在数据被生效之后向控制器发送状态更新。操作系统可以可操作以请求数据从控制器的传送。操作系统可以附加地可操作以向操作系统发送关于数据的可用性的通知。驱动器更新代理可以将管理员从直接接触操作系统中解脱,防止安全问题或对主计算机的中断。
操作系统或处理器还可以可操作以使文件或数据生效以确定是否要从基带管理控制器接收数据。远程管理卡可以可操作以检查(例如,允许存储到卡存储器中、等待或拒绝)由基板管理控制器从外部工作站传送文件的要求。
控制器还可选地可操作以向操作系统发送关于数据的可用性的通知。操作系统或微处理器可以附加地可操作以执行作为由操作系统调节的文件的数据,以用于使文件或数据生效。例如,微处理器还可操作以通过执行文件来安装由操作系统调节的设备驱动器或固件。在一些情况下,微处理器还可操作以在安装设备驱动器之前检查设备驱动器的硬件组件是否就绪(例如,相关应用是否被关闭)。可选地,微处理器还可操作以在文件或数据被生效之后向基板管理控制器或外部工作站发送状态更新(例如,消息、映像文件)。
应用的实施例提供了操作系统或微处理器还可操作以将由控制器或操作系统接收到的数据与操作系统内的对应数据进行比较。例如,微处理器还可操作以当对应或现有文件比该文件更合适时将对应或现有文件保持安装在操作系统上。在一些情况下,如果对应数据比由控制器或操作系统接收到的数据更适合,则操作系统可操作以将对应数据保持在操作系统内。
附图说明
附图示出了实施例并且用于解释所公开的实施例的原理。然而,应当理解,这些附图仅仅是为了说明的目的,而不用于定义对相关发明的限制。特别地,
图1示出了经由基板管理控制器(BMC)连接到管理客户端的主计算机;
图2示出了采用智能平台管理接口(IPMI)的远程管理卡;
图3示出了主机的外部机箱上的计算机端口;
图4示出管理客户端的过程流;
图5示出了在设备驱动器更新过程期间BMC的过程流程图;
图6示出了在设备驱动器更新过程期间BMC向其邮箱发送的过程流程图;
图7示出了在设备驱动器更新过程期间更新代理的过程流程图;
图8示出了在设备驱动器更新过程期间主计算机的过程流程图。
具体实施方式
现在将参考上述附图描述本申请的示例性、非限制性实施例。
图1示出了主计算机104,其经由其板管理控制器(BMC)108被连接到外部管理客户端102,它们被统称为带外管理100。管理客户端102也称为控制节点或电连接到主计算机104的外部计算机。管理客户端102是具有显示屏、输入键盘、中央处理单元(CPU)和若干计算机端口(未示出)的计算机。主计算机104是运行安装在主计算机104的操作系统105上的应用软件包的计算服务器或工作站。特别地,BMC 108是嵌入在主计算机104的主板上的专用微控制器。主计算机104还安装有更新代理106,其是应用软件。外部管理客户端102经由双绞线连接到BMC 108,双绞线被称为支持250MHz带宽和10GBASE-T(10吉比特以太网)的LAN(局域网)连接。
管理客户端102提供管理控制以更新任务发起和远程管理主计算机104。电连接110为数据或电信号传输提供安全可靠的通信信道。主计算机104驻留在数据中心中,并且根据安装的软件包连续执行多个任务(例如,货币交易)。主计算机104的BMC 108具有计算机端口,包括以太网端口和串行端口。管理客户端102与BMC之间的通信不由主计算机104的操作系统105处理。相反,BMC 108利用外部管理客户端102或管理客户端计算机102提供映像传送、状态检查和进度报告。
主计算机104具有软件实现(即,应用软件包)形式的更新代理106。更新代理106具有与BMC 108的直接通信信道,不受阻碍地或绕过主计算机的操作系统105(OS),因此不访问主机计算机104外的端点或者打开用于外部访问的端口。更新代理106和BMC 108之间的直接通信信道通过许多协议被实现,诸如KCS(键盘控制器规格)、USB(通用串行总线)上的以太网和PCIe(快速外围部件互连)。KCS是在BMC 108和IPMI(智能平台管理接口)架构中的净荷处理器之间使用的接口。
IPMI定义了用于计算机系统的带外管理和监视主计算机104的操作的一组接口或通信协议。例如,IPMI提供管理主计算机104的方式,主机计算机104可以通过使用与硬件而非与操作系统105或登录shell的网络连接被断电或以其他方式无响应。IPMI是基于消息的硬件级接口规范。IPMI独立于操作系统105(OS)操作,以在没有操作系统105或系统管理软件的情况下远程地管理主计算机104。
图2示出了采用智能平台管理接口(IPMI)111的基板管理控制器(BMC)108。IPMI由主控制器实现,称为基板管理控制器(BMC)108和分布在不同系统模块之间的其他管理控制器,被称为卫星控制器。这些卫星控制器经由称为智能平台管理总线/桥接器(IPMB)114的系统接口与BMC 108共享相同的机箱,其是I2C(内部集成电路)112的增强型实现。BMC 108经由智能平台管理控制器(IPMC)总线连接到卫星控制器。BMC 108将利用远程管理控制协议(RMCP)来被管理,其是本规范定义的专用线路协议。RMCP+(即,具有比RMCP更强的认证的基于UDP的协议)被用于LAN上的IPMI。
基板管理控制器(BMC)108在IPMI架构中提供智能。BMC 108是嵌入在主计算机104的主板上的专用微控制器。BMC108管理系统管理软件和平台硬件之间的接口。用于嵌入式应用的BMC 108具有有限的存储器,并且需要优化的固件代码来实现完整的IPMI功能。高度集成的BMC 108提供复杂的指令和完整的主机104的带外功能。BMC 108仓库的现场可替换单元(FRU)持有潜在可替换设备的库存清单,诸如供应商ID和制造商。BMC 108的传感器数据记录(SDR)仓库提供存在于主板上的各个传感器的属性。例如,BMC 108持有用于温度、风扇速度和电压的传感器。
不同类型的传感器被构建在计算机系统内,向BMC108报告关于诸如温度、冷却风扇速度、电源状态、操作系统105(OS)状态等参数。BMC108监视传感器并且可操作以当参数中的任何参数不保持在预设限制内、指示主计算机104的潜在故障时,经由网络110向管理客户端102发送警报。管理员还可以与BMC 108远程通信以采取一些纠正动作,诸如重置或重新启动系统以使挂起的OS再次运行。这些能力节省了拥有主计算机104的总成本。
到BMC 108的物理接口包括SMBus 116总线、具有带有RS-232串行控制台124和超级输入/输出(I/O)126的开关逻辑122的串行端口120、地址和数据线以及智能平台管理总线(IPMB)114,其使得BMC 108能够从主计算机104中的其他管理控制器114、118、122、126接收IPMI请求消息128。SMBus 116总线主要用于边带管理,其中经由网络接口卡118与正常操作共享主计算机104的数据链接。
当连接110本身被保护时,到BMC 108的直接串行连接不被加密。通过LAN(局域网)到BMC 108的连接110基于主计算机104的用户的特定安全性考虑来利用加密。
图3示出了主计算机104的外部机箱144上的计算机端口130~136,其包括控制台端口130、管理端口132、辅助端口134和两个数据端口136。连接端口130~136是与驻留在主计算机104的主板上的BMC108的连接接口。
管理端口132、控制台端口130和数据端口136使用CAT(类别)5电缆连接,其用于计算机网络(例如,以太网)的结构化布线。相关电缆标准提供高达100MHz的性能,并且适用于大多数种类的双绞线上的以太网。CAT 5还用于携带其他信号,诸如电话和视频。连接到连接端口130~136的连接器由TIA-568以及连接器的多边形尺寸定义,TIA-568定义八导体100欧姆平衡双绞线电缆的引脚/配对分配。
管理端口132(由TIA-568定义的网络端口)、控制台端口130(串行端口)和辅助端口134(串行端口)在主计算机104的带外模式中被操作。两个数据端口136属于联网端口,并且操作在带内模式处。辅助端口134,其使用USB上的以太网,其提供经由USB端口连接以太网设备的能力。本文中的以太网设备将被使用并被表示为管理客户端102。当在管理客户端102和主计算机104之间建立有电连接时,管理端口132和具有发光二极管(LED)“链接”138的两个数据端口136指示建立的链接。管理端口132的“活动”LED 140和数据端口136处的“模式”LED 142闪烁指示主动传输。
图4示出了管理客户端102的过程流150。在管理客户端102处更新设备驱动器107的方法150包括以下步骤。首先,管理客户端102向主计算机104的BMC 108发送更新设备驱动器107的请求152。管理客户端102等待来自BMC的响应154。如果主计算机104的BMC 108不可用,则管理客户端102等待预定时间段156(例如60秒),并且尝试执行与BMC 108的握手。握手是在通过连接110的正常通信开始之前动态地设置在BMC 108和管理客户端102之间建立的通信信道的参数的自动协商过程的。握手跟随连接110的物理建立,并且在正常的信息传送之前。该管理客户端102将重做直到完成握手。相反,如果管理客户端102接收到BMC108的确认,则管理客户端102将向BMC 108发送设备驱动器107,158或设备驱动器映像。
管理客户端在将设备驱动器107成功发送到主计算机104之后等待来自BMC 108的“设备驱动器已接收”响应160。如果在预定时间之后156没有响应,则管理客户端102重新发送设备驱动器107。如果成功地接收到“设备驱动器已接收”响应,则管理客户端102等待“更新成功”响应162。在从BMC 108接收到“更新成功”响应时,管理客户端102已经完成其传递和更新设备驱动器107,164或设备驱动器映像的过程。
图5示出了在设备驱动器更新期间的BMC的过程流170,其中BMC 108驻留在主计算机104处。在BMC 108处更新设备驱动器107的方法包括BMC 108等待来自管理客户端102的设备驱动器107更新请求172以更新主机计算机104处的设备驱动器107的步骤。BMC 108检查主机计算机104的可用性以用于更新发生174。如果主计算机104不可用,则BMC向管理客户端102通知主计算机104不可用176。如果主计算机104可用,则BMC 108接受从管理客户端178传送的设备驱动器107。BMC 108还从管理客户端180接收请求描述文件。BMC 108使用两个接收到的文件创建映像文件182(即,设备驱动器107)。BMC 108通知更新代理106哪个是在主计算机184处的软件实现。BMC 108经由更新代理186将经更新的设备驱动器107文件发送到主计算机104。BMC 108然后等待来自更新代理106的关于设备驱动器107更新状态的响应188。如果在预定时间之后156,没有来自更新代理的响应,则BMC 108将与更新代理106联系并再次发送设备驱动器107文件。如果更新代理106响应,则BMC 108向管理客户端102通知关于设备驱动器107、190的成功更新,并且过程结束192。
备选地,参考图6,BMC 108通过向其邮箱发送200来更新主计算机104的设备驱动器107。BMC 108从管理客户端102接收设备驱动器107和设备驱动器107的描述文件,并且使用中断线(引脚)发送到其邮箱194,其在想要向主计算机104信号通知中断时断言。这种形式的中断信令是控制信令的带外形式,因为它使用与主数据路径分离的专用路径来发送这种控制信息。使用邮箱方法在BMC 108处的设备驱动器107更新过程结束202。
图7示出了作为软件实现驻留在主计算机104处的设备驱动器107更新期间的更新代理106的过程流210。更新代理106从BMC 108接收通知212。驻留在主计算机104中的更新代理106检查当前设备驱动器107版本214。如果当前设备驱动器107的版本相同216,则更新代理106向BMC 108通知设备驱动器107更新为“不改变”218。相反,如果当前设备驱动器107版本比来自BMC 108的版本更旧,则更新代理106继续检查主计算机104的可用性220。如果主计算机104不可用,则更新代理106通知BMC 108“主计算机不可用”。如果主计算机104可用,则设备驱动器107将由主计算机222处的更新代理106更新。在由主计算机104的操作系统105对设备驱动器107的成功安装之后,更新代理106向BMC 108通知为“成功安装”218。更新代理106更新设备驱动器107的过程结束224。
图8示出了在设备驱动器107更新期间主计算机104的过程流230。首先,主计算机104确认并经由更新代理232响应于BMC 108。BMC 108将经更新的设备驱动器107文件发送到主计算机104,并在完成时通知更新代理234。主计算机104处的更新代理106在主计算机104的操作系统105处提示并更新(例如,升级、降级或移除)设备驱动器107,236。主计算机104经由更新代理238向BMC 108通知设备驱动器107更新状态。然后是主计算机240更新设备驱动器107的过程流的结束。
设备驱动器107更新过程由管理客户端102发起。作为安装在主计算机104的主板上的芯片的BMC 108负责在带外模式中与管理客户端102进行通信。主计算机104继续其正常操作,未觉察在BMC 108和管理客户端102之间发生的通信。作为软件实现的更新代理106驻留在主机计算机104的存储器中,其根据来自BMC 108的指令待命。更新代理106与BMC108和主计算机104通信。根据来自BMC 108的更新设备驱动器107的指令,更新代理106将尝试周期性地查询主计算机104的状态,以获得更新的最佳时间而不中断正常操作。
管理客户端102的主要角色是提供设备驱动器107文件以用于经由BMC 108向主计算机104的传输。
当前应用提供了设备驱动器107更新(尤其在BMC 108处)的两种方法。第一种方法是接收一个描述文件和一个设备驱动器107文件并且然后在BMC 108处创建映像图像文件。第二种方法是在BMC 108处使用中断引脚在BMC108中的邮箱处保存两个提到的文件。该中断可以由BMC 108本身触发或者来自管理客户端102。BMC提供文件的存储并且执行与更新代理106的握手。
更新代理106的角色是在执行设备驱动器107更新之前轮询和查询主计算机104的操作状态。在成功更新时,更新代理106通知BMC108,并且BMC108通知管理客户端102。通过采用本申请,管理客户端102能够远程且容易地控制主计算机104的网络。
在申请中,除非另有指明,术语“包括”、“包含”及其语法变体旨在表示“开放的”或“包含性”的语言,使得它们包括所记载的元素,而且还允许包括附加的、非明确记载的元素。
将是明显的,在不脱离本申请的精神和范围的情况下,在阅读前述公开内容之后,本申请的各种其他修改和调整对于本领域技术人员将是显而易见的,并且意图是所有这些修改和调整都在所附权利要求的范围内。
Claims (23)
1.一种管理计算设备的方法,所述方法包括以下步骤:
经由所述计算设备的控制器接收数据,所述数据要被提供给所述计算设备的操作系统以用于对所述计算设备的管理;
由所述操作系统的操作系统代理确定所述计算设备的所述操作系统是否准备好从所述控制器接收所述数据,包括:由所述计算设备的所述操作系统更新所述计算设备的注册表来使所述数据生效,以确定所述计算设备的所述操作系统是否准备好从所述控制器接收所述数据;
由所述操作系统代理通知所述控制器所述操作系统准备好从所述控制器接收所述数据;以及
仅当所述操作系统准备好接收所述数据时,将所述数据从所述计算设备的所述控制器传送到所述操作系统。
2.根据权利要求1所述的方法,其中
接收所述数据的所述步骤独立于所述计算设备的CPU、固件和所述操作系统被执行。
3.根据权利要求1或2所述的方法,其中
接收所述数据的所述步骤经由所述计算设备的所述控制器的带外管理连接被执行。
4.根据权利要求1所述的方法,还包括
所述计算设备的所述控制器在所述数据被生效之后由所述控制器接收状态更新。
5.根据权利要求1所述的方法,还包括
所述计算设备的所述控制器监视传送所述数据的请求。
6.根据权利要求1所述的方法,还包括
所述计算设备的所述控制器发送关于所述数据的可用性的通知。
7.根据权利要求1所述的方法,其中
使所述数据生效的所述步骤包括执行所述数据。
8.根据权利要求7所述的方法,其中
执行所述数据的所述步骤包括在所述计算设备的所述操作系统内安装设备驱动器。
9.根据权利要求8所述的方法,还包括
在安装所述设备驱动器之前确定所述设备驱动器的硬件组件是否就绪。
10.根据权利要求1所述的方法,还包括
将数据与所述操作系统内的对应数据进行比较。
11.根据权利要求10所述的方法,还包括
如果所述对应数据比所述数据更合适,则将所述对应数据保持为被安装在所述操作系统内。
12.一种计算设备,包括:
操作系统;
控制器,所述控制器被耦合到所述操作系统,所述控制器被配置为接收数据,所述数据要被提供给所述操作系统以用于对所述计算设备的管理;
其中所述操作系统包括代理,所述代理被配置为确定所述操作系统是否准备好从所述控制器接收所述数据,通知所述控制器所述操作系统准备好从所述控制器接收所述数据,并且仅当所述操作系统准备好从所述控制器接收所述数据时从所述控制器接收所述数据,其中所述操作系统被配置为通过更新所述计算设备的注册表来使所述数据生效,以确定是否要从所述控制器接收所述数据。
13.根据权利要求12所述的计算设备,其中
所述控制器被配置为独立于所述计算设备的所述操作系统或固件被执行。
14.根据权利要求12所述的计算设备,其中
所述控制器被配置为经由带外管理连接来接收数据。
15.根据权利要求12所述的计算设备,其中
所述控制器包括用于与所述操作系统的所述代理通信的基板管理控制器。
16.根据权利要求12所述的计算设备,其中
所述操作系统的所述代理包括驱动器更新代理。
17.根据权利要求16所述的计算设备,其中
所述驱动器更新代理被配置为在安装设备驱动器之前确定所述计算设备的硬件组件是否已经就绪。
18.根据权利要求17所述的计算设备,其中
所述操作系统还被配置为在所述数据被生效之后向所述控制器发送状态更新。
19.根据权利要求12所述的计算设备,其中
所述操作系统被配置为请求所述数据从所述控制器的传送。
20.根据权利要求12所述的计算设备,其中
所述控制器还被配置为向所述操作系统发送关于所述数据的可用性的通知。
21.根据权利要求12所述的计算设备,其中
所述操作系统还被配置为将所述数据作为文件执行。
22.根据权利要求12所述的计算设备,其中
所述操作系统还被配置为将由所述控制器接收的所述数据与所述操作系统内的对应数据进行比较。
23.根据权利要求22所述的计算设备,其中
所述操作系统被配置为当所述对应数据比所述数据更合适时将所述对应数据保持在所述操作系统内。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710817399.6A CN109491855B (zh) | 2017-09-12 | 2017-09-12 | 管理计算设备的方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710817399.6A CN109491855B (zh) | 2017-09-12 | 2017-09-12 | 管理计算设备的方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN109491855A CN109491855A (zh) | 2019-03-19 |
CN109491855B true CN109491855B (zh) | 2023-07-14 |
Family
ID=65688579
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710817399.6A Active CN109491855B (zh) | 2017-09-12 | 2017-09-12 | 管理计算设备的方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109491855B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10936295B2 (en) * | 2018-11-01 | 2021-03-02 | Dell Products L.P. | Software update system |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CA2504336A1 (en) * | 2005-04-15 | 2006-10-15 | Symbium Corporation | Method and apparatus for building an autonomic controller system |
CN101202649A (zh) * | 2006-12-14 | 2008-06-18 | 英业达股份有限公司 | 计算机设备信息的收集和管理方法 |
US7627667B1 (en) * | 2002-11-26 | 2009-12-01 | Dell Marketing Usa, L.P. | Method and system for responding to an event occurring on a managed computer system |
CN104572347A (zh) * | 2014-12-02 | 2015-04-29 | 上海爱数软件有限公司 | 基于块级恢复与修改注册表并注入驱动的系统恢复方法 |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8260741B2 (en) * | 2003-08-15 | 2012-09-04 | Intel Corporation | System and method for utilizing a modular operating system (OS) resident agent allowing an out-of-band server management |
US7484084B1 (en) * | 2005-12-20 | 2009-01-27 | Netapp, Inc. | Use of a baseboard management controller to facilitate installation of firmware in a processing system |
JP5640154B2 (ja) * | 2010-10-16 | 2014-12-10 | ヒューレット−パッカード デベロップメント カンパニー エル.ピー.Hewlett‐Packard Development Company, L.P. | デバイスハードウェアエージェント |
US8566847B2 (en) * | 2011-03-11 | 2013-10-22 | Cisco Technology, Inc. | Out-of-band host management via a management controller |
US10015023B2 (en) * | 2014-09-08 | 2018-07-03 | Quanta Computer Inc. | High-bandwidth chassis and rack management by VLAN |
US9851996B2 (en) * | 2015-03-24 | 2017-12-26 | Lenovo Enterprise Solutions (Singapore) Pte. Ltd. | Applying firmware updates in a system with zero downtime by selectively offlining and onlining hardware using a scale-up hypervisor layer |
-
2017
- 2017-09-12 CN CN201710817399.6A patent/CN109491855B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7627667B1 (en) * | 2002-11-26 | 2009-12-01 | Dell Marketing Usa, L.P. | Method and system for responding to an event occurring on a managed computer system |
CA2504336A1 (en) * | 2005-04-15 | 2006-10-15 | Symbium Corporation | Method and apparatus for building an autonomic controller system |
CN101202649A (zh) * | 2006-12-14 | 2008-06-18 | 英业达股份有限公司 | 计算机设备信息的收集和管理方法 |
CN104572347A (zh) * | 2014-12-02 | 2015-04-29 | 上海爱数软件有限公司 | 基于块级恢复与修改注册表并注入驱动的系统恢复方法 |
Also Published As
Publication number | Publication date |
---|---|
CN109491855A (zh) | 2019-03-19 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10089028B2 (en) | Remote secure drive discovery and access | |
US10693813B1 (en) | Enabling and disabling links of a networking switch responsive to compute node fitness | |
US7930425B2 (en) | Method of effectively establishing and maintaining communication linkages with a network interface controller | |
US20080043769A1 (en) | Clustering system and system management architecture thereof | |
US9872205B2 (en) | Method and system for sideband communication architecture for supporting manageability over wireless LAN (WLAN) | |
US20190235890A1 (en) | Method for dynamically provisioning virtualized functions in a usb device by means of a virtual usb hub | |
US9652216B2 (en) | System and method for providing out-of-band software or firmware upgrades for a switching device | |
US9696777B2 (en) | Computer port control | |
JP4636629B2 (ja) | リモート・サーバの遠隔復旧を提供することができるシステム | |
US9734100B2 (en) | Network controller sharing between SMM firmware and OS drivers | |
US20080140811A1 (en) | Method and apparatus for a host controller operations over a network | |
US11132187B2 (en) | Bare metal provisioning of software defined infrastructure | |
EP2317440A2 (en) | Embedded system administration and method therefor | |
US20070233833A1 (en) | Data transmission system for electronic devices with server units | |
RU2614569C2 (ru) | Стойка с функцией автоматического восстановления и способ автоматического восстановления для этой стойки | |
US20110276625A1 (en) | Method and system for host independent keyboard, video, and mouse (kvm) redirection | |
US7734948B2 (en) | Recovery of a redundant node controller in a computer system | |
US10699668B1 (en) | Configurable video redirection in a data center | |
US11516095B2 (en) | Network function virtualization compute element image upgrade | |
US20120233628A1 (en) | Out-of-band host management via a management controller | |
US9779037B2 (en) | Establishing connectivity of modular nodes in a pre-boot environment | |
CN115981776A (zh) | 位于服务器网络接口卡处的基板管理控制器 | |
CN109491855B (zh) | 管理计算设备的方法 | |
US10339076B2 (en) | System and method for adaptable fabric consistency validation and issue mitigation in an information handling system | |
US20230176986A1 (en) | USB Terminal Server |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |