This article provides users with the instructions to create and launch a K3s cluster on an Tencent CVM instance, and to add nodes for an existing K3s cluster on Tencent CVM instance. In addition, this article provides guidance of advanced usages of running K3s on Tencent CVM, such as setting up private registry, enabling Tencent CCM, and enabling UI components.
To ensure that CVM instances can be created and accessed successfully, please follow the instructions below.
Configure the following environment variables as showed below for the host on which you are running autok3s
.
export CVM_SECRET_ID='<secret-id>'
export CVM_SECRET_KEY='<secret-key>'
This provider needs certain permissions to access Tencent Cloud, so need to create a few RAM policies for your CVM instances:
{
"version": "2.0",
"statement": [
{
"action": [
"cvm:RunInstances",
"cvm:DescribeInstances",
"cvm:TerminateInstances",
"cvm:StartInstances",
"cvm:StopInstances",
"cvm:DescribeInstancesStatus",
"cvm:AllocateAddresses",
"cvm:ReleaseAddresses",
"cvm:AssociateAddress",
"cvm:DisassociateAddress",
"cvm:DescribeAddresses",
"cvm:DescribeImages"
],
"resource": "*",
"effect": "allow"
},
{
"action": ["vpc:*"],
"resource": "*",
"effect": "allow"
},
{
"action": [
"tag:AddResourceTag",
"tag:DescribeResourcesByTags",
"tag:AttachResourcesTag"
],
"resource": "*",
"effect": "allow"
},
{
"action": ["ccs:Describe*", "ccs:CreateClusterRoute"],
"resource": "*",
"effect": "allow"
},
{
"action": ["clb:*"],
"resource": "*",
"effect": "allow"
}
]
}
The CVM instances need to apply the following minimum Security Group Rules:
Rule Protocol Port Source Description
InBound TCP 22 ALL SSH Connect Port
InBound TCP 6443 K3s agent nodes Kubernetes API
InBound TCP 10250 K3s server & agent Kubelet
InBound UDP 8472 K3s server & agent (Optional) Required only for Flannel VXLAN
InBound TCP 2379,2380 K3s server nodes (Optional) Required only for embedded ETCD
OutBound ALL ALL ALL Allow All
As rancher.cn
is under filing, the default https://rancher-mirror.rancher.cn/k3s/k3s-install.sh
may cause cluster up failure. If the above situation occurs, use the following workaround: --k3s-install-script=https://rancher-mirror.oss-cn-beijing.aliyuncs.com/k3s/k3s-install.sh
.
The following command uses Tencent as cloud provider, creates a K3s cluster named "myk3s", and assign it with 1 master node and 1 worker node:
autok3s -d create -p tencent --name myk3s --master 1 --worker 1
Please use one of the following commands to create an HA cluster.
The following command uses Tencent as cloud provider, creates an HA K3s cluster named "myk3s", and assigns it with 3 master nodes.
autok3s -d create -p tencent --name myk3s --master 3 --cluster
The following requirements must be met before creating an HA K3s cluster with an external database:
- The number of master nodes in this cluster must be greater or equal to 1.
- The external database information must be specified within
--datastore "PATH"
parameter.
In the example below, --master 2
specifies the number of master nodes to be 2, while --datastore "PATH"
specifies the external database information. As a result, requirements listed above are met.
Run the command below and create an HA K3s cluster with an external database:
autok3s -d create -p tencent --name myk3s --master 2 --datastore "mysql://<user>:<password>@tcp(<ip>:<port>)/<db>"
The AutoK3s supports more advanced settings to customize your K3s cluster.
If you want to add more installation environments, please set the args below:
--install-env INSTALL_K3S_SKIP_SELINUX_RPM=true --install-env INSTALL_K3S_FORCE_RESTART=true
We recommend you to only use INSTALL_* parameters for this case because this is a global setting to your K3s cluster. If you want to set the K3S_* environments, please use the K3s configuration file args.
In addition to configuring K3s with environment variables and CLI arguments, K3s can also use a config file.
If you want to do more customize and complex configurations for your K3s cluster, such as etcd snapshot or datastore. This arg is what you need.
Here's an example of a K3s server configuration with etcd snapshot information and change the node port range.
etcd-snapshot-schedule-cron: "* * * * *"
etcd-snapshot-retention: 15
service-node-port-range: "20000-30000"
Save this yaml file to your local path, such as myk3s-server-config.yaml
. Then pass this file by the following arg:
--server-config-file /your/path/myk3s-server-config.yaml
If you want to set the configuration file to your agent node, use the arg --agent-config-file /your/path/agent-config.yaml
Please use autok3s join
command to add one or more nodes for an existing K3s cluster.
The command below shows how to add a worker node for an existing K3s cluster named "myk3s".
autok3s -d join --provider tencent --name myk3s --worker 1
The commands to add one or more nodes for an existing HA K3s cluster varies based on the types of HA cluster. Please choose one of the following commands to run.
autok3s -d join --provider tencent --name myk3s --master 2 --worker 1
This command will delete a k3s cluster named "myk3s".
autok3s -d delete --provider tencent --name myk3s
This command will list the clusters that you have created on this machine.
autok3s list
NAME REGION PROVIDER STATUS MASTERS WORKERS VERSION
myk3s cn-hangzhou alibaba Running 2 2 v1.19.5+k3s2
myk3s ap-nanjing tencent Running 2 1 v1.19.5+k3s2
This command will show detail information of a specified cluster, such as instance status, node IP, kubelet version, etc.
autok3s describe -n <clusterName> -p tencent
Note:There will be multiple results if using the same name to create with different providers, please use
-p <provider>
to choose a specified cluster. i.e.autok3s describe -n myk3s -p tencent
Name: myk3s
Provider: tencent
Region: ap-nanjing
Zone: ap-nanjing-1
Master: 2
Worker: 1
Status: Running
Version: v1.19.5+k3s2
Nodes:
- internal-ip: x.x.x.x
external-ip: x.x.x.x
instance-status: RUNNING
instance-id: xxxxx
roles: etcd,master
status: Ready
hostname: xxxx
container-runtime: containerd://1.4.3-k3s1
version: v1.19.5+k3s2
- internal-ip: x.x.x.x
external-ip: x.x.x.x
instance-status: RUNNING
instance-id: xxxxx
roles: <none>
status: Ready
hostname: xxxxxx
container-runtime: containerd://1.4.3-k3s1
version: v1.19.5+k3s2
- internal-ip: x.x.x.x
external-ip: x.x.x.x
instance-status: RUNNING
instance-id: xxxxxx
roles: etcd,master
status: Ready
hostname: xxxxx
container-runtime: containerd://1.4.3-k3s1
version: v1.19.5+k3s2
After the cluster is created, autok3s
will automatically merge the kubeconfig
so that you can access the cluster.
autok3s kubectl config use-context myk3s.ap-guangzhou.tencent
autok3s kubectl <sub-commands> <flags>
In the scenario of multiple clusters, the access to different clusters can be completed by switching context.
autok3s kubectl config get-contexts
autok3s kubectl config use-context <context>
Login to a specific k3s cluster node via ssh, i.e. myk3s.
autok3s ssh --provider tencent --name myk3s
The following command will help you to upgrade your K3s cluster version to latest version.
autok3s upgrade --provider tencent --name myk3s --k3s-channel latest
If you want to upgrade K3s cluster to a specified version, you can use --k3s-version
to overrides --k3s-channel
.
autok3s upgrade --provider tencent --name myk3s --k3s-version v1.22.4+k3s1
More usage details please running autok3s <sub-command> --provider tencent --help
commands.
Below are examples showing how you may configure /etc/autok3s/registries.yaml
on your current node when using TLS, and make it take effect on k3s cluster by autok3s
.
mirrors:
docker.io:
endpoint:
- "https://mycustomreg.com:5000"
configs:
"mycustomreg:5000":
auth:
username: xxxxxx # this is the registry username
password: xxxxxx # this is the registry password
tls:
cert_file: # path to the cert file used in the registry
key_file: # path to the key file used in the registry
ca_file: # path to the ca file used in the registry
When running autok3s create
or autok3s join
command, take effect with the--registry /etc/autok3s/registries.yaml
flag, i.e.:
autok3s -d create -p tencent --name myk3s --master 3 --registry /etc/autok3s/registries.yaml
You should create cluster route table if enabled CCM, and set --router
with you router table name.
Autok3s uses 10.42.0.0/16
as default cluster CIDR, your route table should set the same cidr-block.
Using route-ctl to create cluster route table.
export QCloudSecretId=************************************
export QCloudSecretKey=********************************
export QCloudCcsAPIRegion=<your-region>
./route-ctl route-table create --route-table-cidr-block 10.42.0.0/16 --route-table-name <your-route-table-name> --vpc-id <your-vpc-id>
Then using <your-route-table-name>
value for --router
, the --vpc
should be the same with vpc you set for route table name.
autok3s -d create \
... \
--cloud-controller-manager --router <your-route-table-name> --vpc <your-vpc-id> --subnet <your-subnet-id>
The cluster route table will not DELETE AUTOMATICALLY, please remove router with route-ctl.
AutoK3s support cnrancher/kube-explorer as UI Component.
You can enable kube-explorer using following command.
autok3s explorer --context myk3s.ap-southeast-2.aws --port 9999
You can enable kube-explorer when creating K3s Cluster by UI.
You can also enable/disable kube-explorer any time from UI, and access kube-explorer dashboard by dashboard
button.
You can enable helm-dashboard using the following command.
autok3s helm-dashboard --port 8888
After the server started success, you can access the helm-dashboard by http://127.0.0.1:8888
You can also enable/disable helm-dashboard any time from UI, and access helm-dashboard by dashboard
button.
PS: You can only enable helm-dashboard when you have a cluster at least.