Skip to content

Commit

Permalink
Fixing Calico installation steps
Browse files Browse the repository at this point in the history
This update moves Calico to an operator based installer.
Removes the `calico.yaml` since it is not the recommended way.
  • Loading branch information
frozenprocess committed Nov 5, 2024
1 parent 3b15086 commit 0fb2a21
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 3,804 deletions.
77 changes: 28 additions & 49 deletions docs/usage/advanced/calico.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,21 +4,7 @@
k3s comes with a controller that enforces network policies by default. You do not need to switch to Calico for network policies to be enforced. See <https://github.com/k3s-io/k3s/issues/1308> for more information.
The docs below assume you want to switch to Calico's policy engine, thus setting `--disable-network-policy`.

## 1. Download and modify the Calico descriptor

You can following the [documentation](https://docs.projectcalico.org/master/reference/cni-plugin/configuration)

And then you have to change the ConfigMap `calico-config`. On the `cni_network_config` add the entry for allowing IP forwarding

```json
"container_settings": {
"allow_ip_forwarding": true
}
```

Or you can directly use this [calico.yaml](calico.yaml) manifest

## 2. Create the cluster without flannel and with calico
## 1. Create the cluster without flannel and with calico

On the k3s cluster creation :

Expand All @@ -29,58 +15,51 @@ So the command of the cluster creation is (when you are at root of the k3d repos

```bash
k3d cluster create "${clustername}" \
--k3s-arg '--flannel-backend=none@server:*' \
--k3s-arg '--flannel-backend=none@server:*' --no-lb \
--k3s-arg '--disable-network-policy' \
--volume "$(pwd)/docs/usage/guides/calico.yaml:/var/lib/rancher/k3s/server/manifests/calico.yaml"
--k3s-arg '--cluster-cidr=192.168.0.0/16'
```

In this example :

- change `"${clustername}"` with the name of the cluster (or set a variable).
- `$(pwd)/docs/usage/guides/calico.yaml` is the absolute path of the calico manifest, you can adapt it.

You can add other options, [see](../commands.md).
- Change the `"${clustername}"` with the name of the cluster (or set a variable).
- Cluster will use the "192.168.0.0/16" CIDR, if you want to change the default CIDR make sure to change it in the `custom-resources.yaml` too.

The cluster will start without flannel and with Calico as CNI Plugin.

For watching for the pod(s) deployment
## 2. Install Calico
Calico offers multiple ways to install it in an environment. Here, we are going to use the Tigera Operator to configure and install Calico.

Use the following command to install the operator:
```bash
watch "kubectl get pods -n kube-system"
kubectl create -f https://raw.githubusercontent.com/projectcalico/calico/v3.29.0/manifests/tigera-operator.yaml
```
The operator periodically checks for the installation manifest. This manifest is how we instruct the Tigera Operator on how to install Calico.

You will have something like this at beginning (with the command line `#!bash kubectl get pods -n kube-system`)

Use the following command to configure the installation:
```bash
NAME READY STATUS RESTARTS AGE
helm-install-traefik-pn84f 0/1 Pending 0 3s
calico-node-97rx8 0/1 Init:0/3 0 3s
metrics-server-7566d596c8-hwnqq 0/1 Pending 0 2s
calico-kube-controllers-58b656d69f-2z7cn 0/1 Pending 0 2s
local-path-provisioner-6d59f47c7-rmswg 0/1 Pending 0 2s
coredns-8655855d6-cxtnr 0/1 Pending 0 2s
kubectl create -f https://raw.githubusercontent.com/projectcalico/calico/v3.29.0/manifests/custom-resources.yaml
```

And when it finish to start

At this point, our installation is in progress, and we can verify it using the following command:
```bash
NAME READY STATUS RESTARTS AGE
metrics-server-7566d596c8-hwnqq 1/1 Running 0 56s
calico-node-97rx8 1/1 Running 0 57s
helm-install-traefik-pn84f 0/1 Completed 1 57s
svclb-traefik-lmjr5 2/2 Running 0 28s
calico-kube-controllers-58b656d69f-2z7cn 1/1 Running 0 56s
local-path-provisioner-6d59f47c7-rmswg 1/1 Running 0 56s
traefik-758cd5fc85-x8p57 1/1 Running 0 28s
coredns-8655855d6-cxtnr 1/1 Running 0 56s
kubectl get tigerastatus
```

Note :
After a minute, you should see a result similar to the following:
```
NAME AVAILABLE PROGRESSING DEGRADED SINCE
apiserver True False False 30s
calico True False False 10s
ippools True False False 70s
```
Great Calico is up and running!

- you can use the auto deploy manifest or a kubectl apply depending on your needs
- :exclamation: Calico is not as quick as Flannel (but it provides more features)
## 3. IP forwarding
By default, Calico disables IP forwarding inside the containers. Use the following command to enable forwarding via the operator:
```bash
kubectl patch installation default --type=merge --patch='{"spec":{"calicoNetwork":{"containerIPForwarding":"Enabled"}}}'
```

## References

- <https://rancher.com/docs/k3s/latest/en/installation/network-options/>
- <https://docs.projectcalico.org/getting-started/kubernetes/k3s/>
- <https://docs.tigera.io/calico/latest/getting-started/kubernetes/k3s/quickstart>
Loading

0 comments on commit 0fb2a21

Please sign in to comment.