Component architecture
About Calico Enterprise architectureβ
The following diagram shows the components that comprise a Kubernetes on-premises deployment using the Calico Enterprise CNI for networking and network policy.
Tip: For best visibility, right-click on the image below and select "Open image in new tab"
Calico open-source components are the foundation of Calico Enterprise. Calico Enterprise provides value-added components for visibility and troubleshooting, compliance, policy lifecycle management, threat detection, and multi-cluster management.
Calico Enterprise componentsβ
- calicoq
- Compliance
- Linseed API and ES gateway
- Intrusion detection
- kube-controllers
- Manager
- Packet capture API
- Prometheus API service
Bundled third-party componentsβ
Calico open-source componentsβ
Kubernetes componentsβ
Cloud orchestrator plugins (not pictured)β
Translates the orchestrator APIs for managing networks to the Calico Enterprise data-model and datastore.
For cloud providers, Calico Enterprise has a separate plugin for each major cloud orchestration platform. This allows Calico Enterprise to tightly bind to the orchestrator, so users can manage the Calico Enterprise network using their orchestrator tools. When required, the orchestrator plugin provides feedback from the Calico Enterprise network to the orchestrator. For example, providing information about Felix liveness, and marking specific endpoints as failed if network setup fails.
Calico Enterprise componentsβ
calicoqβ
Main task: A command line tool for policy inspection to ensure policies are configured as intended. For example, you can determine which endpoints a selector or policy matches, or which policies apply to an endpoint. Requires a separate installation. calicoq.
Complianceβ
Main task: Generates compliance reports for the Kubernetes cluster. Report are based on archived flow and audit logs for Calico Enterprise resources, plus any audit logs youβve configured for Kubernetes resources in the Kubernetes API server. Compliance reports provide the following high-level information:
- Protection
- Endpoints explicitly protected using ingress or egress policy
- Policies and services
- Policies and services associated with endpoints
- Policy audit logs
- Traffic
- Allowed ingress/egress traffic to/from namespaces, and to/from the internet
Compliance is comprised of these components:
compliance-snapshotter
Handles listing of required Kubernetes and Calico Enterprise configuration and pushes snapshots to Elasticsearch. Snapshots give you visibility into configuration changes, and how the cluster-wide configuration has evolved within a reporting interval.
compliance-reporter
Handles report generation. Reads configuration history from Elasticsearch and determines time evolution of cluster-wide configuration, including relationships between policies, endpoints, services and networksets. Data is then passed through a zero-trust aggregator to determine the "worst-case outliers" in the reporting interval.
compliance-controller
Reads report configuration, and manages creation, deletion, and monitoring of report generation jobs.
compliance-server
Provides the API for listing, downloading, and rendering reports, and RBAC by performing authentication and authorization through the Kubernetes API server. RBAC is determined from the users RBAC for the GlobalReportType and GlobalReport resources.
compliance-benchmarker
A daemonset that runs checks in the CIS Kubernetes Benchmark on each node so you can see if Kubernetes is securely deployed.
Linseed API and ES gatewayβ
The Linseed API uses mTLS to connect to clients, and provides an API to access Elasticsearch data. The ES gateway proxies requests to Elasticsearch, and provides backwards-compatibility for managed clusters that run versions before 3.17.
Intrusion detectionβ
Main task: Consists of a controller that handles integrations with threat intelligence feeds and Calico Enterprise custom alerts, and an installer that installs the Kibana dashboards for viewing jobs through the Kibana UI.
kube-controllersβ
Main task: Monitors the Kubernetes API and performs actions based on cluster state. The Calico Enterprise kube-controllers container includes these controllers:
- Node
- Service
- Federated services
- Authorization
- Managed cluster (for management clusters only)
Managerβ
Main task: Provides network traffic visibility, centralized multi-cluster management, threat-defense troubleshooting, policy lifecycle management, and compliance using a browser-based UI for multiple roles/stakeholders. Manager.
Packet capture APIβ
Main task: Retrieves capture files (pcap format) generated by a packet capture for use with network protocol analysis tools like Wireshark. The packet capture feature is installed by default in all cluster types. Packet capture data is visible in the Manager UI, service graph.
Prometheus API serviceβ
Main task: A proxy querying service that checks a userβs token RBAC to validate its scope and forwards the query to the Prometheus monitoring component.
Bundled third-party componentsβ
Elasticsearch and Kibanaβ
Main task: Built-in third-party search-engine and visualization dashboard, which provide logs for visibility into workloads, to troubleshoot Kubernetes clusters. Installed and configured by default. Elasticsearch.
fluentdβ
Main task: Collects and forwards Calico Enterprise logs (flows, DNS, L7) to Elasticsearch. Open source data collector for unified logging. fluentd open source.
Prometheusβ
Main task: The default monitoring component for collecting Calico Enterprise policy metrics. It can also be used to collect metrics on calico/nodes from Felix. Prometheus is an open-source toolkit for systems monitoring and alerting. Prometheus metrics, and Configure Prometheus.
Calico open-source componentsβ
API serverβ
Main task: Allows users to manage Calico Enterprise resources such as policies and tiers through kubectl
or the Kubernetes API. kubectl
has significant advantages over calicoctl
including: audit logging, RBAC using Kubernetes Roles and RoleBindings, and not needing to provide privileged Kubernetes CRD access to anyone who needs to manage resources. API server.
BIRDβ
Main task: Gets routes from Felix and distributes to BGP peers on the network for inter-host routing. Runs on each node that hosts a Felix agent. Open source, internet routing daemon. BIRD.
The BGP client is responsible for:
Route distribution
When Felix inserts routes into the Linux kernel FIB, the BGP client distributes them to other nodes in the deployment. This ensures efficient traffic routing for the deployment.
BGP route reflector configuration
BGP route reflectors are often configured for large deployments rather than a standard BGP client. (Standard BGP requires that every BGP client be connected to every other BGP client in a mesh topology, which is difficult to maintain.) For redundancy, you can seamlessly deploy multiple BGP route reflectors. Note that BGP route reflectors are involved only in control of the network: endpoint data does not passes through them. When the Calico Enterprise BGP client advertises routes from its FIB to the route reflector, the route reflector advertises those routes to the other nodes in the deployment.
calicoctlβ
Main task: Command line interface used largely during pre-installation for CRUD operations on Calico Enterprise objects. kubectl
is the recommended CLI for CRUD operations. calicoctl is available on any host with network access to the Calico Enterprise datastore as either a binary or a container. Requires separate installation. calicoctl).
calico-nodeβ
Main task: Bundles key components that are required for networking containers with Calico Enterprise:
- Felix
- BIRD
- confd
The calico repository contains the Dockerfile for calico-node, along with various configuration files to configure and βglueβ these components together. In addition, we use runit for logging (svlogd) and init (runsv) services. calico-node.
CNI pluginβ
Main task: Provides Calico Enterprise networking for Kubernetes clusters.
The Calico CNI plugin allows you to use Calico networking for any orchestrator that makes use of the CNI networking specification. The Calico binary that presents this API to Kubernetes is called the CNI plugin, and must be installed on every node in the Kubernetes cluster. Configured through the standard CNI configuration mechanism, and Calico CNI plugin.
confdβ
Main task: Monitors Calico Enterprise datastore for changes to BGP configuration and global defaults such as AS number, logging levels, and IPAM information. An open source, lightweight configuration management tool.
Confd dynamically generates BIRD configuration files based on the updates to data in the datastore. When the configuration file changes, confd triggers BIRD to load the new files. Configure confd, and confd project.
Datastore pluginβ
Main task: The datastore for the Calico Enterprise CNI plugin. The Kubernetes API datastore:
- Is simple to manage because it does not require an extra datastore
- Uses Kubernetes RBAC to control access to Calico resources
- Uses Kubernetes audit logging to generate audit logs of changes to Calico Enterprise resources
Felixβ
Main task: Programs routes and ACLs, and anything else required on the host to provide desired connectivity for the endpoints on that host. Runs on each machine that hosts endpoints. Runs as an agent daemon. Felix resource.
Depending on the specific orchestrator environment, Felix is responsible for:
Interface management
Programs information about interfaces into the kernel so the kernel can correctly handle the traffic from that endpoint. In particular, it ensures that the host responds to ARP requests from each workload with the MAC of the host, and enables IP forwarding for interfaces that it manages. It also monitors interfaces to ensure that the programming is applied at the appropriate time.
Route programming
Programs routes to the endpoints on its host into the Linux kernel FIB (Forwarding Information Base). This ensures that packets destined for those endpoints that arrive on at the host are forwarded accordingly.
ACL programming
Programs ACLs into the Linux kernel to ensure that only valid traffic can be sent between endpoints, and that endpoints cannot circumvent Calico Enterprise security measures.
State reporting
Provides network health data. In particular, it reports errors and problems when configuring its host. This data is written to the datastore so it visible to other components and operators of the network.
cnx-node
can be run in policy only mode where Felix runs without BIRD and confd. This provides policy management without route distribution between hosts, and is used for deployments like managed cloud providers.
IPAM pluginβ
Main task: Uses Calico Enterpriseβs IP pool resource to control how IP addresses are allocated to pods within the cluster. It is the default plugin used by most Calico Enterprise installations. It is one of the Calico Enterprise CNI plugins.
Typhaβ
Main task: Increases scale by reducing each nodeβs impact on the datastore. Runs as a daemon between the datastore and instances of Felix. Installed by default, but not configured. Typha description, and Typha component.
Typha maintains a single datastore connection on behalf of all of its clients like Felix and confd. It caches the datastore state and deduplicates events so that they can be fanned out to many listeners. Because one Typha instance can support hundreds of Felix instances, it reduces the load on the datastore by a large factor. And because Typha can filter out updates that are not relevant to Felix, it also reduces Felixβs CPU usage. In a high-scale (100+ node) Kubernetes cluster, this is essential because the number of updates generated by the API server scales with the number of nodes.
Kubernetes componentsβ
Kubernetes API serverβ
Main task: A Kubernetes component that validates and configures data for the API objects (for example, pods, services, and others). Proxies requests for Calico Enterprise API resources to the Kubernetes API server through an aggregation layer.
kubectlβ
Main task: The recommended command line interface for CRUD operations on Calico Enterprise and Calico objects. kubectl.