Frequently Asked Questions
General
What is Chameleon?
Chameleon is an experimental, deeply reconfigurable testbed funded by the National Science Foundation (NSF) for computer science research, education, and emergent applications. Chameleon Infrastructure (CHI) is built over three sites -- the University of Chicago (CHI@UC), the Texas Advanced Computing Center (CHI@TACC), and the National Center for Atmospheric Research (CHI@NCAR) -- offering a total of over 400+ nodes and 5 PB of space in Standard Cloud Unit (SCU) racks. To effectively support CS experiments, Chameleon offers bare metal reconfigurability on most of the hardware. To provide easy access to educational users, racks at TACC are configured with OpenStack KVM (KVM@TACC). You can read more about Chameleon here.
What does CHI mean?
CHI stands for Chameleon Infrastructure, and refers to the technology powering our bare metal clouds: a combination of software components from OpenStack, Grid'5000, and our own developments.
How should I acknowledge Chameleon?
An acknowledgement of support from the Chameleon project and the NSF should appear in any publication of material, whether copyrighted or not, that describes work which benefited from access to Chameleon cyberinfrastructure resources. The suggested acknowledgement is as follows: “Results presented in this paper were obtained using the Chameleon testbed supported by the National Science Foundation”.
In addition, it helps us a lot when you cite the Chameleon paper (see below). This makes it much easier for us to find the specific instances of research produced using Chameleon, and understand better how the testbed is used to support specific experiments.
How should I cite Chameleon?
If you publish work that benefited from access to Chameleon, we would appreciate citations to our references. The best reference for Chameleon is:
Kate Keahey, Jason Anderson, Zhuo Zhen, Pierre Riteau, Paul Ruth, Dan Stanzione, Mert Cevik, Jacob Colleran, Haryadi S. Gunawi, Cody Hammock, Joe Mambretti, Alexander Barnes, François Halbach, Alex Rocha and Joe Stubbs. "Lessons Learned from the Chameleon Testbed". In Proceedings of the 2020 USENIX Annual Technical Conference (USENIX ATC '20). USENIX Association. July 2020. Full paper
BibTex entry:
@incollection{keahey2020lessons,
  title={Lessons Learned from the Chameleon Testbed},
  author={Kate Keahey and Jason Anderson and Zhuo Zhen and Pierre Riteau and Paul Ruth and Dan Stanzione and Mert Cevik and Jacob Colleran and Haryadi S. Gunawi and Cody Hammock and Joe Mambretti and Alexander Barnes and Fran\c{c}ois Halbach and Alex Rocha and Joe Stubbs},
  booktitle={Proceedings of the 2020 USENIX Annual Technical Conference (USENIX ATC '20)},
  publisher={USENIX Association},
  month={July},
  year={2020}
}Visit the papers page for more Chameleon papers.
Where do I find help?
If you need any help with specific questions and requests related to Chameleon, the help desk staff is here to support you. You can easily reach the help desk by submitting tickets through the help desk portal, visible next to your username on the Chameleon home page.
We also offer users a Forum as a space for user discussion and non-urgent questions about using Chameleon Cloud that will be addressed on a best-effort basis. However, if you need help immediately, please reach out to our Help Desk.
Project and Allocation Management
How do I apply for a Chameleon project?
Project applications may be filled out here. If you want to apply for a project you have to be PI eligible; if you fulfill the PI eligibility criteria but did not request PI eligibility when you applied for a Chameleon account you can request it by modifying options in your profile. An application for a project has to include a description of the research or education project to be performed using the testbed and the type of resources needed (see below). Each Chameleon project is awarded an allocation of service units for a specific amount of time. Users can expect a project decision within one business day.
My PI/Professor/Colleague already has a Chameleon Project. How do I get added as a user on the project?
You will need to contact the project PI and request that they add you as a user. Provide the PI with your Chameleon username. The project PI should visit the Chameleon Project Management page. See our documentation on how to manage users.
What are the units of an allocation, and how am I charged?
Chameleon allocations can consist of several components of the system. Users can request allocation of individual compute nodes, storage servers, or specialized hardware such as GPUs and FPGAs.
Resources are allocated and charged in Service Units (SUs) which equate to one hour of wall clock time on a base bare metal server.
- Base Bare Metal Servers: One SU equates to one hour of wall clock time on a base bare metal server (i.e., no attachments). Note this unit differs from traditional HPC or cloud service units that are charged in core-hours; a Chameleon SU is a full server, as the type of experiments and performance measurements users may wish to do may be contaminated by sharing nodes. Specific instances may be charged a multiple of an SU (e.g., if they include accelerators or other special features, see below).
- Specialized Bare Metal Hardware: Servers with expensive and unique features including storage, GPU, or FPGA nodes are charged at 2x the rate of standard compute servers (i.e., 1 hour of use on 1 storage server costs 2 SUs).
- A100 Bare Metal Hardware: Servers with our most modern GPUs are charged at 4x the rate of standard compute servers (i.e., 1 hour of use on 1 A100 bare metal server costs 4 SUs). This rate is constant for hosts with more than 1 GPU. For example, hosts that contain 4x A100 GPUs are charged an hourly rate of 16 SUs.
- Reservable Network Resources: Reserved floating IP addresses and non-stitchable VLANs are both charged at a rate of 1 SU per hour. Reserved stitchable VLANs are charged at a rate of 2 SUs per hour.
- Virtual Machines (KVM Instances): KVM instances also require a reservation and are charged based on the fraction of the host server's resources they use (see the following FAQ entry).
Here is a summary of the charge rates:
| Resource Type | Charge Rate (per hour) | Maximum Duration | 
|---|---|---|
| Base Bare Metal Server | 1 SU | 7 days | 
| Specialized Bare Metal Server: FPGAs, Storage Nodes, High RAM, All GPUs except A100 | 2 SUs | 7 days | 
| Bare Metal A100 GPU | 4 SUs | 7 days | 
| 4x Bare Metal A100 GPU | 16 SUs | 7 days | 
| Reservable Floating IP/Non-Stitchable VLAN | 1 SU | 7 days | 
| Reservable Stitchable VLAN | 2 SUs | 7 days | 
| KVM Instance | Fractional (See details below) | Up to 6 months | 
The basic principle for charging SUs is to evaluate the amount of time a fraction of the resource is unavailable to other users. If you make a reservation, you will be charged for the reserved time whether you use the resources or not, as they are held for you. You may cancel a reservation at any time before it starts to avoid being charged.
How are KVM instances (virtual machines) charged?
All KVM instances require a reservation and are charged against your project’s SU allocation.
Note: The pricing model below is preliminary and subject to change.
The core principle is that a KVM instance is charged based on the fraction of the physical host's resources it consumes. The charge is calculated based on the fraction of CPU cores the VM uses relative to the total available on the host (typically 48 cores). The same principle applies to specialized resources like GPUs. We then round these fractional prices down to account for hypervisor and Noisy Neighbors overhead.
For example, a bare metal host with 4x modern GPUs (e.g., 4x A100s or H100s) has a charge rate of 16 SUs per hour. The g1.h100.pci.1 flavor reserves 1 of 4 available H100 GPUs, so your project will be charged for 1/4 of the host's rate (16 SUs), which is 4 SUs per hour.
Storage for KVM instances is not charged against your SU allocation.
The table below shows pre-defined instance "flavors" with their SU cost listed.
KVM Instance Flavors and SU Costs
| Flavor Name | vCPUs | RAM (MB) | SU Cost / Hour | Maximum Duration | 
|---|---|---|---|---|
| m1.tiny | 1 | 512 | 0.01 | 6 months | 
| m1.small | 1 | 2048 | 0.02 | 6 months | 
| m1.medium | 2 | 4096 | 0.04 | 6 months | 
| m1.large | 4 | 8192 | 0.08 | 6 months | 
| m1.xlarge | 8 | 16384 | 0.15 | 6 months | 
| m1.xxlarge | 16 | 32768 | 0.3 | 6 months | 
| g1.h100.pci.1 | 24 | 49152 | 4 | 7 days | 
| g1.h100.pci.4 | 192 | 1000000 | 16 | 7 days | 
Note: SU Costs for standard flavors are calculated based on a 48-core host. You cannot currently reserve a VM with FPGA resources.
In addition to the above pricing, KVM leases are restricted to a 6-month maximum duration (except for GPU VM leases, which are restricted to a 7-day maximum duration), which is discussed further in the FAQ on resource usage policies.
What are the project allocation sizes and limits?
Chameleon operates on a “soft allocation model” where each project, if approved, receives a startup allocation of 20,000 SUs for six months. This allocation can be both recharged (more SUs added) and renewed (duration extended) by submitting a request through the user portal (see our docs here)+. This startup amount is designed to cover a significant amount of experimentation while ensuring fair access for all users.
All allocation requests, including new projects, renewals, and recharges, are typically processed within one business day of submission. A PI can apply for multiple projects; however, the number of held allocations will be taken into account during the review process.
What is the format of an allocation request?
A Chameleon Allocation request consists of the following components:
- Project Title
- Research tag identifying the research area that is most similar to the project's focus
- Project abstract describing the proposed experiments, the intended scientific questions to address, and the type and scale of resources needed; this part is required and may be published on Chameleon website (~200 words)
- Resource justification describing how you intend to use Chameleon to accomplish your research goals; an extension of the project abstract, potentially including details that the PI does not wish to publish such as e.g., notes on funding sources, specifics about the methodology, and detailed resource requirements
- Funding source disclosure (optional but encouraged for reporting impact!)
You will receive a follow-up from our team for more information if your application is incomplete.
What criteria is used to review project proposals?
Requests for projects and allocations are reviewed by project staff within 1 business day. The following criteria are used:
- PI eligibility
- Relevance of the proposed experiment to computer science research; scientific merit and significance of the proposed experiments
- Demonstrated need for Chameleon resources, methodology appropriate to the use of the Chameleon resource, justification of the requested allocation
- Success of prior or other existing allocations (for renewals) in terms of published research results and new funding
- Technical feasibility (i.e, can the project succeed in the Chameleon environment?)
- Any funded support for the project (optional, but we want to make certain that we give allocations to NSF CISE-supported cloud computing research!)
Policies
What are the security best practices on Chameleon?
The security best practices are described in this article.
What are the consequences of not following the security best practices and causing a security incident?
The Chameleon team will terminate all instances involved in a security incident and place an administrative lock on all interactions from the project under which the incident was caused that will last until the incident is resolved. Negligence in following best practices can affect not only you but also your collaborators on the project for the duration of the incident. Depending on the severity of incident, Chameleon personnel may further suspend Chameleon access for anybody on the affected project for a week. In the case of repeat offenders, Chameleon access will be withdrawn until further notice.
What are the policies on Chameleon resource usage?
Allocation:
To use Chameleon resources, users must belong to an approved project with an active approved allocation. All created projects receive an initial 6-month allocation of 20,000 SUs immediately upon project approval. All approved members added to a project can use the allocation resources to create leases for bare metal and virtualized instances on the testbed. Project PIs and managers may request extensions on active allocations (within one (1) month of allocation expiration) and recharge requests for additional SUs (upon depletion of allocation SUs prior to expiration). See the project management documentation for more details on Chameleon allocations
Leases:
All Chameleon resources (bare metal and virtual) require a lease to be created before use. Leases are charged against the project's allocation of service units (SUs) based on the instance pricing above.
To ensure fairness to all users, resource reservations (leases) are subject to the following policies:
- A new lease cannot conflict with a pre-existing one, but can be scheduled in the future if needed.
- You can request a lease duration of up to 7 days for bare metal hosts and VMs with GPUs attached
- You can request a lease duration of up to 6 months for VM instances (except for those with GPU attachments)
- Users can renew a lease when 30% or less of its duration remains. For example, if you make a 7-day bare metal lease, you will recieve a notification for renewal when you have less than 48 hours remaining in your lease duration. If you make a 6-month VM lease, you will receive notification for renewal one and a half (1 1/2) months before your expiration date.
We actively discourage “lease stacking”—the practice of obtaining multiple overlapping reservations for resources (e.g., compute instances, storage, or networking components) to extend project usage beyond typical limits or to ensure continuous access. Please do not try to circumvent the one week lease restriction by stacking leases. Engaging in such stacking could lead to resource hoarding, impacting the availability for other users. Our experience has shown that such conduct results in idle hardware capacity and creates negative incentives for all users to “overfish” the pond out of fear that others will do so first.
We monitor the number and duration of leases across all projects for a given resource type. Projects with excessive reservations will be flagged for review. The project’s Principal Investigator (PI) will be contacted to provide justification or remove the violating leases within 3 business days. Failure to respond in a timely manner will result in the violating leases being terminated by Chameleon staff.
Exceptions for extended access or intensive resource use may be granted for projects with significant computational needs, such as large-scale experiments and educational use cases. Users can submit exception requests through the Help Desk.
Requests for exceptions should be made by the Project's PI and must detail the project’s goals, the need for additional resources, and how impact on the broader user community will be minimized. If you require a longer lease than 7 days or if you would like to extend your current lease, see the relevant FAQ items below.
Exceptions will be made sparingly. Chameleon offers other tools and methods for saving your work at the end of a lease and automating relaunching on a new lease. See documentation on cc-snapshot (which simplifies the process of saving the state of a bare-metal instance) and our blog post on making instance snapshots on Chameleon.
What are the best practices for using Chameleon bare metal partitions?
- While it is possible to repeatedly request a lease for the same resource, we strongly discourage this. Instead, save your work between leases using the CC-Snapshot instructions below.
- Do not reserve more resources that you need at any given time. For example, if you need relatively few resources to develop something that you will then test at large scale, start with a small reservation for the development phase of your work and enlarge it later to test at scale – as opposed to making a large reservation up front.
- Always release the reservation if you will not use the testbed for an extended period of time. For example, when you leave for the weekend, holidays, or simply need to take a break from experimentation and analyze your experiment, the resources could be used by others.
- Automate creating your experimental environment. You can use scripting or some of the tools we provide that let you save your appliances/images between sessions (cc-snapshot ) or to orchestrate the deployment of complex environments (Complex Appliances) – if you need more ideas read our article on How to Make the Most of your Seven Day Lease. This will make reestablishing your experiment in a new lease easier and also makes it easier for you to reproduce your work and eventually share it with colleagues.
What happens to my resources when my allocation expires?
Note: All retention periods are subject to the overall lifetime of the Chameleon project.
Once your Chameleon allocation expires, resources are retained according to the following schedule:
- KVM instances: Automatically shutdown and offloaded to storage 48 hours after allocation expiration. After renewing your expired allocation, you will be able to unshelve and reload your instance. All KVM instances are deleted 1 year after expiration
- Bare metal instances, leases, and networks (including floating IPs): Deleted immediately after allocation expiration
- Storage resources (private images, volumes, object stores, Jupyter volumes): Retained for 1 year after allocation expiration
- Public resources (public images and object store buckets): Retained for 5 years after allocation expiration
- SSH keys: Retained for the lifetime of your project
To prevent unintended data loss, consider: (1) keeping your allocation active through renewal, (2) downloading important data before your allocation expires, or (3) making valuable resources public to extend their retention period.
Who can use Chameleon?
Chameleon is broadly available to members of the US Computer Science research community and its international collaborators working in the open community on cloud research. By emphasizing “open” we mean that the expectation is that any research performed on Chameleon will result in publication in a broadly available journal or conference.
Who is eligible to be Chameleon PI?
See our documentation on eligibility for PI status. In general, students of any kind are not eligible for PI status.
Tips and Tricks
How do I make sure that my PI status is reflected in my profile?
If you are eligible to be PI (you can verify in this section), in order to apply for a project you need to make sure that your Chameleon profile reflects your status. You can do so on the Edit Account Profile page. Simply check the "Request PI Eligibility" checkbox and save you Account Profile.
How can I extend a Chameleon lease?
Users can renew a lease when 30% or less of its duration remains. Users may extend the lease by up to the duration limit for the requested resource (7 days for GPU VMs and bare metal; 6 months for non-GPU VMs) from the moment of request if resources are available. To prolong a lease, click on the “Update Lease” button in the Reservations panel of the CHI OpenStack dashboard, and enter the additional duration requested in the “Prolong for” boxes. If there is an advance reservation blocking your lease prolongation that could potentially be moved, you can interact through the users mailing list to coordinate with others users.
What if I need a lease that is longer than the limitation (i.e., 7 days for GPU VMs and bare metal; 6 months for all other VMs)?
If you know from the start that your lease has will require more than the resource's duration limit and cannot be broken into two or more leases because of the nature of the experiment, you can contact Chameleon staff via the ticketing system to request a one-time exception to create a longer lease. The request has to be submitted by the project PI and should contain a detailed justification for why a contiguous lease is needed. Please note, that these requests may take a longer time to consider as needed to understand all the details.
I am new to SSH, how do I create my own SSH key pairs on Linux/macOS?
Whenever you are creating an instance in Chameleon, you will have an option to select an Public SSH Key imported from your desktop. Once selected, this public key will be inserted into the instance's ~/.ssh/known_hosts file. When a user attempts to connect to the instance, the private key provided by the user will be validated against this public key in the known_hosts file. These instructions will help you create an SSH key pair and log in to your instance on Chameleon.
For Linux/ Mac OS X
Open a terminal window:
- In a Mac OS X system, click on your launchpad and search for terminal
- In an Ubuntu system you can use the keys Ctrl+Alt+T (for desktop version)
Access the SSH key pairs directory; in your terminal type the command:
cd ~/.ssh
Create your ssh key pair (public and private keys); in the .ssh directory, type the command:
ssh-keygen
Press the enter key, then enter a name for your key.
After completing the previous step, a message stating “Enter file in which to save the Key” will be displayed. Enter the name of your preference. I will use in this example the name “sample-key”. Then press the enter key.
Then, you will be requested to enter a passphrase for your key. Entering a passphrase is not necessary, so you can proceed to leave it blank and press enter. You will receive a message “Enter same passphrase again:” so just leave it blank and press enter.
Since we are still in the .ssh directory, now you can see your newly created key by typing ls.
You will see two files:
- sample-key (containing the private key)
- sample-key.pub (containing the public key)
You may view your sample-key.pub contents by typing:
cat sample-key.pub
Select and copy the contents displayed starting ssh-rsa all the way to the end. To add a key pair in Chameleon, follow the instructions for importing key pair and paste the contents of the key in the Public Key text entry.
After you have created a key pair and imported it in Chameleon, you can connect to any instance configured with this key pair. To do so you can use the command:
ssh -i ~/.ssh/sample-key cc@<instance ip address>
For Windows
First, download and install PuTTY and PuTTYgen from here. Once downloaded, opening PuTTYgen will open a key generator window, seen below.
I can't ping or SSH to my instance, what are some good things to try?
While the possibility that the system is being taking over by nanites should not be discounted too easily, it is always prudent to first check for the following issues:
- Do you have a floating IP associated with your instance? By default, instances do not have publicly-accessible IP addresses assigned. See our documentation on associating a floating ip.
- KVM only: Does your security group allow incoming ICMP (e.g. ping) traffic? By default, firewall rules do not allow ping to your instances. If you wish to enable it, see our documentation on security group.
- KVM only: Does your security group allow incoming SSH (TCP port 22) traffic? By default, firewall rules do not allow SSH to your instances. If you wish to enable it, see our documentation on security group.
If none of these solve your problem, please open a ticket with our help desk, and send us the results of the above (and any evidence of nanites you find as well).
Why are my instances failing to launch?
Chameleon requires users to reserve resources before allowing them to launch instances. Please follow the documentation on making reservations and make sure that:
- You have created a lease with resources and it has started (the associated reservation is shown as 'Active')
- You have selected your reservation in the Launch Instance panel
- You don't over-use your reservation
If you get an error stating that 'No valid host was found', it might be caused by a lack of resources in the cloud. The Chameleon staff continuously monitors the utilization of the testbed, but there might be times when no more resources are available. If the error persists, please open a ticket with our help desk.
What is CHI-in-a-box?
CHI-in-a-box is a packaging of the implementation of the core services that together constitute the Chameleon testbed for experimental Computer Science research. These services allow Chameleon users to discover information about Chameleon resources, allocate those resources for present and future use, configure them in various ways, and monitor various types of metrics.
While a large part of CHI (CHameleon Infrastructure) is based on an open source project (OpenStack), and all the extensions we made are likewise open source, without proper packaging there was no clear recipe on how to combine them and configure a testbed of this type. CHI-in-a-box is composed of the following three components: (a) open source dependencies supported by external projects (e.g., OpenStack and Grid’5000), (b) open source extensions made by the Chameleon team, both ones that are scheduled to be integrated into the original project (but have not been yet) and ones that are specific to the testbed, and (c) new code written by the team released under the Apache License 2.0.
We have identified demand for three types of scenarios in which users would like to use a packaging of Chameleon infrastructure:
Chameleon Associate: In this scenario a provider wants to add resources to the Chameleon testbed such that they are discoverable and available to all Chameleon users while retaining their own project identity (via branding, usage reports, some of the policies, etc.). This type of provider will provide system administration of their resources (hardware configuration and operation as well as CHI administration with the support of the Chameleon team) and use the Chameleon user services (user/project management, etc.), user portal, resource discovery, and appliance catalog. All user support will be provided by the Chameleon team.
Chameleon Part-time Associate: This scenario is similar to the Chameleon Associate but while the resources are available to the testbed users most of the time, the provider anticipates that they may want to take them offline for extended periods of time for other uses. In this scenario Chameleon support extends only to the time resources are available to the testbed.
Independent Testbed: In this scenario a provider wants to create a testbed that is in every way separate from Chameleon. This type of provider will use CHI for the core testbed services only and operate their user services (i.e., manage their own user accounts and/or projects, help desk, mailing lists and other communication channels, etc.), user portal, resource discovery, and appliance catalog (some of those services can in principle be left out at the cost of providing a less friendly interface to users). This scenario will be supported on a best effort basis only.
What is a Jupyter Notebook?
Developed by Project Jupyter, the Jupyter Notebook is an open-source web application where you can create rich documents that marry code, data, documentation, and visualization. Jupyter Notebooks are used in many fields for the collection and analysis of data, and we are now seeing explorations of their use in the research sphere. All Chameleon users can get their own Jupyter Notebook server provisioned automatically by going to the Chameleon JupyterHub server and logging in with their Chameleon credentials. Chameleon Notebook servers come pre-installed with some convenience libraries to make it easier to interact with the Chameleon testbed. See the Jupyter Notebook documentation for more details.
What is Trovi?
Chameleon Trovi is a sharing portal that allows you to share digital research and education artifacts, such as packaged experiments, workshop tutorials, or class materials. Each research artifact is represented as a deposition (a remotely accessible folder) where a user can put Jupyter notebooks, links to images, orchestration templates, data, software, and other digital representations that together represent a focused contribution that can be run on Chameleon. Users can use these artifacts to recreate and rerun experiments or class exercises on a Jupyter Notebook within Chameleon. They can also create their own artifacts and publish them directly to Trovi from within Chameleon’s Jupyter server. You can learn more in the Trovi documentation.
How should I cite Trovi artifacts?
Note: If you are looking to cite the Trovi service generally (rather than a specific Trovi artifact), please refer to our formal Trovi reference on our Chameleon Papers webpage.
To ensure that both Trovi and the original authors receive proper credit, we recommend a general citation format for artifacts hosted on Trovi that includes both the Trovi URL and the Zenodo DOI. This ensures the citation is formal and discoverable while also acknowledging Trovi as the publishing platform.
Please use the following general format for your citations (please note that the specific format will depend on the venue or author style, but citations to Trovi artifacts should always contain the following information):
General Format:
[Author(s)]. ([Year]). [Title of Artifact]. Trovi. [Trovi URL]. [DOI]. (Optional note acknowledging FOUNT/REPETO).
Example:
Meng Wang. (2023). SC23 MLEC Artifact. Trovi. https://chameleoncloud.org/experiment/share/50692573-4094-466c-b4fe-0ed3471f8993. https://doi.org/10.5281/zenodo.8231461.
If you are citing a Trovi artifact with a REPETO or FOUNT badge, please include a note acknowledging support of the relevant NSF award title and number.
REPETO: NSF Award No. 2226406
FOUNT: NSF Award No. 2230077
The bibtex format is displayed below:
@misc{key,
    author={author_names},
    title={artifact_title},
    publisher={{Trovi}},
    url={trovi_url},
    doi={zenodo_doi},
    year={year},
    month={month},
    note={acknowlegdment)
}
How do I reserve GigaIO Composable Hardware?
To reserve our new composable hardware, please follow these steps:
- 
	Review the background information Read our blog post on GigaIO Hardware for an overview of the technology and its capabilities. 
- 
	Understand the reservation process - You need to reserve multiple nodes to access multiple GPUs, even if you plan to compose a system with multiple GPUs on one node.
- Each node's "default" configuration is available in the reference-api and for reservation.
- Example: To reserve 4 GPUs and 1 node, you'll need to reserve all 4 nodes, as each node "comes with" one GPU.
 
- 
	Make your reservation Use the standard reservation process to book the required number of nodes. 
- 
	Request reconfiguration After making your reservation, submit a helpdesk ticket with the title "Composable Hardware Configuration Request." We will trigger the re-composition of the resources when your reservation starts. 
Note: Due to the complexity of reconfiguring the switch fabric, we do not currently have an API for direct reconfiguration. Our team will handle the reconfiguration based on your helpdesk ticket.
For any questions or assistance, please don't hesitate to contact our support team.
Federated Login
What is federated login?
Federated login enables users to use a single set of credentials to log into many different services. For example, federated login allows you to use your university or other institutional credentials to log into Chameleon -- there is no need to create a new account. In addition, since federated login is supported by many testbeds and services across scientific infrastructures you will be able to sign in once and use multiple services. For example, users who have allocation on both the CloudBank and Chameleon testbeds will be able to sign into one of them and use both. Users who have allocation on both GENI and Chameleon testbeds will likewise be able to access both by signing in only once. And users who use Globus services and Chameleon at the same time will be able to use both as well.
Why does Chameleon use federated login?
Federated login has many advantages for our users: it makes it easier to log into Chameleon, reduces the number of accounts a user has to create to use scientific infrastructure, and makes using testbeds and tools in conjunction much easier by supporting single sign-on across multiple services. The latter also makes it easier for Chameleon to add new integrated services -- for example, federated login enables support for single sign-on for Jupyter on Chameleon. Finally, long-term it will allow us to scale the testbed to many sites more efficiently and securely.
How is federated login implemented on Chameleon?
Chameleon uses Globus Auth, a popular authentication service, to implement federated login. New users can sign up via their existing host institution account, use their Google account, or create a Globus ID tied to an email and password that they provide.
It looks like I have multiple set of credentials that I could log in with: which one should I choose?
In many cases, our uses will be able to use multiple identities to gain access to the testbed: this happens for example if your institution is part of InCommon and you also have a Google account. Is one set of credentials better to use than another? This largely depends on your preferences and the nature of your work. Many users like to use their Google account in a “lingua franca”, access everything capacity: it has the advantage of simplicity. On the other hand, if you use infrastructure based on InCommon login (such as GENI or CloudBank) in conjunction with Chameleon, logging in via credentials linked to one of the InCommon institutions will have the advantage that you need to authenticate only once in order to access both infrastructures. Note that no specific set of credentials is permanently linked to your CHameleon access: so if you you choose to log in with Google account one time, you may choose your institutional credentials another time without changes to your authentication workflow.
What entities is Chameleon federated with?
Since Chameleon uses Globus Auth, it is federated with identities supported via InCommon, Google, and Globus ID. For most of you, the good news is probably that you can log in with your google account!
How do I migrate to federated identity on Chameleon?
If you are still using a password and username to log onto Chameleon, you will need to migrate to federated identity. To migrate, please follow our migration instructions.
What should I expect when working with a federated identity management?
A federated identity creates a login context over potentially multiple infrastructures and tools; these tools refresh their login information based on this context. This provides a single sign-on over multiple tools (it may take a few clicks in some cases though you will likely not have to enter a password). It may also mean that logging out of one of those tools will not affect your login status with others, and when you try to log in again your context will be refreshed based on the federated login context (i.e., you won’t be prompted for a password). In order to ensure that you have logged out completely, after you log out of Chameleon, you should also terminate your session with your federated identity provider--this could mean logging out of your Google account, or perhaps your InCommon institution.
Appliances
What is an appliance?
An appliance is an application packaged together with the environment that this application requires. For example, an appliance can consists of the operating system, libraries and tools used by the application, configuration features such as environment variable settings, and the installation of the application itself. Examples of appliances might include a KVM virtual machine image, a Docker image, or a bare metal image. Chameleon appliance refers to bare metal images that can be deployed on the Chameleon testbed. Since an appliance captures the experimental environment exactly, it is a key element of reproducibility; publishing an appliance used to obtain experimental results will go a long way to allowing others to reproduce and build on your research easily.
To deploy distributed applications on several Chameleon instances, complex appliances combine an image and a template describing how the cluster should be configured and contextualized. You can read more about them in the complex appliance documentation.
What is the Chameleon Appliance Catalog?
The Chameleon Appliance Catalog is a repository that allows users to discover, publish, and share appliances. The appliance catalog contains useful images of both bare metal and virtual machine appliances supported by the Chameleon team as well appliances contributed by users.
How to build or customize a Chameleon appliance?
There are two options to build or customize a Chameleon appliance -- the cc-snapshot utility and the OpenStack diskimage-builder.
The cc-snapshot-utility
The cc-snapshot tool is pre-installed in all Chameleon supported appliances and it provides a quick and easy way to customize a Chameleon appliance. To start, spin up an instance with the Chameleon appliance you would like to customize. Then install the libraries and tools you would like to add into your new appliance, or uninstall things you want to exclude from your new appliance. Finally, take a snapshot by running the cc-snapshot command.
The OpenStack diskimage-builder
You can use diskimage-builder to build your appliance from scratch or customize the Chameleon appliances by using the code on Github as templates (CC-CentOS7, CC-Ubuntu14.04, CC-Ubuntu16.04). The OpenStack diskimage-builder provides a more manageable way of building appliances. For more information about OpenStack diskimage-builder, please see the OpenStack documentation.
How do I publish an appliance in the Chameleon Appliance Catalog?
The new Appliance Catalog allows you to easily publish and share your own appliances so that others can discover them and use them either to reproduce the research of others or as a basis for their own research. Before creating your own appliance it is advisable to review other appliances on the Chameleon Appliance Catalog in order to get an idea of the categories you will want to contribute and what others have done.
Two methods exist to submit an appliance to the Appliance Catalog. They can be added using the simplified process available through the Images view. They can also be added using the manual process as described below:
- Create the appliance itself. You may want to test it as well as give some thought to what support you are willing to provide for the appliance (e.g., if your group developed and supports a software package, the appliance may be just a new way of packaging the software and making it available, in which case your standard support channels may be appropriate for the appliance as well).
- Upload the appliance to the Chameleon Image Repository (Glance) and make the image public. In order to enter the appliance into the Catalog you will be asked to provide the Glance ID for the image. These IDs are per-cloud, so that there are three options right now: bare metal/CHI at University of Chicago, bare metal/CHI at TACC, and OpenStack/KVM at TACC. You will need to provide at least one appliance, but may want to provide all three.
- Go to the Appliance Catalog Create Appliance web form, fill out, and submit the form. Be prepared to provide the following information: a descriptive name (this sometimes requires some thought!), author and support contact, version, and an informative description. The description is a very important part of the appliance record; others will use it to evaluate if the appliance contains tools they need for their research so it makes sense to prepare it carefully. To make your description effective you may want to think of the following questions: what does the appliance contain? what are the specific packages and their versions? what is it useful for? where can it be deployed and/or what restrictions/limitations does it have? how should users connect to it / what accounts are enabled?
If you are adding a complex appliance, skip the image ID fields and enter your template instead in the dedicated text box.
As always, if you encounter any problems or want to share with us additional improvements we should do to the process, please don’t hesitate to submit a ticket.
How can I manage an appliance on Chameleon Appliance Catalog?
If you are the owner of the appliance, you can edit the appliance data, such as the description or the support information. Browse to the appliance that you want to edit and view its Details page. At the top right of the page is an Edit button. You will be presented with the same web form as when creating the appliance, pre-filled with the appliances current information. Make changes as necessary and click Save at the bottom of the page.
And finally, you can delete appliances you had made available. Browse to the appliance that you want to delete and click Edit on the Appliance Details page. At the bottom of the page is a Delete button. You will be asked to confirm once more that you do want to delete this appliance. After confirming, the appliance will be removed and no longer listed on the Appliance Catalog.
Why are there different image IDs for KVM@TACC, CHI@TACC, and CHI@UC for the same appliance?
The three clouds forming the Chameleon testbed are fully separated, each having its own Glance image repository. The same appliance image uploaded to the three clouds will produce three different image IDs. In addition, it is sometimes needed to customize an appliance image for each site, resulting in slightly different image files.
What appliances/images should I use on Chameleon resources?
It depends on your specific hardware requirements and research goals. Chameleon Cloud hosts diverse node types—including various CPUs, AMD GPUs, and NVIDIA GPUs—and different images are optimized for different configurations.
We recommend using Chameleon-supported images (go to our appliances catalog and select the "Chameleon Supported" filter), which are built and maintained by our team. These images are regularly updated and provide Chameleon-specific customizations, such as login using the cc account, the cc-checks utility to verify hardware against our resource registry, gathering of metrics, etc. We continue adding new ones based on community needs and new hardware integration.
You can identify Chameleon-supported images by the Chameleon icon displayed next to them in the image selection interface.
The cc-snapshot tool doesn't work on previously snapshot images.
The cc-snapshot is occasionally updated to accommodate changes to the infrastructure and distributions. To replace the script in your image, follow our instructions for updating cc-snapshot.
How do I move images between sites?
Chameleon bare metal sites -- CHI@TACC, CHI@UC, and CHI@NCAR -- belong to a single OpenStack deployment as two independent regions.
You can move images between sites by using the command line interface. Make sure you have installed CLI properly and configured the environment variables using the rc script.
- Download the image from the source site to local
openstack --os-region-name <source_site [CHI@TACC or CHI@UC]> image save <image_name> --file <filename>
- Upload the image to the target site from local
openstack --os-region-name <target_site [CHI@TACC or CHI@UC]> image create --file <filename> --disk-format <format> <image_name>
You can get disk-format from the output of the following command:
openstack --os-region-name <source_site [CHI@TACC or CHI@UC]> image show <image_name>