Providing User Security Guarantees in Public Infrastructure Clouds
Total Page:16
File Type:pdf, Size:1020Kb
1 Providing User Security Guarantees in Public Infrastructure Clouds Nicolae Paladi, Christian Gehrmann, and Antonis Michalas Abstract—The infrastructure cloud (IaaS) service model offers improved resource flexibility and availability, where tenants – insulated from the minutiae of hardware maintenance – rent computing resources to deploy and operate complex systems. Large-scale services running on IaaS platforms demonstrate the viability of this model; nevertheless, many organizations operating on sensitive data avoid migrating operations to IaaS platforms due to security concerns. In this paper, we describe a framework for data and operation security in IaaS, consisting of protocols for a trusted launch of virtual machines and domain-based storage protection. We continue with an extensive theoretical analysis with proofs about protocol resistance against attacks in the defined threat model. The protocols allow trust to be established by remotely attesting host platform configuration prior to launching guest virtual machines and ensure confidentiality of data in remote storage, with encryption keys maintained outside of the IaaS domain. Presented experimental results demonstrate the validity and efficiency of the proposed protocols. The framework prototype was implemented on a test bed operating a public electronic health record system, showing that the proposed protocols can be integrated into existing cloud environments. Index Terms—Security; Cloud Computing; Storage Protection; Trusted Computing F 1 INTRODUCTION host level. While support data encryption at rest is offered by several cloud providers and can be configured by tenants Cloud computing has progressed from a bold vision to mas- in their VM instances, functionality and migration capabil- sive deployments in various application domains. However, ities of such solutions are severely restricted. In most cases the complexity of technology underlying cloud computing cloud providers maintain and manage the keys necessary introduces novel security risks and challenges. Threats and for encryption and decryption of data at rest. This further mitigation techniques for the IaaS model have been under convolutes the already complex data migration procedure intensive scrutiny in recent years [1], [2], [3], [4], while between different cloud providers, disadvantaging tenants the industry has invested in enhanced security solutions through a new variation of vendor lock-in. Tenants can and issued best practice recommendations [5]. From an choose to encrypt data on the operating system (OS) level end-user point of view the security of cloud infrastructure within their VM environments and manage the encryption implies unquestionable trust in the cloud provider, in some keys themselves. However, this approach suffers from sev- cases corroborated by reports of external auditors. While eral drawbacks: first, the underlying compute host will still providers may offer security enhancements such as protec- have access encryption keys whenever the VM performs tion of data at rest, end-users have limited or no control cryptographic operations; second, this shifts towards the over such mechanisms. There is a clear need for usable and tenant the burden of maintaining the encryption software cost-effective cloud platform security mechanisms suitable in all their VM instances and increases the attack surface; for organizations that rely on cloud infrastructure. third, this requires injecting, migrating and later securely One such mechanism is platform integrity verification withdrawing encryption keys to each of the VM instances for compute hosts that support the virtualized cloud infras- with access to the encrypted data, increasing the probability tructure. Several large cloud vendors have signaled practical than an attacker eventually obtains the keys. In this paper implementations of this mechanism, primarily to protect we present DBSP (domain-based storage protection), a vir- the cloud infrastructure from insider threats and advanced tual disk encryption mechanism where encryption of data is persistent threats. We see two major improvement vectors done directly on the compute host, while the key material regarding these implementations. First, details of such pro- necessary for re-generating encryption keys is stored in prietary solutions are not disclosed and can thus not be im- the volume metadata. This approach allows easy migration plemented and improved by other cloud platforms. Second, of encrypted data volumes and withdraws the control of to the best of our knowledge, none of the solutions provides the cloud provider over disk encryption keys. In addition, cloud tenants a proof regarding the integrity of compute DBSP significantly reduces the risk of exposing encryption hosts supporting their slice of the cloud infrastructure. To keys and keeps a low maintenance overhead for the tenant address this, we propose a set of protocols for trusted launch – in the same time providing additional control over the of virtual machines (VM) in IaaS, which provide tenants choice of the compute host based on its software stack. with a proof that the requested VM instances were launched We focus on the Infrastructure-as-a-Service model – in a on a host with an expected software stack. simplified form, it exposes to its tenants a coherent platform Another relevant security mechanism is encryption of supported by compute hosts which operate VM guests that virtual disk volumes, implemented and enforced at compute communicate through a virtual network. The system model 2 chosen for this paper is based on requirements identified for identification each time a client launches a VM. The while migrating a currently deployed, distributed electronic paper presents a good initial set of ideas for trusted VM health record (EHR) system to an IaaS platform [6]. launch and migration, in particular the use of a trusted coordinator. A limitation of this solution is that the trusted 1.1 Contribution coordinator maintains information about all hosts deployed We extend previous work applying Trusted Computing to on the IaaS platform, making it a valuable target to an strengthen IaaS security, allowing tenants to place hard adversary who attempts to expose the public IaaS provider security requirements on the infrastructure and maintain to privacy attacks. exclusive control of the security critical assets. We propose A decentralized approach to integrity attestation is a security framework consisting of three buiding blocks: adopted by Schiffman et al. [2] to address the limited trans- parency of IaaS platforms and scalability limits imposed by • Protocols for trusted launch of VM instances in IaaS; third party integrity attestation mechanisms. The authors • Key management and encryption enforcement func- describe a trusted architecture where tenants verify the tions for VMs, providing transparent encryption of integrity of IaaS hosts through a trusted cloud verifier proxy persistent data storage in the cloud; placed in the cloud provider domain. Tenants evaluate the • Key management and security policy enforcement by cloud verifier integrity, which in turn attests the hosts. a Trusted Third Party (TTP); Once the VM image has been verified by the host and We describe several contributions that enhance cloud countersigned by the cloud verifier, the tenant can allow the infrastructure with additional security mechanisms: launch. The protocol increases the complexity for tenants 1. We describe a trusted VM launch (TL) protocol which both by introducing the evaluation of integrity attestation allows tenants – referred to as domain managers – to reports of the cloud verifier and host and by adding steps to launch VM instances exclusively on hosts with an at- the trusted VM launch, where the tenant must act based tested platform configuration and reliably verify this. on the data returned from the cloud verifier. Our proto- 2. We introduce a domain-based storage protection proto- col maintains the VM launch traceability and transparency col to allow domain managers store encrypted data vol- without relying on a proxy verifier residing in the IaaS. umes partitioned according to administrative domains. Furthermore, the TL protocol does not require additional 3. We introduce a list of attacks applicable to IaaS environ- tenant interaction to launch the VM on a trusted host, ments and use them to develop protocols with desired beyond the initial launch arguments. security properties, perform their security analysis and Platform attestation prior to VM launch is also applied prove their resistance against the attacks. in [7], which introduces two protocols – “TPM-based certi- 4. We describe the implementation of the proposed pro- fication of a Remote Resource” (TCRR) and “VerifyMyVM”. tocols on an open-source cloud platform and present With TCRR a tenant can verify the integrity of a remote extensive experimental results that demonstrate their host and establish a trusted channel for further commu- practicality and efficiency. nication. In “VerifyMyVM”, the hypervisor running on an attested host uses an emulated TPM to verify on-demand 1.2 Organization the integrity of running VMs. Our approach is in many aspects similar to the one in [7] in particular with regard The rest of this paper is organized as follows. In Section2 to host attestation prior to VM instance launch. However, trusted virtual machine we describe relevant related work on the approach in [7] requires the user to always encrypt the launch cloud storage protection and . In Section3