US20180357429A1 - Network security for data storage systems - Google Patents
Network security for data storage systems Download PDFInfo
- Publication number
- US20180357429A1 US20180357429A1 US15/716,870 US201715716870A US2018357429A1 US 20180357429 A1 US20180357429 A1 US 20180357429A1 US 201715716870 A US201715716870 A US 201715716870A US 2018357429 A1 US2018357429 A1 US 2018357429A1
- Authority
- US
- United States
- Prior art keywords
- packet
- storage
- storage system
- adapter
- network adapter
- 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.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/604—Tools and structures for managing or administering access control systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/50—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
- G06F21/55—Detecting local intrusion or implementing counter-measures
- G06F21/554—Detecting local intrusion or implementing counter-measures involving event detection and direct action
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/62—Protecting access to data via a platform, e.g. using keys or access control rules
- G06F21/6218—Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0653—Monitoring storage devices or systems
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/02—Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
- H04L63/0227—Filtering policies
- H04L63/0263—Rule management
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/06—Network architectures or network communication protocols for network security for supporting key management in a packet data network
- H04L63/061—Network architectures or network communication protocols for network security for supporting key management in a packet data network for key exchange, e.g. in peer-to-peer networks
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/50—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/02—Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
- H04L63/0227—Filtering policies
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/02—Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
- H04L63/0227—Filtering policies
- H04L63/0236—Filtering by address, protocol, port number or service, e.g. IP-address or URL
Definitions
- the present invention relates generally to the field of data storage systems, and more particularly to network security in data storage systems.
- Computer data storage often called storage or memory, is a technology consisting of computer components and recording media used to retain digital data. It is a core function and fundamental component of computers.
- the central processing unit (CPU) of a computer is what manipulates data by performing computations.
- CPU central processing unit
- almost all computers use a storage hierarchy, which puts fast, expensive, small storage options close to the CPU and slower but larger and cheaper options farther away.
- the fast volatile technologies which lose data when off power
- storage slower persistent technologies
- “memory” is sometimes also used when referring to persistent storage.
- iSCSI Internet Small Computer System Interface
- TCP/IP Transmission Control Protocol/Internet Protocol
- the iSCSI protocol describes a transport protocol for SCSI, which operates on top of TCP and provides a mechanism for encapsulating SCSI commands in an IP infrastructure.
- the iSCSI protocol is employed for data storage systems that have a TCP/IP infrastructure.
- a server is created, and a computer readable storage media is included in the server.
- An adapter is connected to the server, a set of packets is received by the adapter from a network, and the network and a repository are interfaced by the adapter.
- a firmware is stored on the adapter, and the adapter is controlled by the firmware.
- a management component is stored on the computer readable storage media, and the server is managed by the management component.
- a driver is stored on the management component, and the driver communicates with the adapter.
- a set of filters that controls transmission of the set of packets is created, and each filter in the set of filters has a set of filter rules. The set of filters is stored on the server.
- FIG. 1 illustrates a networked computing environment, in accordance with an embodiment of the present invention.
- FIG. 2 depicts a flowchart of the operational blocks of a program for providing security in a computer storage system, in accordance with an embodiment of the present invention.
- FIG. 3 is a block diagram of components of a computing system, in accordance with an embodiment of the present invention.
- the present invention describes methods for a storage system to allow remote support connectivity while securing the data center from external attacks by abusing access granted to the storage system.
- a remote support channel is often supported on storage systems for maintainability, debugging and recoveries.
- Support operations may require privileged access to the storage system. This privileged access to the storage system can be abused to invoke an attack on the data center on which the storage system in installed. This creates a need to protect the data center from the storage system, as it may be a security vulnerability for other hosts on the data center.
- Embodiments of the present invention recognize that a storage system provides services to hosts and clients through various protocols, including iSCSI or other Ethernet based communication protocols.
- a storage system may be connected to one or more clients through a network that is accessible in the local data center.
- a storage system may be connected to network ports for management or for remote serviceability and support.
- a storage system may require a privileged access permission to access the system through a support network. For example, third party developers or engineers may have privileged access to service (e.g., debug) a storage system through an external access over a set of support connections.
- Embodiments of the present invention recognize that privileged access to a storage system by a third party creates a security risk to the data center on which the storage system resides.
- a storage system providing security of a data center against traffic with privileged access to the storage system i.e., protecting the data center's internal network from attacks utilizing access to the storage system, is a problem that is not addressed by current security approaches (e.g., a firewall).
- Embodiments of the present invention recognize that the importance of the issue of monitoring storage system traffic from the host side is rising at least because of an increase in the popularity of iSCSI or other Ethernet based protocols.
- Embodiments of the present invention provide for restricting outbound traffic from the storage system through communication protocols (e.g., TCP/IP over Ethernet) in a manner that prevents a user on the storage system from overriding the restrictions or that makes such an attempt harder and simpler to detect.
- communication protocols e.g., TCP/IP over Ethernet
- FIG. 1 is a functional block diagram illustrating computing environment 100 in accordance with an embodiment of the present invention.
- FIG. 1 provides only an illustration of one implementation and does not imply any limitations with regard to the environments in which different embodiments may be implemented. Some modifications to the depicted environment may be made by those skilled in the art without departing from the scope of the invention as recited by the claims.
- computing environment 100 includes server device 102 , client device 120 , network 140 , and storage 130 .
- server device 102 , client device 120 , and storage 130 are interconnected and communicate through network 140 .
- network 140 can be a local area network (LAN), a telecommunications network, a wireless local area network (WLAN), such as an intranet, a wide area network (WAN), such as the Internet, or any combination thereof.
- LAN local area network
- WLAN wireless local area network
- WAN wide area network
- network 140 can include wired, wireless, or fiber optic connections.
- network 140 can generally be any combination of connections and protocols that will support communications between server device 102 , client device 120 , storage 130 , and any other computing device connected to network 140 .
- server device 102 can be any electronic device, or combination of electronic devices, capable of executing computer readable program instructions and communicating with any computing device within computing environment 100 .
- server device 102 may be a workstation, personal computer, laptop computer, tablet, personal digital assistant, or mobile phone.
- server device 102 can be a computer system utilizing clustered computers and components (e.g., database server computers, application server computers) that act as a single pool of seamless resources when accessed by elements of computing environment 100 .
- server device 102 may be a data center in a cloud computing environment.
- server device 102 includes components as depicted and described with respect to computing system 300 ( FIG. 3 ).
- client device 120 is substantially similar to server device 102 and includes components as depicted and described with respect to computing system 300 .
- storage system 104 manages transmission of data to and from storage 130 .
- storage system 104 includes Internet protocol suite (TCP/IP) network infrastructure or storage area network (SAN) infrastructure.
- Storage system 104 protocols can include, for example, Fibre Channel (FC), Fibre Channel over Ethernet (FCoE), ATA over Ethernet (AOE), iSCSI, and HyperSCSI.
- Storage system 104 includes LPAR 106 , storage program 112 , hypervisor 114 , adapter 116 , firmware 118 , device driver 110 , kernel 122 , and storage 130 .
- storage 130 includes data organized as one or more data repositories.
- a repository is implemented using any non-volatile storage media known in the art.
- a repository can be implemented with a tape library, optical library, one or more independent hard disk drives or flash drives, or multiple hard disk drives or flash drives in a redundant array of independent disks (RAID).
- RAID redundant array of independent disks
- a repository can be implemented using any suitable storage architecture known in the art.
- a repository can be implemented as a relational database or an object-oriented database.
- storage 130 is partitioned by hardware or software to provide one or more storage subsystems.
- storage 130 can represent multiple virtual storage area networks (VSANs).
- VSANs virtual storage area networks
- the use of VSANs allows for isolation of traffic within specific portions of storage system 104 . For example, if a problem occurs in one VSAN, the problem can be handled with minimal disruption to the rest of storage system 104 .
- VSANs are enabled for various high-level protocols such as FCP, FLIP, FICON®, and iSCSI.
- each VSAN is configured separately and independently.
- Each VSAN is a separate self-contained fabric using distinct security policies, zones, events, memberships, and name services.
- storage 130 is connected to server device 102 and storage system 104 through network 140 and a network device (not shown), such as an Ethernet port and adapter, network interface card (NIC), a host bus adapter (HBA), or a converged network adapter (CNA).
- a network device such as an Ethernet port and adapter, network interface card (NIC), a host bus adapter (HBA), or a converged network adapter (CNA).
- adapter 116 is a hardware device, such as a circuit board or integrated circuit adapter, that connects server device 102 and storage system 104 to network 140 .
- adapter 116 may be a host bus adapter (HBA).
- HBA host bus adapter
- adapter 116 is a network interface card (NIC) or a converged network adapter (CNA).
- adapter 116 represents any other networking device that provides a communicative interface between storage system 104 and another computing device.
- adapter 116 may represent a repeater, a modem, a bridge, a hub, a switch, or a router.
- firmware 118 is software embedded in adapter 116 that provides control of, or data manipulation in, adapter 116 .
- firmware 118 monitors, or listens to, traffic from network 140 attempting to connect to storage system 104 through adapter 116 .
- traffic includes data in the form of data packets.
- a data packet, or packet is a unit of data organized as a single package.
- a packet includes parameters (packet parameters) such as the source port, the source Internet Protocol (IP) address, the destination port, the destination IP address, and the protocol used by the packet.
- the packet parameters of a packet are located in the header of the packet.
- firmware 118 includes a traffic filter that includes a defined list (filter rules) of port numbers or protocols that are allowed to be, or are blocked from being, transmitted from storage system 104 , e.g., through adapter 116 .
- firmware 118 in response to adapter 116 receiving a packet, firmware 118 analyzes the header of the packet and determines the packet parameters.
- Firmware 118 compares the packet parameters of the packet with the filter rules, i.e., the protocols or ports defined to as allowed or blocked. If the packet parameters are consistent with the filter, the packet is allowed to be transmitted through adapter 116 .
- storage system 104 drops, or rejects, the packet, and any memory (i.e., on the hardware of server device 102 ) utilized by the packet is marked as available, i.e., the utilized memory can be overwritten by another packet.
- storage system 104 includes one or more partitions that include logical partition (LPAR) 106 .
- hypervisor 114 creates LPAR 106 from virtual and physical resources of server device 102 .
- each logical partition runs an independent operating environment, including an operating system (OS) (guest OS).
- OS operating system
- guest OS guest OS
- VM virtual machine
- the guest OS is an instance, or configuration, of the host OS (i.e., kernel 122 ) of storage system 104 .
- kernel 122 implements the virtual operating environment of LPAR 106 .
- kernel 122 and storage program 112 are located in the guest OS of LPAR 106 .
- the guest OS is a distinct OS from kernel 122 .
- the guest OS operates in conjunction with kernel 122 .
- LPAR 106 includes a virtual I/O server (VIOS).
- VIPOS virtual I/O server
- a VIOS is a computer program in a logical partition that enables multiple logical partitions to share access to a physical I/O resource where only one of the logical partitions owns the resource.
- a VIOS can enable multiple logical partitions to share access to a single hardware device, such as a SCSI adapter and SCSI disk.
- LPAR 106 includes one or more virtual adapters (not shown) to facilitate communications between a VM of LPAR 106 and a VM of another logical partition, or between a VM of a logical partition and other systems of storage system 104 .
- virtual adapters include virtualized network interface cards (vNICs), virtual host bus adapters (vHBAs), virtual Ethernet adapters, virtual Fibre Channel (FC) adapters, virtual small computer serial interface (SCSI) adapters, and virtual serial adapters.
- hypervisor 114 is a computer program that manages virtual (including paravirtual) operations of storage system 104 .
- hypervisor 114 manages execution of guest OSs of VMs.
- hypervisor 114 manages access to resources of storage system 104 by the VMs.
- storage system 104 includes an operating system (host OS), which includes kernel 122 , that is distinct from hypervisor 114 .
- hypervisor 114 loads and operates on top of the host OS.
- hypervisor 114 includes kernel 122 , which does not operate independently from hypervisor 114 .
- Hypervisor 114 performs operating system functions for storage system 104 by directly communicating with physical resources of storage system 104 (e.g., to allocate resources to LPAR 106 ).
- hypervisor 114 manages communications within storage system 104 , and communications between storage system 104 and server device 102 , through a communications fabric. For example, hypervisor 114 can manage a resource request from a guest OS of LPAR 106 through communications fabric 304 , which is further described with respect to FIG. 3 . In some embodiments, hypervisor 114 manages communications between logical partitions, and communications between a logical partition and other systems of storage system 104 , through one or more virtual switches (not shown). In some embodiments, a virtual switch is a computer program that facilitates the transmission of data packets between components of storage system 104 .
- a virtual switch can provide connectivity between LPAR 106 (i.e., a virtual adapter of LPAR 106 ) and adapter 116 .
- virtual switches are represented by hypervisor 114 .
- virtual switches are represented by communications fabric 304 .
- the communications fabric is a communications subsystem of storage system 104 .
- the communications fabric can be configured as a Virtual Local Area Network (VLAN).
- the communications fabric is embedded in virtualization software of storage system 104 .
- the communications fabric is included in the hardware components of server device 102 as firmware.
- the communications fabric includes a combination of physical and virtualized resources, such as fiber optic cables, Ethernet cables, physical and virtual adapters, and wireless connections.
- device driver 110 is a computer program, application, or subprogram of a larger program that provides an interface to one or more hardware components of storage system 104 .
- device driver 110 provides an interface that enables hypervisor 114 , kernel 122 , and storage program 112 to communicate with firmware 118 and adapter 116 .
- device driver 110 provides access to the packet filter of firmware 118 and thereby control of the network traffic filtering function of adapter 116 .
- device driver 110 communicates with devices (e.g., adapter 116 ) and other programs (e.g., firmware 118 ) of storage system 104 through the communications fabric.
- device driver 110 is run by hypervisor 114 .
- device driver 110 is run by kernel 122 , which can be located in LPAR 106 or, alternatively, outside of LPAR 106 .
- storage program 112 is a computer program, application, subprogram of a larger program, such as an OS, or a combination thereof, that manages access to storage system 104 , including storage 130 , by incoming network traffic.
- storage program 112 in response to a request to update, replace, or otherwise modify the filter rules (i.e., the allowed or blocked ports or network protocols) of firmware 118 , device driver 110 , or kernel 122 , storage program 112 prompts the requestor for a cryptographic key or password and allows the action only if the cryptographic key or password is provided.
- storage program 112 allows kernel 122 to load a driver of a networking device (e.g., a driver that facilitates communications with firmware 118 ) only if the driver is cryptographically signed (e.g., a key or password is provided).
- storage program 112 periodically inspects or queries device driver 110 , firmware 118 , hypervisor 114 , and kernel 122 to determine if a modification has been made to the filter rules. If storage program 112 determines that a modification has been made, storage system 104 takes a responsive action, e.g., raises an event.
- storage program 112 runs directly on server device 102 . In alternative embodiments, storage program 112 runs on a VM of LPAR 106 . In some such embodiments where storage program 112 runs on a VM, the VM utilizes a para-virtualized device driver 110 , which runs on hypervisor 114 . In other such embodiments where storage program 112 runs on a VM, the VM utilizes a virtualized or emulated device, which runs on hypervisor 114 and includes an implementation of the logic further described with respect to FIG. 2 .
- adapter 116 and firmware 118 include code that prevents altering firmware 118 without cryptographic signing. This prevents a user from replacing firmware 118 with a version of firmware that does not implement some or all of the restrictions further described with respect to FIG. 2 .
- logic and restrictions further described with respect to FIG. 2 are implemented in kernel 122 of the operating system running the storage program 112 .
- a kernel image is cryptographically signed and a boot loader, on server 102 , prevents loading a version of kernel 122 that is not signed.
- logic and restrictions further described with respect to FIG. 2 are implemented in device driver 110 .
- kernel 122 requires driver 110 to be cryptographically signed and prevents loading a version of device driver 110 that is not signed.
- FIG. 2 is a flowchart of workflow 200 depicting operational steps for providing security for a networked storage system, in accordance with embodiments of the present invention.
- workflow 200 is performed by storage system 104 .
- various aspects of workflow 200 can be performed by storage program 112 , hypervisor 114 , firmware 118 , device driver 110 , or kernel 122 .
- workflow 200 is performed by any other computer program while working with storage system 104 .
- storage system 104 begins performing workflow 200 in response to receiving an indication by a user of storage system 104 , client device 120 , or any other computing device connected to network 140 .
- workflow 200 initiates in response to a boot, or reboot, of storage system 104 .
- storage system 104 receives a packet.
- storage system 104 receives a packet at adapter 116 from client device 120 through network 140 .
- storage system 104 can receive a request from client device 120 to access port 23 , or Telnet protocol, in order to manage a network device in storage system 104 .
- Storage system 104 can receive the request as a stream of multiple packets at adapter 116 .
- storage system 104 is a virtual environment, and storage hypervisor 114 or kernel 122 receives a packet from a guest OS running in LPAR 106 .
- a guest OS in LPAR 106 requires para-virtualization.
- paravirtualized device driver 110 can run on hypervisor 114 and receive a packet from the guest OS.
- the environment is fully virtualized.
- device driver 110 can be located in kernel 122 , and kernel 122 and device driver 110 can be emulated by hypervisor 114 . In such embodiments, the device corresponding to device driver 110 (e.g., adapter 116 ) does not appear virtualized to the guest OS.
- storage system 104 analyzes packet parameters of the packet.
- packet parameters include the source port, the source Internet Protocol (IP) address, the destination port, the destination IP address, or the protocol.
- IP Internet Protocol
- packet parameters are located in the header of each packet.
- storage system 104 analyzes the packet parameters of the packet in response to adapter 116 receiving the packet.
- firmware 118 identifies the packet parameters of the packet.
- kernel 122 or hypervisor 114 receive the packet.
- hypervisor 114 can receive the packet and transfer the packet to device driver 110 .
- storage system 104 includes a distinct host OS and device driver is located in kernel 122 .
- hypervisor 114 performs OS functions for storage system 104 and device driver is located in hypervisor 114 .
- device driver 110 identifies the packet parameters of the packet.
- filter rules include an exhaustive list of port numbers or protocols that are allowed to be accessed within storage system 104 (e.g., a whitelist).
- the filter in firmware 118 might define only port 3260 as an allowed port, or only TCP connections on the iSCSI protocol.
- filter rules additionally or alternatively include a defined list of port numbers or protocols that are blocked from being accessed within storage system 104 (e.g., a blacklist).
- a filter in kernel 122 might define the Fibre Channel over IP (FCIP) protocol, or port 3225 , as a blocked port.
- FCIP Fibre Channel over IP
- storage system 104 compares the analyzed packet parameters of the packet with the filter rules.
- the packet parameters are consistent with the filter if the parameters appear on a defined whitelist, if any is defined in the filter, and the parameters do not appear on a defined blacklist, if any is defined in the filter.
- a filter is hard-coded in firmware 118 , device driver 110 , or kernel 122 .
- a filter is embedded in the source code of firmware 118 , and the filter can only be modified if the source code of firmware 118 is modified.
- storage system 104 includes more than one filter, and a filter is hard-coded in a combination of firmware 118 , device driver 110 , and kernel 122 .
- firmware 118 , device driver 110 , and kernel 122 may each include a defined list of ports that are allowed to be accessed within storage system 104 .
- storage program 112 provides cryptographic protection within storage system 104 .
- storage program 112 in response to an attempt to update, replace, or otherwise modify filter rules of firmware 118 , device driver 110 , or kernel 122 , storage program 112 prompts the requestor for a cryptographic key or password and allows the access only if the key or password is provided.
- storage program 112 allows kernel 122 to load a new driver of a networking device only if the new driver is cryptographically signed, i.e., a cryptographic key or password is provided.
- a user that has privileged access to storage system 104 e.g., through a guest OS running on LPAR 106 of storage system 104 , is thereby prevented from utilizing the privileged access to disable a filter, unless the user provides the key or password.
- storage program 112 inspects firmware 118 , device driver 110 , or kernel 122 at periodic intervals to determine if the packet filter rules have been modified.
- step 220 responsive to determining that the analyzed packet parameters are consistent with the filter (Yes branch, decision step 215 ), storage system 104 allows the packet to be transmitted to a requested destination.
- step 225 responsive to determining that the analyzed packet parameters are not consistent with the filter, (No branch, decision step 215 ), storage system 104 prevents the packet from being transmitted to the requested destination and drops, or rejects, the packet.
- any memory (i.e., on the hardware of server device 102 ) utilized by the dropped packet is marked as available, i.e., the utilized memory can be overwritten by another packet.
- FIG. 3 depicts computing system 300 , which illustrates components of server device 102 and client device 120 .
- Computing system 300 includes processor(s) 301 , cache 303 , memory 302 , persistent storage 305 , communications unit 307 , I/O interface(s) 306 , and communications fabric 304 .
- Communications fabric 304 provides communications between cache 303 , memory 302 , persistent storage 305 , communications unit 307 , and I/O interface(s) 306 .
- Communications fabric 304 can be implemented with any architecture designed for passing data and/or control information between processors (e.g., microprocessors, communications and network processors, etc.), system memory, peripheral devices, and any other hardware components within a system.
- processors e.g., microprocessors, communications and network processors, etc.
- Communications fabric 304 may be implemented with one or more buses or a crossbar switch.
- Memory 302 and persistent storage 305 are computer readable storage media.
- memory 302 includes random access memory (RAM) (not shown).
- RAM random access memory
- memory 302 may include any suitable volatile or non-volatile computer readable storage media.
- Cache 303 is a fast memory that enhances the performance of processors 301 by holding recently accessed data, and data near recently accessed data, from memory 302 .
- persistent storage 305 includes a magnetic hard disk drive.
- persistent storage 305 may include a solid state hard drive, a semiconductor storage device, read-only memory (ROM), erasable programmable read-only memory (EPROM), flash memory, or any other computer readable storage media that is capable of storing program instructions or digital information.
- the media used by persistent storage 305 may also be removable.
- a removable hard drive may be used for persistent storage 305 .
- Other examples include optical and magnetic disks, thumb drives, and smart cards that are inserted into a drive for transfer onto another computer readable storage medium that is also part of persistent storage 305 .
- Communications unit 307 in these examples, provides for communications with other data processing systems or devices.
- communications unit 307 includes one or more network interface cards.
- Communications unit 307 may provide communications through the use of either or both physical and wireless communications links.
- Program instructions and data used to practice embodiments of the present invention may be downloaded to persistent storage 305 through communications unit 307 .
- I/O interface(s) 306 allows for input and output of data with other devices that may be connected to each computer system.
- I/O interface 306 may provide a connection to external devices 308 such as a keyboard, keypad, a touch screen, and/or some other suitable input device.
- External devices 308 can also include portable computer readable storage media such as, for example, thumb drives, portable optical or magnetic disks, and memory cards.
- Software and data used to practice embodiments of the present invention can be stored on such portable computer readable storage media and can be loaded onto persistent storage 305 through I/O interface(s) 306 .
- I/O interface(s) 306 also connect to display 309 .
- Display 309 provides a mechanism to display data to a user and may be, for example, a computer monitor.
- the present invention may be a system, a method, and/or a computer program product at any possible technical detail level of integration
- the computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present invention
- the computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device.
- the computer readable storage medium may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing.
- a non-exhaustive list of more specific examples of the computer readable storage medium includes the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon, and any suitable combination of the foregoing.
- RAM random access memory
- ROM read-only memory
- EPROM or Flash memory erasable programmable read-only memory
- SRAM static random access memory
- CD-ROM compact disc read-only memory
- DVD digital versatile disk
- memory stick a floppy disk
- a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon
- a computer readable storage medium is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
- Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network.
- the network may comprise copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers.
- a network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer readable storage medium within the respective computing/processing device.
- Computer readable program instructions for carrying out operations of the present invention may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, configuration data for integrated circuitry, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++, or the like, and procedural programming languages, such as the “C” programming language or similar programming languages.
- the computer readable program instructions may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server.
- the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
- electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) may execute the computer readable program instructions by utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present invention.
- These computer readable program instructions may be provided to a processor of a general-purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
- These computer readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
- the computer readable program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational blocks to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
- each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s).
- the functions noted in the blocks may occur out of the order noted in the Figures.
- two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved.
- Embodiments of the present invention may also be delivered as part of a service engagement with a client corporation, nonprofit organization, government entity, internal organizational structure, or the like. These embodiments may include configuring a computer system to perform, and deploying software, hardware, and web services that implement, some or all of the methods described herein. These embodiments may also include analyzing the client's operations, creating recommendations responsive to the analysis, building systems that implement portions of the recommendations, integrating the systems into existing processes and infrastructure, metering use of the systems, allocating expenses to users of the systems, and billing for use of the systems.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- General Engineering & Computer Science (AREA)
- Computer Hardware Design (AREA)
- Software Systems (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- General Health & Medical Sciences (AREA)
- Bioethics (AREA)
- Health & Medical Sciences (AREA)
- Signal Processing (AREA)
- Computer Networks & Wireless Communication (AREA)
- Computing Systems (AREA)
- Databases & Information Systems (AREA)
- Automation & Control Theory (AREA)
- Business, Economics & Management (AREA)
- General Business, Economics & Management (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
- Human Computer Interaction (AREA)
Abstract
Description
- The present invention relates generally to the field of data storage systems, and more particularly to network security in data storage systems.
- Computer data storage, often called storage or memory, is a technology consisting of computer components and recording media used to retain digital data. It is a core function and fundamental component of computers.
- The central processing unit (CPU) of a computer is what manipulates data by performing computations. In practice, almost all computers use a storage hierarchy, which puts fast, expensive, small storage options close to the CPU and slower but larger and cheaper options farther away. Generally, the fast volatile technologies (which lose data when off power) are referred to as “memory”, while slower persistent technologies are referred to as “storage”; however, “memory” is sometimes also used when referring to persistent storage.
- Internet Small Computer System Interface (iSCSI) is a Transmission Control Protocol/Internet Protocol (TCP/IP) based protocol for establishing and managing connections between IP-based storage devices, hosts, and clients. The iSCSI protocol describes a transport protocol for SCSI, which operates on top of TCP and provides a mechanism for encapsulating SCSI commands in an IP infrastructure. The iSCSI protocol is employed for data storage systems that have a TCP/IP infrastructure.
- In one embodiment of the present invention, a server is created, and a computer readable storage media is included in the server. An adapter is connected to the server, a set of packets is received by the adapter from a network, and the network and a repository are interfaced by the adapter. A firmware is stored on the adapter, and the adapter is controlled by the firmware. A management component is stored on the computer readable storage media, and the server is managed by the management component. A driver is stored on the management component, and the driver communicates with the adapter. A set of filters that controls transmission of the set of packets is created, and each filter in the set of filters has a set of filter rules. The set of filters is stored on the server.
-
FIG. 1 illustrates a networked computing environment, in accordance with an embodiment of the present invention. -
FIG. 2 depicts a flowchart of the operational blocks of a program for providing security in a computer storage system, in accordance with an embodiment of the present invention. -
FIG. 3 is a block diagram of components of a computing system, in accordance with an embodiment of the present invention. - The present invention describes methods for a storage system to allow remote support connectivity while securing the data center from external attacks by abusing access granted to the storage system. A remote support channel is often supported on storage systems for maintainability, debugging and recoveries. Support operations may require privileged access to the storage system. This privileged access to the storage system can be abused to invoke an attack on the data center on which the storage system in installed. This creates a need to protect the data center from the storage system, as it may be a security vulnerability for other hosts on the data center.
- Embodiments of the present invention recognize that a storage system provides services to hosts and clients through various protocols, including iSCSI or other Ethernet based communication protocols. A storage system may be connected to one or more clients through a network that is accessible in the local data center. A storage system may be connected to network ports for management or for remote serviceability and support. Further, a storage system may require a privileged access permission to access the system through a support network. For example, third party developers or engineers may have privileged access to service (e.g., debug) a storage system through an external access over a set of support connections.
- Embodiments of the present invention recognize that privileged access to a storage system by a third party creates a security risk to the data center on which the storage system resides. Embodiments of the present invention recognize that a storage system providing security of a data center against traffic with privileged access to the storage system, i.e., protecting the data center's internal network from attacks utilizing access to the storage system, is a problem that is not addressed by current security approaches (e.g., a firewall). Embodiments of the present invention recognize that the importance of the issue of monitoring storage system traffic from the host side is rising at least because of an increase in the popularity of iSCSI or other Ethernet based protocols.
- Embodiments of the present invention provide for restricting outbound traffic from the storage system through communication protocols (e.g., TCP/IP over Ethernet) in a manner that prevents a user on the storage system from overriding the restrictions or that makes such an attempt harder and simpler to detect.
- The descriptions of the various instances, scenarios, and examples related to the present invention are presented for purposes of illustration and are not intended to be exhaustive or limited to the embodiments disclosed.
- The present invention will now be described in detail with reference to the Figures.
FIG. 1 is a functional block diagram illustratingcomputing environment 100 in accordance with an embodiment of the present invention.FIG. 1 provides only an illustration of one implementation and does not imply any limitations with regard to the environments in which different embodiments may be implemented. Some modifications to the depicted environment may be made by those skilled in the art without departing from the scope of the invention as recited by the claims. In some embodiments,computing environment 100 includesserver device 102,client device 120,network 140, andstorage 130. - In some embodiments,
server device 102,client device 120, andstorage 130 are interconnected and communicate throughnetwork 140. In some embodiments,network 140 can be a local area network (LAN), a telecommunications network, a wireless local area network (WLAN), such as an intranet, a wide area network (WAN), such as the Internet, or any combination thereof. In some embodiments,network 140 can include wired, wireless, or fiber optic connections. In some embodiments,network 140 can generally be any combination of connections and protocols that will support communications betweenserver device 102,client device 120,storage 130, and any other computing device connected tonetwork 140. - In some embodiments,
server device 102 can be any electronic device, or combination of electronic devices, capable of executing computer readable program instructions and communicating with any computing device withincomputing environment 100. For example,server device 102 may be a workstation, personal computer, laptop computer, tablet, personal digital assistant, or mobile phone. In some embodiments,server device 102 can be a computer system utilizing clustered computers and components (e.g., database server computers, application server computers) that act as a single pool of seamless resources when accessed by elements ofcomputing environment 100. For example,server device 102 may be a data center in a cloud computing environment. In some embodiments,server device 102 includes components as depicted and described with respect to computing system 300 (FIG. 3 ). In some embodiments,client device 120 is substantially similar toserver device 102 and includes components as depicted and described with respect tocomputing system 300. - In some embodiments,
storage system 104 manages transmission of data to and fromstorage 130. In some embodiments,storage system 104 includes Internet protocol suite (TCP/IP) network infrastructure or storage area network (SAN) infrastructure.Storage system 104 protocols can include, for example, Fibre Channel (FC), Fibre Channel over Ethernet (FCoE), ATA over Ethernet (AOE), iSCSI, and HyperSCSI.Storage system 104 includes LPAR 106,storage program 112,hypervisor 114,adapter 116,firmware 118,device driver 110,kernel 122, andstorage 130. - In some embodiments,
storage 130 includes data organized as one or more data repositories. In some embodiments, a repository is implemented using any non-volatile storage media known in the art. For example, a repository can be implemented with a tape library, optical library, one or more independent hard disk drives or flash drives, or multiple hard disk drives or flash drives in a redundant array of independent disks (RAID). A repository can be implemented using any suitable storage architecture known in the art. For example, a repository can be implemented as a relational database or an object-oriented database. - In some embodiments,
storage 130 is partitioned by hardware or software to provide one or more storage subsystems. For example,storage 130 can represent multiple virtual storage area networks (VSANs). The use of VSANs allows for isolation of traffic within specific portions ofstorage system 104. For example, if a problem occurs in one VSAN, the problem can be handled with minimal disruption to the rest ofstorage system 104. VSANs are enabled for various high-level protocols such as FCP, FLIP, FICON®, and iSCSI. In some embodiments, each VSAN is configured separately and independently. Each VSAN is a separate self-contained fabric using distinct security policies, zones, events, memberships, and name services. - In some embodiments,
storage 130 is connected toserver device 102 andstorage system 104 throughnetwork 140 and a network device (not shown), such as an Ethernet port and adapter, network interface card (NIC), a host bus adapter (HBA), or a converged network adapter (CNA). - In some embodiments,
adapter 116 is a hardware device, such as a circuit board or integrated circuit adapter, that connectsserver device 102 andstorage system 104 tonetwork 140. For example,adapter 116 may be a host bus adapter (HBA). In alternative embodiments,adapter 116 is a network interface card (NIC) or a converged network adapter (CNA). In further alternative embodiments,adapter 116 represents any other networking device that provides a communicative interface betweenstorage system 104 and another computing device. For example,adapter 116 may represent a repeater, a modem, a bridge, a hub, a switch, or a router. - In some embodiments,
firmware 118 is software embedded inadapter 116 that provides control of, or data manipulation in,adapter 116. In some embodiments,firmware 118 monitors, or listens to, traffic fromnetwork 140 attempting to connect tostorage system 104 throughadapter 116. In some embodiments, traffic includes data in the form of data packets. A data packet, or packet, is a unit of data organized as a single package. A packet includes parameters (packet parameters) such as the source port, the source Internet Protocol (IP) address, the destination port, the destination IP address, and the protocol used by the packet. In some embodiments, the packet parameters of a packet are located in the header of the packet. - In some embodiments,
firmware 118 includes a traffic filter that includes a defined list (filter rules) of port numbers or protocols that are allowed to be, or are blocked from being, transmitted fromstorage system 104, e.g., throughadapter 116. In some embodiments, in response toadapter 116 receiving a packet,firmware 118 analyzes the header of the packet and determines the packet parameters.Firmware 118 compares the packet parameters of the packet with the filter rules, i.e., the protocols or ports defined to as allowed or blocked. If the packet parameters are consistent with the filter, the packet is allowed to be transmitted throughadapter 116. If the packet parameters are inconsistent with the filter,storage system 104 drops, or rejects, the packet, and any memory (i.e., on the hardware of server device 102) utilized by the packet is marked as available, i.e., the utilized memory can be overwritten by another packet. - In some embodiments,
storage system 104 includes one or more partitions that include logical partition (LPAR) 106. In some embodiments,hypervisor 114 createsLPAR 106 from virtual and physical resources ofserver device 102. In some embodiments, each logical partition runs an independent operating environment, including an operating system (OS) (guest OS). In some embodiments, a virtual machine (VM) represents the guest OS and the resources ofserver device 102 allocated toLPAR 106 byhypervisor 114. - In some embodiments, the guest OS is an instance, or configuration, of the host OS (i.e., kernel 122) of
storage system 104. In addition to providing operating functions forstorage system 104,kernel 122 implements the virtual operating environment ofLPAR 106. In some such embodiments,kernel 122 andstorage program 112 are located in the guest OS ofLPAR 106. In alternative embodiments, the guest OS is a distinct OS fromkernel 122. In some such embodiments, the guest OS operates in conjunction withkernel 122. - In some embodiments,
LPAR 106 includes a virtual I/O server (VIOS). A VIOS is a computer program in a logical partition that enables multiple logical partitions to share access to a physical I/O resource where only one of the logical partitions owns the resource. For example, a VIOS can enable multiple logical partitions to share access to a single hardware device, such as a SCSI adapter and SCSI disk. - In some embodiments,
LPAR 106 includes one or more virtual adapters (not shown) to facilitate communications between a VM ofLPAR 106 and a VM of another logical partition, or between a VM of a logical partition and other systems ofstorage system 104. Examples of virtual adapters include virtualized network interface cards (vNICs), virtual host bus adapters (vHBAs), virtual Ethernet adapters, virtual Fibre Channel (FC) adapters, virtual small computer serial interface (SCSI) adapters, and virtual serial adapters. - In some embodiments,
hypervisor 114 is a computer program that manages virtual (including paravirtual) operations ofstorage system 104. In some embodiments,hypervisor 114 manages execution of guest OSs of VMs. As an example,hypervisor 114 manages access to resources ofstorage system 104 by the VMs. In some embodiments,storage system 104 includes an operating system (host OS), which includeskernel 122, that is distinct fromhypervisor 114.Hypervisor 114 loads and operates on top of the host OS. In alternative embodiments,hypervisor 114 includeskernel 122, which does not operate independently fromhypervisor 114.Hypervisor 114 performs operating system functions forstorage system 104 by directly communicating with physical resources of storage system 104 (e.g., to allocate resources to LPAR 106). - In some embodiments,
hypervisor 114 manages communications withinstorage system 104, and communications betweenstorage system 104 andserver device 102, through a communications fabric. For example,hypervisor 114 can manage a resource request from a guest OS ofLPAR 106 throughcommunications fabric 304, which is further described with respect toFIG. 3 . In some embodiments,hypervisor 114 manages communications between logical partitions, and communications between a logical partition and other systems ofstorage system 104, through one or more virtual switches (not shown). In some embodiments, a virtual switch is a computer program that facilitates the transmission of data packets between components ofstorage system 104. For example, a virtual switch can provide connectivity between LPAR 106 (i.e., a virtual adapter of LPAR 106) andadapter 116. In some embodiments, virtual switches are represented byhypervisor 114. In alternative embodiments, virtual switches are represented bycommunications fabric 304. - In some embodiments, the communications fabric is a communications subsystem of
storage system 104. For example, the communications fabric can be configured as a Virtual Local Area Network (VLAN). In some embodiments, the communications fabric is embedded in virtualization software ofstorage system 104. In alternative embodiments, the communications fabric is included in the hardware components ofserver device 102 as firmware. In some embodiments, the communications fabric includes a combination of physical and virtualized resources, such as fiber optic cables, Ethernet cables, physical and virtual adapters, and wireless connections. - In some embodiments,
device driver 110 is a computer program, application, or subprogram of a larger program that provides an interface to one or more hardware components ofstorage system 104. For example,device driver 110 provides an interface that enableshypervisor 114,kernel 122, andstorage program 112 to communicate withfirmware 118 andadapter 116. For example,device driver 110 provides access to the packet filter offirmware 118 and thereby control of the network traffic filtering function ofadapter 116. In some embodiments,device driver 110 communicates with devices (e.g., adapter 116) and other programs (e.g., firmware 118) ofstorage system 104 through the communications fabric. In some embodiments,device driver 110 is run byhypervisor 114. In alternative embodiments,device driver 110 is run bykernel 122, which can be located inLPAR 106 or, alternatively, outside ofLPAR 106. - In some embodiments,
storage program 112 is a computer program, application, subprogram of a larger program, such as an OS, or a combination thereof, that manages access tostorage system 104, includingstorage 130, by incoming network traffic. In some embodiments, in response to a request to update, replace, or otherwise modify the filter rules (i.e., the allowed or blocked ports or network protocols) offirmware 118,device driver 110, orkernel 122,storage program 112 prompts the requestor for a cryptographic key or password and allows the action only if the cryptographic key or password is provided. In some embodiments,storage program 112 allowskernel 122 to load a driver of a networking device (e.g., a driver that facilitates communications with firmware 118) only if the driver is cryptographically signed (e.g., a key or password is provided). In some embodiments,storage program 112 periodically inspects orqueries device driver 110,firmware 118,hypervisor 114, andkernel 122 to determine if a modification has been made to the filter rules. Ifstorage program 112 determines that a modification has been made,storage system 104 takes a responsive action, e.g., raises an event. - In some embodiments,
storage program 112 runs directly onserver device 102. In alternative embodiments,storage program 112 runs on a VM ofLPAR 106. In some such embodiments wherestorage program 112 runs on a VM, the VM utilizes apara-virtualized device driver 110, which runs onhypervisor 114. In other such embodiments wherestorage program 112 runs on a VM, the VM utilizes a virtualized or emulated device, which runs onhypervisor 114 and includes an implementation of the logic further described with respect toFIG. 2 . - In some embodiments, where
storage program 112 is not running on a VM ofLPAR 106, or where further security is desired,adapter 116 andfirmware 118 include code that prevents alteringfirmware 118 without cryptographic signing. This prevents a user from replacingfirmware 118 with a version of firmware that does not implement some or all of the restrictions further described with respect toFIG. 2 . - In further embodiments, logic and restrictions further described with respect to
FIG. 2 are implemented inkernel 122 of the operating system running thestorage program 112. In some such embodiments, a kernel image is cryptographically signed and a boot loader, onserver 102, prevents loading a version ofkernel 122 that is not signed. In alternative embodiments, logic and restrictions further described with respect toFIG. 2 are implemented indevice driver 110. In some such embodiments,kernel 122 requiresdriver 110 to be cryptographically signed and prevents loading a version ofdevice driver 110 that is not signed. -
FIG. 2 is a flowchart ofworkflow 200 depicting operational steps for providing security for a networked storage system, in accordance with embodiments of the present invention. In some embodiments,workflow 200 is performed bystorage system 104. For example, various aspects ofworkflow 200 can be performed bystorage program 112,hypervisor 114,firmware 118,device driver 110, orkernel 122. In alternative embodiments,workflow 200 is performed by any other computer program while working withstorage system 104. In some embodiments,storage system 104 begins performingworkflow 200 in response to receiving an indication by a user ofstorage system 104,client device 120, or any other computing device connected tonetwork 140. In alternative embodiments,workflow 200 initiates in response to a boot, or reboot, ofstorage system 104. - In
step 205,storage system 104 receives a packet. In some embodiments,storage system 104 receives a packet atadapter 116 fromclient device 120 throughnetwork 140. For example,storage system 104 can receive a request fromclient device 120 to access port 23, or Telnet protocol, in order to manage a network device instorage system 104.Storage system 104 can receive the request as a stream of multiple packets atadapter 116. - In some embodiments,
storage system 104 is a virtual environment, andstorage hypervisor 114 orkernel 122 receives a packet from a guest OS running inLPAR 106. In some embodiments, a guest OS inLPAR 106 requires para-virtualization. In some paravirtualized environments,paravirtualized device driver 110 can run onhypervisor 114 and receive a packet from the guest OS. In alternative embodiments, the environment is fully virtualized. In some virtualized environments,device driver 110 can be located inkernel 122, andkernel 122 anddevice driver 110 can be emulated byhypervisor 114. In such embodiments, the device corresponding to device driver 110 (e.g., adapter 116) does not appear virtualized to the guest OS. - In
step 210,storage system 104 analyzes packet parameters of the packet. In some embodiments, packet parameters include the source port, the source Internet Protocol (IP) address, the destination port, the destination IP address, or the protocol. In some embodiments, packet parameters are located in the header of each packet. In some embodiments,storage system 104 analyzes the packet parameters of the packet in response toadapter 116 receiving the packet. In response toadapter 116 receiving the packet atadapter 116 throughnetwork 140,firmware 118 identifies the packet parameters of the packet. - In some embodiments,
kernel 122 orhypervisor 114 receive the packet. For example, when a logical partition is running a guest OS,hypervisor 114 can receive the packet and transfer the packet todevice driver 110. In some embodiments,storage system 104 includes a distinct host OS and device driver is located inkernel 122. In alternative embodiments,hypervisor 114 performs OS functions forstorage system 104 and device driver is located inhypervisor 114. In response to receiving a packet,device driver 110 identifies the packet parameters of the packet. - In
decision step 215,storage system 104 determines whether the analyzed packet parameters are consistent with filter rules. In some embodiments, filter rules include an exhaustive list of port numbers or protocols that are allowed to be accessed within storage system 104 (e.g., a whitelist). For example, the filter infirmware 118 might define only port 3260 as an allowed port, or only TCP connections on the iSCSI protocol. In some embodiments, filter rules additionally or alternatively include a defined list of port numbers or protocols that are blocked from being accessed within storage system 104 (e.g., a blacklist). For example, a filter inkernel 122 might define the Fibre Channel over IP (FCIP) protocol, or port 3225, as a blocked port. - In some embodiments,
storage system 104 compares the analyzed packet parameters of the packet with the filter rules. The packet parameters are consistent with the filter if the parameters appear on a defined whitelist, if any is defined in the filter, and the parameters do not appear on a defined blacklist, if any is defined in the filter. - In some embodiments, a filter is hard-coded in
firmware 118,device driver 110, orkernel 122. For example, a filter is embedded in the source code offirmware 118, and the filter can only be modified if the source code offirmware 118 is modified. In alternative embodiments,storage system 104 includes more than one filter, and a filter is hard-coded in a combination offirmware 118,device driver 110, andkernel 122. For example,firmware 118,device driver 110, andkernel 122 may each include a defined list of ports that are allowed to be accessed withinstorage system 104. - In some embodiments,
storage program 112 provides cryptographic protection withinstorage system 104. In some embodiments, in response to an attempt to update, replace, or otherwise modify filter rules offirmware 118,device driver 110, orkernel 122,storage program 112 prompts the requestor for a cryptographic key or password and allows the access only if the key or password is provided. In some embodiments,storage program 112 allowskernel 122 to load a new driver of a networking device only if the new driver is cryptographically signed, i.e., a cryptographic key or password is provided. A user that has privileged access tostorage system 104, e.g., through a guest OS running onLPAR 106 ofstorage system 104, is thereby prevented from utilizing the privileged access to disable a filter, unless the user provides the key or password. In some embodiments,storage program 112 inspectsfirmware 118,device driver 110, orkernel 122 at periodic intervals to determine if the packet filter rules have been modified. - In
step 220, responsive to determining that the analyzed packet parameters are consistent with the filter (Yes branch, decision step 215),storage system 104 allows the packet to be transmitted to a requested destination. Instep 225, responsive to determining that the analyzed packet parameters are not consistent with the filter, (No branch, decision step 215),storage system 104 prevents the packet from being transmitted to the requested destination and drops, or rejects, the packet. In some embodiments, any memory (i.e., on the hardware of server device 102) utilized by the dropped packet is marked as available, i.e., the utilized memory can be overwritten by another packet. -
FIG. 3 depictscomputing system 300, which illustrates components ofserver device 102 andclient device 120.Computing system 300 includes processor(s) 301,cache 303,memory 302,persistent storage 305,communications unit 307, I/O interface(s) 306, andcommunications fabric 304. -
Communications fabric 304 provides communications betweencache 303,memory 302,persistent storage 305,communications unit 307, and I/O interface(s) 306.Communications fabric 304 can be implemented with any architecture designed for passing data and/or control information between processors (e.g., microprocessors, communications and network processors, etc.), system memory, peripheral devices, and any other hardware components within a system. For example,communications fabric 304 may be implemented with one or more buses or a crossbar switch. -
Memory 302 andpersistent storage 305 are computer readable storage media. In some embodiments,memory 302 includes random access memory (RAM) (not shown). In general,memory 302 may include any suitable volatile or non-volatile computer readable storage media.Cache 303 is a fast memory that enhances the performance ofprocessors 301 by holding recently accessed data, and data near recently accessed data, frommemory 302. - Program instructions and data used to practice embodiments of the present invention may be stored in
persistent storage 305 and inmemory 302 for execution by one or more of therespective processors 301 viacache 303. In some embodiments,persistent storage 305 includes a magnetic hard disk drive. Alternatively, or in addition to a magnetic hard disk drive,persistent storage 305 may include a solid state hard drive, a semiconductor storage device, read-only memory (ROM), erasable programmable read-only memory (EPROM), flash memory, or any other computer readable storage media that is capable of storing program instructions or digital information. - The media used by
persistent storage 305 may also be removable. For example, a removable hard drive may be used forpersistent storage 305. Other examples include optical and magnetic disks, thumb drives, and smart cards that are inserted into a drive for transfer onto another computer readable storage medium that is also part ofpersistent storage 305. -
Communications unit 307, in these examples, provides for communications with other data processing systems or devices. In these examples,communications unit 307 includes one or more network interface cards.Communications unit 307 may provide communications through the use of either or both physical and wireless communications links. Program instructions and data used to practice embodiments of the present invention may be downloaded topersistent storage 305 throughcommunications unit 307. - I/O interface(s) 306 allows for input and output of data with other devices that may be connected to each computer system. For example, I/
O interface 306 may provide a connection toexternal devices 308 such as a keyboard, keypad, a touch screen, and/or some other suitable input device.External devices 308 can also include portable computer readable storage media such as, for example, thumb drives, portable optical or magnetic disks, and memory cards. Software and data used to practice embodiments of the present invention can be stored on such portable computer readable storage media and can be loaded ontopersistent storage 305 through I/O interface(s) 306. I/O interface(s) 306 also connect to display 309. -
Display 309 provides a mechanism to display data to a user and may be, for example, a computer monitor. - The programs described herein are identified based upon the application for which they are implemented in a specific embodiment of the invention. However, it should be appreciated that any particular program nomenclature herein is used merely for convenience, and thus the invention should not be limited to use solely in any specific application identified and/or implied by such nomenclature.
- The present invention may be a system, a method, and/or a computer program product at any possible technical detail level of integration. The computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present invention.
- The computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device. The computer readable storage medium may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing. A non-exhaustive list of more specific examples of the computer readable storage medium includes the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon, and any suitable combination of the foregoing. A computer readable storage medium, as used herein, is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
- Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network. The network may comprise copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers. A network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer readable storage medium within the respective computing/processing device.
- Computer readable program instructions for carrying out operations of the present invention may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, configuration data for integrated circuitry, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++, or the like, and procedural programming languages, such as the “C” programming language or similar programming languages. The computer readable program instructions may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider). In some embodiments, electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) may execute the computer readable program instructions by utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present invention.
- Aspects of the present invention are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems), and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer readable program instructions.
- These computer readable program instructions may be provided to a processor of a general-purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
- The computer readable program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational blocks to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
- The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods, and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s). In some alternative implementations, the functions noted in the blocks may occur out of the order noted in the Figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts or carry out combinations of special purpose hardware and computer instructions. The descriptions of the various embodiments of the present invention have been presented for purposes of illustration, but are not intended to be exhaustive or limited to the embodiments disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. The terminology used herein was chosen to best explain the principles of the embodiment, the practical application or technical improvement over technologies found in the marketplace, or to enable others of ordinary skill in the art to understand the embodiments disclosed herein.
- Embodiments of the present invention may also be delivered as part of a service engagement with a client corporation, nonprofit organization, government entity, internal organizational structure, or the like. These embodiments may include configuring a computer system to perform, and deploying software, hardware, and web services that implement, some or all of the methods described herein. These embodiments may also include analyzing the client's operations, creating recommendations responsive to the analysis, building systems that implement portions of the recommendations, integrating the systems into existing processes and infrastructure, metering use of the systems, allocating expenses to users of the systems, and billing for use of the systems.
Claims (1)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/716,870 US10169594B1 (en) | 2017-06-07 | 2017-09-27 | Network security for data storage systems |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/616,189 US10599856B2 (en) | 2017-06-07 | 2017-06-07 | Network security for data storage systems |
US15/716,870 US10169594B1 (en) | 2017-06-07 | 2017-09-27 | Network security for data storage systems |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/616,189 Continuation US10599856B2 (en) | 2017-06-07 | 2017-06-07 | Network security for data storage systems |
Publications (2)
Publication Number | Publication Date |
---|---|
US20180357429A1 true US20180357429A1 (en) | 2018-12-13 |
US10169594B1 US10169594B1 (en) | 2019-01-01 |
Family
ID=64562239
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/616,189 Expired - Fee Related US10599856B2 (en) | 2017-06-07 | 2017-06-07 | Network security for data storage systems |
US15/716,870 Expired - Fee Related US10169594B1 (en) | 2017-06-07 | 2017-09-27 | Network security for data storage systems |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/616,189 Expired - Fee Related US10599856B2 (en) | 2017-06-07 | 2017-06-07 | Network security for data storage systems |
Country Status (1)
Country | Link |
---|---|
US (2) | US10599856B2 (en) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20180343302A1 (en) * | 2017-05-26 | 2018-11-29 | Realtek Semiconductor Corporation | Data management circuit with network functions and network-based data management method |
US20200389459A1 (en) * | 2018-01-12 | 2020-12-10 | Brian Girardi | System and Method for Trustworthy Internet Whitelists |
US20230269180A1 (en) * | 2020-07-28 | 2023-08-24 | Inspur Suzhou Intelligent Technology Co., Ltd. | Iscsi multipath management system and method, device, and storage medium |
US11748483B2 (en) * | 2018-06-27 | 2023-09-05 | Giesecke+Devrient Mobile Security Gmbh | Efficient firmware updates |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111325687B (en) * | 2020-02-14 | 2022-10-14 | 上海工程技术大学 | Smooth filtering evidence obtaining method based on end-to-end deep network |
Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20140289864A1 (en) * | 2011-11-04 | 2014-09-25 | British Telecommunications Public Limited Company | Method and apparatus for securing a computer |
Family Cites Families (45)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20020108059A1 (en) * | 2000-03-03 | 2002-08-08 | Canion Rodney S. | Network security accelerator |
US20110214157A1 (en) * | 2000-09-25 | 2011-09-01 | Yevgeny Korsunsky | Securing a network with data flow processing |
US20020078382A1 (en) * | 2000-11-29 | 2002-06-20 | Ali Sheikh | Scalable system for monitoring network system and components and methodology therefore |
US20020157020A1 (en) * | 2001-04-20 | 2002-10-24 | Coby Royer | Firewall for protecting electronic commerce databases from malicious hackers |
US7028225B2 (en) * | 2001-09-25 | 2006-04-11 | Path Communications, Inc. | Application manager for monitoring and recovery of software based application processes |
US20030115447A1 (en) * | 2001-12-18 | 2003-06-19 | Duc Pham | Network media access architecture and methods for secure storage |
US6745333B1 (en) | 2002-01-31 | 2004-06-01 | 3Com Corporation | Method for detecting unauthorized network access by having a NIC monitor for packets purporting to be from itself |
WO2004090675A2 (en) * | 2003-04-03 | 2004-10-21 | Commvault Systems, Inc. | System and method for performing storage operations through a firewall |
US7420931B2 (en) * | 2003-06-05 | 2008-09-02 | Nvidia Corporation | Using TCP/IP offload to accelerate packet filtering |
US20050108518A1 (en) * | 2003-06-10 | 2005-05-19 | Pandya Ashish A. | Runtime adaptable security processor |
US7707309B2 (en) | 2004-01-29 | 2010-04-27 | Brocade Communication Systems, Inc. | Isolation switch for fibre channel fabrics in storage area networks |
JP4327630B2 (en) * | 2004-03-22 | 2009-09-09 | 株式会社日立製作所 | Storage area network system, security system, security management program, storage device using Internet protocol |
JP4495508B2 (en) | 2004-04-23 | 2010-07-07 | 株式会社日立製作所 | Computer system configuration management method and configuration management apparatus |
EP1759317B1 (en) | 2004-06-17 | 2010-05-26 | Broadcom Corporation | Method and system for supporting read operations for iscsi and iscsi chimney |
US20060092751A1 (en) * | 2004-11-04 | 2006-05-04 | Hewlett-Packard Development Company, L.P. | Peripheral management |
US7865908B2 (en) | 2005-03-11 | 2011-01-04 | Microsoft Corporation | VM network traffic monitoring and filtering on the host |
US8631483B2 (en) * | 2005-06-14 | 2014-01-14 | Texas Instruments Incorporated | Packet processors and packet filter processes, circuits, devices, and systems |
US20070043851A1 (en) * | 2005-08-16 | 2007-02-22 | Netdevices, Inc. | Facilitating a user to detect desired anomalies in data flows of networks |
US20070266433A1 (en) * | 2006-03-03 | 2007-11-15 | Hezi Moore | System and Method for Securing Information in a Virtual Computing Environment |
US8009566B2 (en) * | 2006-06-26 | 2011-08-30 | Palo Alto Networks, Inc. | Packet classification in a network security device |
US7853998B2 (en) * | 2007-03-22 | 2010-12-14 | Mocana Corporation | Firewall propagation |
US8006297B2 (en) * | 2007-04-25 | 2011-08-23 | Oracle America, Inc. | Method and system for combined security protocol and packet filter offload and onload |
US9270594B2 (en) | 2007-06-01 | 2016-02-23 | Cisco Technology, Inc. | Apparatus and method for applying network policy at virtual interfaces |
US20100175104A1 (en) * | 2008-03-03 | 2010-07-08 | Khalid Atm Shafiqul | Safe and secure program execution framework with guest application space |
US20090319772A1 (en) * | 2008-04-25 | 2009-12-24 | Netapp, Inc. | In-line content based security for data at rest in a network storage system |
US8387046B1 (en) * | 2009-03-26 | 2013-02-26 | Symantec Corporation | Security driver for hypervisors and operating systems of virtualized datacenters |
US8984296B1 (en) * | 2009-03-29 | 2015-03-17 | Cypress Semiconductor Corporation | Device driver self authentication method and system |
US8646068B2 (en) | 2009-10-13 | 2014-02-04 | Lenovo (Singapore) Pte. Ltd. | Home image content securely isolated from corporate IT |
US8607054B2 (en) * | 2010-10-15 | 2013-12-10 | Microsoft Corporation | Remote access to hosted virtual machines by enterprise users |
WO2012114398A1 (en) | 2011-02-24 | 2012-08-30 | Nec Corporation | Network system, controller, and flow control method |
US8917742B2 (en) * | 2011-07-13 | 2014-12-23 | Microsoft Corporation | Mechanism to save system power using packet filtering by network interface |
US8621123B2 (en) * | 2011-10-06 | 2013-12-31 | Honeywell International Inc. | Device management using virtual interfaces |
JP5903873B2 (en) | 2011-12-19 | 2016-04-13 | 富士通株式会社 | Storage device, storage device control method, and storage device control program |
US8255538B1 (en) | 2011-12-23 | 2012-08-28 | Cirrus Data Solutions, Inc. | Systems and methods for intercepting data relating to storage volume access |
US9027024B2 (en) * | 2012-05-09 | 2015-05-05 | Rackspace Us, Inc. | Market-based virtual machine allocation |
US8848741B2 (en) * | 2012-06-21 | 2014-09-30 | Breakingpoint Systems, Inc. | High-speed CLD-based TCP segmentation offload |
US9571507B2 (en) * | 2012-10-21 | 2017-02-14 | Mcafee, Inc. | Providing a virtual security appliance architecture to a virtual cloud infrastructure |
US9565213B2 (en) * | 2012-10-22 | 2017-02-07 | Centripetal Networks, Inc. | Methods and systems for protecting a secured network |
US9407725B2 (en) * | 2013-06-14 | 2016-08-02 | Dell Products L.P. | Generic transcoding service for client-server communication |
US9762444B1 (en) * | 2013-12-06 | 2017-09-12 | Mobile Iron, Inc. | Detecting a configuration profile from a management agent |
US10095534B2 (en) | 2015-02-24 | 2018-10-09 | Red Hat Israel, Ltd. | Guest controlled virtual device packet filtering |
US10349304B2 (en) * | 2015-09-23 | 2019-07-09 | Cloudflare, Inc. | Software defined dynamic filtering |
US9813357B2 (en) | 2015-11-03 | 2017-11-07 | Gigamon Inc. | Filtration of network traffic using virtually-extended ternary content-addressable memory (TCAM) |
US10096081B2 (en) * | 2016-09-20 | 2018-10-09 | Advanced Micro Devices, Inc. | Adaptive filtering of packets in a graphics processing system |
US10191762B2 (en) * | 2017-01-31 | 2019-01-29 | Vmware, Inc. | Transparent deployment of intermediary manager into guest operating system network traffic |
-
2017
- 2017-06-07 US US15/616,189 patent/US10599856B2/en not_active Expired - Fee Related
- 2017-09-27 US US15/716,870 patent/US10169594B1/en not_active Expired - Fee Related
Patent Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20140289864A1 (en) * | 2011-11-04 | 2014-09-25 | British Telecommunications Public Limited Company | Method and apparatus for securing a computer |
Cited By (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20180343302A1 (en) * | 2017-05-26 | 2018-11-29 | Realtek Semiconductor Corporation | Data management circuit with network functions and network-based data management method |
US10645166B2 (en) * | 2017-05-26 | 2020-05-05 | Realtek Semiconductor Corporation | Network interface card |
US20200389459A1 (en) * | 2018-01-12 | 2020-12-10 | Brian Girardi | System and Method for Trustworthy Internet Whitelists |
US11711371B2 (en) * | 2018-01-12 | 2023-07-25 | Sanctuary Networks LLC | System and method for trustworthy internet whitelists |
US20230319046A1 (en) * | 2018-01-12 | 2023-10-05 | Sanctuary Networks LLC | System and Method for Trustworthy Internet Whitelists |
US12088593B2 (en) * | 2018-01-12 | 2024-09-10 | Sanctuary Networks LLC | System and method for trustworthy internet whitelists |
US11748483B2 (en) * | 2018-06-27 | 2023-09-05 | Giesecke+Devrient Mobile Security Gmbh | Efficient firmware updates |
US20230269180A1 (en) * | 2020-07-28 | 2023-08-24 | Inspur Suzhou Intelligent Technology Co., Ltd. | Iscsi multipath management system and method, device, and storage medium |
US11909634B2 (en) * | 2020-07-28 | 2024-02-20 | Inspur Suzhou Intelligent Technology Co., Ltd. | ISCSI multipath management system and method, device, and storage medium |
Also Published As
Publication number | Publication date |
---|---|
US20180357428A1 (en) | 2018-12-13 |
US10169594B1 (en) | 2019-01-01 |
US10599856B2 (en) | 2020-03-24 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11962622B2 (en) | Automated enforcement of security policies in cloud and hybrid infrastructure environments | |
US11469964B2 (en) | Extension resource groups of provider network services | |
US10048981B2 (en) | Performing virtual machine live migration within a threshold time by adding available network path in multipath network | |
US10169594B1 (en) | Network security for data storage systems | |
US9766943B2 (en) | Method and system for managing interconnection of virtual network functions | |
US9380523B1 (en) | System, method and computer program product for connecting roaming mobile devices to a virtual device platform | |
US10735452B2 (en) | Virtual machine compliance checking in cloud environments | |
US11924167B2 (en) | Remote session based micro-segmentation | |
TW201439917A (en) | Expansion of services for a virtual data center guest | |
US11057385B2 (en) | Methods to restrict network file access in guest virtual machines using in-guest agents | |
US8272031B2 (en) | Policy-based virtualization method involving adaptive enforcement | |
US9652279B1 (en) | Remotely interacting with a virtualized machine instance | |
US20220417257A1 (en) | Protecting accelerators from malicious network functions | |
Al-Ayyoub et al. | A novel framework for software defined based secure storage systems | |
US20200184074A1 (en) | Security detection system with privilege management | |
US11526373B2 (en) | Agentless personal network firewall in virtualized datacenters | |
EP3884628A1 (en) | Provider network service extensions | |
US9444790B2 (en) | Method and apparatus for threat isolation and remote resolution for computer systems | |
Ver | Dynamic load balancing based on live migration of virtual machines: Security threats and effects | |
US20230418650A1 (en) | System and method for sharing secret with an agent running in a virtual computing instance | |
US20240106855A1 (en) | Security telemetry from non-enterprise providers to shutdown compromised software defined wide area network sites | |
Lakshmipriya et al. | A novel approach for performance and security enhancement during live migration | |
Mansour | Towards effective live cloud migration on public cloud IaaS. | |
Ibou et al. | Openstack: The cloud os | |
Marotta | Architectures and Algorithms for Resource Management in Virtualized Cloud Data Centers |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:BARZIK, ZAH;KALAEV, MAXIM;SNAST, ALEXANDER;SIGNING DATES FROM 20170601 TO 20170604;REEL/FRAME:044034/0352 |
|
FEPP | Fee payment procedure |
Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
LAPS | Lapse for failure to pay maintenance fees |
Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20230101 |