Releases: projectcalico/calico
v3.1.2
Bug fixes
- Fix invalid filter in "calicoctl node diags" command calicoctl #1854 (@bcreane)
- Felix supports watching a configurable interface prefix when using the Kubernetes API datastore. libcalico-go #865 (@caseydavenport)
v3.0.7
Bug fixes
- Fix invalid filter in "calicoctl node diags" command calicoctl #1855 (@bcreane)
- Felix supports watching a configurable interface prefix when using the Kubernetes API datastore libcalico-go #864 (@caseydavenport)
v3.1.1
Bug fixes
- Fix bug in parsing of empty namespace selectors libcalico-go #857 (@caseydavenport)
- Add support for configuring container IP forwarding via the CNI configuration file. cni-plugin #509 (@caseydavenport)
v3.0.6
Bug fixes
- Fix bug in parsing of empty namespace selectors projectcalico/libcalico-go#856 (@caseydavenport)
v2.6.9
Bug fixes
-
Fix an interaction between failsafe inbound/outbound ports and do-not-track policy that resulted in failsafe ports being blocked if do-not-track policy was added. felix #1748 (@fasaxc)
-
Fix a bug where the Egress type was displayed for upgraded pre-dnat network policies libcalico-go #851 (@tmjd)
-
Support '.' character in interface names libcalico-go #834 (@CoderTux)
v3.0.5
Bug fixes
- Add support for configuring container IP forwarding via the CNI configuration file. cni-plugin #508 (@caseydavenport)
- When auto-detecting a node name, Calico will convert the hostname to lowercase. calico #1880 (@robbrockbank)
- Fix bug typha #118 where calico/node and Typha race to create the cluster information resource, causing Typha to crash. libcalico-go #845 (@robbrockbank)
- Improve confd behavior when using the Kubernetes API datastore and node-to-node mesh disabled. libcalico-go #838 (@caseydavenport)
- Support '.' character in interface names libcalico-go #832 (@CoderTux)
- Fix an interaction between failsafe inbound/outbound ports and do-not-track policy that resulted in failsafe ports being blocked if do-not-track policy was added. felix #1775 (@fasaxc)
Build changes
- Backport s390x build support cni-plugin #502 (@fasaxc)
- Backport s390x build support kube-controllers #241 (@fasaxc)
- Backport s390x build support calico #1868 (@fasaxc)
- Backport s390x build support felix #1783 (@fasaxc)
- Backport s390x build support calicoctl #1839 (@fasaxc)
- Backport s390x build support typha #137 (@fasaxc)
v3.1.0
What's new
Support for OpenStack
Calico v3.1 reintroduces support for OpenStack. Existing users can upgrade their Calico OpenStack clusters to v3.1 by following the documented procedure.
Introducing GlobalNetworkSets
Calico now supports a new resource type: GlobalNetworkSet. A GlobalNetworkSet contains a set of CIDRs with associated labels, which can be matched by global network policies. This allows for rules to refer to external networks, possibly consisting of thousands of CIDRs. GlobalNetworkSets allow you to write network policies that are more portable across clusters by introducing a label-based abstraction on top of network CIDRs. To learn more, see the GlobalNetworkSet resource definition.
Beta support for IPVS kube-proxy
Calico v3.1 moves support for the IPVS kube-proxy from alpha to beta with support for pod ingress, pod egress, and host endpoint network policy. The IPVS kube-proxy is itself still beta, but promises greater scale and performance compared to the existing iptables proxy.
Kubernetes IPv6 support
Calico v3.1 includes fixes which better support running an IPv6-based Kubernetes cluster. In Calico v3.1, you can now use the Kubernetes API datastore in IPv6 mode. Additionally, Calico now generates a /48 unique local address (ULA) prefix when no IPv6 pool is specified rather than using a fixed CIDR. This prevents multiple Calico clusters from sharing the same IPv6 address space. Check out the documentation on enabling IPv6 support for more information.
HostEndpoint support for Kubernetes API datastore
Calico now supports configuration of host endpoints when using the Kubernetes API datastore. This allows you to seamlessly apply network policy to Kubernetes host machines and Kubernetes pods alike using Calico global network policies.
Other changes
- The install-cni container now maintains the original mode on certificates copied from Kubernetes secrets. cni-plugin #481 (@caseydavenport)
- The install-cni container now writes the calico-kubeconfig file with mode 600 by default. It can be configured by setting the KUBECONFIG_MODE option. cni-plugin #481 (@caseydavenport)
- The Calico CNI plugin by default expects the /var/lib/calico/nodename file to be created by calico/node. To disable this feature, set
nodename_file_optional: true
in your CNI network configuration. cni-plugin #480 (@caseydavenport) - Fix a bug where IPs could be assigned from disabled IP pools. libcalico-go #806 (@ozdanborne)
- Fix a bug where profiles were periodically and unnecessarily reprogrammed by kube-controllers. libcalico-go #805 (@caseydavenport)
- Fix a bug where nodes were periodically and unnecessarily processed by kube-controllers. kube-controllers #216 (@caseydavenport)
- Closes a number of race conditions and failure scenarios in IPAM block allocation and releasing. libcalico-go #785 (@caseydavenport)
- Improves log output around IPAM block allocation and releasing. libcalico-go #785 (@caseydavenport)
- The self-hosted Kubernetes manifests now set mode 400 for TLS secrets by default calico #1725 (@caseydavenport)
- Fix a rare bug where a node could in some circumstances advertise /26 blocks that it didn't own calico #1712 (@caseydavenport)
- Use networking.k8s.io api in place of deprecated extensions/v1beta1. calico #1614 (@bcreane)
- Fix an interaction between failsafe inbound/outbound ports and do-not-track policy that resulted in failsafe ports being blocked if do-not-track policy was added. felix #1718 (@fasaxc)
- Fix bug in icmp validation where ipVersion was required for all icmp rules. calicoctl #1814 (@ozdanborne)
Limitations
-
Offers only Kubernetes, OpenShift, OpenStack, and host endpoint integrations: the
Mesos, DC/OS, and libnetwork orchestrators have not been tested. The latest supported release
for these orchestrators is v2.6. We plan to resume support for these orchestrators in a future release. -
GoBGP not supported: Setting the
CALICO_NETWORKING_BACKEND
environment
variable togobgp
is not supported. See Configuring calico/node
for more information. We plan to resume support for GoBPG in a future release. -
Route reflectors cannot be clustered: We plan to resume support for
this in a future release.
v3.0.4
Bug fixes
- Fixes a bug where the calico/cni container would ignore termination signals. cni-plugin #487 (@ketkulka)
- Closes a number of race conditions and failure scenarios in IPAM block allocation and releasing. libcalico-go #819 (@caseydavenport)
- Improves log output around IPAM block allocation and releasing. libcalico-go #819 (@caseydavenport)
- Fixes a bug where IPs could be assigned from disabled IP pools. libcalico-go #819 (@ozdanborne)
- Fixes a rare bug where a node could, in some circumstances, advertise /26 blocks that it didn't own calico #1751 (@caseydavenport)
v3.1.0-rc1
Merge pull request #1781 from caseydavenport/add_docs_dirs Add docs directories
v3.0.3
Bug fixes
- Improved error messages when failing to initialize a connection to etcd libcalico-go #794 (@ozdanborne)
- Ignore hidden files when checking for etcd certificates to copy over when installing CNI. cni-plugin #473 (@tmjd)