curl方式:
Rancher在每个节点上部署代理以与节点通信。 此页面描述了可以传递给代理的选项,要使用这些选项,您需要采用创建自定义集群 ,并在docker run
添加节点时将选项添加到生成的命令中。
常规选项
参数 | 环境变量 | 描述 |
---|---|---|
—server | CATTLE_SERVER | Rancher配置的url地址 |
—token | CATTLE_TOKEN | 在Rancher中注册节点所需的令牌,可以在https://<rancher_url>/v3/clusters/<Cluster-ID>/clusterregistrationtokens 页面查询 |
—ca-checksum | CATTLE_CA_CHECKSUM | Rancher配置的cacerts 的SHA256校验和,可以在https://<rancher_url>/v3/clusters/<Cluster-ID>/clusterregistrationtokens 页面查询 |
—node-name | CATTLE_NODE_NAME | 用于覆盖注册节点原有的主机名(默认取: hostname -s) |
—label | CATTLE_NODE_LABEL | 向节点添加标签 (—label key=value ) |
浏览器:
https://172.16.10.67:18443/v3/clusters/c-kp9nl/clusterregistrationtokens
cluster id:
[root@172 script]# rancher cluster
WARN[0000] No context set; some commands will not work. Run `rancher login` again.
CURRENT ID STATE NAME PROVIDER NODES CPU RAM PODS
c-kp9nl active jettech Rancher Kubernetes Engine 1 0/0 0/0 GB 0/0
角色选项
参数 | 环境变量 | 描述 |
---|---|---|
—all-roles | ALL=true | 给节点指定所有角色 (etcd ,controlplane ,worker ) |
—etcd | ETCD=true | 指定etcd 角色 |
—controlplane | CONTROL=true | 指定 controlplane 角色 |
—worker | WORKER=true | 指定 worker 角色 |
IP地址选项
参数 | 环境变量 | 描述 |
---|---|---|
—address | CATTLE_ADDRESS | 节点注册使用的IP地址 |
—internal-address | CATTLE_INTERNAL_ADDRESS | 专用网络上用于主机间通信的IP地址 |
动态IP地址选项
出于自动化目的,您不能在命令中具有特定的IP地址。为此,我们有动态IP地址选项。它们支持 —address
和 —internal-address
。
命令方式:
在rancher上导入一个集群,得到yaml,修改这个yaml,去掉deploy部分,然后apply
执行kc get secret -n cattle-system可以得到2个secret,
其中cattle-credentials-XXX是agent访问rancher的凭证,里边的token配置到环境变CATTLE_TOKEN中
cattle-token-XXX是agent访问自己所在K8S的凭证,里边的ca和token放到./kubernetes下的ca.crt和token文件中
配置agent环境变量:
CATTLE_TOKEN=7dtfjd7x5b6zkfr8rz4rtz592dtrwbnpzdt87t9jzgbjrpnxf5fmpw;CATTLE_SERVER=https://127.0.0.1:8443;CATTLE_CLUSTER=true;KUBERNETES_SERVICE_HOST=172.17.18.12;KUBERNETES_SERVICE_PORT=6443
把K8S的config文件拷贝到默认用户下.kube目录下
然后就可以启动agent了