Organize Environments

The Scalr hierarchical model is a unique feature of Scalr that helps small or large organizations enable multi-tenancy, ease overhead, and ensure security through centralized modules, vcs connections, policies, and more. The Scalr account administrator has the ability to centrally manage these objects and make them available for consumption by the end users. The hierarchy is comprised of an account and environment scope(s). The environment is the child of an account, there is no limit on how many environments an account can have. The entire structure can be managed at scale with the Scalr Terraform provider.

4434

There are no strict rules on how to structure environments other than that environments are a collection of related workspaces and users, but we do see some common use cases… If you’re an MSP, you can manage individual customers in each environment. If you’re a large organization, each environment can be a business unit. If you’re a smaller organization, each environment can be an application or project. Or you can have a combination of all the examples listed, the main idea is to make the overall management of objects easier and more secure.

Accounts

An account is created when a user initially signs up for Scalr. The account scope is where administrators can:

  1. Create objects that will be shared across all environments.
  2. Create and assign objects to specific environments.

Shared Objects

The objects in the table below can be created and shared across all environments from the account scope:

2676
ObjectDescription
IAMRequired. Control teams, users, services accounts, and SAML/LDAP integrations. Access policies can be assigned to the account, environment, and/or workspace scope.
Provider ConfigurationsOptional. Provider configurations are created and managed at the account scope but assigned to environments. A single configuration can be assigned to one or more environments.
EnvironmentsRequired. Environments are the child of accounts. Environments are where workspaces are created and Terraform runs are executed.
Policy EngineOptional. OPA policy groups can be created and managed at the account scope but assigned to environments. A policy group can be assigned to one or more environments.
VariablesOptional. If a shell variable is created at the account scope, the variable will be inherited by all environments and workspaces.
VCS ProvidersOptional. If a VCS provider is created at the account scope, the provider will be available to all environments and workspaces.
ModulesOptional. If a module is created at the account scope, the module will be available to all environments and workspaces.
Agent PoolsOptional. If an agent is created at the account scope, the agent will be available to all environments and workspaces.

Assigned Objects

Optionally, environments can have provider credentials, vcs providers, variables, policies, and webhooks created and assigned to them from the environments page at the account scope. Typically, an environment corresponds to functional areas, applications, cloud accounts, projects, or any grouping that is required. If any objects are assigned to the environment they can only be seen and used by users within the environment.

The objects in the table below can be created and assigned to environments from the account scope. To access this, go to the account scope, click on environments, and then the environment you want to manage:

2678
ObjectDescription
Provider ConfigurationsOptional. A single provider configuration can be used across one or more environments. When a provider configuration is the default for an environment Scalr will automatically insert the provider block when needed in a run.
VCS ProvidersOptional. A VCS provider is needed for the module registry and VCS connected workspaces. If a VCS provider is created here, it is only available in this environment. The VCS provider will be made available for workspaces within the environment, but not required if the workspace is CLI driven.
VariablesOptional. If a shell variable is assigned to an environment, the variable will be inherited by all workspaces within the environment.
OPA PoliciesOptional. OPA policy groups must be created at the account scope. The policy group is then assigned to an environment.
WebhooksOptional. If a webhook and endpoint are created and assigned to an environment, the webhook will be available to all workspaces.
Access PoliciesRequired. For users or teams to access an environment, they must be assigned an access policy within the environment.

Environments

Environments contain a collection of related workspaces. The objects in the table below can be created and managed within an environment:

2682
ObjectDescription
WorkspacesRequired. A workspace is where all objects related to Terraform-managed resources are stored and managed.
ModulesOptional. If a Module is created at the environment scope, the module will be available to all workspaces within the environment
Agent PoolsOptional. If an agent is created at the environment scope, the agent will be available to all workspaces.

Video

More of a visual learner? Check out this feature on YouTube.