title | layout | prism_languages | weight | tags | updated | category | intro | |||
---|---|---|---|---|---|---|---|---|---|---|
TSB Terminology |
2017/sheet |
|
0 |
|
2022-12-07 |
Concepts |
A handy list of terms used when describing TSB and its environment. |
A handy list of terms used when describing TSB and its environment.
TSB is a service mesh management plane that's designed to provide you with a single place to manage your entire infrastructure. It maps to your existing organizational structure, and enables you to provision access rights according to your already established teams and needs.
More details can be found in the TSB Architecture page.
In TSB, an organization is the name we give to the corporation that has a shared infrastructure, and manages all the individual teams within that corporation.
A tenant is a group within an organization (e.g. a team or department) who shares organizational resources, and common access to resources with specific privileges (including read, write).
A workspace is a strictly partitioned zone where teams manage their exclusively-owned namespaces. It maintains all service mesh-related configurations associated with that team's namespaces across any number of Virtual Machines and Kubernetes clusters.
A network servable/addressable destination that is identifiable and independently authenticated.
A logical grouping of resources under a Workspace. A group may be one of gateway, traffic, or security group.
A logical grouping of Services that expose a set of APIs that can be consumed by end-users or other services. Applications are scoped to a Tenant and configure how the different services they contain can be consumed and observed.
They provide a developer-centric experience when it comes to configuring how services behave and the conditions that need to be enforced when accessing them.
A set of endpoints serving features that are exposed by an Application. APIs provide a developer-centric experience and allow configuring the Application Ingress gateways with standard OpenAPI documents. This provides an abstraction that is agnostic of the infrastructure that developers can leverage to configure their applications and services without having to be exposed to the details of the underlying compute and networking technologies.
A user models an entity in TSB - both humans and a non-person entities. They can be grouped into Teams. Users can be assigned access to resources with TSB's RBAC API just like Teams. You can create and manage Users in TSB manually via the Users and Teams API, but in most cases TSB syncs Users and Teams from your source of truth at a regular interval (configured during TSB installation).
A team is a group of Users, and acts as a handle for assigning many users access to resources with TSB's RBAC API. We recommend always assigning teams, never individuals, access in TSB as a security best practice. You can create and manage Teams in TSB manually via the Users and Teams API, but in most cases TSB syncs Users and Teams from your source of truth at a regular interval (configured during TSB installation).
The TSB management plane is your primary access point to everything within your environment. It's your one place to configure networking, security, and observability using the UI or CLI to make updates and changes. It provides centralized control in a multi control plane service mesh.
More information can be found in the TSB Architecture page.
The global control plane is part of the management plane. It's concerned with the literal state of your mesh-managed system as a whole, and holds the state of the entire ecosystem under the control of TSB. It provides multi-cluster features on top of the different local control planes.
More information can be found in the TSB Architecture page.
The local control plane is an Istio service mesh that is deployed in every cluster to create isolated failure domains between clusters. It allows TSB to make use of all the features of Istio, including enforcing mTLS between applications, as well as making intelligent networking and traffic routing decisions between microservices within each cluster.
More information can be found in the TSB Architecture page.
Powered by Envoy, the data plane enables data transfer between services using ‘sidecars' that sit next to microservices and send and receive data on behalf of the applications.
More information can be found in the TSB Architecture page.
A instance of Envoy deployed beside an instance of your application as part of the mesh. It intercepts all traffic into and out of the application, allowing the service mesh to implement its traffic management, security, and observability features. This is in contrast to a Load Balance or Gateway which are deployed separately from your application.
In these docs we'll often shorten "sidecar proxy" to just sidecar.
A load balancer sits in front of your servers and distributes requests based on availability and capacity.
A gateway describes a load balancer operating at the edge of a mesh receiving incoming or outgoing HTTP/TCP connections. In a multi-cluster TSB ecosystem we distinguish between the following types of gateways:
- Application Edge Gateway (also called a "Tier 1 Gateway") distributes traffic across one or more ingress gateways in other clusters over Istio mTLS. This will be the entry point to the TSB service mesh which is spanning over multiple clusters.
- Application Ingress Gateway (also called a "Tier 2 Gateway") distributes traffic to one or more workloads (business application services) running in the cluster. The source of the traffic could be:
- an Edge Gateway: communicating over Istio mTLS. Then the mesh started at that Edge Gateway.
- a Client on the internet (outside TSB). Then the mesh starts at this Ingress Gateway.
- a service running on another cluster in TSB. Then the mesh entrypoint will be an Ingress Gateway or sidecar on the remote cluster.
- Egress Gateway provides a gateway for traffic originating from one or more workloads (business application services) running in the cluster to external services outside the mesh.
- VM Gateway provides a gateway for traffic originating from onboarded VMs to route correctly to other mesh workloads.
The service registry is a central point where you can see a list of every service that exists in the TSB platform's onboarded clusters.
The Envoy gateway that accepts incoming traffic to TSB components, e.g. API calls, commands from tctl
, communications to clusters managed by TSB (i.e. Global Control Plane)
Your guess is as good as mine… But here is an overview on the Kubernetes site.
A cluster is a set of compute nodes. A node can contain Kubernetes pods, VMs, Bare Metal, or a combination of all three if they share a trust domain.
Namespaces are used in Kubernetes to group resources (e.g. containers, pods or nodes) into a logical grouping. By default all resources in Kubernetes belong to the "default" namespace. TSB resources typically are grouped into the "tsb" namespace.
A physical or logical section of your environment that is negatively affected, or likely to fail when a critical device or service experiences problems.
A set of failure domains that are aligned together into a single unit that can be reasoned about and replicated for availability.
An isolated location within a cloud provider's Region to deploy infrastructure resources like compute, storage, and networking. These represent a set of infrastructure failure domains from the cloud provider's point of view. It's not uncommon that multiple availability zones in the same region can have correlated failure modes - i.e. go down together. To build reliable applications we certainly need to deploy in multiple availability zones, and often across multiple regions too.
A set of physical locations -- typically one or more data centers -- that represent a set of failure domains for a cloud provider. These are typically subdivided into availability zones which are the unit you actually interact with.
Istio is an open source service mesh that provides a transparent and language-independent way to flexibly and easily automate application network functions. To learn more about Istio's capabilities, visit the Istio website.
Envoy is an L7 proxy and communications system designed for large modern service oriented architectures. All of the Envoys form a transparent communication mesh in which each application sends and receives messages to and from localhost and is unaware of the network topology. To learn more about Envoy, visit the Envoy Proxy website.
Apache SkyWalking is an Observability Application Platform (OAP) and Application Performance Monitor (APM) tool that includes distributed tracing, service mesh telemetry analysis and metrics aggregation to provide you with a full image of the health of your services and service mesh. For more information, visit the Apache SkyWalking website.
Next Generation Access Control, NGAC, is a cutting-edge access control system developed by NIST and Tetrate under a collaborative research agreement. It's a graph based take on traditional Attribute Based Access Control (ABAC) with better runtime performance, flexible model, and first-class primitives for understanding the effects of a policy change with notions of Audit (who did what when) and Explain (why was an action allowed/disallowed in semantic terms) designed into the specification.me Helm chart.