aws-eks-rancher v2.9.0-部署笔记

0x00 Target

基于AWS EKS 集群,部署目前最新版(v2.9.0)Rancher 。
使用从阿里云购买的SSL证书。
主要参考: https://purushothamkdr453.medium.com/installing-rancher-on-aws-eks-cluster-ec6199e297e4

Rancher K8s 支持矩阵: https://www.suse.com/suse-rancher/support-matrix/all-supported-versions/rancher-v2-8-5/

0x01 Create A New Cluster

  • create a 3 nodes cluster with low spec.
eksctl create cluster \
--name rancher \
--version=1.28 \
--region us-west-2 \
--nodegroup-name rancher-nodegroup \
--node-type t2.medium \
--nodes 3 \
--nodes-min 1 \
--nodes-max 5 \
--managed

This step will take 20 mins

  • update kubeconfig
aws eks --region us-west-2 update-kubeconfig --name rancher

0x02 Deploy Nginx Controller

# config helm 
helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx
helm repo update
# install 
helm upgrade --install ingress-nginx ingress-nginx/ingress-nginx \
--namespace ingress-nginx --set controller.service.type=LoadBalancer  \
--create-namespace
  • check svc
kubectl get svc -A

0x03 Install SSL Cert

  • 从阿里云SSL证书中心下载nginx 证书,包含两个文件: a.key, a.pem
  • 先把.key 转成 .pem
openssl rsa -in a.key -text > key.pem
  • 导入 ssl证书
kubectl create ns cattle-system
kubectl -n cattle-system create secret tls tls-rancher-ingress --cert=a.pem --key=key.pem

上述SSL证书,会在后面的ingress配置中使用。

0x04 Deploy Rancher

helm repo add rancher-latest https://releases.rancher.com/server-charts/latest
helm repo update
# install
helm install rancher rancher-latest/rancher \
  --namespace cattle-system \
  --set hostname=${you-domain} \
  --set ingress.tls.source=secret \
  --set ingress.ingressClassName=nginx

0x05 Update DNS config

  • get svc public lb endpoint
kubectl get svc -A
  • update your dns config

然后正常情况下,已经可以正常访问Rancher UI了。

0x06 安全配置&SSL更新

kubectl -n cattle-system create secret tls tls-rancher-ingress \
  --cert=new.pem\
  --key=newkey.pem \
  --dry-run --save-config -o yaml | kubectl apply -f -

然后,重启 rancher deployment

kubectl rollout restart deploy/rancher -n cattle-system

0x07 Q&A

  • 如果发现 rancher pod实例启动失败时,需要导入下面的权限补丁:
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
  annotations:
    meta.helm.sh/release-name: rancher
    meta.helm.sh/release-namespace: cattle-system
  finalizers:
    - wrangler.cattle.io/auth-prov-v2-crb
  labels:
    app: rancher
    app.kubernetes.io/managed-by: Helm
    chart: rancher-2.9.0
    heritage: Helm
    release: rancher
  name: rancher
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: cluster-admin
subjects:
  - kind: ServiceAccount
    name: rancher
    namespace: cattle-system
  • 重置 Rancher Amdin 密码
    万一哪天 rancher admin 密码忘记了,可以通过 kubectl 进行重置。
kubectl -n cattle-system exec $(kubectl  -n cattle-system get pods -l app=rancher | grep '1/1' | head -1 | awk '{ print $1 }') -- reset-password
  • rancher 卸载
    官方提供了卸载工具: https://github.com/rancher/rancher-cleanup

  • rancher agent 问题
    level=error msg="unable to read CA file from /etc/kubernetes/ssl/certs/serverca: open /etc/kubernetes/ssl/certs/serverca: no such file or directory"
    在Rancher设置那边切换 agent 端的证书验证方式: SystemStore

    image.png

  • K8s 版本
    EKS 升级至 1.30 版本亲测可用

0x08 ArgoCD 部署

参考:https://argo-cd.readthedocs.io/en/stable/getting_started/

kubectl create namespace argocd
kubectl apply -n argocd -f https://raw.githubusercontent.com/argoproj/argo-cd/stable/manifests/install.yaml

0x09 ArgoCD SSL配置

参考:https://argo-cd.readthedocs.io/en/stable/operator-manual/tls/

kubectl edit cm argocd-cmd-params-cm -n argocd

增加

data:
  server.insecure: "true"

重启 server:

kubectl rollout restart deploy argocd-server -n argocd

0x0A ArgoCD Ingress配置

复用上面rancher 生成的 elb , 我们新建一个域名绑定: argocd.domain.
由于 rancher 和 argocd 在不同的 namespace下面,所以手动复制一下 rancher 下面的 ssl 证书 secret 至 argocd namespace.
然后,执行下面的 yaml, 相当于在nginx 配置一个外部ssl访问,内部使用 80 端口转发流量

apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  annotations:
    nginx.ingress.kubernetes.io/backend-protocol: HTTP
    nginx.ingress.kubernetes.io/force-ssl-redirect: "true"
  labels:
    app: argocd-server
  name: argocd-server
  namespace: argocd
spec:
  ingressClassName: nginx
  rules:
  - host: {argocd.domain}
    http:
      paths:
      - backend:
          service:
            name: argocd-server
            port:
              name: http
        path: /
        pathType: ImplementationSpecific
  tls:
  - hosts:
    - {argocd.domain}
    secretName: tls-rancher-ingress
status:
  loadBalancer:
    ingress:
    - hostname: {rancher-elb}.us-west-2.elb.amazonaws.com

0x0B ArgoCD 登录

argocd 默认的 admin 密码存储在 argocd namespace 下面的 secret 中
可以这样直接获取,查完后安全起见应该立刻删掉。

kubectl get secret -n argocd argocd-initial-admin-secret -o json  | jq -r .data.password | base64 -d
argocd

备忘:

https://docs.aws.amazon.com/zh_cn/codecommit/latest/userguide/customer-managed-policies.html#:~:text=You%20can%20create%20a%20Deny,is%20within%20a%20specific%20block.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,236评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,867评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,715评论 0 340
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,899评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,895评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,733评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,085评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,722评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,025评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,696评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,816评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,447评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,057评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,254评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,204评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,561评论 2 343

推荐阅读更多精彩内容