rancher 离线安装rancher2

Last updated on September 9, 2024 am

🧙 Questions

离线使用helm安装rancher2.8.5
系统: CentOS Linux release 7.9.2009 (Core)
注意:全程使用root用户或通过sudo运行

☄️ Ideas

创建用户

关闭防火墙

systemctl disable firewalld
systemctl stop firewalld
systemctl status firewalld

修改hostname

#172.16.215.83 iZ8vbgxsdbuxmnqr4qd0ykZ iZ8vbgxsdbuxmnqr4qd0ykZ
172.16.215.83 isxcode

hostnamectl set-hostname isxcode
vim /etc/hosts

关闭selinux

setenforce 0
getenforce

关闭swap分区

swapoff -a
free -m

挂载磁盘

挂载磁盘,绑定/data

mkdir -p /data

上传资源

需要资源邮箱找我

scp -r /Users/ispong/OneDrive/Downloads/rancher root@47.92.128.32:/tmp

离线安装docker

cd /tmp/rancher
tar -xvf docker-19.03.9.tgz
cp docker/* /usr/bin
vim /etc/systemd/system/docker.service
[Unit]
Description=Docker Application Container Engine
Documentation=https://docs.docker.com
After=network-online.target firewalld.service
Wants=network-online.target

[Service]
Type=notify
ExecStart=/usr/bin/dockerd
ExecReload=/bin/kill -s HUP $MAINPID
TimeoutSec=0
RestartSec=2
Restart=always
StartLimitBurst=3
StartLimitInterval=60s
LimitNOFILE=infinity
LimitNPROC=infinity
LimitCORE=infinity
TasksMax=infinity
Delegate=yes
KillMode=process

[Install]
WantedBy=multi-user.target
chmod +x /etc/systemd/system/docker.service

mkdir -p /data/docker
mkdir -p /etc/docker
tee /etc/docker/daemon.json <<-'EOF'
{
  "data-root":"/data/docker"
}
EOF
systemctl daemon-reload
systemctl enable docker
systemctl start docker
systemctl status docker

离线安装docker-compose

cd /tmp/rancher
cp docker-compose-linux-x86_64 /usr/bin/docker-compose
chmod +x /usr/bin/docker-compose
docker-compose --version

生成harbor的ssl证书

注意CN修改域名

mkdir -p /data/harbor/ssl
cd /data/harbor/ssl

openssl genrsa -out ca.key 4096
openssl req -x509 -new -nodes -sha512 -days 3650 \
 -subj "/C=CN/ST=Beijing/L=Beijing/O=example/OU=Personal/CN=isxcode" \
 -key ca.key \
 -out ca.crt

openssl genrsa -out isxcode.key 4096
openssl req -sha512 -new \
    -subj "/C=CN/ST=Beijing/L=Beijing/O=example/OU=Personal/CN=isxcode" \
    -key isxcode.key \
    -out isxcode.csr

cat > v3.ext <<-EOF
authorityKeyIdentifier=keyid,issuer
basicConstraints=CA:FALSE
keyUsage = digitalSignature, nonRepudiation, keyEncipherment, dataEncipherment
extendedKeyUsage = serverAuth
subjectAltName = @alt_names

[alt_names]
DNS.1=isxcode
DNS.2=isxcode
DNS.3=isxcode
EOF

openssl x509 -req -sha512 -days 3650 \
    -extfile v3.ext \
    -CA ca.crt -CAkey ca.key -CAcreateserial \
    -in isxcode.csr \
    -out isxcode.crt

openssl x509 -inform PEM -in isxcode.crt -out isxcode.cert

mkdir -p /data/harbor/data/cert
cp isxcode.crt /data/harbor/data/cert
cp isxcode.key /data/harbor/data/cert

mkdir -p /etc/docker/certs.d/isxcode:8443/
cp isxcode.cert /etc/docker/certs.d/isxcode:8443/
cp isxcode.key /etc/docker/certs.d/isxcode:8443/
cp ca.crt /etc/docker/certs.d/isxcode:8443/
systemctl daemon-reload
systemctl restart docker

cp /etc/docker/certs.d/isxcode:8443/* /etc/pki/ca-trust/source/anchors/
update-ca-trust

离线安装harbor

mkdir -p /data/harbor/data

cd /tmp/rancher
docker load -i prepare-1.9.3.tar
tar zxf harbor-offline-installer-v1.9.3.tgz -C /data/harbor/
cd /data/harbor/harbor

vim harbor.yml

修改hostname
修改https
修改port
修改data

hostname: isxcode

http:
  port: 8800

https:
  port: 8443
  certificate: /data/harbor/ssl/isxcode.crt
  private_key: /data/harbor/ssl/isxcode.key

data_volume: /data/harbor/data

cd /var/log/harbor 看日志
docker-compose down -v
docker-compose up -d

./prepare
chmod +x ./install.sh
./install.sh
docker ps -a

创建rke2目录

mkdir -p /data/rancher
ln -s /data/rancher /var/lib/rancher

mkdir -p /data/containers
ln -s /data/containers /var/lib/containers

安装rke2

mkdir -p /data/rke2-artifacts
cp /tmp/rancher/rke2-images.linux-amd64.tar.zst /data/rke2-artifacts/
cp /tmp/rancher/rke2.linux-amd64.tar.gz /data/rke2-artifacts/
cp /tmp/rancher/sha256sum-amd64.txt /data/rke2-artifacts/

cd /tmp/rancher
INSTALL_RKE2_ARTIFACT_PATH=/data/rke2-artifacts sh install.sh

启动rke2

journalctl -u rke2-server -f 看日志

systemctl enable rke2-server.service
systemctl start rke2-server.service
systemctl status rke2-server.service

检查服务是否启动

此时k8s已经安装好了

tee -a /etc/profile <<-'EOF'
export KUBECONFIG=/etc/rancher/rke2/rke2.yaml 
export PATH=$PATH:/var/lib/rancher/rke2/bin
EOF
source /etc/profile
kubectl get nodes
kubectl get pods -n kube-system

离线安装helm

cd /tmp/rancher
tar -zxvf helm-v3.15.3-linux-amd64.tar.gz
mv /tmp/rancher/linux-amd64/helm /usr/bin/helm
helm version

导入rancher镜像 v2.8.5

username: admin
password: Harbor12345

docker login isxcode:8443
cd /tmp/rancher
chmod +x rancher-load-images.sh
./rancher-load-images.sh --image-list ./rancher-images.txt --registry isxcode:8443/library

修改tls认证

vim /etc/rancher/rke2/registries.yaml
mirrors:
  docker.io:
    endpoint:
      - "https://isxcode:8443"
configs:
  "https://isxcode:8443":
    auth:
      username: admin
      password: Harbor12345
    tls:
      cert_file: /data/harbor/ssl/isxcode.cert
      key_file: /data/harbor/ssl/isxcode.key
      ca_file: /data/harbor/ssl/ca.crt
systemctl restart rke2-server.service

k8s安装自签证书

cd /tmp/rancher
kubectl create namespace cert-manager
kubectl apply -f ./cert-manager-crd.yaml
# helm install cert-manager  --namespace cert-manager --debug
helm install cert-manager /tmp/rancher/cert-manager-v1.15.1.tgz \
    --namespace cert-manager \
    --set image.repository=docker.io/library/quay.io/jetstack/cert-manager-controller \
    --set webhook.image.repository=docker.io/library/quay.io/jetstack/cert-manager-webhook \
    --set cainjector.image.repository=docker.io/library/quay.io/jetstack/cert-manager-cainjector \
    --set startupapicheck.image.repository=docker.io/library/quay.io/jetstack/cert-manager-startupapicheck \
    --debug
helm list -A

k8s安装rancher

卸载:helm uninstall rancher -n cattle-system

cd /tmp/rancher
kubectl create namespace cattle-system
helm install rancher /tmp/rancher/rancher-2.8.5.tgz \
  --namespace cattle-system \
  --set hostname=isxcode \
  --set certmanager.version=1.15.1 \
  --set rancherImage=docker.io/library/rancher/rancher \
  --set useBundledSystemChart=true \
  --set systemDefaultRegistry=docker.io/library \
  --set rancherImageTag=v2.8.5 \
  --set service.type=NodePort
kubectl -n cattle-system get deploy rancher

访问

获取端口号

kubectl get svc -n cattle-system
# NAME              TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)                      AGE
# rancher           NodePort    10.43.104.172   <none>        80:32316/TCP,443:31908/TCP   47m
# rancher-webhook   ClusterIP   10.43.77.134    <none>        443/TCP                      45m

获取密码

kubectl get secret --namespace cattle-system bootstrap-secret -o go-template='{{.data.bootstrapPassword|base64decode}}{{ "\n" }}'

相关调试命令

kubectl logs -l app=rancher -n cattle-system
kubectl get pods -o wide -n cert-manager
kubectl describe pod cert-manager-startupapicheck-bc2gn -n cert-manager
kubectl get events -n cattle-system
kubectl logs helm-operation-54s9f  -n cattle-system
kubectl rollout status deployment -n cattle-system rancher
kubectl edit svc rancher -n cattle-system
kubectl delete ns cert-manager
kubectl get pods --all-namespaces -o jsonpath='{.items[*].spec.containers[*].image}' | tr -s '[[:space:]]' '\n' | sort | uniq
tail -f /data/rancher/rke2/agent/logs/kubelet.log

修改rancher端口

kubectl edit svc rancher -n cattle-system

rancher 离线安装rancher2
https://ispong.isxcode.com/kubernetes/rancher/rancher 离线安装rancher2/
Author
ispong
Posted on
July 25, 2024
Licensed under