來源:51CTO
閱讀:1972
作者:juestnow
欄目:系統(tǒng)運維

環(huán)境

操作系統(tǒng):CentOS Linux release 7.7.1908 (Core)
Kernel version:3.10.0-1062.1.1.el7.x86_64
工作系統(tǒng):win10 on Ubuntu 19.04
ETCD 部署IP: 192.168.30.50
ETCD 版本: v3.4.1
kube-apiserver,kube-scheduler,kube-controller-manager 部署IP: 192.168.30.52
kubelet部署IP:192.168.30.52,192.168.30.51
flannel版本:v0.11.0
cni版本:v0.8.2
kubernetes版本: 1.16.0
工作目錄:/root/work
遠程服務(wù)器工作目錄:/apps/業(yè)務(wù)名稱
kubernetes 集群通信cidr: 10.66.0.0/16
POD 集群通信cidr:10.67.0.0/16

準備工作

# 創(chuàng)建工作目錄
mkdir /root/work
cd /root/work
# 下載二進制包
wget https://storage.googleapis.com/kubernetes-release/release/v1.16.0/kubernetes-server-linux-amd64.tar.gz
wget https://github.com/etcd-io/etcd/releases/download/v3.4.1/etcd-v3.4.1-linux-amd64.tar.gz
wget https://github.com/containernetworking/plugins/releases/download/v0.8.2/cni-plugins-linux-amd64-v0.8.2.tgz
# 解壓壓縮包
tar -xvf kubernetes-server-linux-amd64.tar.gz
tar -xvf etcd-v3.4.1-linux-amd64.tar.gz
# cni-plugins 壓縮包不帶子文件夾所以我們創(chuàng)建cni 文件夾
mkdir cni
cd cni
mv ../cni-plugins-linux-amd64-v0.8.2.tgz ./
tar -xvf cni-plugins-linux-amd64-v0.8.2.tgz
# 清理解壓縮無用的文件創(chuàng)建目錄結(jié)構(gòu)方便分發(fā)
rm cni-plugins-linux-amd64-v0.8.2.tgz
cd ../etcd-v3.4.1-linux-amd64
rm -rf Documentation  README-etcdctl.md  README.md  READMEv2-etcdctl.md
mkdir -p {bin,ssl,conf,data}
mv etcd* ./bin
cd ../kubernetes/server/bin/
rm -rf *.tar
rm -rf *_tag
rm -rf apiextensions-apiserver  hyperkube  kubeadm mounter
# 備份舊kubectl
mv /bin/kubectl /bin/kubectl1.14
cp kubectl /bin/kubectl

ETCD 部署

# 回到頂級工作目錄/root/work
cd /root/work
# 創(chuàng)建ssl 配置文件目錄
mkdir -p cfssl/
# 創(chuàng)建ca 證書json
cat << EOF | tee ./cfssl/ca-config.json
{
signing: {
default: {
expiry: 87600h
},
profiles: {
kubernetes: {
usages: [
signing,
key encipherment,
server auth,
client auth
],
expiry: 87600h
}
}
}
}
EOF
# 創(chuàng)建etcd ca證書配置
mkdir -p ./cfssl/etcd
cat << EOF | tee ./cfssl/etcd/etcd-ca-csr.json
{
CN: etcd,
key: {
algo: rsa,
size: 2048
},
names: [
{
C: CN,
ST: GuangDong,
L: GuangZhou,
O: cluster,
OU: cluster
}
]
}
EOF
# 生成 ETCD CA 證書和私鑰
mkdir -p ./cfssl/pki/etcd
cfssl gencert -initca ./cfssl/etcd/etcd-ca-csr.json | \\\\
cfssljson -bare ./cfssl/pki/etcd/etcd-ca
# 創(chuàng)建 ETCD Server 證書 
export ETCD_SERVER_IPS= \\\\
\\\\192.168.30.50\\\\ \\\\
 && \\\\
export ETCD_SERVER_HOSTNAMES= \\\\
\\\\etcd\\\\ \\\\
 && \\\\
cat << EOF | tee ./cfssl/etcd/etcd_server.json
{
CN: etcd,
hosts: [
127.0.0.1,
${ETCD_SERVER_IPS},
${ETCD_SERVER_HOSTNAMES}
],
key: {
algo: rsa,
size: 2048
},
names: [
{
C: CN,
ST: GuangDong,
L: GuangZhou,
O: cluster,
OU: cluster
}
]
}
EOF
# 生成 ETCD Server 證書和私鑰
cfssl gencert \\\\
-ca=./cfssl/pki/etcd/etcd-ca.pem \\\\
-ca-key=./cfssl/pki/etcd/etcd-ca-key.pem \\\\
-config=./cfssl/ca-config.json \\\\
-profile=kubernetes \\\\
./cfssl/etcd/etcd_server.json | \\\\
cfssljson -bare ./cfssl/pki/etcd/etcd_server

# 創(chuàng)建 ETCD Member 證書
export ETCD_MEMBER_1_IP= \\\\
    \\\\192.168.30.50\\\\ \\\\
 && \\\\
export ETCD_MEMBER_1_HOSTNAMES=etcd\\\\
 && \\\\
cat << EOF | tee ./cfssl/etcd/${ETCD_MEMBER_1_HOSTNAMES}.json
{
  CN: etcd,
  hosts: [
    127.0.0.1,
    ${ETCD_MEMBER_1_IP},
    ${ETCD_MEMBER_1_HOSTNAMES}
  ],
  key: {
    algo: rsa,
    size: 2048
  },
  names: [
    {
      C: CN,
      ST: GuangDong,
      L: GuangZhou,
      O: cluster,
      OU: cluster
    }
  ]
}
EOF
##### 生成 ETCD Member 1 證書和私鑰
cfssl gencert \\\\
    -ca=./cfssl/pki/etcd/etcd-ca.pem \\\\
    -ca-key=./cfssl/pki/etcd/etcd-ca-key.pem \\\\
    -config=./cfssl/ca-config.json \\\\
    -profile=kubernetes \\\\
    ./cfssl/etcd/${ETCD_MEMBER_1_HOSTNAMES}.json | \\\\
    cfssljson -bare ./cfssl/pki/etcd/etcd_member_${ETCD_MEMBER_1_HOSTNAMES}

# 創(chuàng)建 ETCD Client 配置文件
cat << EOF | tee ./cfssl/etcd/etcd_client.json
{
CN: client,
hosts: [], 
key: {
algo: rsa,
size: 2048
},
names: [
{
C: CN,
ST: GuangDong,
L: GuangZhou,
O: cluster,
OU: cluster
}
]
}
EOF
#生成 ETCD Client 證書和私鑰

cfssl gencert \\\\
-ca=./cfssl/pki/etcd/etcd-ca.pem \\\\
-ca-key=./cfssl/pki/etcd/etcd-ca-key.pem \\\\
-config=./cfssl/ca-config.json \\\\
-profile=kubernetes \\\\
./cfssl/etcd/etcd_client.json | \\\\
cfssljson -bare ./cfssl/pki/etcd/etcd_client
# 復(fù)制證書到etcd 分發(fā)目錄
cp -pdr ./cfssl/pki/etcd/*  ./etcd-v3.4.1-linux-amd64/ssl
# 創(chuàng)建etcd 啟動配置文件
cd ./etcd-v3.4.1-linux-amd64/conf
vi etcd
ETCD_OPTS=--name=etcd \\\\
           --data-dir=/apps/etcd/data/default.etcd \\\\
           --listen-peer-urls=https://192.168.30.50:2380 \\\\
           --listen-client-urls=https://192.168.30.50:2379,https://127.0.0.1:2379 \\\\
           --advertise-client-urls=https://192.168.30.50:2379 \\\\
           --initial-advertise-peer-urls=https://192.168.30.50:2380 \\\\
           --initial-cluster=etcd=https://192.168.30.50:2380\\\\
           --initial-cluster-token=node4=etcd=https://192.168.30.50:2380 \\\\
           --initial-cluster-state=new \\\\
           --heartbeat-interval=6000 \\\\
           --election-timeout=30000 \\\\
           --snapshot-count=5000 \\\\
           --auto-compaction-retention=1 \\\\
           --max-request-bytes=33554432 \\\\
           --quota-backend-bytes=17179869184 \\\\
           --trusted-ca-file=/apps/etcd/ssl/etcd-ca.pem \\\\
           --cert-file=/apps/etcd/ssl/etcd_server.pem \\\\
           --key-file=/apps/etcd/ssl/etcd_server-key.pem \\\\
           --peer-cert-file=/apps/etcd/ssl/etcd_member_etcd.pem \\\\
           --peer-key-file=/apps/etcd/ssl/etcd_member_etcd-key.pem \\\\
           --peer-client-cert-auth \\\\
           --peer-trusted-ca-file=/apps/etcd/ssl/etcd-ca.pem
# 遠程服務(wù)器創(chuàng)建目錄
ssh 192.168.30.50 mkdir -p /apps/etcd
# 分發(fā)ETCD 到遠程運行服務(wù)器
#回到etcd-v3.4.1-linux-amd64
cd ../
scp -r * 192.168.30.50:/apps/etcd
# 遠程服務(wù)器創(chuàng)建etcd 賬號
ssh 192.168.30.50 useradd etcd -s /sbin/nologin -M
# 遠程etcd 目錄etcd 賬號權(quán)限
ssh 192.168.30.50 chown -R etcd.etcd /apps/etcd
# 創(chuàng)建etcd.service 
vi etcd.service
[Unit]
Description=Etcd Server
After=network.target
After=network-online.target
Wants=network-online.target
[Service]
Type=notify
LimitNOFILE=1024000
LimitNPROC=1024000
LimitCORE=infinity
LimitMEMLOCK=infinity
User=etcd
Group=etcd
EnvironmentFile=-/apps/etcd/conf/etcd
ExecStart=/bin/bash -c GOMAXPROCS=$(nproc) /apps/etcd/bin/etcd $ETCD_OPTS
Restart=on-failure
[Install]
WantedBy=multi-user.target
# 分發(fā)etcd.service 到遠程服務(wù)器
scp etcd.service 192.168.30.50:/usr/lib/systemd/system/etcd.service
# 啟動 etcd 
ssh 192.168.30.50 systemctl start etcd
# 查看啟動是否成功
ssh 192.168.30.50  systemctl status etcd
[root@]~/work/etcd-v3.4.1-linux-amd64]#ssh 192.168.30.50  systemctl status etcd
● etcd.service - Etcd Server
   Loaded: loaded (/usr/lib/systemd/system/etcd.service; enabled; vendor preset: disabled)
   Active: active (running) since Thu 2019-09-19 16:54:34 CST; 17h ago
 Main PID: 9321 (etcd)
   CGroup: /system.slice/etcd.service
           └─9321 /apps/etcd/bin/etcd --name=etcd --data-dir=/apps/etcd/data/default.etcd --listen-peer-urls=https://192.168.30.50:2380 --listen-client-urls=https://192.168.30.50:2379,https://127.0.0.1:2379 --advertise-client-urls=https://192.168.30.50:2379 --initial-advertise-peer-urls=https://192.168.30.50:2380 --initial-cluster=etcd=https://192.168.30.50:2380 --initial-cluster-token=node4=etcd=https://192.168.30.50:2380 --initial-cluster-state=new --heartbeat-interval=6000 --election-timeout=30000 --snapshot-count=5000 --auto-compaction-retention=1 --max-request-bytes=33554432 --quota-backend-bytes=17179869184 --trusted-ca-file=/apps/etcd/ssl/etcd-ca.pem --cert-file=/apps/etcd/ssl/etcd_server.pem --key-file=/apps/etcd/ssl/etcd_server-key.pem --peer-cert-file=/apps/etcd/ssl/etcd_member_etcd.pem --peer-key-file=/apps/etcd/ssl/etcd_member_etcd-key.pem --peer-client-cert-auth --peer-trusted-ca-file=/apps/etcd/ssl/etcd-ca.pem

Sep 20 10:10:02 etcd etcd[9321]: store.index: compact 79182
Sep 20 10:10:02 etcd etcd[9321]: finished scheduled compaction at 79182 (took 1.966939ms)
# 設(shè)置開機啟動
ssh 192.168.30.50 systemctl enable etcd

kubernetes 證書準備

#創(chuàng)建kube-apiserver ca證書配置
mkdir -p ./cfssl/k8s
cat << EOF | tee ./cfssl/k8s/k8s-ca-csr.json
{
CN: kubernetes,
key: {
algo: rsa,
size: 2048
},
names: [
{
C: CN,
ST: GuangDong,
L: GuangZhou,
O: cluster,
OU: cluster
}
]
}
EOF
#生成 Kubernetes CA 證書和私鑰

mkdir -p ./cfssl/pki/k8s
cfssl gencert -initca ./cfssl/k8s/k8s-ca-csr.json | \\\\
cfssljson -bare ./cfssl/pki/k8s/k8s-ca
#創(chuàng)建 Kubernetes API Server 證書配置文件
export K8S_APISERVER_VIP= \\\\
\\\\192.168.30.52\\\\ \\\\
 && \\\\
export K8S_APISERVER_SERVICE_CLUSTER_IP=10.66.0.1 && \\\\
export K8S_APISERVER_HOSTNAME=api.k8s.cluster.local && \\\\
export K8S_CLUSTER_DOMAIN_SHORTNAME=cluster && \\\\
export K8S_CLUSTER_DOMAIN_FULLNAME=cluster.local && \\\\
cat << EOF | tee ./cfssl/k8s/k8s_apiserver.json
{
CN: kubernetes,
hosts: [
127.0.0.1,
${K8S_APISERVER_VIP},
${K8S_APISERVER_SERVICE_CLUSTER_IP}, 
${K8S_APISERVER_HOSTNAME},
kubernetes,
kubernetes.default,
kubernetes.default.svc,
kubernetes.default.svc.${K8S_CLUSTER_DOMAIN_SHORTNAME},
kubernetes.default.svc.${K8S_CLUSTER_DOMAIN_FULLNAME} 
],
key: {
algo: rsa,
size: 2048
},
names: [
{
C: CN,
ST: GuangDong,
L: GuangZhou,
O: cluster,
OU: cluster
}
]
}
EOF
#生成 Kubernetes API Server 證書和私鑰

cfssl gencert \\\\
-ca=./cfssl/pki/k8s/k8s-ca.pem \\\\
-ca-key=./cfssl/pki/k8s/k8s-ca-key.pem \\\\
-config=./cfssl/ca-config.json \\\\
-profile=kubernetes \\\\
./cfssl/k8s/k8s_apiserver.json | \\\\
cfssljson -bare ./cfssl/pki/k8s/k8s_server
# 創(chuàng)建 Kubernetes webhook 證書配置文件
cat << EOF | tee ./cfssl/k8s/aggregator.json
{
  CN: aggregator,
  hosts: [], 
  key: {
    algo: rsa,
    size: 2048
  },
  names: [
    {
      C: CN,
      ST: GuangDong,
      L: GuangZhou,
      O: cluster,
      OU: cluster
    }
  ]
}
EOF
# 生成Kubernetes webhook 證書
cfssl gencert \\\\
    -ca=./cfssl/pki/k8s/k8s-ca.pem \\\\
    -ca-key=./cfssl/pki/k8s/k8s-ca-key.pem \\\\
    -config=./cfssl/ca-config.json \\\\
    -profile=kubernetes \\\\
    ./cfssl/k8s/aggregator.json | \\\\
    cfssljson -bare ./cfssl/pki/k8s/aggregator
    # 創(chuàng)建 Kubernetes admin 證書配置文件    
    cat << EOF | tee ./cfssl/k8s/k8s_apiserver_admin.json
{
  CN: admin,
  hosts: [], 
  key: {
    algo: rsa,
    size: 2048
  },
  names: [
    {
      C: CN,
      ST: GuangDong,
      L: GuangZhou,
      O: system:masters,
      OU: Kubernetes-manual
    }
  ]
}
EOF
# 生成Kubernetes admin 證書
cfssl gencert -ca=./cfssl/pki/k8s/k8s-ca.pem \\\\
    -ca-key=./cfssl/pki/k8s/k8s-ca-key.pem \\\\
    -config=./cfssl/ca-config.json \\\\
    -profile=kubernetes \\\\
        ./cfssl/k8s/k8s_apiserver_admin.json | \\\\
        cfssljson -bare ./cfssl/pki/k8s/k8s_apiserver_admin
# 創(chuàng)建kube-scheduler  證書配置文件  
cat << EOF | tee ./cfssl/k8s/k8s_scheduler.json
{
  CN: system:kube-scheduler,
  hosts: [], 
  key: {
    algo: rsa,
    size: 2048
  },
  names: [
    {
      C: CN,
      ST: GuangDong,
      L: GuangZhou,
      O: system:kube-scheduler,
      OU: Kubernetes-manual
    }
  ]
}
EOF

#  生成 Kubernetes Scheduler 證書和私鑰
cfssl gencert \\\\
    -ca=./cfssl/pki/k8s/k8s-ca.pem \\\\
    -ca-key=./cfssl/pki/k8s/k8s-ca-key.pem \\\\
    -config=./cfssl/ca-config.json \\\\
    -profile=kubernetes \\\\
    ./cfssl/k8s/k8s_scheduler.json | \\\\
    cfssljson -bare ./cfssl/pki/k8s/k8s_scheduler
# kube-controller-manager        證書配置文件 
cat << EOF | tee ./cfssl/k8s/k8s_controller_manager.json
{
  CN: system:kube-controller-manager,
  hosts: [], 
  key: {
    algo: rsa,
    size: 2048
  },
  names: [
    {
      C: CN,
      ST: GuangDong,
      L: GuangZhou,
      O: system:kube-controller-manager,
      OU: Kubernetes-manual
    }
  ]
}
EOF

## 生成 Kubernetes Controller Manager 證書和私鑰
cfssl gencert \\\\
    -ca=./cfssl/pki/k8s/k8s-ca.pem \\\\
    -ca-key=./cfssl/pki/k8s/k8s-ca-key.pem \\\\
    -config=./cfssl/ca-config.json \\\\
    -profile=kubernetes \\\\
    ./cfssl/k8s/k8s_controller_manager.json | \\\\
    cfssljson -bare ./cfssl/pki/k8s/k8s_controller_manager
# 創(chuàng)建flannel 證書配置
cat << EOF | tee ./cfssl/k8s/flannel.json
{
  CN: flannel,
  hosts: [], 
  key: {
    algo: rsa,
    size: 2048
  },
  names: [
    {
      C: CN,
      ST: GuangDong,
      L: GuangZhou,
      O: system:masters,
      OU: Kubernetes-manual
    }
  ]
}
EOF

## 生成 flannel 證書和私鑰
cfssl gencert \\\\
        -ca=./cfssl/pki/k8s/k8s-ca.pem \\\\
        -ca-key=./cfssl/pki/k8s/k8s-ca-key.pem \\\\
        -config=./cfssl/ca-config.json \\\\
        -profile=kubernetes \\\\
         ./cfssl/k8s/flannel.json | \\\\
         cfssljson -bare ./cfssl/pki/k8s/flannel
# 創(chuàng)建kube-proxy 證書配置
cat << EOF | tee ./cfssl/k8s/kube-proxy.json
{
  CN: system:kube-proxy,
  hosts: [], 
  key: {
    algo: rsa,
    size: 2048
  },
  names: [
    {
      C: CN,
      ST: GuangDong,
      L: GuangZhou,
      O: system:masters,
      OU: Kubernetes-manual
    }
  ]
}
EOF
## 生成 kube-proxy 證書和私鑰
cfssl gencert \\\\
        -ca=./cfssl/pki/k8s/k8s-ca.pem \\\\
        -ca-key=./cfssl/pki/k8s/k8s-ca-key.pem \\\\
        -config=./cfssl/ca-config.json \\\\
        -profile=kubernetes \\\\
         ./cfssl/k8s/kube-proxy.json | \\\\
         cfssljson -bare ./cfssl/pki/k8s/kube-proxy
# 創(chuàng)建 kubernetes-dashboard證書配置
cat << EOF | tee ./cfssl/k8s/dashboard.json
{
  CN: dashboard,
  hosts: [], 
  key: {
    algo: rsa,
    size: 2048
  },
  names: [
    {
      C: CN,
      ST: GuangDong,
      L: GuangZhou,
      O: cluster,
      OU: cluster
    }
  ]
}
EOF
##### 生成kubernetes-dashboard 證書
cfssl gencert \\\\
        -ca=./cfssl/pki/k8s/k8s-ca.pem \\\\
       -ca-key=./cfssl/pki/k8s/k8s-ca-key.pem \\\\
        -config=./k8s/cfssl/ca-config.json \\\\
        -profile=kubernetes \\\\
        ./cfssl/k8s/dashboard.json | \\\\
        cfssljson -bare ./dashboard         
# 創(chuàng)建metrics-server 證書配置
  cat << EOF | tee ./cfssl/k8s/metrics-server.json
{
  CN: metrics-server,
  key: {
    algo: rsa,
    size: 2048
  },
  names: [
    {
      C: CN,
      ST: GuangDong,
      L: GuangZhou,
      O: cluster,
      OU: cluster
    }
  ]
}
EOF
# 生成metrics-server證書
cfssl gencert -ca=./cfssl/pki/k8s/k8s-ca.pem \\\\
    -ca-key=./cfssl/pki/k8s/k8s-ca-key.pem \\\\
    -config=./cfssl/ca-config.json \\\\
    -profile=kubernetes ./cfssl/k8s/metrics-server.json | \\\\
        cfssljson -bare ./metrics-server

創(chuàng)建kubernetes kubeconfig配置文件

設(shè)置環(huán)境變量
export KUBE_APISERVER=https://192.168.30.52:5443
# 創(chuàng)建 admin kubeconfig
# 設(shè)置集群參數(shù)
kubectl config set-cluster kubernetes \\\\
--certificate-authority=./cfssl/pki/k8s/k8s-ca.pem \\\\
--embed-certs=true  \\\\
--server=${KUBE_APISERVER} \\\\
--kubeconfig=admin.kubeconfig
# 設(shè)置客戶端認證參數(shù)
 kubectl config set-credentials admin \\\\
 --client-certificate=./cfssl/pki/k8s/k8s_apiserver_admin.pem \\\\
 --client-key=./cfssl/pki/k8s/k8s_apiserver_admin-key.pem \\\\
 --embed-certs=true \\\\
 --kubeconfig=admin.kubeconfig
 # 設(shè)置上下文參數(shù)
kubectl config set-context kubernetes \\\\
--cluster=kubernetes \\\\
--user=admin \\\\
--namespace=kube-system \\\\
--kubeconfig=admin.kubeconfig
# 設(shè)置默認上下文
kubectl config use-context kubernetes --kubeconfig=admin.kubeconfig
# 創(chuàng)建kube-scheduler kubeconfig 配置文件
# 設(shè)置集群參數(shù)
kubectl config set-cluster kubernetes \\\\
    --certificate-authority=./cfssl/pki/k8s/k8s-ca.pem \\\\
    --embed-certs=true \\\\
    --server=${KUBE_APISERVER} \\\\
    --kubeconfig=kube_scheduler.kubeconfig
# 設(shè)置客戶端認證參數(shù)
kubectl config set-credentials system:kube-scheduler \\\\
    --client-certificate=./cfssl/pki/k8s/k8s_scheduler.pem \\\\
    --embed-certs=true \\\\
    --client-key=./cfssl/pki/k8s/k8s_scheduler-key.pem \\\\
    --kubeconfig=kube_scheduler.kubeconfig
 # 設(shè)置上下文參數(shù)
kubectl config set-context kubernetes \\\\
    --cluster=kubernetes \\\\
    --user=system:kube-scheduler \\\\
    --kubeconfig=kube_scheduler.kubeconfig
# 設(shè)置默認上下文
kubectl config use-context kubernetes --kubeconfig=kube_scheduler.kubeconfig
# 創(chuàng)建kube-controller-manager kubeconfig 配置文件
# 設(shè)置集群參數(shù)
kubectl config set-cluster kubernetes \\\\
   --certificate-authority=./cfssl/pki/k8s/k8s-ca.pem \\\\
   --embed-certs=true \\\\
   --server=${KUBE_APISERVER} \\\\
   --kubeconfig=kube_controller_manager.kubeconfig
# 設(shè)置客戶端認證參數(shù)
kubectl config set-credentials system:kube-controller-manager \\\\
   --client-certificate=./cfssl/pki/k8s/k8s_controller_manager.pem \\\\
   --embed-certs=true \\\\
   --client-key=./cfssl/pki/k8s/k8s_controller_manager-key.pem \\\\
   --kubeconfig=kube_controller_manager.kubeconfig
 # 設(shè)置上下文參數(shù)
kubectl config set-context kubernetes \\\\
   --cluster=kubernetes \\\\
   --user=system:kube-controller-manager \\\\
   --kubeconfig=kube_controller_manager.kubeconfig
# 設(shè)置默認上下文
kubectl config use-context kubernetes --kubeconfig=kube_controller_manager.kubeconfig
# 創(chuàng)建bootstrap  kubeconfig 配置
# 生成TOKEN
export TOKEN_ID=$(head -c 6 /dev/urandom | md5sum | head -c 6)
export TOKEN_SECRET=$(head -c 16 /dev/urandom | md5sum | head -c 16)
export BOOTSTRAP_TOKEN=${TOKEN_ID}.${TOKEN_SECRET}
# 設(shè)置集群參數(shù)
kubectl config set-cluster kubernetes \\\\
  --certificate-authority=./cfssl/pki/k8s/k8s-ca.pem \\\\
  --embed-certs=true \\\\
  --server=${KUBE_APISERVER} \\\\
  --kubeconfig=bootstrap.kubeconfig
# 設(shè)置客戶端認證參數(shù)
kubectl config set-credentials system:bootstrap:${TOKEN_ID} \\\\
  --token=${BOOTSTRAP_TOKEN} \\\\
  --kubeconfig=bootstrap.kubeconfig
# 設(shè)置上下文參數(shù)
kubectl config set-context default \\\\
  --cluster=kubernetes \\\\
  --user=system:bootstrap:${TOKEN_ID} \\\\
  --kubeconfig=bootstrap.kubeconfig
# 設(shè)置默認上下文
kubectl config use-context default --kubeconfig=bootstrap.kubeconfig
# 創(chuàng)建flannel kubeconfig
# 設(shè)置集群參數(shù)
kubectl config set-cluster kubernetes \\\\
  --certificate-authority=./cfssl/pki/k8s/k8s-ca.pem \\\\
  --embed-certs=true \\\\
  --server=${KUBE_APISERVER} \\\\
  --kubeconfig=kubeconfig.conf
# 設(shè)置客戶端認證參數(shù)
    kubectl config set-credentials flannel \\\\
  --client-certificate=./cfssl/pki/k8s/flannel.pem \\\\
  --client-key=./cfssl/pki/k8s/flannel-key.pem \\\\
  --embed-certs=true \\\\
  --kubeconfig=kubeconfig.conf
# 設(shè)置上下文參數(shù)
    kubectl config set-context default \\\\
  --cluster=kubernetes \\\\
  --user=flannel \\\\
  --kubeconfig=kubeconfig.conf
# 設(shè)置默認上下文
kubectl config use-context default --kubeconfig=kubeconfig.conf
# 創(chuàng)建kube-proxy kubeconfig
# 設(shè)置集群參數(shù)
kubectl config set-cluster kubernetes \\\\
  --certificate-authority=./cfssl/pki/k8s/k8s-ca.pem \\\\
  --embed-certs=true \\\\
  --server=${KUBE_APISERVER} \\\\
  --kubeconfig=kube-proxy.kubeconfig 
# 設(shè)置客戶端認證參數(shù)
    kubectl config set-credentials system:kube-proxy \\\\
  --client-certificate=./cfssl/pki/k8s/kube-proxy.pem \\\\
  --client-key=./cfssl/pki/k8s/kube-proxy-key.pem \\\\
  --embed-certs=true \\\\
  --kubeconfig=kube-proxy.kubeconfig 
# 設(shè)置上下文參數(shù)
    kubectl config set-context default \\\\
  --cluster=kubernetes \\\\
  --user=system:kube-proxy \\\\
  --kubeconfig=kube-proxy.kubeconfig 
# 設(shè)置默認上下文
kubectl config use-context default --kubeconfig=kube-proxy.kubeconfig 
# k8s 所需要的kubeconfig 創(chuàng)建完成

創(chuàng)建kubernetes 啟動配置文件

cd /root/work/kubernetes/server
# 創(chuàng)建配置文件目錄
# 目錄說明 conf 主要存放啟動參數(shù)文件 config 存放其它配置文件 log 存放運行日志 kubelet-plugins 插件目錄
mkdir conf config log  kubelet-plugins
# 創(chuàng)建啟動配置文件
cd conf
#kube-apiserver 配置
vi kube-apiserver
KUBE_APISERVER_OPTS=--logtostderr=false \\\\
        --bind-address=192.168.30.52 \\\\
        --advertise-address=192.168.30.52 \\\\
        --secure-port=5443 \\\\
        --insecure-port=0 \\\\
        --service-cluster-ip-range=10.66.0.0/16 \\\\
        --service-node-port-range=30000-65000 \\\\
        --etcd-cafile=/apps/kubernetes/ssl/etcd/etcd-ca.pem \\\\
        --etcd-certfile=/apps/kubernetes/ssl/etcd/etcd_client.pem \\\\
        --etcd-keyfile=/apps/kubernetes/ssl/etcd/etcd_client-key.pem \\\\
        --etcd-prefix=/registry \\\\
        --etcd-servers=https://192.168.30.50:2379 \\\\
        --client-ca-file=/apps/kubernetes/ssl/k8s/k8s-ca.pem \\\\
        --tls-cert-file=/apps/kubernetes/ssl/k8s/k8s_server.pem \\\\
        --tls-private-key-file=/apps/kubernetes/ssl/k8s/k8s_server-key.pem \\\\
        --kubelet-client-certificate=/apps/kubernetes/ssl/k8s/k8s_server.pem \\\\
        --kubelet-client-key=/apps/kubernetes/ssl/k8s/k8s_server-key.pem \\\\
        --service-account-key-file=/apps/kubernetes/ssl/k8s/k8s-ca.pem \\\\
        --requestheader-client-ca-file=/apps/kubernetes/ssl/k8s/k8s-ca.pem \\\\
        --proxy-client-cert-file=/apps/kubernetes/ssl/k8s/aggregator.pem \\\\
        --proxy-client-key-file=/apps/kubernetes/ssl/k8s/aggregator-key.pem \\\\
        --requestheader-allowed-names=aggregator \\\\
        --requestheader-group-headers=X-Remote-Group \\\\
        --requestheader-extra-headers-prefix=X-Remote-Extra- \\\\
        --requestheader-username-headers=X-Remote-User \\\\
        --enable-aggregator-routing=true \\\\
        --anonymous-auth=false \\\\
        --allow-privileged=true \\\\
        --experimental-encryption-provider-config=/apps/kubernetes/config/encryption-config.yaml \\\\
        --enable-admission-plugins=DefaultStorageClass,DefaultTolerationSeconds,LimitRanger,NamespaceExists,NamespaceLifecycle,NodeRestriction,OwnerReferencesPermissionEnforcement,PodNodeSelector,PersistentVolumeClaimResize,PodPreset,PodTolerationRestriction,ResourceQuota,ServiceAccount,StorageObjectInUseProtection MutatingAdmissionWebhook ValidatingAdmissionWebhook \\\\
        --disable-admission-plugins=DenyEscalatingExec,ExtendedResourceToleration,ImagePolicyWebhook,LimitPodHardAntiAffinityTopology,NamespaceAutoProvision,Priority,EventRateLimit,PodSecurityPolicy \\\\
        --cors-allowed-origins=.* \\\\
        --enable-swagger-ui \\\\
        --runtime-config=api/all=true \\\\
        --kubelet-preferred-address-types=InternalIP,ExternalIP,Hostname \\\\
        --authorization-mode=Node,RBAC \\\\
        --apiserver-count=1 \\\\
        --audit-log-maxage=30 \\\\
        --audit-log-maxbackup=3 \\\\
        --audit-log-maxsize=100 \\\\
        --kubelet-https \\\\
        --event-ttl=1h \\\\
        --feature-gates=RotateKubeletServerCertificate=true,RotateKubeletClientCertificate=true \\\\
        --enable-bootstrap-token-auth=true \\\\
        --audit-log-path=/apps/kubernetes/log/api-server-audit.log \\\\
        --alsologtostderr=true \\\\
        --log-dir=/apps/kubernetes/log \\\\
        --v=2 \\\\
        --endpoint-reconciler-type=lease \\\\
        --max-mutating-requests-inflight=100 \\\\
        --max-requests-inflight=500 \\\\
        --target-ram-mb=6000
# 創(chuàng)建kube-controller-manager 配置文件
vi kube-controller-manager
KUBE_CONTROLLER_MANAGER_OPTS=--logtostderr=false \\\\
 --leader-elect=true \\\\
 --address=0.0.0.0 \\\\
 --service-cluster-ip-range=10.66.0.0/16 \\\\
 --cluster-cidr=10.67.0.0/16 \\\\
 --node-cidr-mask-size=24 \\\\
 --cluster-name=kubernetes \\\\
 --allocate-node-cidrs=true \\\\
 --kubeconfig=/apps/kubernetes/config/kube_controller_manager.kubeconfig \\\\
 --authentication-kubeconfig=/apps/kubernetes/config/kube_controller_manager.kubeconfig \\\\
 --authorization-kubeconfig=/apps/kubernetes/config/kube_controller_manager.kubeconfig \\\\
 --use-service-account-credentials=true \\\\
 --client-ca-file=/apps/kubernetes/ssl/k8s/k8s-ca.pem \\\\
 --requestheader-client-ca-file=/apps/kubernetes/ssl/k8s/k8s-ca.pem \\\\
 --node-monitor-grace-period=40s \\\\
 --node-monitor-period=5s \\\\
 --pod-eviction-timeout=5m0s \\\\
 --terminated-pod-gc-threshold=50 \\\\
 --alsologtostderr=true \\\\
 --cluster-signing-cert-file=/apps/kubernetes/ssl/k8s/k8s-ca.pem \\\\
 --cluster-signing-key-file=/apps/kubernetes/ssl/k8s/k8s-ca-key.pem  \\\\
 --deployment-controller-sync-period=10s \\\\
 --experimental-cluster-signing-duration=86700h0m0s \\\\
 --enable-garbage-collector=true \\\\
 --root-ca-file=/apps/kubernetes/ssl/k8s/k8s-ca.pem \\\\
 --service-account-private-key-file=/apps/kubernetes/ssl/k8s/k8s-ca-key.pem \\\\
 --feature-gates=RotateKubeletServerCertificate=true,RotateKubeletClientCertificate=true \\\\
 --controllers=*,bootstrapsigner,tokencleaner \\\\
 --horizontal-pod-autoscaler-use-rest-clients=true \\\\
 --horizontal-pod-autoscaler-sync-period=10s \\\\
 --flex-volume-plugin-dir=/apps/kubernetes/kubelet-plugins/volume \\\\
 --tls-cert-file=/apps/kubernetes/ssl/k8s/k8s_controller_manager.pem \\\\
 --tls-private-key-file=/apps/kubernetes/ssl/k8s/k8s_controller_manager-key.pem \\\\
 --kube-api-qps=100 \\\\
 --kube-api-burst=100 \\\\
 --log-dir=/apps/kubernetes/log \\\\
 --v=2
 # 創(chuàng)建kube-scheduler 配置文件
 vi kube-scheduler
 KUBE_SCHEDULER_OPTS= \\\\
                   --logtostderr=false \\\\
                   --address=0.0.0.0 \\\\
                   --leader-elect=true \\\\
                   --kubeconfig=/apps/kubernetes/config/kube_scheduler.kubeconfig \\\\
                   --authentication-kubeconfig=/apps/kubernetes/config/kube_scheduler.kubeconfig \\\\
                   --authorization-kubeconfig=/apps/kubernetes/config/kube_scheduler.kubeconfig \\\\
                   --alsologtostderr=true \\\\
                   --kube-api-qps=100 \\\\
                   --kube-api-burst=100 \\\\
                   --log-dir=/apps/kubernetes/log \\\\
                   --v=2
# 創(chuàng)建kubelet 配置文件
KUBELET_OPTS=--bootstrap-kubeconfig=/apps/kubernetes/conf/bootstrap.kubeconfig \\\\
              --fail-swap-on=false \\\\
              --network-plugin=cni --cni-conf-dir=/etc/cni/net.d --cni-bin-dir=/apps/cni/bin \\\\
              --kubeconfig=/apps/kubernetes/conf/kubelet.kubeconfig \\\\
              --address=192.168.30.52 \\\\節(jié)點IP 一定要修改
              --node-ip=192.168.30.52 \\\\ 節(jié)點IP 一定要修改
              --hostname-override=master \\\\節(jié)點hostname 一定要修改
              --cluster-dns=10.66.0.2 \\\\ # dns IP
              --cluster-domain=cluster.local \\\\ # 集群域
              --authorization-mode=Webhook \\\\
              --authentication-token-webhook=true \\\\
              --client-ca-file=/apps/kubernetes/ssl/k8s/k8s-ca.pem \\\\
              --rotate-certificates=true \\\\
              --cgroup-driver=cgroupfs \\\\
              --healthz-port=10248 \\\\
              --healthz-bind-address=192.168.30.52 \\\\ # 節(jié)點IP 一定要修改
              --cert-dir=/apps/kubernetes/ssl \\\\
              --feature-gates=RotateKubeletClientCertificate=true,RotateKubeletServerCertificate=true \\\\
              --node-labels=node.kubernetes.io/k8s-node=true \\\\ # node-role.kubernetes.io 已經(jīng)取消添加會報錯
              --serialize-image-pulls=false \\\\
              --enforce-node-allocatable=pods,kube-reserved,system-reserved \\\\
              --pod-manifest-path=/apps/work/kubernetes/manifests \\\\
              --runtime-cgroups=/systemd/system.slice/kubelet.service \\\\
              --kubelet-cgroups=/systemd/system.slice/kubelet.service \\\\
              --kube-reserved-cgroup=/systemd/system.slice/kubelet.service \\\\
              --system-reserved-cgroup=/systemd/system.slice \\\\
              --root-dir=/apps/work/kubernetes/kubelet \\\\
              --log-dir=/apps/kubernetes/log \\\\
              --alsologtostderr=true \\\\
              --logtostderr=false \\\\
              --anonymous-auth=true \\\\
              --image-gc-high-threshold=70 \\\\
              --image-gc-low-threshold=50 \\\\
              --kube-reserved=cpu=500m,memory=512Mi,ephemeral-storage=1Gi \\\\
              --system-reserved=cpu=1000m,memory=1024Mi,ephemeral-storage=1Gi \\\\
              --eviction-hard=memory.available<500Mi,nodefs.available<10% \\\\
              --serialize-image-pulls=false \\\\
              --sync-frequency=30s \\\\
              --resolv-conf=/etc/resolv.conf \\\\
              --pod-infra-container-image=registry.cn-hangzhou.aliyuncs.com/google-containers/pause-amd64:3.0 \\\\
              --image-pull-progress-deadline=30s \\\\
              --v=2 \\\\
              --event-burst=30 \\\\
              --event-qps=15 \\\\
              --kube-api-burst=30 \\\\
              --kube-api-qps=15 \\\\
              --max-pods=200 \\\\
              --pods-per-core=10 \\\\
              --read-only-port=0 \\\\
              --allowed-unsafe-sysctls \\\'kernel.msg*,kernel.shm*,kernel.sem,fs.mqueue.*,net.*\\\' \\\\
              --volume-plugin-dir=/apps/kubernetes/kubelet-plugins/volume
# 創(chuàng)建 kube-proxy 配置文件
vi  kube-proxy
KUBE_PROXY_OPTS=--logtostderr=false \\\\
--v=2 \\\\
--feature-gates=SupportIPVSProxyMode=true \\\\
--masquerade-all=true \\\\
--proxy-mode=ipvs \\\\
--ipvs-min-sync-period=5s \\\\
--ipvs-sync-period=5s \\\\
--ipvs-scheduler=rr \\\\
--cluster-cidr=10.67.0.0/16 \\\\  #pod  CIDR 
--log-dir=/apps/kubernetes/log \\\\
--kubeconfig=/apps/kubernetes/conf/kube-proxy.kubeconfig
# 創(chuàng)建kube-apiserver 其它配置 放到config目錄
cd ../config
#創(chuàng)建 encryption-config.yaml
 export ENCRYPTION_KEY=$(head -c 32 /dev/urandom | base64)
 cat > encryption-config.yaml <<EOF
kind: EncryptionConfig
apiVersion: v1
resources:
  - resources:
      - secrets
    providers:
      - aescbc:
          keys:
            - name: key1
              secret: ${ENCRYPTION_KEY}
      - identity: {}
EOF
# cp kubeconfig 到config
cp -r ../../../kube_scheduler.kubeconfig ../../../kube_controller_manager.kubeconfig ./
復(fù)制 bootstrap.kubeconfig  kube-proxy.kubeconfig 到conf 每個node 節(jié)點都有
cd ../conf
cp -r ../../../bootstrap.kubeconfig ../../../kube-proxy.kubeconfig ./
# 創(chuàng)建啟動配置文件
cd  /root/work/kubernetes/server
# kube-apiserver 啟動文件
vi kube-apiserver.service
[Unit]
Description=Kubernetes API Server
Documentation=https://github.com/kubernetes/kubernetes

[Service]
Type=notify
LimitNOFILE=1024000
LimitNPROC=1024000
LimitCORE=infinity
LimitMEMLOCK=infinity

EnvironmentFile=-/apps/kubernetes/conf/kube-apiserver
ExecStart=/apps/kubernetes/bin/kube-apiserver $KUBE_APISERVER_OPTS
Restart=on-failure
RestartSec=5
User=k8s
[Install]
WantedBy=multi-user.target
# kube-controller-manager啟動文件
vi kube-controller-manager.service
[Unit]
Description=Kubernetes Controller Manager
Documentation=https://github.com/kubernetes/kubernetes

[Service]
LimitNOFILE=1024000
LimitNPROC=1024000
LimitCORE=infinity
LimitMEMLOCK=infinity
EnvironmentFile=-/apps/kubernetes/conf/kube-controller-manager
ExecStart=/apps/kubernetes/bin/kube-controller-manager $KUBE_CONTROLLER_MANAGER_OPTS
Restart=on-failure
RestartSec=5
User=k8s

[Install]
WantedBy=multi-user.target
#  kube-scheduler 啟動文件
vi  kube-scheduler.service
[Unit]
Description=Kubernetes Scheduler
Documentation=https://github.com/kubernetes/kubernetes

[Service]
LimitNOFILE=1024000
LimitNPROC=1024000
LimitCORE=infinity
LimitMEMLOCK=infinity

EnvironmentFile=-/apps/kubernetes/conf/kube-scheduler
ExecStart=/apps/kubernetes/bin/kube-scheduler $KUBE_SCHEDULER_OPTS
Restart=on-failure
RestartSec=5
User=k8s

[Install]
WantedBy=multi-user.target
# kubelet啟動文件
vi kubelet.service
[Unit]
Description=Kubernetes Kubelet
After=docker.service
Requires=docker.service

[Service]
LimitNOFILE=1024000
LimitNPROC=1024000
LimitCORE=infinity
LimitMEMLOCK=infinity
EnvironmentFile=-/apps/kubernetes/conf/kubelet
ExecStart=/apps/kubernetes/bin/kubelet $KUBELET_OPTS
Restart=on-failure
KillMode=process
[Install]
WantedBy=multi-user.target
# kube-proxy啟動文件
vi kube-proxy.service
[Unit]
Description=Kubernetes Proxy
After=network.target

[Service]
LimitNOFILE=1024000
LimitNPROC=1024000
LimitCORE=infinity
LimitMEMLOCK=infinity
EnvironmentFile=-/apps/kubernetes/conf/kube-proxy
ExecStart=/apps/kubernetes/bin/kube-proxy $KUBE_PROXY_OPTS
Restart=on-failure
RestartSec=5
[Install]
WantedBy=multi-user.target
# cp ssl /root/work/kubernetes/server/ssl
mkdir ssl
cd ssl
cp -pdr /root/work/cfssl/pki/k8s ./
# 復(fù)制etcd 證書
mkdir etcd
cp -pdr /root/work/cfssl/pki/etcd/etcd_client* ./etcd/
cp -pdr /root/work/cfssl/pki/etcd/etcd-ca.pem ./etcd/

分發(fā)文件并啟動kubernetes server

cd /root/work/kubernetes/server
# 創(chuàng)建遠程目錄
ssh 192.168.30.52 mkdir -p /apps/kubernetes
scp -r bin conf config ssl 192.168.30.52:/apps/kubernetes
# 分發(fā)啟動文件
scp -r *.service 192.168.30.52:/usr/lib/systemd/system/
# 創(chuàng)建 k8s 用戶
ssh 192.168.30.52 useradd k8s -s /sbin/nologin -M
# /apps/kubernetes 目錄k8s 權(quán)限
ssh 192.168.30.52 chown -R k8s.k8s /apps/kubernetes
# 啟動  kube-apiserver  kube-controller-manager kube-scheduler
# 啟動kube-apiserver
ssh 192.168.30.52 systemctl start kube-apiserver
# 設(shè)置開機啟動
ssh 192.168.30.52 systemctl enable kube-apiserver
# 啟動狀態(tài)
ssh 192.168.30.52 systemctl status kube-apiserver
# 驗證api 是否啟動成功
# 備份舊config 文件
mv  ~/.kube/config  ~/.kube/config.old
# 復(fù)制kubeconfig 到~/.kube 目錄
cp ~/work/admin.kubeconfig ~/.kube/config
# 驗證kube-apiserver 是否正常
kubectl cluster-info 
[root@]~/work]#kubectl cluster-info
Kubernetes master is running at https://192.168.30.52:5443
# 啟動kube-controller-manager 
ssh 192.168.30.52 systemctl start kube-controller-manager 
# 設(shè)置開機啟動
ssh 192.168.30.52 systemctl enable kube-controller-manager 
# 啟動狀態(tài)
ssh 192.168.30.52 systemctl status kube-controller-manager 
# 啟動  kube-scheduler
ssh 192.168.30.52 systemctl startkube-scheduler
# 設(shè)置開機啟動
ssh 192.168.30.52 systemctl enable kube-scheduler
# 啟動狀態(tài)
ssh 192.168.30.52 systemctl status kube-scheduler
# 驗證是否啟動成功
[root@]~/work]#kubectl get cs # 最新kubectl  返回
NAME                 AGE
controller-manager   <unknown>
scheduler            <unknown>
etcd-0               <unknown>
../kubernetes-1.14.4/_output/bin/kubectl get cs
[root@]~/work]#../kubernetes-1.14.4/_output/bin/kubectl get cs
NAME                 STATUS    MESSAGE             ERROR
controller-manager   Healthy   ok
scheduler            Healthy   ok
etcd-0               Healthy   {health:true}
# 配置 kube-controller-manager,kubelet 、kube-scheduler 訪問kube-api 用戶授權(quán)
授予 kubernetes API 的權(quán)限
kubectl create clusterrolebinding controller-node-clusterrolebing --clusterrole=system:kube-controller-manager  --user=system:kube-controller-manager
kubectl create clusterrolebinding scheduler-node-clusterrolebing  --clusterrole=system:kube-scheduler --user=system:kube-scheduler
kubectl create clusterrolebinding controller-manager:system:auth-delegator --user system:kube-controller-manager --clusterrole system:auth-delegator
授予 kubernetes 證書訪問 kubelet API 的權(quán)限
kubectl create clusterrolebinding --user system:serviceaccount:kube-system:default kube-system-cluster-admin --clusterrole cluster-admin
kubectl create clusterrolebinding kubelet-node-clusterbinding --clusterrole=system:node --group=system:nodes
kubectl create clusterrolebinding kube-apiserver:kubelet-apis --clusterrole=system:kubelet-api-admin --user kubernetes

配置啟動node 節(jié)點

192.168.30.52 daemon 節(jié)點其它節(jié)點參考
分發(fā)cni
cd /root/work
scp -r cni 192.168.30.52:/apps/
# 創(chuàng)建cni 配置目錄
ssh 192.168.30.52 mkdir -p  /etc/cni/net.d
# 安裝docker 
# 創(chuàng)建 /etc/docker/daemon.json
ssh 192.168.30.52 mkdir -p /etc/docker
vi daemon.json
{
    max-concurrent-downloads: 20,
    data-root: /apps/docker,
    exec-root: /apps/docker,
    log-driver: json-file,
    bridge: none,
    oom-score-adjust: -1000,
    debug: false,
    log-opts: {
        max-size: 100M,
        max-file: 10
    },
    default-ulimits: {
        nofile: {
            Name: nofile,
            Hard: 1024000,
            Soft: 1024000
        },
        nproc: {
            Name: nproc,
            Hard: 1024000,
            Soft: 1024000
        },
      core: {
            Name: core,
            Hard: -1,
            Soft: -1    
      }

    }
}
scp -r daemon.json 192.168.30.52:/etc/docker

ssh 192.168.30.52 sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
ssh 192.168.30.52 yum install -y  epel-release
ssh 192.168.30.52 yum install -y   yum-utils  ipvsadm  telnet  wget  net-tools  conntrack  ipset  jq  iptables  curl  sysstat  libseccomp  socat  nfs-utils  fuse  fuse-devel 
# 安裝docker依賴
ssh 192.168.30.52 yum install -y    python-pip python-devel yum-utils device-mapper-persistent-data lvm2 
# 安裝docker
ssh 192.168.30.52 yum install -y docker-ce
# reload service 配置
ssh 192.168.30.52 systemctl daemon-reload
# 重啟docker
ssh 192.168.30.52 systemctl restart docker
# 設(shè)置開機啟動
ssh 192.168.30.52 systemctl enable docker
# bootstrap secret 
cat << EOF | tee bootstrap.secret.yaml
apiVersion: v1
kind: Secret
metadata:
  # Name MUST be of form bootstrap-token-<token id>
  name: bootstrap-token-${TOKEN_ID}
  namespace: kube-system

# Type MUST be \\\'bootstrap.kubernetes.io/token\\\'
type: bootstrap.kubernetes.io/token
stringData:
  # Human readable description. Optional.
  description: The default bootstrap token generated by \\\'kubelet \\\'.

  # Token ID and secret. Required.
  token-id: ${TOKEN_ID}
  token-secret: ${TOKEN_SECRET}

  # Allowed usages.
  usage-bootstrap-authentication: true
  usage-bootstrap-signing: true

  # Extra groups to authenticate the token as. Must start with system:bootstrappers:
  auth-extra-groups: system:bootstrappers:worker,system:bootstrappers:ingress
---
# A ClusterRole which instructs the CSR approver to approve a node requesting a
# serving cert matching its client cert.
kind: ClusterRole
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  name: system:certificates.k8s.io:certificatesigningrequests:selfnodeserver
rules:
- apiGroups: [certificates.k8s.io]
  resources: [certificatesigningrequests/selfnodeserver]
  verbs: [create]
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
  annotations:
    rbac.authorization.kubernetes.io/autoupdate: true
  labels:
    kubernetes.io/bootstrapping: rbac-defaults
  name: system:kubernetes-to-kubelet
rules:
  - apiGroups:
      - 
    resources:
      - nodes/proxy
      - nodes/stats
      - nodes/log
      - nodes/spec
      - nodes/metrics
    verbs:
      - *
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
  name: system:kubernetes
  namespace: 
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: system:kubernetes-to-kubelet
subjects:
  - apiGroup: rbac.authorization.k8s.io
    kind: User
    name: kubernetes
EOF

#  創(chuàng)建資源
kubectl create -f bootstrap.secret.yaml
### 查看創(chuàng)建的token
kubeadm token list
# 允許 system:bootstrappers 組用戶創(chuàng)建 CSR 請求
kubectl create clusterrolebinding kubelet-bootstrap --clusterrole=system:node-bootstrapper --group=system:bootstrappers
# 自動批準 system:bootstrappers 組用戶 TLS bootstrapping 首次申請證書的 CSR 請求
kubectl create clusterrolebinding node-client-auto-approve-csr --clusterrole=system:certificates.k8s.io:certificatesigningrequests:nodeclient --group=system:bootstrappers
# 自動批準 system:nodes 組用戶更新 kubelet 自身與 apiserver 通訊證書的 CSR 請求
kubectl create clusterrolebinding node-client-auto-renew-crt --clusterrole=system:certificates.k8s.io:certificatesigningrequests:selfnodeclient --group=system:nodes

# 自動批準 system:nodes 組用戶更新 kubelet 10250 api 端口證書的 CSR 請求
kubectl create clusterrolebinding node-server-auto-renew-crt --clusterrole=system:certificates.k8s.io:certificatesigningrequests:selfnodeserver --group=system:nodes
# kubernetes 工作目錄
ssh 192.168.30.52 mkdir -p /apps/work/kubernetes/{manifests,kubelet}
# 啟動kubelet
ssh 192.168.30.52 systemctl kubelet
# 設(shè)置開機啟動
ssh 192.168.30.52 systemctl enable kubelet
# 啟動狀態(tài)
ssh 192.168.30.52 systemctl status kubelet
# 啟動kube-proxy
ssh 192.168.30.52 systemctl kube-proxy
# 設(shè)置開機啟動
ssh 192.168.30.52 systemctl enable kube-proxy
# 啟動狀態(tài)
ssh 192.168.30.52 systemctl status kube-proxy
[root@]~/work]#kubectl get node
NAME      STATUS     ROLES    AGE    VERSION
master    NotReady   <none>   140m   v1.16.0
master2   NotReady   <none>   34m    v1.16.0
# 由于cni 一直沒就緒所以一直存在這個狀態(tài)

flannel 部署

# 創(chuàng)建flannel configmap  kubeconfig
kubectl create configmap kube-proxy --from-file=kubeconfig.conf
# 創(chuàng)建yaml
vi kube-flannel.yml
---
kind: ClusterRole
apiVersion: rbac.authorization.k8s.io/v1beta1
metadata:
  name: flannel
rules:
  - apiGroups:
      - 
    resources:
      - pods
    verbs:
      - get
  - apiGroups:
      - 
    resources:
      - nodes
    verbs:
      - list
      - watch
  - apiGroups:
      - 
    resources:
      - nodes/status
    verbs:
      - patch
---
kind: ClusterRoleBinding
apiVersion: rbac.authorization.k8s.io/v1beta1
metadata:
  name: flannel
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: flannel
subjects:
- kind: ServiceAccount
  name: flannel
  namespace: kube-system
---
apiVersion: v1
kind: ServiceAccount
metadata:
  name: flannel
  namespace: kube-system
---
kind: ConfigMap
apiVersion: v1
metadata:
  name: kube-flannel-cfg
  namespace: kube-system
  labels:
    tier: node
    app: flannel
data:
  cni-conf.json: |
     {
     name:cni0,
     cniVersion:0.3.1, # 一定要添加不然Kubelet 一直出現(xiàn)NotReady 狀態(tài)
     plugins:[
       {
         type:flannel,
         delegate:{
          hairpinMode: true,
           isDefaultGateway:true
         }
       },
       {
         type:portmap,
         capabilities:{
           portMappings:true
         }
       }
     ]
     }
  net-conf.json: |
    {
      Network: 10.67.0.0/16, # 記得修改POD cidr
      Backend: {
        Type: vxlan
      }
    }
---
apiVersion: apps/v1
kind: DaemonSet
metadata:
  name: kube-flannel-ds-amd64
  namespace: kube-system
  labels:
    tier: node
    app: flannel
spec:
  selector:
    matchLabels:
      app: flannel
  template:
    metadata:
      labels:
        tier: node
        app: flannel
    spec:
      hostNetwork: true
      nodeSelector:
        beta.kubernetes.io/arch: amd64
      tolerations:
      - operator: Exists
        effect: NoSchedule
      serviceAccountName: flannel
      initContainers:
      - name: install-cni
        image: quay.io/coreos/flannel:v0.11.0-amd64
        command:
        - cp
        args:
        - -f
        - /etc/kube-flannel/cni-conf.json
        - /etc/cni/net.d/10-flannel.conflist
        volumeMounts:
        - name: cni
          mountPath: /etc/cni/net.d
        - name: flannel-cfg
          mountPath: /etc/kube-flannel/
      containers:
      - name: kube-flannel
        image: quay.io/coreos/flannel:v0.11.0-amd64
        command:
        - /opt/bin/flanneld
        args:
        - --ip-masq
        - --kube-subnet-mgr
        - --healthz-port=10244
        - --kubeconfig-file=/var/lib/flannel/kubeconfig
        livenessProbe:
          httpGet:
            path: /healthz
            port: 10244
          initialDelaySeconds: 10
          periodSeconds: 3
        resources:
          requests:
            cpu: 100m
            memory: 50Mi
          limits:
            cpu: 100m
            memory: 50Mi
        securityContext:
          privileged: true
        env:
        - name: POD_NAME
          valueFrom:
            fieldRef:
              fieldPath: metadata.name
        - name: POD_NAMESPACE
          valueFrom:
            fieldRef:
              fieldPath: metadata.namespace
        volumeMounts:
        - name: run
          mountPath: /run
        - name: flannel-cfg
          mountPath: /etc/kube-flannel/
        - name: kubeconfig
          mountPath: /var/lib/flannel
          readOnly: true
      volumes:
        - name: run
          hostPath:
            path: /run
        - name: cni
          hostPath:
            path: /etc/cni/net.d
        - name: flannel-cfg
          configMap:
            name: kube-flannel-cfg
        - name: kubeconfig
          configMap:
            name: kube-proxy
            items:
            - key: kubeconfig.conf
              path: kubeconfig
  updateStrategy:
    rollingUpdate:
      maxUnavailable: 1
    type: RollingUpdate
# 創(chuàng)建 flannel 服務(wù)
kubectl apply -f kube-flannel.yml
# 查看POD 狀態(tài)
traefik-zs6h3                     1/1     Running   0          3h37m
[root@]~/work]#kubectl get pod| grep flannel
kube-flannel-ds-amd64-6bpf7       1/1     Running   0          3h57m
kube-flannel-ds-amd64-6sxz2       1/1     Running   0          3h58m
# 查看node 狀態(tài)
[root@]~/work]#kubectl get node
NAME      STATUS   ROLES    AGE   VERSION
master    Ready    <none>   18h   v1.16.0
master2   Ready    <none>   16h   v1.16.0
# 已經(jīng)正常狀態(tài) cni 也能正常分配ip
[root@master2 ~]# ip a | grep cni
7: cni0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1450 qdisc noqueue state UP group default qlen 1000
    inet 10.67.2.1/24 brd 10.67.2.255 scope global cni0

部署coredns

# __MACHINE_GENERATED_WARNING__

apiVersion: v1
kind: ServiceAccount
metadata:
  name: coredns
  namespace: kube-system
  labels:
      kubernetes.io/cluster-service: true
      addonmanager.kubernetes.io/mode: Reconcile
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
  labels:
    kubernetes.io/bootstrapping: rbac-defaults
    addonmanager.kubernetes.io/mode: Reconcile
  name: system:coredns
rules:
- apiGroups:
  - 
  resources:
  - endpoints
  - services
  - pods
  - namespaces
  verbs:
  - list
  - watch
- apiGroups:
  - 
  resources:
  - nodes
  verbs:
  - get
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
  annotations:
    rbac.authorization.kubernetes.io/autoupdate: true
  labels:
    kubernetes.io/bootstrapping: rbac-defaults
    addonmanager.kubernetes.io/mode: EnsureExists
  name: system:coredns
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: system:coredns
subjects:
- kind: ServiceAccount
  name: coredns
  namespace: kube-system
---
apiVersion: v1
kind: ConfigMap
metadata:
  name: coredns
  namespace: kube-system
  labels:
      addonmanager.kubernetes.io/mode: EnsureExists
data:
  Corefile: |
    .:53 {
        errors
        health
        kubernetes cluster.local in-addr.arpa ip6.arpa {
            pods insecure
            upstream /etc/resolv.conf
            fallthrough in-addr.arpa ip6.arpa
        }
        prometheus :9153
        forward . /etc/resolv.conf
        cache 30
        reload
        loadbalance
    }
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: coredns
  namespace: kube-system
  labels:
    k8s-app: kube-dns
    kubernetes.io/cluster-service: true
    addonmanager.kubernetes.io/mode: Reconcile
    kubernetes.io/name: CoreDNS
spec:
  # replicas: not specified here:
  # 1. In order to make Addon Manager do not reconcile this replicas parameter.
  # 2. Default is 1.
  # 3. Will be tuned in real time if DNS horizontal auto-scaling is turned on.
  strategy:
    type: RollingUpdate
    rollingUpdate:
      maxUnavailable: 1
  selector:
    matchLabels:
      k8s-app: kube-dns
  template:
    metadata:
      labels:
        k8s-app: kube-dns
      annotations:
        seccomp.security.alpha.kubernetes.io/pod: \\\'docker/default\\\'
    spec:
      priorityClassName: system-cluster-critical
      serviceAccountName: coredns
      tolerations:
        - key: CriticalAddonsOnly
          operator: Exists
      nodeSelector:
        beta.kubernetes.io/os: linux
      containers:
      - name: coredns
        image: coredns/coredns
        imagePullPolicy: Always
        resources:
          limits:
            memory: 170Mi
          requests:
            cpu: 100m
            memory: 70Mi
        args: [ -conf, /etc/coredns/Corefile ]
        volumeMounts:
        - name: config-volume
          mountPath: /etc/coredns
          readOnly: true
        ports:
        - containerPort: 53
          name: dns
          protocol: UDP
        - containerPort: 53
          name: dns-tcp
          protocol: TCP
        - containerPort: 9153
          name: metrics
          protocol: TCP
        livenessProbe:
          httpGet:
            path: /health
            port: 8080
            scheme: HTTP
          initialDelaySeconds: 60
          timeoutSeconds: 5
          successThreshold: 1
          failureThreshold: 5
        readinessProbe:
          httpGet:
            path: /health
            port: 8080
            scheme: HTTP
        securityContext:
          allowPrivilegeEscalation: false
          capabilities:
            add:
            - NET_BIND_SERVICE
            drop:
            - all
          readOnlyRootFilesystem: true
      dnsPolicy: Default
      volumes:
        - name: config-volume
          configMap:
            name: coredns
            items:
            - key: Corefile
              path: Corefile
---
apiVersion: v1
kind: Service
metadata:
  name: kube-dns
  namespace: kube-system
  annotations:
    prometheus.io/port: 9153
    prometheus.io/scrape: true
  labels:
    k8s-app: kube-dns
    kubernetes.io/cluster-service: true
    addonmanager.kubernetes.io/mode: Reconcile
    kubernetes.io/name: CoreDNS
spec:
  selector:
    k8s-app: kube-dns
  clusterIP: 10.66.0.2
  ports:
  - name: dns
    port: 53
    protocol: UDP
  - name: dns-tcp
    port: 53
    protocol: TCP
  - name: metrics
    port: 9153
    protocol: TCP
# 創(chuàng)建CoreDNS 服務(wù)
kubectl apply -f coredns.yaml
# 驗證dns
[root@master net.d]# dig @10.66.0.2 www.baidu.com

; <<>> DiG 9.11.4-P2-RedHat-9.11.4-9.P2.el7 <<>> @10.66.0.2 www.baidu.com
; (1 server found)
;; global options:  cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 31727
;; flags: qr rd ra; QUERY: 1, ANSWER: 3, AUTHORITY: 4, ADDITIONAL: 5

;; OPT PSEUDOSECTION:
; EDNS: version: 0, flags:; udp: 4096
;; QUESTION SECTION:
;www.baidu.com.                 IN      A

;; ANSWER SECTION:
www.baidu.com.          30      IN      CNAME   www.a.shifen.com.
www.a.shifen.com.       30      IN      A       14.215.177.38
www.a.shifen.com.       30      IN      A       14.215.177.39

;; AUTHORITY SECTION:
shifen.com.             30      IN      NS      ns3.baidu.com.
shifen.com.             30      IN      NS      ns4.baidu.com.
shifen.com.             30      IN      NS      ns2.baidu.com.
shifen.com.             30      IN      NS      dns.baidu.com.

;; ADDITIONAL SECTION:
ns3.baidu.com.          30      IN      A       112.80.248.64
ns2.baidu.com.          30      IN      A       220.181.33.31
ns4.baidu.com.          30      IN      A       14.215.178.80
dns.baidu.com.          30      IN      A       202.108.22.220

;; Query time: 3 msec
;; SERVER: 10.66.0.2#53(10.66.0.2)
;; WHEN: Fri Sep 20 13:07:01 CST 2019
;; MSG SIZE  rcvd: 413
返回正常

創(chuàng)建 traefik Ingress 啟用https

# base64 加密
cat tls.crt |base64 | tr -d \\\'\\\\n\\\'
cat tls.key|base64 | tr -d \\\'\\\\n\\\'
# 創(chuàng)建traefik-secret
vi traefik-secret.yaml
---
apiVersion: v1
kind: Secret
metadata:
  labels:
    k8s-app: tls-cert
  name: tls-cert
type: Opaque
data:
  tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUdYVENDQlVXZ0F3SUJBZ0lTQTBCSy82MUwvZVNHb2FjNmFjRnZLaDVOTUEwR0NTcUdTSWIzRFFFQkN3VUEKTUVveEN6QUpCZ05WQkFZVEFsVlRNUll3RkFZRFZRUUtFdzFNWlhRbmN5QkZibU55ZVhCME1TTXdJUVlEVlFRRApFeHBNWlhRbmN5QkZibU55ZVhCMElFRjFkR2h3Y21sMGVTQllNekFlRncweE9UQTVNRFl4TlRNNE1EVmFGdzB4Ck9URXlNRFV4TlRNNE1EVmFNQll4RkRBU0JnTlZCQU1UQzIxa1pHZGhiV1V1WTI5dE1JSUNJakFOQmdrcWhraUcKOXcwQkFRRUZBQU9DQWc4QU1JSUNDZ0tDQWdFQW9mSVdOdTE4YUp1T3Jzd0JjZE9lODN0dWpXZ2dpUXl0VVYxQwpqNVhYbzNjQTM1L2ZxQXNGVHpJRGNwUmxhTGJ6SHd1d1psOWNSKzJuRENaUzI4VlhZaXcrSkQvQXpna3FzTHFJCjZ3YlFhcHNCa1lYUzRuT1UrZzhSMVgwcm52ckpickE1eHFJSWJKM002ajVLTXZ4RktvMEV3YXNBY2NiYlVGOW4KMHQ2RzNreG4zWW1Sek5HeHh2bXZ4V2prNWNkSWMza0MyT1VuRktGOG5XemJab2JiNk9PUnZSaElEWW5YdjkxdgoyMUYwQnZ0Q21GY0FEaDRqZXUrLzNKVDVLcEJkdkFHOHI3aU1wbkhKaFU1alhqTXlPRytMbkcvcnJuRzJGaXpHCmx1UHQwKzRlK0ZRSXFZY1BUM1cyTUF2ZDlzQTNEMThsUW82M00vZlMyYjNIYVNidFY0b1pmNS9zTzJNeEVPVnoKVEd1M0NxYk40TkcrZE8ycXoxYWxMQmlGZlVjNEdmUVpYRmlLaDFzazl3Qm5zeWhqYUZmdUx6bHRxMDg3STJLYQorVlRaUzFQSlJFbGduM3UwY1FmaENjelF5ZTJ3Vjl6RE9lVmUxeTBjLzZ0RWJhNllCeGR2ZGcwOFpKL0QwYTBLCnJvWlVJMW5Rc2RKeE8rQ3N1OURLYjROZzJCYnZkWVpHVWJrSCtSUDU0UUdrS1VnYnVxNVIwbXI0U1I2VUwrRE4KZjNxem81a3ZiMXVRWXFpaDZYUFVDVUVPOTNOU1Y2MTNUSUVOTUpyYjVhbGRLUkhPZlpWL201QThlUy9ibFFYcgpOV3FCRy9OL2RtckZjMmcyNGJEY3d5OXIzL3FkNy9MTWxmMVRVdzJGczR3M2x2VHJFanlwWEZhQ3BRRGxkc0xJCkYwcWVKVnNDQXdFQUFhT0NBbTh4Z2dKck1BNEdBMVVkRHdFQi93UUVBd0lGb0RBZEJnTlZIU1VFRmpBVUJnZ3IKQmdFRkJRY0RBUVlJS3dZQkJRVUhBd0l3REFZRFZSMFRBUUgvQkFJd0FEQWRCZ05WSFE0RUZnUVVHUUNXOGNFbgpaNWhVWjBDa004QW03Wjh7NGJNd0h4WURWUjBqQkJnd0ZvQVVxRXBxWXdSOTNicm0wVG0zcGtWbDcvT283S0V3CmJ3WUlLd1lCQlFVSEFRRUVZekJoTUM0R0NDc0dBUVVGQnpBQmhpSm9kSFJ3T2k4dmIyTnpjQzVwYm5RdGVETXUKYkdWMGMyVnVZM0o1Y0hRdWIzSm5NQzhHQ0NzR0FRVUZCekFDaGlOb2RIUndPaTh3WTJWeWRDNXBiblF0ZURNdQpiR1YwYzJWdVkzSjVjSFF1YjNKbkx6QWxCZ05WSFJFRUhqQWNnZzBxTG0xa1pHZGhiV1V1WTI5dGdndHRaR1JuCllXMWxMbU52YlRCTUJnTlZIU0FFUlRCRE1BZ0dCbWVCREFFQ0FUQTNCZ3NyQmdFRUFZTGZFd0VCQVRBb01DWUcKQ0NzR0FRVUZCd0lCRmhwb2RIUndPaTh3WTNCekxteGxkSE5sYm1OeWVYQjBMbTl5WnpDQ0FRUUdDaXNHQVFRQgoxbmtDQkFJRWdmVUVnZklBOEFCM0FPSnBTNjRtNk9sQUNlaUdHN1k3ZzlRKzUvNTBpUHVranlpVEFaM2Q4ZHYrCkFBQUJiUWR3b2dNQUFBUURBRWd3UmdJaEFLWldRaVVPZkZDcGdjT0JPZ0xoTjFBQjgycHg3bUR2QXYxUnRKVmoKQU0zNEFpRUFtQWpPY012WTQ2Y0VwT2lKbW4vKzB4bnZsTmR0TlNoNExvWHJaUW9sUnJZQWRRQXBQRkdXVk1nNQpaYnFxVVB4WUI5UzNiNzlZZWlseTNLVEREUFRsUlVmMGVBQUFBVzBIY0tJbEFBQUVBd0JHTUVRQ0lEeGhFMThpCm14MjBySFFHS2RpYzVCVnQ3bFBiTzBRNy9KdGI3bkVvR1grSEFpQnRDTWxXbGxlMStNV3JrUXBKbXBaTHE3bWYKWXEyZjZXc2k1QVpmQmZFRndqQU5CZ2txaGtpRzl3MEJBUXNGQUFPQ0FRRUFXUS8ycG8wcHRXWXJkbk5ndkZIbgpMK2RyclBDT2xpUXNuaFJWajdiTlhFOGNWb0l6TmU3VGRjazJINE5CUTZUZkZicmkvdHdubkFXRThzCDNPNHVWClV1bVM1Y2FGYmFPdnJIa3ZLVTNUVGhLODNqcmpFZ1N6cEo0d3k2MUlkNGhPZ0FYODVpd2REUEhvL0o0YXkzVDEKanpyMGduY0x0N1R0Tjd3dzJ5Z1RZSXBPTTBVVWtjd05GUGZZYmFRYzVqVjdvcU1raGlMNUtiSGpYVDdRcXR4YwprY3J2VXZMdERDTTQvMGpWN01FNnd4enhCQ1N1ekZWTlVlSEVVS0dDci9qRHRXV0hFZ25JNEZ5MGhQT0F0RlZzCmpDVDhWSTVYMUVmeExTRUdONkxob2NoOHl1akJYWTVNSGlVUDc5REtHaXkzaXJTZ2xtU3BVZXpMSzkwdDVzb3MKd2c9PQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCgotLS0tLUJFR0lOIENFUlRJRklDQVRFLS0tLS0KTUlJRWtqQ0NBM3FnQXdJQkFnSVFDZ0ZCUWdBQUFWT0ZjMm9MaGV5bkNEQU5CZ2txaGtpRzl3MEJBUXNGQURBLwpNU1F3SWdZRFZRUUtFeHRFYVdkcGRHRnNJRk5wWjI1aGRIVnlaU0JVY25WemRDQkRieTR4RnpBVkJnTlZCQU1UCkRrUlRWQ0JTYjI5MElFTkJJRmd6TUI0WERURTJNRE14TnpFMk5EQTBObG9YRFRJeE1ETXhOekUyTkRBME5sb3cKU2pFTE1Ba0dBMVVFQmhNQ1ZWTXhGakFVQmdOVkJBb1REVXhsZENkeklFVnVZM0o1Y0hReEl6QWhCZ05WQkFNVApHa3hsZENkeklFVnVZM0o1Y0hRZ1FYVjBhRzl5YVhSNUlGZ3pNSUlCSWpBTkJna3Foa2lHOXcwQkFRRUZBQU9DCkFROEFNSUlCQ2dLQ0FRRUFuTk1NOEZybExrZTNjbDAzZzdOb1l6RHExelVtR1NYaHZiNDE4WENTTDdlNFMwRUYKcTZtZU5RaFk3TEVxeEdpSEM2UGpkZVRtODZkaWNicDVnV0FmMTVHYW4vUFFlR2R4eUdrT2xaSFAvdWFaNldBOApTTXgreWsxM0VpU2RSeHRhNjduc0hqY0FISnlzZTZjRjZzNUs2NzFCNVRhWXVjdjliVHlXYU44aktrS1FESVowClo4aC9wWnE0VW1FVUV6OWw2WUtIeTl2NkRsYjJob256aFQrWGhxK3czQnJ2YXcyVkZuM0VLNkJsc3BrRU5uV0EKYTZ4Szh5dVFTWGd2b3BaUEtpQWxLUVRHZE1EUU1jMlBNVGlWRnJxb003aEQ4YkVmd3pCL29ua3hFejB0TnZqagovUEl6YXJrNU1jV3Z4STBOSFdRV002cjZoQ20yMUF2QTJIM0Rrd0lEQVFBQm80SUJmVENDQVhrd0VnWURWUjBUCkFRSC9CQWd3QmdFQi93SUJBREFPQmdOVkhROEJBZjhFQkFNQ0FZWXdmd1lJS3dZQkJRVUhBUUVFY3pCeE1ESUcKQ0NzR0FRVUZCekFCaGlab2RIUndPaTh3YVhOeVp5NTBjblZ6ZEdsa0xtOWpjM0F1YVdSbGJuUnlkWE4wTG1OdgpiVEE3QmdnckJnRUZCUWN3QW9ZdmFIUjBjRG92TDJGd2NITXVhV1JsYm5SeWRYTjBMbU52YlM5eWIyOTBjeTlrCmMzUnliMjkwWTJGNE15NXdOMk13SHdZRFZSMGpCQmd3Rm9BVXhLZXhwSHNzY2ZyYjRVdVFkZi9FRldDRmlSQXcKVkFZRFZSMGdCRTB3U3pBSUJnWm5nUXdCQWdFd1B3WUxLd1lCQkFHQzN4TUJBUUV3TURBdUJnZ3JCZ0VGQlFjQwpBUllpYUhSMGNEb3ZMMk53Y3k1eWIyOTBMWGd4TG14bGRITmxibU55ZVhCMExtOXlaekE4QmdOVkhSOEVOVEF6Ck1ER2dMNkF0aGl0b2RIUndPaTh3WTNKc0xtbGtaVzUwY25WemRDNWpiMjB2UkZOVVVrOVBWRU5CV0RORFVrd3UKWTNKc01CMEdBMVVkRGdRV0JCU29TbXBqQkgzZHV1YlJPYmVtUldYdjg2anNvVEFOQmdrcWhraUc5dzBCQVFzRgpBQU9DQVFFQTNUUFhFZk5qV0RqZEdCWDdDVlcrZGxhNWNFaWxhVWNuZThJa0NKTHhXaDlLRWlrM0pIUlJIR0pvCnVNMlZjR2ZsOTZTOFRpaFJ6WnZvcm9lZDZ0aTZXcUVCbXR6dzNXb2RhdGcrVnlPZXBoNEVZcHIvMXdYS3R4OC8Kd0FwSXZKU3d0bVZpNE1GVTVhTXFyU0RFNmVhNzNNajJ0Y015bzVqTWQ2am1lV1VISzhzby9qb1dVb0hPVWd3dQpYNFBvMVFZeiszZHN6a0RxTXA0ZmtseEJ3WFJzVzEwS1h7UE1UWitzT1BBdmV5eGluZG1qa1c4bEd5K1FzUmxHClBmWitHNlo2aDdtamVtMFkraVdsa1ljVjRQSVdMMWl3Qmk4c2FDYkdTNWpOMnA4TStYK1E3VU5LRWtST2IzTjYKS09xa3FtNTdUSDJIM2VESkFrU25oNi9ETkZ1MFFnPT0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo=
  tls.key: LS0tLS1CRUdJTiBSU0EgUFJJVkFURSBLRVktLS0tLQpNSUlKS0FJQkFBS0NBZ0VBb2ZJV051MThhSnVPcnN3QmNkT2U4M3R1aldnZ2lReXRVVjFDajVYWG8zY0EzNS9mCnFBc0ZUeklEY3BSbGFMYnpId3V3Wmw5Y1IrMm5EQ1pTMjhWWFlpdytKRC9BemdrcXNMcUk2d2JRYXBzQmtZWFMKNG5PVStnOFIxWDBybnZySmJyQTV4cUlJYkozTTZqNUtNdnhGS28wRXdhc0FjY2JiVUY5bjB0Nkcza3huM1ltUgp6Tkd4eHVtdnhXams1Y2RJYzNrQzJPVW5GS0Y4bld6YlpvYmI2T09SdlJoSURZblh3OTF2MjFGMEJ2dENtRmNBCkRoNGpldSsvM0pUNUtwQmR2QUc4cjdpTXBuSEpoVTVqWGpNeU9HK0xuRy9ycm5HMkZpekdsdVB0MCs0ZStGUUkKcVljUFQzVzJNQXZkOXNBM0QxOGxRbzYzTS9mUzJiM0hhU2J0VjRvWmY1L3NPMk14RU9WelRHdTNDcWJONE5HKwpkTzJxejFhbExCaUZmVWM0R2ZRWlhGaUtoMXNrOXdCbnN5aGphRmZ1THpsdHEwODdJMkthK1ZUWlMxUEpSRWxnCm4zdTBjUWZoQ2N6UXllMndWOXpET2VWZTF5MGMvNnRFYmE2WUJ4ZHZkZzA4WkovRDBhMEtyb1pVSTFuUXNkSngKTytDc3U5REtiNE5nMkJidmRZWkdVYmtIK1JQNTRRR2tLVWdidXE1UjBtcjRTUjZVTCtETmYzcXpvNWt2YjF1UQpZcWloNlhQVUNVRU85M05TVjYxM1RJRU5NSnJiNWFsZEtSSE9mWlYvbTVBOGVTL2JsUVhyTldxQkcvTi9kbXJGCmMyZzI0YkRjd3k5cjMvcWQ3L0xNbGYxVFV3MkZzNHczbHZUckVqeXBYRmFDcFFEbGRzTElGMHFlSlZzQ0F3RUEKQVFLQ0FnQXY5Zk13UnpzTisrdlF4cWd5M3JwM1gzbkpOU3BWakVTVUVTdVNQSTFGWXd3R0xtSGRjWTRiK3pMYwpMeWl0VDJsSEszNE5nM1pmOHZrQzl5S1k1YVBRZGt2ZERtaDZYR3FoTmswd1ZhOUpzeWhPd2JSSHpuVXpiVjBaCnZkMDZVd2x1MTQvMHpLMzBCUFBYOTZTZjN1aFpCclIrNnJiUisxT2VSUE1KbDArWDdFYmliRWlhd1F1R1hsVHAKQVB5eE5FaTNzZ0h2M0VhcnJIdXNYNzNHYW5BY1U3RW9zRlUrZFRGSktEcGxXSVVsUUNwajFYZzF0aVZKMWxFYQo4Wit0UkY0T1BQRjFsUkZLaGU1cHBXSjJWbkVzRjVUZ09xRXc0NHBLbk80Zlo5ZGFhVzRRbTBxSmNtOU5XQTRoCndwSDA3czRmcGt6eG5qU1JsbmFDZDlyandGeVBsSkJzUXNhVlFFNzlpQzJZMTRnTk9KQ0xyMXRKSEQ2ODN3bW4KS3ZNOHZpOTdHTmIybXZHeWNtZnloNVpzTFBpTWNqOFFER3VWZU53dlNESXpybnhqVkZlc0liTWt5UlZRem9IVApTTHRQbXdVR3lwRHVrMDhaZytsT0lYOC85K3lqMER3MDRqenllTVptYlFVdkd2N2lNWjFUaHdaRHF1YkJXV3J4CmtYTmJwTG9BMGxrcHh5bjdGam9Ya20zM2ZKQURjd2xWSS82WFNrSm1FaFVlZmZnaFFSMGNyVGphQVd1Qkx2Qk0KT0s5aEEzT3RTN2F0S2FDb1lvSmRrYkpHQTdWdytNNzA4NEJOTGhxM1Fyckg4S3M3Z05pdC9NN3lxSnU1alBaZgo2SE1seHNyWU9NVUhuVlk4VDkwN0Q3cS9ORUNnRThzODhnZzAyQ3JNWTFqanE4UnBpUUtDQVFFQTE2UHJaMUEwClNISS83akdmS3BETkJzQ0xrVUFxRERKSzQ0dFdJYmJBUXFhRTN1eDh4bkFlU2NjSHozbS9ScEpPSGtteHZTZlgKbTJ1Wk8veGtNTWhYK2lwOHdFOHZibzR1enVNYitTSXE3bWpialJkK1JJczJ5NHJsZVQ2NGVjRWc4R2pZckExZgpiSEI0MmhQclVTcXpxUVIwOTZocm1Lb1diU0RDZDZwOUVNeWVzT3IwTjdtQmJYVVZPazJxZGtYRlZWbHBlUDdpClFxWGdRUUI0bHgzLzJJdlpBMlhJUXlQdGJ0RWVRbmgyQ3FNM2NDMzR0VEVjZ244K0VwNG9SWmkwTTBHaUY3bXgKOTEvZHY2THZlNTR5K1pON1lXd1NFQ09ubzd5bDlvTlBZVnVGMGRiMjh0elppMThCeHJTQ2JESE1XbExvUzhWNgpXTEo0OGlSODJDYkc1d0tDQVFFQXdFRjM4KzYyeDhDU2x0blZZNlJaN0J0NEdiNEJqVWhWYXZ0NFkxUGFlbXFNCjFidFVnR2JyUnBoNHFUSEFTckUwUUZLeVZKYnlCUkJyRHIxWHU4WWRSVXQzZC92VzlIR1dPd1BKdTN2M3pLbHMKQ2xsZnpFY3J5L1l2aHAzSzlEcGR6OE1icHdueW5xcGV6b0xMNlJpL3JnK0hyTzBueXd1RSt0T2xYVFo2eUtadApHWVdTSVBWaG00NUJkc2ZxUzhnYjVvbjA0bHh4bnhxVnJvN0c0TUR6cmVEYlFhaGdyS3VuRWxwajZ4eW1PVWpBCkdCZDR3QUVrUExxNUUrRWcreDY4TkRLVTYwK29ybFhLWVhDQm5HSFZOQ3BVcmswVXkrcHFZZmFEN3VuR2VzaHMKSEwra3lXbXl5a3ErTmNKbnRXMFNSNy9sU1IvZUFhVEZyVzZVaXV0RGJRS0NBUUVBemhRYU9PNmVPSW51N016QgpScVdCT3EyeDg4cjFKQmpBRnZzbkFpc3JTOGJsZmtGVTdXREdvVTB5K3FWb0ZhSm1RMjI4RFlCUS9YZnp4aTdxCjlPL1JuQU1VbTVoUlJQOWVYbHNPZGFXZ2o1em9ETXRoNFZHRnVUbHhHZERGN1oyU3hBMysyMVlnVm5xYUZCY3IKTUxOMVpOWWNqajJITGl1R0tSNUFtcW4wd2FRN0YrcENJQ3NKTkxqSzQ2QXJnc0lrMXU4TzdCSHgyeTI0eFlZVQp1SjV6emRmQU9nNEFONkhURzY5L2twaWFmb29DeGhNNDlyZ0xmZTdxUEZLbk8vTzJhckdUbmNiWi9BWEMzb3h4Ci81dHRMYlF6R2lSMGtyWHdWSHRKdys4elltQmIzL0RtcWF4RHZueTZMdEo5UGJiTmk1aGw1VnZCRTVqa0dzeWgKL3RQNEN3S0NBUUJ2R1dZb0lKcWZkRGxCMHovdEJOeXlCRzJ5OG9vVEN1blJtT0JKQmZ3TEllZWcyMUJKb3kveQo2OGxPZk9HU1NEVFp0dkEyMGNPcUNZTFVVYmFSWERzdUFCNVp4NzdBSTZPZEZ1Tk01S2FlTG9td3NWVWF4MFlYCjUzd3ZYcUFaNG1DejN4dnJ1MlBwTEtyOHk3anFTdEw1MHgra1hxZlFQaWZxaXNQVXlkYktmT0l2RFhFVWVyaWQKRytmWXJFNUkzS3JDM3BZVStUWmJ1eEVrZm4yUEEvSE5XVk5hN2VKdjVnSDJLU1gwaCtuRzBMT3hPRjhmRlluTApUbHdGa09OdU9xU254Vk1wYUM4aUQ1R1VIVi9JN3dBMTFRQjZlVEM3Wmd0ejhQRHM3MHN6U1A2dzNrNXIxaGpyCnJhV2RpMnBDL1hUQzRiR3VRQ3dhNXcwVTNBSWJCVGxCQW9JQkFEc1RONGhvclVHNWw3MXhLZk5ibVBTbDZ6RlIKYTJ4d2U2VVZPOVZzMFpHeEdLWWJSN1VuVDBDL1FqUiswS2JsbE9leDdFY3cyMklCcmFFVzBGbXpuVnoyUW9FNwpMUE5COXhyTTFEeE56UjZEbFBUeERMcEFGWVlUcm40SWY1cjFVdVdpc2lMdmd6T2xGTlVITnN5UFJIZWNGblhUCnNhTk9JWkgrQTJ5KzF3QWdpSFZIS2JPRGRHeVFQVlQ0TXFFWkJaY2pQcmRBekNKcnloSHlYdHBqRjFSdlFEYTMKTVM3U3JVTGM4djJGQWJ1VG1QZ2R1ZHBKd1Q4dENCa2VRKzZ4YmJWN3YrZzBEMG5EWFNIZFVwNXFyUzcrTnhtVwp4NWV4UHo1VENhYXcxSnkzWjRmT1MzMTV6eHJGdmRHTmhWRXhMMzRlUVlzOHRYN0N0VWxuWkNray9zYz0KLS0tLS1FTkQgUlNBIFBSSVZBVEUgS0VZLS0tLS0K
#  創(chuàng)建traefik bac
vi traefik-rbac.yaml
---
kind: ClusterRole
apiVersion: rbac.authorization.k8s.io/v1beta1
metadata:
  name: traefik
  namespace: kube-system
rules:
  - apiGroups:
      - 
    resources:
      - services
      - endpoints
      - secrets
    verbs:
      - get
      - list
      - watch
  - apiGroups:
      - extensions
    resources:
      - ingresses
    verbs:
      - get
      - list
      - watch
  - apiGroups:
    - extensions
    resources:
    - ingresses/status
    verbs:
    - update
---
kind: ClusterRoleBinding
apiVersion: rbac.authorization.k8s.io/v1beta1
metadata:
  name: traefik
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: traefik
subjects:
- kind: ServiceAccount
  name: traefik
  namespace: kube-system
# 創(chuàng)建 traefik-daemonset-https
vi traefik-daemonset-https.yaml
---
apiVersion: v1
kind: ServiceAccount
metadata:
  name: traefik
  namespace: kube-system
---
kind: DaemonSet
apiVersion: apps/v1
metadata:
  name: traefik
  namespace: kube-system
  labels:
    k8s-app: traefik
spec:
  selector:
    matchLabels:
      k8s-app: traefik
  template:
    metadata:
      labels:
        k8s-app: traefik
        name: traefik
    spec:
      serviceAccountName: traefik
      terminationGracePeriodSeconds: 60
      volumes:
      - name: ssl
        secret:
          secretName: tls-cert
      hostNetwork: true
      dnsPolicy: ClusterFirstWithHostNet      
      containers:
      - image: traefik:v1.7.16
        name: traefik
        imagePullPolicy: Always
        volumeMounts:
        - mountPath: /certs         
          name: ssl
        ports:
        - name: http
          containerPort: 80
          hostPort: 80
        - name: https
          containerPort: 443
          hostPort: 443
        - name: admin
          containerPort: 8080
        securityContext:
          capabilities:
            drop:
            - ALL
            add:
            - NET_BIND_SERVICE
        args:
        - --api
        - --web
        - --api.dashboard
        - --logLevel=INFO
        - --web.metrics
        - --metrics.prometheus
        - --web.metrics.prometheus
        - --kubernetes
        - --traefiklog
        - --traefiklog.format=json
        - --accesslog
        - --accesslog.format=json
        - --accessLog.fields.headers.defaultMode=redact
        - --insecureskipverify=true
        - --defaultentrypoints=http,https
        - --entrypoints=Name:https Address::443 TLS
        - --entrypoints=Name:http Address::80      
      #nodeSelector:
      #  ingress: yes
      tolerations:
      - effect: NoSchedule
        key: node-role.kubernetes.io/ingress
        operator: Equal
  updateStrategy:
    type: RollingUpdate
    rollingUpdate:
      maxUnavailable: 1

---
kind: Service
apiVersion: v1
metadata:
  labels:
    k8s-app: traefik
  name: traefik
  namespace: kube-system
spec:
  selector:
    k8s-app: traefik
  clusterIP: None
  ports:
    - protocol: TCP
      port: 80
      name: http
    - protocol: TCP
      port: 443
      name: https
    - protocol: TCP
      port: 8080
      name: admin
  type: ClusterIP
# 創(chuàng)建traefik-dashboard
vi traefik-dashboard.yaml
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: traefik-dashboard
  namespace: kube-system
  annotations:
    kubernetes.io/ingress.class: traefik
    traefik.ingress.kubernetes.io/frontend-entry-points: http,https
spec:
  rules:
  - host: trae.xxxx.com
    http:
      paths:
        - backend:
            serviceName: traefik
            servicePort: 8080
  tls:
   - secretName: tls-cert

#創(chuàng)建traefik 服務(wù)
kubectl apply -f .
# dns 解析 
http://trae.xxxx.com

kubernetes-dashboard 部署

# base64 加密
cat dashboard.pem|base64 | tr -d \\\'\\\\n\\\'
cat dashboard-key.pem|base64 | tr -d \\\'\\\\n\\\'
vi kubernetes-dashboard.yaml
# Copyright 2017 The Kubernetes Authors.
#
# Licensed under the Apache License, Version 2.0 (the License);
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an AS IS BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

apiVersion: v1
kind: Namespace
metadata:
  name: kubernetes-dashboard

---

apiVersion: v1
kind: ServiceAccount
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard
  namespace: kubernetes-dashboard

kind: Service
apiVersion: v1
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard
  namespace: kubernetes-dashboard
  annotations:
    kubernetes.io/ingress.class: traefik
spec:
  ports:
    - port: 443
      targetPort: 8443
  selector:
    k8s-app: kubernetes-dashboard

---

apiVersion: v1
kind: Secret
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard-certs
  namespace: kubernetes-dashboard
type: Opaque
data:
  dashboard.key: LS0tLS1CRUdJTiBSU0EgUFJJVkFURSBLRVktLS0tLQpNSUlFcEFJQkFBS0NBUUVBeFlFV0MxbGlqcnFzNW5vcHBxTXF0YzZSY0pnSWFJSGhGemZZUWhRQm5pK0Vjam8vCkRTUkYvY3BUOFlkTTg2MVpEV1lSN1FEelFLNmJUTmRLWXJJYmpVWHJpRFVFU01EUW13Y1VteTMzWjFpeXR6K0wKUUVmTVFvWVNReGVIY2RqUHp3bUhFS0todk9vNmxQTHNFWkMwQ3ZCamw2VHlERjhuSDEzby9kRlRVbGJhWUlGaQpPeGVIWkxMMTZKbmNLK3RVaW9ncjdLekFKMUkxTjdwOVQ1blZ5YU9PbWNCVEFnU3RJM0ZwSzdMZG1zaVU0ZEZ0CkpSSFZ0eTh6Y3dCSU9wWnhqV29mM2ROVkRrVUFsYjVtV2psU0RaQ2lhYmFYQi91NmJ0R0k3RlY2cENaUzdDVG4KeWlpUFlFSXRPSGRCT0VycGpKZWQ0bHQ5K2MvNDE3UTRIaiswdndJREFRQUJBb0lCQVFDK1daSWdjQTZRRnhScQpzVlNST1BNQjlFdXlJNlQrN0NZL2xXQUZGM2tUdHlKRVlTVEJpck0yVFprbjBFbjNGSndlVU1CNEZwRmJScTJBCm1vSWpxeHJveG5taGRjOWlPd3NTVHZtcU1kd2ZLNXBiQ0pBeDdNRE5ZS0FiTDRNbjAxazlaaVpaZnhTNG1WcksKa1hHNTRDZlYzeWR0VU5qRDJiVkFBdWQ2TVJQSDV5QWJTVktsMG9ONkRCaFV4MlYyWEo0WnRUVHE0b3R6VGYxZwp3SjNJeVFjSXl3czE2V3dkeHpuYStqVmpOYU5OQ3ZCT1BMbm9TeXZBQXZGRG9UYmUrMG1tcnZLVmlSeDBDT1FzCkUwNjFtNHY2eUExL3locndkT1BDYXN6SkpjWlYzOThJTzFKb2QxUHk3OU9aT1FpY1FEOGhwQmxqb0FSQ2JlY3QKRFFPcG5CR0JBb0dCQVBhYlJSSGpPTkxIQ25JZWlFQU1EYXNwQXo2RGxRNkQvdWNNdzROdkVPRVNVa3dvQ0p4cApwK1hJeVVzT1B1d2swTzVCcHJRcHZjdGYyWXlLZTFtR25iVUpmUVNWNGpLdWpqb0M0OWhOWk9lSE8zd0xMcnNXCkl1SU1Qeko0TjhxSzl0dUpDQ3BVYUZFVzRiN1R2OGsyK1pJWHJwN3hzNklDd01EUnpTaW9wY0hCQW9HQkFNMEgKQVl1bmdzY3hTM2JnZ05idU5sQ3lIOHBLZFVPbi95cU9IQUdYcG9vZmJUbXJiUUlWN0ZOVSszUTlYc2ErVVE0QwpUbVdFbzhabVhrL3lIV2FDVWxpRkN0ckRhTzNUZVhvb2pia1JyaDcxakFXN0pjVDRVZ1ZwcG1RakFVUW8vOWtVCmxHMUNpOTFZZy94dlV5dHlYM1BnZHJ6SnU2aWNsM1pVZ1h4dzNoWi9Bb0dBZENmY2w3bFVLWXZSTXNHSTRjb0wKb2lRMlAvclFlYjdZa05IbFFZSk9EQVdLT0E3ZlIzVkl2U1lmRWpoS2tRWWlWeWNiTTE4NTQ1SnBNUmFGVlR6ZwpDY2JIV1NLVUlkVXdic2l2czFGNUJza2V6cVdoeEVOLytNTlYvUnE5QkswQjY1UVhBWUV5aFlkbW0zQzN0RG90CndZOWdFOE83SGNONE1ScGhMUmFLeE1FQ2dZRUFoS2E5eHorUUM1VEhRSmlzZzJNSVhWbUIyLzRrdEt0akdvTnIKZDFSSStpQ3ZLSnJUSW9CUXNQSFE1em8xc2R5ODBKV0paNEZUL1MrS1lhdENmbXBmSU1xalpUcjlEcksrYTkwRgpKUEpkZDhaaTIrcGoyM2JXaW8zNmk5dGlIRmx5ZjE4alVUVzNESFVTb0NiZTVzTlBJc2ZkeXZPeXFMcjMvQ1ZjCnlaOU1jYjBDZ1lBMVp2RVM3bU42Nm10T2JpSlR3a3hhaTVvS2tHbDdHTDJkZXJFUmxsc1YrNWRCSVY4dG5DTnAKT2tjMFlMbHV2TEg4cG4zd2VCNzg5dUFCQjNXYmNKcHg0L2NIRm9oZDNhdlR0RThRVjJod0tNS2RKQVBvTHNoMgprK2lEUWd1dmFxSzNmL1RYUW43bWU3dWFqSDk3SXZldXJtWWsvVmRJY0dicnd1SVRzd0FEYWc9PQotLS0tLUVORCBSU0EgUFJJVkFURSBLRVktLS0tLQo=
  dashboard.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUQ5ekNDQXQrZ0F3SUJBZ0lVUWRIVXdKS1JYc1ZRb2VYS1JDTjd0eVcwWU04d0RRWUpLb1pJaHZjTkFRRUwKQlFBd2JqRUxNQWtHQTFVRUJoTUNRMDR4RWpBUUJnTlZCQWdUQ1VkMVlXNW5SRzl1WnpFU01CQUdBMVVFQnhNSgpSM1ZoYm1kYWFHOTFNUkF3RGdZRFZRUUtFd2R0WkdSbllXMWxNUkF3RGdZRFZRUUxFd2R0WkdSbllXMWxNUk13CkVRWURWUVFERXdwcmRXSmxjbTVsZEdWek1CNFhEVEU1TURjd05ERXhNVE13TUZvWERUSTVNRGN3TVRFeE1UTXcKTUZvd2JURUxNQWtHQTFVRUJoTUNRMDR4RWpBUUJnTlZCQWdUQ1VkMVlXNW5SRzl1WnpFU01CQUdBMVVFQnhNSgpSM1ZoYm1kYWFHOTFNUkF3RGdZRFZRUUtFd2R0WkdSbllXMWxNUkF3RGdZRFZRUUxFd2R0WkdSbllXMWxNUkl3CkVBWURWUVFERXdsa1lYTm9ZbTloY21Rd2dnRWlNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJEd0F3Z2dFS0FvSUIKQVFERmdSWUxXV0tPdXF6bWVpbW1veXExenBGd21BaG9nZUVYTjloQ0ZBR2VMNFJ5T2o4TkpFWDl5bFB4aDB6egpyVmtOWmhIdEFQTkFycHRNMTBwaXNodU5SZXVJTlFSSXdOQ2JCeFNiTGZkbldMSzNQNHRBUjh5Q2hoSkRGNGR4CjJNL1BDWWNRb3FHODZqcVU4dXdSa0xRSzhHT1hwUElNWHljZlhlajkwVk5TVnRwZ2dXSTdGNGRrc3ZYb21kd3IKNjFTS2lDdnNyTUFuVWpVM3VuMVBtZFhKbzQ2WndGTUNCSzBqY1drcnN0MmF5SlRoMFcwbEVkVzNMekp6QUVnNgpsbkdOYWgvZDAxVU9SUUNWdm1aYU9WSU5rS0pwdHBjSCs3cHUwWWpzVlhxa0psTHNKT2ZLS0k5Z1FpMDRkMEU0ClN1bU1sNTNpVzMzNXovalh0RGdlUDdTL0FnTUJBQUdqZ1kwd2dZb3dEZ1lEVlIwUEFRSC9CQVFEQWdXZ01CMEcKQTFVZEpRUVdNQlFHQ0NzR0FRVUZCd01CQmdnckJnRUZCUWNEQWpBTUJnTlZIUk1CQWY4RUFqQUFNQjBHQTFVZApEZ1FXQkJURTl6cWx4dkErRXMrbE8zWlFEMlhubGFHRFpqQWZCZ05WSFNNRUdEQVdnQlJ4NEtjQVJjYWtSL2J4Cm13b1RCZURzK3hBb2FUQUxCZ05WSFJFRUJEQUNnZ0F3RFFZSktvWklodmNOQVFFTEJRQURnZ0VCQUJnWHZwTEMKQjIybXlQaURlZnhsWGNZRzAvY0R2RXlYcTlENWtKTnBxKzFZQ0EvMlp2RDIyN1Q5VjY3aHVyTlA3T2FvSG95Tgo0MHpkR3lZTGRNV3pyZTQwVksxdC84N3pDTENzamt1ZXRCRWEwNVRqUTJhbDRhSzJ6TXl5MkJLWEpYbjlvdkhzCjJwNndvL001eklEOXl2OEhyRkZqWHM3NitTUTFzNXpOdUxuaDBET0Z1SktiZUZxSUJyNmZRbXlsb0l1VURtZjYKcGtQYkJyRnJpNHFGS0lDcVZKRCt3Z01zRFBiclVMZXF5NWlBVjNqRzJKMFgxOE4zdklCeUFwdWhZbjNudlV0TwpLREVIWkFJcFpjRWdqQ2ZLVDNyaERLL3JLN0VFZkxLcGlCdGJya3pFbjVWV3FQUFJEK3ZPU2VySldETDl1K0xyCmhEazlvZ084cmNqQzZGdz0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQ==
---

apiVersion: v1
kind: Secret
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: dashboard-tls-cert
  namespace: kubernetes-dashboard
type: Opaque
data:
  tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUdYVENDQlVXZ0F3SUJBZ0lTQTBCSy82MUwvZVNHb2FjNmFjRnZLaDVOTUEwR0NTcUdTSWIzRFFFQkN3VUEKTUVveEN6QUpCZ05WQkFZVEFsVlRNUll3RkFZRFZRUUtFdzFNWlhRbmN5QkZibU55ZVhCME1TTXdJUVlEVlFRRApFeHBNWlhRbmN5QkZibU55ZVhCMElFRjFkR2h3Y21sMGVTQllNekFlRncweE9UQTVNRFl4TlRNNE1EVmFGdzB4Ck9URXlNRFV4TlRNNE1EVmFNQll4RkRBU0JnTlZCQU1UQzIxa1pHZGhiV1V1WTI5dE1JSUNJakFOQmdrcWhraUcKOXcwQkFRRUZBQU9DQWc4QU1JSUNDZ0tDQWdFQW9mSVdOdTE4YUp1T3Jzd0JjZE9lODN0dWpXZ2dpUXl0VVYxQwpqNVhYbzNjQTM1L2ZxQXNGVHpJRGNwUmxhTGJ6SHd1d1psOWNSKzJuRENaUzI4VlhZaXcrSkQvQXpna3FzTHFJCjZ3YlFhcHNCa1lYUzRuT1UrZzhSMVgwcm52ckpickE1eHFJSWJKM002ajVLTXZ4RktvMEV3YXNBY2NiYlVGOW4KMHQ2RzNreG4zWW1Sek5HeHh2bXZ4V2prNWNkSWMza0MyT1VuRktGOG5XemJab2JiNk9PUnZSaElEWW5YdjkxdgoyMUYwQnZ0Q21GY0FEaDRqZXUrLzNKVDVLcEJkdkFHOHI3aU1wbkhKaFU1alhqTXlPRytMbkcvcnJuRzJGaXpHCmx1UHQwKzRlK0ZRSXFZY1BUM1cyTUF2ZDlzQTNEMThsUW82M00vZlMyYjNIYVNidFY0b1pmNS9zTzJNeEVPVnoKVEd1M0NxYk40TkcrZE8ycXoxYWxMQmlGZlVjNEdmUVpYRmlLaDFzazl3Qm5zeWhqYUZmdUx6bHRxMDg3STJLYQorVlRaUzFQSlJFbGduM3UwY1FmaENjelF5ZTJ3Vjl6RE9lVmUxeTBjLzZ0RWJhNllCeGR2ZGcwOFpKL0QwYTBLCnJvWlVJMW5Rc2RKeE8rQ3N1OURLYjROZzJCYnZkWVpHVWJrSCtSUDU0UUdrS1VnYnVxNVIwbXI0U1I2VUwrRE4KZjNxem81a3ZiMXVRWXFpaDZYUFVDVUVPOTNOU1Y2MTNUSUVOTUpyYjVhbGRLUkhPZlpWL201QThlUy9ibFFYcgpOV3FCRy9OL2RtckZjMmcyNGJEY3d5OXIzL3FkNy9MTWxmMVRVdzJGczR3M2x2VHJFanlwWEZhQ3BRRGxkc0xJCkYwcWVKVnNDQXdFQUFhT0NBbTh4Z2dKck1BNEdBMVVkRHdFQi93UUVBd0lGb0RBZEJnTlZIU1VFRmpBVUJnZ3IKQmdFRkJRY0RBUVlJS3dZQkJRVUhBd0l3REFZRFZSMFRBUUgvQkFJd0FEQWRCZ05WSFE0RUZnUVVHUUNXOGNFbgpaNWhVWjBDa004QW03Wjh7NGJNd0h4WURWUjBqQkJnd0ZvQVVxRXBxWXdSOTNicm0wVG0zcGtWbDcvT283S0V3CmJ3WUlLd1lCQlFVSEFRRUVZekJoTUM0R0NDc0dBUVVGQnpBQmhpSm9kSFJ3T2k4dmIyTnpjQzVwYm5RdGVETXUKYkdWMGMyVnVZM0o1Y0hRdWIzSm5NQzhHQ0NzR0FRVUZCekFDaGlOb2RIUndPaTh3WTJWeWRDNXBiblF0ZURNdQpiR1YwYzJWdVkzSjVjSFF1YjNKbkx6QWxCZ05WSFJFRUhqQWNnZzBxTG0xa1pHZGhiV1V1WTI5dGdndHRaR1JuCllXMWxMbU52YlRCTUJnTlZIU0FFUlRCRE1BZ0dCbWVCREFFQ0FUQTNCZ3NyQmdFRUFZTGZFd0VCQVRBb01DWUcKQ0NzR0FRVUZCd0lCRmhwb2RIUndPaTh3WTNCekxteGxkSE5sYm1OeWVYQjBMbTl5WnpDQ0FRUUdDaXNHQVFRQgoxbmtDQkFJRWdmVUVnZklBOEFCM0FPSnBTNjRtNk9sQUNlaUdHN1k3ZzlRKzUvNTBpUHVranlpVEFaM2Q4ZHYrCkFBQUJiUWR3b2dNQUFBUURBRWd3UmdJaEFLWldRaVVPZkZDcGdjT0JPZ0xoTjFBQjgycHg3bUR2QXYxUnRKVmoKQU0zNEFpRUFtQWpPY012WTQ2Y0VwT2lKbW4vKzB4bnZsTmR0TlNoNExvWHJaUW9sUnJZQWRRQXBQRkdXVk1nNQpaYnFxVVB4WUI5UzNiNzlZZWlseTNLVEREUFRsUlVmMGVBQUFBVzBIY0tJbEFBQUVBd0JHTUVRQ0lEeGhFMThpCm14MjBySFFHS2RpYzVCVnQ3bFBiTzBRNy9KdGI3bkVvR1grSEFpQnRDTWxXbGxlMStNV3JrUXBKbXBaTHE3bWYKWXEyZjZXc2k1QVpmQmZFRndqQU5CZ2txaGtpRzl3MEJBUXNGQUFPQ0FRRUFXUS8ycG8wcHRXWXJkbk5ndkZIbgpMK2RyclBDT2xpUXNuaFJWajdiTlhFOGNWb0l6TmU3VGRjazJINE5CUTZUZkZicmkvdHdubkFXRThzcDNPNHVWClV1bVM1Y2FGYmFPdnJIa3ZLVTNUVGhLODNqcmpFZ1N6cEo0d3k2MUlkNGhPZ0FYODVpd2REUEhvL0o0YXkzVDEKanpyMGduY0x0N1R0Tjd3dzJ5Z1RZSXBPTTBVVWtjd05GUGZZYmFRYzVqVjdvcU1raGlMNUtiSGpYVDdRcXR4YwprY3J2VXZMdERDTTQvMGpWN01FNnd4enhCQ1N1ekZWTlVlSEVVS0dDci9qRHRXV0hFZ25JNEZ5MGhQT0F0RlZzCmpDVDhWSTVYMUVmeExTRUdONkxob2NoOHl1akJYWTVNSGlVUDc5REtHaXkzaXJTZ2xtU3BVZXpMSzkwdDVzb3MKd2c9PQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCgotLS0tLUJFR0lOIENFUlRJRklDQVRFLS0tLS0KTUlJRWtqQ0NBM3FnQXdJQkFnSVFDZ0ZCUWdBQUFWT0ZjMm9MaGV5bkNEQU5CZ2txaGtpRzl3MEJBUXNGQURBLwpNU1F3SWdZRFZRUUtFeHRFYVdkcGRHRnNJRk5wWjI1aGRIVnlaU0JVY25WemRDQkRieTR4RnpBVkJnTlZCQU1UCkRrUlRWQ0JTYjI5MElFTkJJRmd6TUI0WERURTJNRE14TnpFMk5EQTBObG9YRFRJeE1ETXhOekUyTkRBME5sb3cKU2pFTE1Ba0dBMVVFQmhNQ1ZWTXhGakFVQmdOVkJBb1REVXhsZENkeklFVnVZM0o1Y0hReEl6QWhCZ05WQkFNVApHa3hsZENkeklFVnVZM0o1Y0hRZ1FYVjBhRzl5YVhSNUlGZ3pNSUlCSWpBTkJna3Foa2lHOXcwQkFRRUZBQU9DCkFROEFNSUlCQ2dLQ0FRRUFuTk1NOEZybExrZTNjbDAzZzdOb1l6RHExelVtR1NYaHZiNDE4WENTTDdlNFMwRUYKcTZtZU5RaFk3TEVxeEdpSEM2UGpkZVRtODZkaWNicDVnV0FmMTVHYW4vUFFlR2R4eUdrT2xaSFAvdWFaNldBOApTTXgreWsxM0VpU2RSeHRhNjduc0hqY0FISnlzZTZjRjZzNUs2NzFCNVRhWXVjdjliVHlXYU44aktrS1FESVowClo4aC9wWnE0VW1FVUV6OWw2WUtIeTl2NkRsYjJob256aFQrWGhxK3czQnJ2YXcyVkZuM0VLNkJsc3BrRU5uV0EKYTZ4Szh5dVFTWGd2b3BaUEtpQWxLUVRHZE1EUU1jMlBNVGlWRnJxb003aEQ4YkVmd3pCL29ua3hFejB0TnZqagovUEl6YXJrNU1jV3Z4STBOSFdRV002cjZoQ20yMUF2QTJIM0Rrd0lEQVFBQm80SUJmVENDQVhrd0VnWURWUjBUCkFRSC9CQWd3QmdFQi93SUJBREFPQmdOVkhROEJBZjhFQkFNQ0FZWXdmd1lJS3dZQkJRVUhBUUVFY3pCeE1ESUcKQ0NzR0FRVUZCekFCaGlab2RIUndPaTh3YVhOeVp5NTBjblZ6ZEdsa0xtOWpjM0F1YVdSbGJuUnlkWE4wTG1OdgpiVEE3QmdnckJnRUZCUWN3QW9ZdmFIUjBjRG92TDJGd2NITXVhV1JsYm5SeWRYTjBMbU52YlM5eWIyOTBjeTlrCmMzUnliMjkwWTJGNE15NXdOMk13SHdZRFZSMGpCQmd3Rm9BVXhLZXhwSHNzY2ZyYjRVdVFkZi9FRldDRmlSQXcKVkFZRFZSMGdCRTB3U3pBSUJnWm5nUXdCQWdFd1B3WUxLd1lCQkFHQzN4TUJBUUV3TURBdUJnZ3JCZ0VGQlFjQwpBUllpYUhSMGNEb3ZMMk53Y3k1eWIyOTBMWGd4TG14bGRITmxibU55ZVhCMExtOXlaekE4QmdOVkhSOEVOVEF6Ck1ER2dMNkF0aGl0b2RIUndPaTh3WTNKc0xtbGtaVzUwY25WemRDNWpiMjB2UkZOVVVrOVBWRU5CV0RORFVrd3UKWTNKc01CMEdBMVVkRGdRV0JCU29TbXBqQkgzZHV1YlJPYmVtUldYdjg2anNvVEFOQmdrcWhraUc5dzBCQVFzRgpBQU9DQVFFQTNUUFhFZk5qV0RqZEdCWDdDVlcrZGxhNWNFaWxhVWNuZThJa0NKTHhXaDlLRWlrM0pIUlJIR0pvCnVNMlZjR2ZsOTZTOFRpaFJ6WnZvcm9lZDZ0aTZXcUVCbXR6dzNXb2RhdGcrVnlPZXBoNEVZcHIvMXdYS3R4OC8Kd0FwSXZKU3d0bVZpNE1GVTVhTXFyU0RFNmVhNzNNajJ0Y015bzVqTWQ2am1lV1VISzhzby9qb1dVb0hPVWd3dQpYNFBvMVFZeiszZHN6a0RxTXA0ZmtseEJ3WFJzVzEwS1h7UE1UWitzT1BBdmV5eGluZG1qa1c4bEd5K1FzUmxHClBmWitHNlo2aDdtamVtMFkraVdsa1ljVjRQSVdMMWl3Qmk4c2FDYkdTNWpOMnA4TStYK1E3VU5LRWtST2IzTjYKS09xa3FtNTdUSDJIM2VESkFrU25oNi9ETkZ1MFFnPT0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo=
  tls.key: LS0tLS1CRUdJTiBSU0EgUFJJVkFURSBLRVktLS0tLQpNSUlKS0FJQkFBS0NBZ0VBb2ZJV051MThhSnVPcnN3QmNkT2U4M3R1aldnZ2lReXRVVjFDajVYWG8zY0EzNS9mCnFBc0ZUeklEY3BSbGFMYnpId3V3Wmw5Y1IrMm5EQ1pTMjhWWFlpdytKRC9BemdrcXNMcUk2d2JRYXBzQmtZWFMKNG5PVStnOFIxWDBybnZySmJyQTV4cUlJYkozTTZqNUtNdnhGS28wRXdhc0FjY2JiVUY5bjB0Nkcza3huM1ltUgp6Tkd4eHVtdnhXams1Y2RJYzNrQzJPVW5GS0Y4bld6YlpvYmI2T09SdlJoSURZblh3OTF2MjFGMEJ2dENtRmNBCkRoNGpldSsvM0pUNUtwQmR2QUc4cjdpTXBuSEpoVTVqWGpNeU9HK0xuRy9ycm5HMkZpekdsdVB0MCs0ZStGUUkKcVljUFQzVzJNQXZkOXNBM0QxOGxRbzYzTS9mUzJiM0hhU2J0VjRvWmY1L3NPMk14RU9WelRHdTNDcWJONE5HKwpkTzJxejFhbExCaUZmVWM0R2ZRWlhGaUtoMXNrOXdCbnN5aGphRmZ1THpsdHEwODdJMkthK1ZUWlMxUEpSRWxnCm4zdTBjUWZoQ2N6UXllMndWOXpET2VWZTF5MGMvNnRFYmE2WUJ4ZHZkZzA4WkovRDBhMEtyb1pVSTFuUXNkSngKTytDc3U5REtiNE5nMkJidmRZWkdVYmtIK1JQNTRRR2tLVWdidXE1UjBtcjRTUjZVTCtETmYzcXpvNWt2YjF1UQpZcWloNlhQVUNVRU85M05TVjYxM1RJRU5NSnJiNWFsZEtSSE9mWlYvbTVBOGVTL2JsUVhyTldxQkcvTi9kbXJGCmMyZzI0YkRjd3k5cjMvcWQ3L0xNbGYxVFV3MkZzNHczbHZUckVqeXBYRmFDcFFEbGRzTElGMHFlSlZzQ0F3RUEKQVFLQ0FnQXY5Zk13UnpzTisrdlF4cWd5M3JwM1gzbkpOU3BWakVTVUVTdVNQSTFGWXd3R0xtSGRjWTRiK3pMYwpMeWl0VDJsSEszNE5nM1pmOHZrQzl5S1k1YVBRZGt2ZERtaDZYR3FoTmswd1ZhOUpzeWhPd2JSSHpuVXpiVjBaCnZkMDZVd2x1MTQvMHpLMzBCUFBYOTZTZjN1aFpCclIrNnJiUisxT2VSUE1KbDArWDdFYmliRWlhd1F1R1hsVHAKQVB5eE5FaTNzZ0h2M0VhcnJIdXNYNzNHYW5BY1U3RW9zRlUrZFRGSktEcGxXSVVsUUNwajFYZzF0aVZKMWxFYQo4Wit0UkY0T1BQRjFsUkZLaGU1cHBXSjJWbkVzRjVUZ09xRXc0NHBLbk80Zlo5ZGFhVzRRbTBxSmNtOU5XQTRoCndwSDA3czRmcGt6eG5qU1JsbmFDZDlyandGeVBsSkJzUXNhVlFFNzlpQzJZMTRnTk9KQ0xyMXRKSEQ2ODN3bW4KS3ZNOHZpOTdHTmIybXZHeWNtZnloNVpzTFBpTWNqOFFER3VWZU53dlNESXpybnhqVkZlc0liTWt5UlZRem9IVApTTHRQbXdVR3lwRHVrMDhaZytsT0lYOC85K3lqMER3MDRqenllTVptYlFVdkd2N2lNWjFUaHdaRHF1YkJXV3J4CmtYTmJwTG9BMGxrcHh5bjdGam9Ya20zM2ZKQURjd2xWSS82WFNrSm1FaFVlZmZnaFFSMGNyVGphQVd1Qkx2Qk0KT0s5aEEzT3RTN2F0S2FDb1lvSmRrYkpHQTdWdytNNzA4NEJOTGhxM1Fyckg4S3M3Z05pdC9NN3lxSnU1alBaZgo2SE1seHNyWU9NVUhuVlk4VDkwN0Q3cS9ORUNnRThzODhnZzAyQ3JNWTFqanE4UnBpUUtDQVFFQTE2UHJaMUEwClNISS83akdmS3BETkJzQ0xrVUFxRERKSzQ0dFdJYmJBUXFhRTN1eDh4bkFlU2NjSHozbS9ScEpPSGtteHZTZlgKbTJ1Wk8veGtNTWhYK2lwOHdFOHZibzR1enVNYitTSXE3bWpialJkK1JJczJ5NHJsZVQ2NGVjRWc4R2pZckExZgpiSEI0MmhQclVTcXpxUVIwOTZocm1Lb1diU0RDZDZwOUVNeWVzT3IwTjdtQmJYVVZPazJxZGtYRlZWbHBlUDdpClFxWGdRUUI0bHgzLzJJdlpBMlhJUXlQdGJ0RWVRbmgyQ3FNM2NDMzR0VEVjZ244K0VwNG9SWmkwTTBHaUY3bXgKOTEvZHY2THZlNTR5K1pON1lXd1NFQ09ubzd5bDlvTlBZVnVGMGRiMjh0elppMThCeHJTQ2JESE1XbExvUzhWNgpXTEo0OGlSODJDYkc1d0tDQVFFQXdFRjM4KzYyeDhDU2x0blZZNlJaN0J0NEdiNEJqVWhWYXZ0NFkxUGFlbXFNCjFidFVnR2JyUnBoNHFUSEFTckUwUUZLeVZKYnlCUkJyRHIxWHU4WWRSVXQzZC92VzlIR1dPd1BKdTN2M3pLbHMKQ2xsZnpFY3J5L1l2aHAzSzlEcGR6OE1icHdueW5xcGV6b0xMNlJpL3JnK0hyTzBueXd1RSt0T2xYVFo2eUtadApHWVdTSVBWaG00NUJkc2ZxUzhnYjVvbjA0bHh4bnhxVnJvN0c0TUR6cmVEYlFhaGdyS3VuRWxwajZ4eW1PVWpBCkdCZDR3QUVrUExxNUUrRWcreDY4TkRLVTYwK29ybFhLWVhDQm5HSFZOQ3BVcmswVXkrcHFZZmFEN3VuR2VzaHMKSEwra3lXbXl5a3ErTmNKbnRXMFNSNy9sU1IvZUFhVEZyVzZVaXV0RGJRS0NBUUVBemhRYU9PNmVPSW51N016QgpScVdCT3EyeDg4cjFKQmpBRnZzbkFpc3JTOGJsZmtGVTdXREdvVTB5K3FWb0ZhSm1RMjI4RFlCUS9YZnp4aTdxCjlPL1JuQU1VbTVoUlJQOWVYbHNPZGFXZ2o1em9ETXRoNFZHRnVUbHhHZERGN1oyU3hBMysyMVlnVm5xYUZCY3IKTUxOMVpOWWNqajJITGl1R0tSNUFtcW4wd2FRN0YrcENJQ3NKTkxqSzQ2QXJnc0lrMXU4TzdCSHgyeTI0eFlZVQp1SjV6emRmQU9nNEFONkhURzY5L2twaWFmb29DeGhNNDlyZ0xmZTdxUEZLbk8vTzJhckdUbmNiWi9BWEMzb3h4Ci81dHRMYlF6R2lSMGtyWHdWSHRKdys4elltQmIzL0RtcWF4RHZueTZMdEo5UGJiTmk1aGw1VnZCRTVqa0dzeWgKL3RQNEN3S0NBUUJ2R1dZb0lKcWZkRGxCMHovdEJOeXlCRzJ5OG9vVEN1blJtT0JKQmZ3TEllZWcyMUJKb3kveQo2OGxPZk9HU1NEVFp0dkEyMGNPcUNZTFVVYmFSWERzdUFCNVp4NzdBSTZPZEZ1Tk01S2FlTG9td3NWVWF4MFlYCjUzd3ZYcUFaNG1DejN4dnJ1MlBwTEtyOHk3anFTdEw1MHgra1hxZlFQaWZxaXNQVXlkYktmT0l2RFhFVWVyaWQKRytmWXJFNUkzS3JDM3BZVStUWmJ1eEVrZm4yUEEvSE5XVk5hN2VKdjVnSDJLU1gwaCtuRzBMT3hPRjhmRlluTApUbHdGa09OdU9xU254Vk1wYUM4aUQ1R1VIVi9JN3dBMTFRQjZlVEM3Wmd0ejhQRHM3MHN6U1A2dzNrNXIxaGpyCnJhV2RpMnBDL1hUQzRiR3VRQ3dhNXcwVTNBSWJCVGxCQW9JQkFEc1RONGhvclVHNWw3MXhLZk5ibVBTbDZ6RlIKYTJ4d2U2VVZPOVZzMFpHeEdLWWJSN1VuVDBDL1FqUiswS2JsbE9leDdFY3cyMklCcmFFVzBGbXpuVnoyUW9FNwpMUE5COXhyTTFEeE56UjZEbFBUeERMcEFGWVlUcm40SWY1cjFVdVdpc2lMdmd6T2xGTlVITnN5UFJIZWNGblhUCnNhTk9JWkgrQTJ5KzF3QWdpSFZIS2JPRGRHeVFQVlQ0TXFFWkJaY2pQcmRBekNKcnloSHlYdHBqRjFSdlFEYTMKTVM3U3JVTGM4djJGQWJ1VG1QZ2R1ZHBKd1Q4dENCa2VRKzZ4YmJWN3YrZzBEMG5EWFNIZFVwNXFyUzcrTnhtVwp4NWV4UHo1VENhYXcxSnkzWjRmT1MzMTV6eHJGdmRHTmhWRXhMMzRlUVlzOHRYN0N0VWxuWkNray9zYz0KLS0tLS1FTkQgUlNBIFBSSVZBVEUgS0VZLS0tLS0K
---

apiVersion: v1
kind: Secret
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard-csrf
  namespace: kubernetes-dashboard
type: Opaque
data:
  csrf: 

---

apiVersion: v1
kind: Secret
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard-key-holder
  namespace: kubernetes-dashboard
type: Opaque

---

kind: ConfigMap
apiVersion: v1
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard-settings
  namespace: kubernetes-dashboard

---

kind: Role
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard
  namespace: kubernetes-dashboard
rules:
  # Allow Dashboard to get, update and delete Dashboard exclusive secrets.
  - apiGroups: []
    resources: [secrets]
    resourceNames: [kubernetes-dashboard-key-holder, kubernetes-dashboard-certs, kubernetes-dashboard-csrf]
    verbs: [get, update, delete]
    # Allow Dashboard to get and update \\\'kubernetes-dashboard-settings\\\' config map.
  - apiGroups: []
    resources: [configmaps]
    resourceNames: [kubernetes-dashboard-settings]
    verbs: [get, update]
    # Allow Dashboard to get metrics.
  - apiGroups: []
    resources: [services]
    resourceNames: [heapster, dashboard-metrics-scraper]
    verbs: [proxy]
  - apiGroups: []
    resources: [services/proxy]
    resourceNames: [heapster, http:heapster:, https:heapster:, dashboard-metrics-scraper, http:dashboard-metrics-scraper]
    verbs: [get]

---

kind: ClusterRole
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard
rules:
  # Allow Metrics Scraper to get metrics from the Metrics server
  - apiGroups: [metrics.k8s.io]
    resources: [pods, nodes]
    verbs: [get, list, watch]

---

apiVersion: rbac.authorization.k8s.io/v1
kind: RoleBinding
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard
  namespace: kubernetes-dashboard
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: Role
  name: kubernetes-dashboard
subjects:
  - kind: ServiceAccount
    name: kubernetes-dashboard
    namespace: kubernetes-dashboard

---

apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
  name: kubernetes-dashboard
  namespace: kubernetes-dashboard
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: kubernetes-dashboard
subjects:
  - kind: ServiceAccount
    name: kubernetes-dashboard
    namespace: kubernetes-dashboard

---

kind: Deployment
apiVersion: apps/v1
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard
  namespace: kubernetes-dashboard
spec:
  replicas: 1
  revisionHistoryLimit: 10
  selector:
    matchLabels:
      k8s-app: kubernetes-dashboard
  template:
    metadata:
      labels:
        k8s-app: kubernetes-dashboard
    spec:
      containers:
        - name: kubernetes-dashboard
          image: kubernetesui/dashboard:v2.0.0-beta4
          imagePullPolicy: Always
          ports:
            - containerPort: 8443
              protocol: TCP
          args:
            - --auto-generate-certificates
            - --namespace=kubernetes-dashboard
            - --token-ttl=43200
            # Uncomment the following line to manually specify Kubernetes API server Host
            # If not specified, Dashboard will attempt to auto discover the API server and connect
            # to it. Uncomment only if the default does not work.
            # - --apiserver-host=http://my-address:port
          volumeMounts:
            - name: kubernetes-dashboard-certs
              mountPath: /certs
              # Create on-disk volume to store exec logs
            - mountPath: /tmp
              name: tmp-volume
          livenessProbe:
            httpGet:
              scheme: HTTPS
              path: /
              port: 8443
            initialDelaySeconds: 30
            timeoutSeconds: 30
      volumes:
        - name: kubernetes-dashboard-certs
          secret:
            secretName: kubernetes-dashboard-certs
        - name: tmp-volume
          emptyDir: {}
      serviceAccountName: kubernetes-dashboard
      # Comment the following tolerations if Dashboard must not be deployed on master
      tolerations:
        - key: node-role.kubernetes.io/master
          effect: NoSchedule

---

kind: Service
apiVersion: v1
metadata:
  labels:
    k8s-app: dashboard-metrics-scraper
  name: dashboard-metrics-scraper
  namespace: kubernetes-dashboard
spec:
  ports:
    - port: 8000
      targetPort: 8000
  selector:
    k8s-app: dashboard-metrics-scraper

---

kind: Deployment
apiVersion: apps/v1
metadata:
  labels:
    k8s-app: dashboard-metrics-scraper
  name: dashboard-metrics-scraper
  namespace: kubernetes-dashboard
spec:
  replicas: 1
  revisionHistoryLimit: 10
  selector:
    matchLabels:
      k8s-app: dashboard-metrics-scraper
  template:
    metadata:
      labels:
        k8s-app: dashboard-metrics-scraper
    spec:
      containers:
        - name: dashboard-metrics-scraper
          image: kubernetesui/metrics-scraper:v1.0.1
          ports:
            - containerPort: 8000
              protocol: TCP
          livenessProbe:
            httpGet:
              scheme: HTTP
              path: /
              port: 8000
            initialDelaySeconds: 30
            timeoutSeconds: 30
          volumeMounts:
          - mountPath: /tmp
            name: tmp-volume
      serviceAccountName: kubernetes-dashboard
      # Comment the following tolerations if Dashboard must not be deployed on master
      tolerations:
        - key: node-role.kubernetes.io/master
          effect: NoSchedule
      volumes:
        - name: tmp-volume
          emptyDir: {}
---
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard
  namespace: kubernetes-dashboard
  annotations:
    kubernetes.io/ingress.class: traefik
    traefik.ingress.kubernetes.io/frontend-entry-points: http,https
    traefik.ingress.kubernetes.io/redirect-entry-point: https
spec:
  rules:
  - host: csdd.xxxx.com
    http:
      paths:
        - backend:
            serviceName: kubernetes-dashboard
            servicePort: 443
  tls:
   - secretName: dashboard-tls-cert
 # 創(chuàng)建kubernetes-dashboard 服務(wù)
 kubectl apply -f kubernetes-dashboard.yaml
 # 創(chuàng)建kubernetes-dashboard token 登錄
#  生成token
kubectl create sa dashboard-admin -n kube-system
 # 授權(quán)token 訪問權(quán)限
kubectl create clusterrolebinding dashboard-admin --clusterrole=cluster-admin --serviceaccount=kube-system:dashboard-admin
# 獲取token 
ADMIN_SECRET=$(kubectl get secrets -n kube-system | grep dashboard-admin | awk \\\'{print $1}\\\')
# 獲取dashboard.kubeconfig 使用token   值
DASHBOARD_LOGIN_TOKEN=$(kubectl describe secret -n kube-system ${ADMIN_SECRET} | grep -E \\\'^token\\\' | awk \\\'{print $2}\\\')
echo ${DASHBOARD_LOGIN_TOKEN}
# 設(shè)置集群參數(shù)
kubectl config set-cluster kubernetes \\\\
  --certificate-authority=/apps/work/k8s/cfssl/pki/k8s/k8s-ca.pem \\\\
  --embed-certs=true \\\\
  --server=${KUBE_APISERVER} \\\\
  --kubeconfig=dashboard.kubeconfig

# 設(shè)置客戶端認證參數(shù),使用上面創(chuàng)建的 Token
kubectl config set-credentials dashboard_user \\\\
  --token=${DASHBOARD_LOGIN_TOKEN} \\\\
  --kubeconfig=dashboard.kubeconfig

# 設(shè)置上下文參數(shù)
kubectl config set-context default \\\\
  --cluster=kubernetes \\\\
  --user=dashboard_user \\\\
  --kubeconfig=dashboard.kubeconfig

# 設(shè)置默認上下文
kubectl config use-context default --kubeconfig=dashboard.kubeconfig
# 綁定hosts
https://csdd.xxxx.com/#/overview?namespace=default
# kubernetes-dashboard 使用metrics 顯示cpu內(nèi)存資源 所有要部署metrics-server

metrics-server 部署

# 創(chuàng)建metrics-server-secrets.yaml
# base64 加密
cat metrics-server.pem|base64 | tr -d \\\'\\\\n\\\'
cat metrics-server-key.pem|base64 | tr -d \\\'\\\\n\\\'
vi metrics-server-secrets.yaml
apiVersion: v1
kind: Secret
metadata:
  labels:
    k8s-app: metrics-server
  name: metrics-server-certs
  namespace: kube-system
type: Opaque
data:
  metrics-server.pem: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUQ3VENDQXRXZ0F3SUJBZ0lVZmdGSjJSUTF6Y20ydndjazFQc1NzTXJtNnJJd0RRWUpLb1pJaHZjTkFRRUwKQlFBd2JqRUxNQWtHQTFVRUJoTUNRMDR4RWpBUUJnTlZCQWdUQ1VkMVlXNW5SRzl1WnpFU01CQUdBMVVFQnhNSgpSM1ZoYm1kYWFHOTFNUkF3RGdZRFZRUUtFd2RqYkhWemRHVnlNUkF3RGdZRFZRUUxFd2RqYkhWemRHVnlNUk13CkVRWURWUVFERXdwcmRXSmxjbTVsZEdWek1CNFhEVEU1TURreU1EQXhOREV3TUZvWERUSTVNRGt4TnpBeE5ERXcKTUZvd2NqRUxNQWtHQTFVRUJoTUNRMDR4RWpBUUJnTlZCQWdUQ1VkMVlXNW5SRzl1WnpFU01CQUdBMVVFQnhNSgpSM1ZoYm1kYWFHOTFNUkF3RGdZRFZRUUtFd2RqYkhWemRHVnlNUkF3RGdZRFZRUUxFd2RqYkhWemRHVnlNUmN3CkZRWURWUVFERXc1dFpYUnlhV056TFhObGNuWmxjakNDQVNJd0RRWUpLb1pJaHZjTkFRRUJCUUFEZ2dFUEFEQ0MKQVFvQ2dnRUJBTzIvZ1RTUERMOU94RUhmQTBtdmpFYWtLMUtrWmoxSDlMYXV0dFRQbS8xYlR5T2pSMFNxemFsZgpCSFJESlNkME5DOGlyZGRDcGtZWUVROVJBWWFIWldIb2ZLbDJ6eWpPSXZqc2JrVWJ0T2N4Q0R6dlNZcDBkaXRECnd4NGpuR2hmSGhrUUw1TWQwaEFQTm5rLzdkakxsQ0c2azlBN00wUHB6dEZZNWVOSWJmZG8wMFRMb2c1VjBIb3YKUTZ4TDRGQWwzbGhSRy9nRHYrdjBkSy9NVUJ3eWtaK2E1WlJJRk5hNE5sS2lac29QdVZ2WlpRek10VFJWLzBXbwp1NmlJZnVkcTB4eWk1dWIxSXFnbml0Wm5TN09ZeDBXWW0xV2VEZlIwbis1TU5oR3hTQ3c4bEM1QkVLU3I2a252Ckp6M0tHci95NzFrU2RsTWhHeVFxT09Ld2pkTmowQThDQXdFQUFhTi9NSDB3RGdZRFZSMFBBUUgvQkFRREFnV2cKTUIwR0ExVWRKUVFXTUJRR0NDc0dBUVVGQndNQkJnZ3JCZ0VGQlFjREFqQU1CZ05WSFJNQkFmOEVBakFBTUIwRwpBMVVkRGdRV0JCVHBBUm5VVmNOS1kzYWFOS0NNZXlNZnZ4aXFPREFmQmdOVkhTTUVHREFXZ0JRWkx0RG9rcm55CnJ4WUhEb2FZSlZQQVZKUDg0ekFOQmdrcWhraUc5dzBCQVFzRkFBT0NBUUVBT3AwWTg1ZjRCSXBscXQ2K3FDMFMKbm9DR2RiVVoyNUNpQ1hEUDBFTWNuQ1QzZzdiWTNGaUpSZDhkbGg1aVNncTRxUlR6N1hDeWhMb1VNVmJTRVVlZApvaEI2Vk90eGJ1azErKzhob2diUUtIQVZlbERjS1MyOGttclZHRXdsSGpjNG1pRUxIbHZ6K0xUYUZzdlYxMFlzCjROdmNMTEE3SVE5N3hMcFNvZURVek5LU2dzU3RQUmVSTW5DR1BMdE1MMFcxRHpjOHNFRWJsTm9sbEFYRWdKMU4KVkxmbHJxbWdxaTcyQmZHOTBFbEtmbVFMV3QwR0lKU0wwdmF2a0kxL0Z0NGFuV2RVT2Zqa3JmYzBpUnhxUVBVNQphRWN5cjF6MzhnZmR6c3ZtV1VuVnpMS0pNeGtPckV3NGZBWHJudmRFSm92YlhJeU9Rd2pqQjhNaklsWER2ZjRvCnN3PT0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo=
  metrics-server-key.pem: LS0tLS1CRUdJTiBSU0EgUFJJVkFURSBLRVktLS0tLQpNSUlFcFFJQkFBS0NBUUVBN2IrQk5JOE12MDdFUWQ4RFNhK01ScVFyVXFSbVBVZjB0cTYyMU0rYi9WdFBJNk5IClJLck5xVjhFZEVNbEozUTBMeUt0MTBLbVJoZ1JEMUVCaG9kbFllaDhxWGJQS000aStPeHVSUnUwNXpFSVBPOUoKaW5SMkswUERIaU9jYUY4ZUdSQXZreDNTRUE4MmVUL3QyTXVVSWJxVDBEc3pRK25PMFZqbDQwaHQ5MmpUUk11aQpEbFhRZWk5RHJFdmdVQ1hlV0ZFYitBTy82L1Iwcjh5UUhES1JuNXJsbEVnVTFyZzJVcUpteWcrNVc5bGxETXkxCk5GWC9SYWk3cUloKzUyclRIS0xtNXZVaXFDZUsxbWRMczVqSFJaaWJWWjROOUhTZjdrdzJFYkZJTER5VUxrRVEKcEt2cVNlOG5QY29hdi9MdldSSjJVeUViSkNvNDRyQ04wMlBRRHdJREFRQUJBb0lCQVFDV09RVW84cUo1VnduSApIV1QwY0VuUWNQYzIxczRMTnFZM3NCbXlTaVFrYUVlUEd5SnpEd0c0WFdOeEd1UWxFOVhOV3JwQlk4bXdUSkNxCi91Slo0TDk4cCt2dElEY3hiMTdGcm83V2QvVk1oN3pPMDl2QjhtaWdXY2EyQ29aUHBKcGQ5ODQzeFFYd1E4eUYKdkpGTEJRZHFjSHZwZlI2ZGNPVFBmcjV6YUZhamxvN3l4eWc5QTRpQ2xSRXUwNVAwNytTeWNiNndUbGJjVFlOeAo4ZU5DaUs5QTVCZXlYZVNmeEJJYmh4bHcrZ2kwdmV4RUxEOTJFWWZjVXNzZjlzT2sxZUhJVmpJNGZmQndodk5kCjhhbkVNRXJEd3pCc0ZGT2Z3Mkdya3hWSndoMXVEMkl4c253b3hjZ0RxWFI5dy9Wais3emhKZ2ZiWXFpT0FUVmUKQTZOeExHb3hBb0dCQVBhUk1ENHFqOGxwcEhnR3FjZWI0aHpaWkI4cG9maS9aUTIvNUl0aHlQV2FHMDlSRFkxZAowd1Z5dXFWb0RwalFWOENGU2U2RzZlQzNXSDRGVy9IMU9wKzVjSjBDT1B1MFJWMUV0eDlaL0I1U1Z2K3lQWU5RCm12Tm9qeWF2Mi9ZbnpuZDBGVkYrckJhT0lDZ0pxUVMvcnA0OGhmelVaWWsrNFlVVUdkeVBHUS85QW9HQkFQYlgKOGRKZjllcTgwN2lGTW9GTlFuODR4L1pUdVJ4N21obEJwaUhOa0tIUGZ1cHBCMFlMRDJQOWxhYkFGaWtZblY2SgpCQjZ1LzdMTm1mOFZHUjNVOEFiak0rZW43VkdVMkExcXIydTZ5ejRESWRTM040czRlVUw5QmZkYWQ4cGVkZis5Cks5SmQ3MmNSaFM2UUxYcmttZXZFOUpNYTF1VWpzeU1RaFQvK1g1LzdBb0dBWkt5ZGZSU1Z4eEJhZGlPS1dSVTkKK3JlTW1PaS8yTGdWUThyeFB6UDdBTVVlbDRFcHZtbnJ5cEt3d082KzN3aGFmQ0l3TUxObmRUaUhhbFUzMkpCZgprbTMrSEMyWEpMYlRoNlNSL0x3YUpDdE1tSFNuaHlGM1V5R0RLYkd1WjFDVGpkU1pDOEJqOVlXc2ZZeU1OWU1xCmdqT0dKZGgzYU5XQzhYcG1vTmJRemVVQ2dZRUF6M1VlWUZrV0xYc1YxZmJjUTUvVFMybEZaZGxuc25DUFNycksKRFk3ZkI1K0VZeTV5Vm9QbEkzeDAwZmlPcDJ0d2w0dEFVeWx3N2EydXg1dkx5QzYyckpNM2hISzJHZUttMGwvZgpud01XM2I5MEozcjB5NlZqQk5IeXViam5CTVh3RmtpL0U4YXU5a2piVGc4T3FrS0d1b2lGcFR6aGJ5Tlo0eFozClp4azY5UkVDZ1lFQW1qTVdrM0JlSy95ZVkrLytCcFVQVzRteWtlOXdHQnNIeUpPa0wyMllXT3lJYnJBMTdMY1QKZUFzNmtvRitMTjY3Q01UQk45Qm5zQnpYTURsQ3RhMjlCcDkyNWZraEpNU0VMajhWNUIwRmNVQXg2dlVEY2o4RAoxQlJBRWNpZjN5eFExd1ZkTUJnaFdEUkduZzFKREtRVXUwaWY1WkNDWkFyWnpCek95YUhreUE4PQotLS0tLUVORCBSU0EgUFJJVkFURSBLRVktLS0tLQo=
# resource-reader.yaml
vi resource-reader.yaml
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
  name: system:metrics-server
rules:
- apiGroups:
  - 
  resources:
  - pods
  - nodes
  - nodes/stats
  verbs:
  - get
  - list
  - watch
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
  name: system:metrics-server
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: system:metrics-server
subjects:
- kind: ServiceAccount
  name: metrics-server
  namespace: kube-system
# metrics-server-service.yaml
vi metrics-server-service.yaml
---
apiVersion: v1
kind: Service
metadata:
  name: metrics-server
  namespace: kube-system
  labels:
    kubernetes.io/name: Metrics-server
spec:
  selector:
    k8s-app: metrics-server
  ports:
  - port: 443
    protocol: TCP
    targetPort: 443
# metrics-apiservice.yaml
vi metrics-apiservice.yaml
---
apiVersion: apiregistration.k8s.io/v1beta1
kind: APIService
metadata:
  name: v1beta1.metrics.k8s.io
spec:
  service:
    name: metrics-server
    namespace: kube-system
  group: metrics.k8s.io
  version: v1beta1
  insecureSkipTLSVerify: true
  groupPriorityMinimum: 100
  versionPriority: 100

# auth-reader.yaml
vi auth-reader.yaml
---
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: RoleBinding
metadata:
  name: metrics-server-auth-reader
  namespace: kube-system
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: Role
  name: extension-apiserver-authentication-reader
subjects:
- kind: ServiceAccount
  name: metrics-server
  namespace: kube-system

#  auth-delegator.yaml
vi auth-delegator.yaml
---
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: ClusterRoleBinding
metadata:
  name: metrics-server:system:auth-delegator
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: system:auth-delegator
subjects:
- kind: ServiceAccount
  name: metrics-server
  namespace: kube-system
# aggregated-metrics-reader.yaml
vi aggregated-metrics-reader.yaml
kind: ClusterRole
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  name: system:aggregated-metrics-reader
  labels:
    rbac.authorization.k8s.io/aggregate-to-view: true
    rbac.authorization.k8s.io/aggregate-to-edit: true
    rbac.authorization.k8s.io/aggregate-to-admin: true
rules:
- apiGroups: [metrics.k8s.io]
  resources: [pods]
  verbs: [get, list, watch]

# metrics-server-deployment.yaml
vi  metrics-server-deployment.yaml
---
apiVersion: v1
kind: ServiceAccount
metadata:
  name: metrics-server
  namespace: kube-system
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: metrics-server
  namespace: kube-system
  labels:
    k8s-app: metrics-server
spec:
  selector:
    matchLabels:
      k8s-app: metrics-server
  template:
    metadata:
      name: metrics-server
      labels:
        k8s-app: metrics-server
    spec:
      serviceAccountName: metrics-server
      tolerations:
        - effect: NoSchedule
          key: node.kubernetes.io/unschedulable
          operator: Exists
        - key: NoSchedule
          operator: Exists
          effect: NoSchedule
      volumes:
      # mount in tmp so we can safely use from-scratch images and/or read-only containers
      - name: tmp-dir
        emptyDir: {}
      - name: metrics-server-certs
        secret:
          secretName: metrics-server-certs
      containers:
      - name: metrics-server
        image: juestnow/metrics-server-amd64:v0.3.4
        imagePullPolicy: Always
        command:
        - /metrics-server
        - --tls-cert-file=/certs/metrics-server.pem
        - --tls-private-key-file=/certs/metrics-server-key.pem
        - --kubelet-preferred-address-types=InternalIP,Hostname,InternalDNS,ExternalDNS,ExternalIP
        - --kubelet-insecure-tls
        volumeMounts:
        - name: tmp-dir
          mountPath: /tmp
        - name: metrics-server-certs
          mountPath: /certs
# 創(chuàng)建metrics-server 服務(wù)
# 創(chuàng)建metrics-server 服務(wù)
kubectl apply -f .
# 驗證metrics-server 
kubectl top node
root@]~/work]#kubectl top node
NAME      CPU(cores)   CPU%   MEMORY(bytes)   MEMORY%
master    162m         6%     957Mi           16%
master2   155m         2%     591Mi           4%
[root@]~/work]#kubectl top pods -A
NAMESPACE              NAME                                         CPU(cores)   MEMORY(bytes)
kube-system            coredns-9d5b6bdb6-phcwt                      6m           11Mi
kube-system            kube-flannel-ds-amd64-6bpf7                  3m           11Mi
kube-system            kube-flannel-ds-amd64-6sxz2                  4m           12Mi
kube-system            metrics-server-668c6bb96b-z7nfl              1m           14Mi
kube-system            traefik-zkhd2                                8m           23Mi
kube-system            traefik-zs6h3                                5m           21Mi
kubernetes-dashboard   dashboard-metrics-scraper-566cddb686-sft6k   7m           12Mi
kubernetes-dashboard   kubernetes-dashboard-6cd89cd7df-nlkzj        18m          29Mi

更多關(guān)于云服務(wù)器域名注冊,虛擬主機的問題,請訪問西部數(shù)碼官網(wǎng):m.youyuetrip.com

贊(0)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享網(wǎng)絡(luò)內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-62778877-8306;郵箱:fanjiao@west.cn。本站原創(chuàng)內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明出處:西部數(shù)碼知識庫 » 二進制方式部署kubernetes 1.16.0

登錄

找回密碼

注冊

韩国爱爱视频中文字幕| 免费在线黄色观看网站| 丝袜美腿视频诱惑亚洲无 | 亚洲无码一区在线影院| 92福利视频午夜1000看| 亚洲熟女综合色一区二区三区四区| 国产欧美精品不卡在线| japanese五十路熟女熟妇| 欧美日本在线观看一区二区 | 欧美精品资源在线观看| 欧美另类一区二区视频| 91av中文视频在线| 在线可以看的视频你懂的| 亚洲一级av大片免费观看| 精品一区二区三四区| 日本乱人一区二区三区| 国产熟妇一区二区三区av| 中文亚洲欧美日韩无线码| 久久这里只有精品热视频| 少妇人妻久久久久视频黄片| 久久久久久久久久性潮| 熟女人妻在线中出观看完整版| 老司机在线精品福利视频| 一区二区视频视频视频| 亚洲欧美国产综合777| 久久久精品精品视频视频| 免费人成黄页网站在线观看国产 | 91精品免费久久久久久| 大学生A级毛片免费视频| 大鸡巴后入爆操大屁股美女| 综合一区二区三区蜜臀| 和邻居少妇愉情中文字幕| 午夜精品在线视频一区| 黄网十四区丁香社区激情五月天 | 婷婷激情四射在线观看视频| 天码人妻一区二区三区在线看 | av中文字幕在线导航| 一区二区三区蜜臀在线| 亚洲一区久久免费视频| 91色九色porny| 中字幕人妻熟女人妻a62v网| 黄色资源视频网站日韩| 超碰在线中文字幕一区二区| 狠狠操操操操操操操操操| 九一传媒制片厂视频在线免费观看| 国产精品精品精品999| 水蜜桃一区二区三区在线观看视频| 亚洲福利精品视频在线免费观看| 欧美亚洲一二三区蜜臀| 国产精品久久久久久美女校花| 亚洲1区2区3区精华液| 亚洲美女美妇久久字幕组| 精品一区二区三区三区色爱| 硬鸡巴动态操女人逼视频| 一区二区三区的久久的蜜桃的视频| sspd152中文字幕在线| 少妇人妻100系列| 熟女91pooyn熟女| av成人在线观看一区| 国产精品精品精品999| 亚洲福利天堂久久久久久| 精品91自产拍在线观看一区| 色花堂在线av中文字幕九九| 阴茎插到阴道里面的视频| 春色激情网欧美成人| 国产精品sm调教视频| 又大又湿又爽又紧A视频| aiss午夜免费视频| 狠狠躁夜夜躁人人爽天天天天97| 免费看国产又粗又猛又爽又黄视频| 欧美一区二区三区在线资源| 久久精品亚洲国产av香蕉| 中文字幕人妻av在线观看| 五月精品丁香久久久久福利社| 欧美交性又色又爽又黄麻豆| 亚洲人妻30pwc| 国产福利小视频免费观看| 狠狠躁夜夜躁人人爽天天久天啪| 欲乱人妻少妇在线视频裸| 亚洲精品色在线观看视频| 97国产福利小视频合集| 中文字幕日韩精品就在这里| 伊人综合aⅴ在线网| 五月天色婷婷在线观看视频免费| 337p日本大胆欧美人| 熟女人妻在线中出观看完整版| 老司机免费福利视频网| 姐姐的朋友2在线观看中文字幕| 美女福利视频导航网站| 欲满人妻中文字幕在线| 精品久久久久久久久久久久人妻| 97精品成人一区二区三区| 老有所依在线观看完整版| 日美女屁股黄邑视频| 自拍偷拍 国产资源| 免费无毒热热热热热热久| 中文字幕在线乱码一区二区| 亚洲精品无码久久久久不卡| 亚洲变态另类色图天堂网| 成人高清在线观看视频| 国产一区成人在线观看视频| 喷水视频在线观看这里只有精品| heyzo蜜桃熟女人妻| 亚洲av自拍偷拍综合| 欧美少妇性一区二区三区| 国产福利小视频大全| 欧美黑人与人妻精品| 中国无遮挡白丝袜二区精品| 亚洲精品一区二区三区老狼| 亚洲最大免费在线观看| 91精品国产黑色丝袜| 老鸭窝日韩精品视频观看| 成熟丰满熟妇高潮xx×xx | 中文字幕一区的人妻欧美日韩| 一区二区三区激情在线| 成人免费公开视频无毒 | 亚洲福利精品福利精品福利 | 综合页自拍视频在线播放| 四川五十路熟女av| 天天摸天天亲天天舔天天操天天爽| 一区二区在线视频中文字幕| 精品首页在线观看视频| 免费观看污视频网站| 免费一级特黄特色大片在线观看 | 国产在线观看黄色视频| 日本高清撒尿pissing| 亚洲免费在线视频网站| 国产在线免费观看成人| 青娱乐最新视频在线| av亚洲中文天堂字幕网| 亚洲欧洲一区二区在线观看| 丝袜美腿欧美另类 中文字幕| 中文字幕日韩精品日本| 中文字幕日韩人妻在线三区| 天天日夜夜操天天摸| 最新激情中文字幕视频| 国产麻豆国语对白露脸剧情| 偷拍3456eee| 日本韩国亚洲综合日韩欧美国产| 日韩人妻xxxxx| 国产精品成人xxxx| 玖玖一区二区在线观看| av俺也去在线播放| 午夜精品亚洲精品五月色| 色综合久久无码中文字幕波多| 大香蕉大香蕉大香蕉大香蕉大香蕉| 亚洲男人在线天堂网| 国产成人小视频在线观看无遮挡| 亚洲另类伦春色综合小| 黄片三级三级三级在线观看| 亚洲在线免费h观看网站| 一色桃子人妻一区二区三区| 一区二区三区毛片国产一区| 欧美成人猛片aaaaaaa| 日韩一区二区三区三州| 黄色中文字幕在线播放| 久草视频在线看免费| 边摸边做超爽毛片18禁色戒 | 播放日本一区二区三区电影| 2020av天堂网在线观看| 欧美爆乳肉感大码在线观看| 一本一本久久a久久精品综合不卡| 欧美在线偷拍视频免费看| 亚洲一区av中文字幕在线观看| 精品成人午夜免费看| 韩国三级aaaaa高清视频| 中文字幕在线第一页成人| 五十路熟女人妻一区二| 亚洲老熟妇日本老妇| 白白操白白色在线免费视频| 成人H精品动漫在线无码播放| 我想看操逼黄色大片| 中英文字幕av一区| 久久久久久国产精品| 亚洲欧美另类自拍偷拍色图| 少妇人妻真实精品视频| 黄色无码鸡吧操逼视频| 色婷婷久久久久swag精品| 亚洲天堂第一页中文字幕| 亚洲人妻国产精品综合| 国产在线拍揄自揄视频网站| 天天色天天操天天舔| 欧美亚洲免费视频观看| 老有所依在线观看完整版| 激情综合治理六月婷婷| 天天操天天干天天艹| 哥哥姐姐综合激情小说| 五月天色婷婷在线观看视频免费| 国产品国产三级国产普通话三级| 男女第一次视频在线观看| 男人的网址你懂的亚洲欧洲av| 国产日本精品久久久久久久| 综合色区亚洲熟妇shxstz| 在线视频精品你懂的| 第一福利视频在线观看| 好太好爽好想要免费| 狠狠嗨日韩综合久久| 又粗又硬又猛又黄免费30| 国产 在线 免费 精品| 成年人黄色片免费网站| 亚洲天堂有码中文字幕视频 | 国产一区自拍黄视频免费观看| 黄片色呦呦视频免费看| 97人人妻人人澡人人爽人人精品| japanese五十路熟女熟妇| 国产高清97在线观看视频| 天天干天天操天天爽天天摸| 啊啊啊视频试看人妻| 国产精品人妻一区二区三区网站| 99热99re在线播放| 懂色av蜜桃a v| 午夜在线观看一区视频| 91精品激情五月婷婷在线| 一本久久精品一区二区| 免费福利av在线一区二区三区| 青青青青在线视频免费观看| 色吉吉影音天天干天天操| 人妻少妇亚洲精品中文字幕| 成人av久久精品一区二区| 91在线免费观看成人| 天天日天天敢天天干| jul—619中文字幕在线| 亚洲第17页国产精品| 午夜的视频在线观看| 日韩欧美国产一区不卡| 瑟瑟视频在线观看免费视频| 91精品免费久久久久久| 亚洲一区二区激情在线| 中国视频一区二区三区| 精品一区二区三区欧美| 欧美综合婷婷欧美综合| 久久麻豆亚洲精品av| 亚洲在线免费h观看网站| 亚洲综合另类精品小说| 大肉大捧一进一出好爽在线视频 | 国产视频精品资源网站| 天天干天天啪天天舔| 美女骚逼日出水来了| 国产免费av一区二区凹凸四季| 91色九色porny| 成人高清在线观看视频| 精品首页在线观看视频| 中文字幕人妻av在线观看| 欧美黑人性猛交xxxxⅹooo| 久久久久五月天丁香社区| 亚洲男人的天堂a在线| 亚洲卡1卡2卡三卡四老狼| 中国老熟女偷拍第一页| 亚洲精品ww久久久久久| 欧美日韩国产一区二区三区三州| 超碰公开大香蕉97| 日本一道二三区视频久久| 蜜桃视频入口久久久| 婷婷六月天中文字幕| asmr福利视频在线观看| 蝴蝶伊人久久中文娱乐网| 人妻丝袜榨强中文字幕| 999久久久久999| 欧美第一页在线免费观看视频| 欧美aa一级一区三区四区| 中文字幕人妻av在线观看| 国产亚洲成人免费在线观看 | 亚洲欧美综合在线探花| 亚洲偷自拍高清视频| 人妻丝袜诱惑我操她视频| 亚洲精品国品乱码久久久久| 日本一区二区三区免费小视频| 深夜男人福利在线观看| 国产乱子伦一二三区| 熟女人妻在线观看视频| 国产91久久精品一区二区字幕| 国产高清女主播在线| 宅男噜噜噜666国产| 青娱乐极品视频青青草| 专门看国产熟妇的网站| 性感美女高潮视频久久久| 国产极品美女久久久久久| 亚洲精品精品国产综合| 亚洲图库另类图片区| 超碰在线观看免费在线观看| 在线观看国产网站资源| 亚洲特黄aaaa片| 成人18禁网站在线播放| 国产日韩欧美视频在线导航| 精品av国产一区二区三区四区| 天天综合天天综合天天网| 精品首页在线观看视频| 亚洲av色图18p| 国产高清精品极品美女| 99热国产精品666| 国产精品sm调教视频| 制服丝袜在线人妻中文字幕| 大香蕉大香蕉在线看| 97资源人妻免费在线视频| 在线视频这里只有精品自拍| 免费观看成年人视频在线观看| 亚洲免费在线视频网站| 91天堂天天日天天操| 国产91嫩草久久成人在线视频| 日韩精品激情在线观看| 国产精品sm调教视频| 不戴胸罩引我诱的隔壁的人妻| 91桃色成人网络在线观看| 在线视频这里只有精品自拍| 粉嫩av蜜乳av蜜臀| 日本真人性生活视频免费看| 中文字幕 人妻精品| 夜夜骑夜夜操夜夜奸| 欧美亚洲免费视频观看| 香港三日本三韩国三欧美三级| 亚洲av可乐操首页| 国产+亚洲+欧美+另类| 国产精品女邻居小骚货| 五月精品丁香久久久久福利社| 丝袜美腿欧美另类 中文字幕| aⅴ精产国品一二三产品| 久久永久免费精品人妻专区| 蜜臀成人av在线播放| 蜜桃久久久久久久人妻| 精品一线二线三线日本| 亚洲va国产va欧美精品88| 久久h视频在线观看| 国产亚洲欧美另类在线观看| 大陆精品一区二区三区久久| 91老熟女连续高潮对白| 男生舔女生逼逼的视频| 亚洲一区二区激情在线| 日本一区美女福利视频| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 欧美性感尤物人妻在线免费看| 亚洲1069综合男同| 亚洲精品亚洲人成在线导航| 日本福利午夜电影在线观看| 一区二区三区久久中文字幕| 日韩在线视频观看有码在线| 人妻丰满熟妇综合网| 在线免费观看日本伦理| 久久精品亚洲成在人线a| 青青青国产免费视频| 黄色大片免费观看网站| 一个色综合男人天堂| 天天通天天透天天插| 国产综合高清在线观看| 国产精品手机在线看片| 3337p日本欧洲大胆色噜噜| 亚洲欧美自拍另类图片| 9国产精品久久久久老师| 在线可以看的视频你懂的 | 女同互舔一区二区三区| 黑人解禁人妻叶爱071| 久久农村老妇乱69系列| 国产精品自偷自拍啪啪啪| 天天干天天插天天谢| 亚洲午夜在线视频福利| 天天日天天干天天要| 欧美一区二区三区高清不卡tv| 国产在线观看免费人成短视频| 青青草人人妻人人妻| 天天日天天干天天舔天天射| 97香蕉碰碰人妻国产樱花| 中文字幕av男人天堂| 玩弄人妻熟妇性色av少妇| 欧美黑人与人妻精品| 男人天堂最新地址av| 亚洲一区制服丝袜美腿| 日韩亚洲高清在线观看| 免费国产性生活视频| 偷拍3456eee| 欧美xxx成人在线| 欧美视频一区免费在线| 亚洲激情,偷拍视频| 久草福利电影在线观看| 免费看美女脱光衣服的视频| 秋霞午夜av福利经典影视| 成人性爱在线看四区| 久久综合老鸭窝色综合久久| 国产97视频在线精品| 色噜噜噜噜18禁止观看| 人妻熟女中文字幕aⅴ在线| 亚洲免费va在线播放| 99国产精品窥熟女精品| 日韩二区视频一线天婷婷五| 国产黄色大片在线免费播放| 成年人午夜黄片视频资源| 亚洲日本一区二区三区| 国产剧情演绎系列丝袜高跟| 国产剧情演绎系列丝袜高跟| 亚洲的电影一区二区三区| 狠狠躁夜夜躁人人爽天天久天啪| 91国语爽死我了不卡| 2017亚洲男人天堂| 黄色录像鸡巴插进去| 欧美aa一级一区三区四区| 国产精品国产三级国产午| www日韩毛片av| 91国语爽死我了不卡| 一区二区三区日韩久久| 国产V亚洲V天堂无码欠欠| 久久永久免费精品人妻专区| 午夜精品一区二区三区更新| 青青青视频自偷自拍38碰| 999热精品视频在线| 97人妻无码AV碰碰视频| 91超碰青青中文字幕| 动漫精品视频在线观看| 国产极品精品免费视频| 欧美韩国日本国产亚洲| 美味人妻2在线播放| 熟女人妻在线观看视频| 日本福利午夜电影在线观看| 晚上一个人看操B片| 亚洲成人国产综合一区| 亚洲麻豆一区二区三区| 欧美成一区二区三区四区| 日韩人妻xxxxx| 天码人妻一区二区三区在线看| 2021久久免费视频| 亚洲av人人澡人人爽人人爱| 97精品综合久久在线| 亚洲成人情色电影在线观看 | 在线观看视频网站麻豆| 女同久久精品秋霞网| 日日夜夜大香蕉伊人| 综合一区二区三区蜜臀| 日本福利午夜电影在线观看| 天堂女人av一区二区| 欧美一级视频一区二区| 91精品国产高清自在线看香蕉网 | 中文字幕一区的人妻欧美日韩| 国产午夜男女爽爽爽爽爽视频| 日韩av大胆在线观看| 黄色大片免费观看网站| 极品性荡少妇一区二区色欲| 亚洲精品国产久久久久久| 中国熟女@视频91| 人妻少妇性色欲欧美日韩| 香港一级特黄大片在线播放| 日本午夜爽爽爽爽爽视频在线观看 | 国产中文字幕四区在线观看| 女生自摸在线观看一区二区三区| 久草视频在线一区二区三区资源站| 中文字幕在线欧美精品| 超碰中文字幕免费观看| 在线观看av观看av| 免费观看丰满少妇做受| 亚洲精品乱码久久久久久密桃明 | 免费观看污视频网站| 大鸡巴操b视频在线| 亚洲熟妇久久无码精品| 日韩近亲视频在线观看| 美女骚逼日出水来了| 熟女在线视频一区二区三区| 亚洲va国产va欧美va在线| 欧美一区二区三区高清不卡tv| 日韩美在线观看视频黄| 清纯美女在线观看国产| 日本一区精品视频在线观看| 青青青青青操视频在线观看| 日本丰满熟妇BBXBBXHD| 好太好爽好想要免费| 亚洲精品乱码久久久本| 视频在线免费观看你懂得| 亚洲自拍偷拍综合色| 自拍偷区二区三区麻豆| 丁香花免费在线观看中文字幕| 亚洲一区二区三区精品视频在线 | 青青青青青青草国产| 青青草原色片网站在线观看| 日韩加勒比东京热二区| 九色porny九色9l自拍视频| 亚洲熟女女同志女同| 免费啪啪啪在线观看视频| 操日韩美女视频在线免费看| 日本少妇在线视频大香蕉在线观看| 美女操逼免费短视频下载链接| 专门看国产熟妇的网站| 亚洲公开视频在线观看| 一区二区三区精品日本| 插逼视频双插洞国产操逼插洞| 成人国产激情自拍三区| 国产成人小视频在线观看无遮挡| 欧美交性又色又爽又黄麻豆| 在线观看黄色成年人网站| 欧洲欧美日韩国产在线| 午夜dv内射一区区| 久久精品36亚洲精品束缚| 精品老妇女久久9g国产| 日本性感美女写真视频| 亚洲午夜精品小视频| 91桃色成人网络在线观看| 日韩人妻xxxxx| 免费在线看的黄网站| 超碰在线观看免费在线观看| 亚洲嫩模一区二区三区| 农村胖女人操逼视频| 亚洲欧美色一区二区| 欧美另类重口味极品在线观看| 亚洲av黄色在线网站| 欧美一区二区三区啪啪同性| 亚洲无线观看国产高清在线| 色伦色伦777国产精品| 久久丁香花五月天色婷婷| 国产污污污污网站在线| 午夜在线一区二区免费| 中文字幕午夜免费福利视频| av网址国产在线观看| 人妻在线精品录音叫床| 黑人变态深video特大巨大| 一区二区三区四区五区性感视频| 日本三极片视频网站观看| 老司机99精品视频在线观看| 3344免费偷拍视频| 最新中文字幕乱码在线| 最新91精品视频在线| 国产在线观看免费人成短视频| 蜜桃视频17c在线一区二区| 黑人借宿ntr人妻的沦陷2| 全国亚洲男人的天堂| 亚洲国产美女一区二区三区软件 | 国产高清女主播在线| 男生舔女生逼逼的视频| 91极品新人『兔兔』精品新作| 在线国产精品一区二区三区| av在线免费中文字幕| 啪啪啪啪啪啪啪啪啪啪黄色| 狠狠鲁狠狠操天天晚上干干| 搡老熟女一区二区在线观看| 亚洲av第国产精品| 欧美亚洲中文字幕一区二区三区| 91麻豆精品传媒国产黄色片| 精品老妇女久久9g国产| 91精品资源免费观看| 色天天天天射天天舔| 一区二区三区的久久的蜜桃的视频| 国产午夜无码福利在线看| 国产精品国产三级麻豆| 沙月文乃人妻侵犯中文字幕在线| 夜夜骑夜夜操夜夜奸| 国产精品三级三级三级| 动漫av网站18禁| 综合一区二区三区蜜臀| 日韩三级电影华丽的外出| 亚洲成人国产综合一区| 欧美专区日韩专区国产专区| av网址在线播放大全| 国产janese在线播放| 在线免费观看日本伦理| 18禁美女黄网站色大片下载| 国产无遮挡裸体免费直播视频| 搞黄色在线免费观看| 午夜极品美女福利视频| 国产真实乱子伦a视频| 搡老妇人老女人老熟女| 欧美一区二区中文字幕电影| 亚洲精品国产在线电影| 日韩视频一区二区免费观看| 亚洲1区2区3区精华液| 91亚洲手机在线视频播放| 9色在线视频免费观看| 日韩精品激情在线观看| 视频二区在线视频观看| 亚洲午夜精品小视频| 亚洲精品一线二线在线观看| 视频一区 二区 三区 综合| 日韩av大胆在线观看| 国产女孩喷水在线观看| 青青草精品在线视频观看| 午夜精品九一唐人麻豆嫩草成人| 亚洲精品ww久久久久久| 日本成人一区二区不卡免费在线| 熟女少妇激情五十路| 欧美综合婷婷欧美综合| 色伦色伦777国产精品| 亚洲综合自拍视频一区| 粉嫩av蜜乳av蜜臀| 免费男阳茎伸入女阳道视频| 97国产福利小视频合集| 免费黄高清无码国产| 一二三中文乱码亚洲乱码one | 免费在线观看视频啪啪| 国产亚州色婷婷久久99精品| 操的小逼流水的文章| 亚洲一区二区三区久久午夜| 欧美综合婷婷欧美综合| 青青青国产免费视频| 日本成人一区二区不卡免费在线| 国产精品污污污久久| 亚洲美女高潮喷浆视频| 亚洲一级av大片免费观看| 57pao国产一区二区| 午夜在线观看岛国av,com| 白白操白白色在线免费视频| 91亚洲精品干熟女蜜桃频道| 天天摸天天日天天操| av手机免费在线观看高潮| 亚洲国际青青操综合网站| 久久久久久久久久久久久97| 韩国女主播精品视频网站| 天天摸天天日天天操| 国产成人精品一区在线观看| 欧美老鸡巴日小嫩逼| 久精品人妻一区二区三区| 国产91嫩草久久成人在线视频| 亚洲一区二区三区在线高清| 天天日夜夜干天天操| 久久美欧人妻少妇一区二区三区| 国产熟妇人妻ⅹxxxx麻豆| 99热久久这里只有精品| 精品区一区二区三区四区人妻| 91麻豆精品秘密入口在线观看| 中文字幕免费在线免费| 欧美亚洲免费视频观看| 亚洲中文字幕乱码区| 黄色成人在线中文字幕| 国产真实乱子伦a视频| 超碰97免费人妻麻豆| 自拍 日韩 欧美激情| 中国无遮挡白丝袜二区精品 | 久久三久久三久久三久久| 天码人妻一区二区三区在线看| 一本久久精品一区二区| 中出中文字幕在线观看| 综合页自拍视频在线播放| 美女吃鸡巴操逼高潮视频| 视频在线亚洲一区二区| 日本18禁久久久久久| 国产熟妇一区二区三区av| 99精品视频之69精品视频 | 在线免费观看日本伦理| 精品人妻伦一二三区久| 国产黑丝高跟鞋视频在线播放 | 亚洲熟妇无码一区二区三区| 天天日天天舔天天射进去| 亚洲天堂精品久久久| 黄网十四区丁香社区激情五月天| av中文字幕网址在线| ka0ri在线视频| 亚洲男人在线天堂网| 亚洲一区二区三区av网站| 国产亚洲精品品视频在线| 视频久久久久久久人妻| 亚洲最大免费在线观看| 黄色录像鸡巴插进去| 亚洲美女自偷自拍11页| 亚洲av色图18p| 日本免费一级黄色录像| 最近的中文字幕在线mv视频| 人妻丝袜诱惑我操她视频| 偷拍自拍亚洲视频在线观看| 亚洲成人情色电影在线观看| 免费岛国喷水视频在线观看| 激情人妻校园春色亚洲欧美 | 国产精品黄色的av| 9色精品视频在线观看| 欧美一区二区三区乱码在线播放| 成年人黄视频在线观看| 一区二区三区精品日本| 色狠狠av线不卡香蕉一区二区| 青草久久视频在线观看| 偷偷玩弄新婚人妻h视频| 亚洲图库另类图片区| 午夜在线一区二区免费| 国产精品人妻一区二区三区网站| 天天插天天色天天日| 馒头大胆亚洲一区二区| 在线免费观看国产精品黄色| 亚洲av午夜免费观看| 国产激情av网站在线观看| 99精品国自产在线人| 美女在线观看日本亚洲一区| 国产在线观看免费人成短视频| 国产又大又黄免费观看| 亚洲嫩模一区二区三区| 新婚人妻聚会被中出| 少妇与子乱在线观看| 狠狠鲁狠狠操天天晚上干干| 亚洲av色香蕉一区二区三区| 岛国免费大片在线观看| 家庭女教师中文字幕在线播放| 93精品视频在线观看| 大骚逼91抽插出水视频| 国产一区二区视频观看| 久久久极品久久蜜桃| 午夜毛片不卡在线看| 无忧传媒在线观看视频| 亚洲精品在线资源站| 婷婷色国产黑丝少妇勾搭AV| 91天堂天天日天天操| 亚洲成人情色电影在线观看| 亚欧在线视频你懂的| 黄色av网站免费在线| www天堂在线久久| 国产精品黄页网站视频| 3D动漫精品啪啪一区二区下载| 成人久久精品一区二区三区| 成人av电影免费版| 欧美另类重口味极品在线观看| 日韩精品二区一区久久| 国产一区二区视频观看| 成年人黄视频在线观看| 国产超码片内射在线| 天堂女人av一区二区| 青青热久免费精品视频在线观看 | 国产午夜男女爽爽爽爽爽视频| 久久久久久久久久久免费女人| 99热色原网这里只有精品| 玩弄人妻熟妇性色av少妇| 欧美成一区二区三区四区| 欧美综合婷婷欧美综合| 91成人精品亚洲国产| 亚洲熟女久久久36d| 91人妻精品久久久久久久网站 | 97人妻无码AV碰碰视频| yellow在线播放av啊啊啊| 亚洲 欧美 精品 激情 偷拍| 亚洲公开视频在线观看| 国产一线二线三线的区别在哪 | 天天操,天天干,天天射| 2018在线福利视频| 亚洲精品国偷自产在线观看蜜桃| 一区二区三区精品日本| 啊啊啊想要被插进去视频| 日本最新一二三区不卡在线| tube69日本少妇| 日韩一个色综合导航| 美女日逼视频免费观看| 夜女神免费福利视频| 天天操天天弄天天射| 亚洲一级 片内射视正片| 曰本无码人妻丰满熟妇啪啪| 精品亚洲中文字幕av| 国产午夜男女爽爽爽爽爽视频| 欧美黑人性暴力猛交喷水| 精彩视频99免费在线| 亚洲少妇高潮免费观看| 国产精品三级三级三级| 日本少妇精品免费视频| 班长撕开乳罩揉我胸好爽| 国产精品久久综合久久| 欧美久久久久久三级网| 亚洲粉嫩av一区二区三区| 国产乱弄免费视频观看| 国产在线拍揄自揄视频网站| 亚洲av自拍天堂网| 欧美伊人久久大香线蕉综合| 国产黄色高清资源在线免费观看| 亚洲精品一区二区三区老狼| 日本人妻精品久久久久久| 亚洲欧美福利在线观看| 黄色片一级美女黄色片| 亚洲精品乱码久久久本| 99精品国产aⅴ在线观看| 最新91九色国产在线观看| 揄拍成人国产精品免费看视频| 亚洲成人国产av在线| 精品人妻伦一二三区久 | 国产三级片久久久久久久| 97精品人妻一区二区三区精品| 成人蜜臀午夜久久一区| 馒头大胆亚洲一区二区| 国产一区二区久久久裸臀| 精品人妻一二三区久久| 一区二区三区四区视频在线播放 | 中国黄片视频一区91| 99精品免费久久久久久久久a| 在线网站你懂得老司机| 日韩成人性色生活片| 欧美黑人巨大性xxxxx猛交| 中字幕人妻熟女人妻a62v网 | 国产精品黄片免费在线观看| 免费无码人妻日韩精品一区二区| 成年人免费看在线视频| 视频 一区二区在线观看| av成人在线观看一区| 无忧传媒在线观看视频| 激情综合治理六月婷婷| 亚洲av色图18p| 欧美精产国品一二三产品价格 | 东京热男人的av天堂| 欧美一区二区三区高清不卡tv| 欧美亚洲偷拍自拍色图| 美女视频福利免费看| 香蕉片在线观看av| 精品久久婷婷免费视频| av中文字幕在线导航| 被大鸡吧操的好舒服视频免费| 91老师蜜桃臀大屁股| 午夜精品在线视频一区| 日韩欧美在线观看不卡一区二区| av视屏免费在线播放| 国产精彩福利精品视频| 日本福利午夜电影在线观看| 国产午夜无码福利在线看| 中文字幕av男人天堂| 一区二区三区美女毛片| 中文字幕人妻熟女在线电影| 人人人妻人人澡人人| 爆乳骚货内射骚货内射在线 | 姐姐的朋友2在线观看中文字幕| 天天躁日日躁狠狠躁躁欧美av| 欧美老鸡巴日小嫩逼| 我想看操逼黄色大片| 中国把吊插入阴蒂的视频| 亚洲第17页国产精品| 久久免费看少妇高潮完整版| 亚洲第17页国产精品| 日韩写真福利视频在线观看| 老熟妇凹凸淫老妇女av在线观看| 黑人大几巴狂插日本少妇| 久久久久久性虐视频| 亚洲自拍偷拍综合色| 亚洲一区制服丝袜美腿| 人人妻人人爽人人澡人人精品| 天天躁日日躁狠狠躁躁欧美av| 中文字幕人妻三级在线观看| 自拍偷拍亚洲欧美在线视频| 国产一级麻豆精品免费| 欧美亚洲免费视频观看| 5528327男人天堂| 天天日天天日天天擦| 国产va在线观看精品| 狠狠地躁夜夜躁日日躁| 亚洲美女美妇久久字幕组| 国产性色生活片毛片春晓精品| 岛国免费大片在线观看 | 久久久91蜜桃精品ad| 男生用鸡操女生视频动漫| 早川濑里奈av黑人番号| 中国无遮挡白丝袜二区精品| 在线国产日韩欧美视频| 亚洲av琪琪男人的天堂| 中文字幕日韩91人妻在线| 成人av电影免费版| 日本熟妇喷水xxx| yy6080国产在线视频| 51国产成人精品视频| 成人国产激情自拍三区| 成年午夜免费无码区| 人妻丰满熟妇综合网| 91国偷自产一区二区三区精品| 亚洲激情,偷拍视频| 性感美女福利视频网站| 日本18禁久久久久久| 九九视频在线精品播放| 亚洲欧美激情国产综合久久久| 人妻无码色噜噜狠狠狠狠色| 亚洲熟女久久久36d| 亚洲高清国产拍青青草原| gogo国模私拍视频| 秋霞午夜av福利经典影视| 一区二区三区的久久的蜜桃的视频| 日韩欧美一级黄片亚洲| 欧美日韩v中文在线| 色综合久久无码中文字幕波多| 免费无毒热热热热热热久| 国产一区成人在线观看视频 | 欧美日韩不卡一区不区二区| 欧美精品黑人性xxxx| 午夜美女少妇福利视频| 91人妻精品一区二区在线看 | 日本熟女50视频免费| 青青青青草手机在线视频免费看| 在线观看免费视频网| av久久精品北条麻妃av观看| 人妻熟女中文字幕aⅴ在线| 亚洲av日韩高清hd| 亚洲 欧美 精品 激情 偷拍| av中文字幕在线导航| 日本午夜久久女同精女女| 色哟哟在线网站入口| 中文字幕网站你懂的| 中文字幕亚洲久久久| 伊人精品福利综合导航| 黑人进入丰满少妇视频| 国产午夜无码福利在线看| 亚洲va国产va欧美精品88| 亚洲国产40页第21页| 免费一级特黄特色大片在线观看| 国产日韩一区二区在线看| 一区二区三区四区中文| 91麻豆精品久久久久| 在线国产中文字幕视频| 天天操,天天干,天天射| 国产精品成人xxxx| 动漫精品视频在线观看| 特级无码毛片免费视频播放| 亚洲精品无码久久久久不卡| 91免费福利网91麻豆国产精品| wwwxxx一级黄色片| 亚洲欧美另类手机在线| 看一级特黄a大片日本片黑人| 人妻3p真实偷拍一二区| 午夜精品九一唐人麻豆嫩草成人| av乱码一区二区三区| 经典亚洲伊人第一页| 韩国亚洲欧美超一级在线播放视频| 欧美爆乳肉感大码在线观看| 亚洲国产香蕉视频在线播放| 深田咏美亚洲一区二区| 喷水视频在线观看这里只有精品| 日韩成人性色生活片| 99国产精品窥熟女精品| 精品久久久久久久久久久久人妻| AV天堂一区二区免费试看| 天天干夜夜操天天舔| 红杏久久av人妻一区| 亚国产成人精品久久久| 熟女国产一区亚洲中文字幕| 国产精品国色综合久久| 中文字幕一区的人妻欧美日韩| 国产亚洲精品品视频在线| 11久久久久久久久久久| 久青青草视频手机在线免费观看 | 沈阳熟妇28厘米大战黑人| 91极品大一女神正在播放| nagger可以指黑人吗| 国产精品国产三级麻豆| 亚洲在线一区二区欧美| 久久机热/这里只有| 极品丝袜一区二区三区| 在线观看黄色成年人网站| 玖玖一区二区在线观看| 75国产综合在线视频| 成人av免费不卡在线观看| 同居了嫂子在线播高清中文| 亚洲午夜福利中文乱码字幕| 国产福利小视频二区| weyvv5国产成人精品的视频| 99热色原网这里只有精品| 大白屁股精品视频国产| 精品一区二区亚洲欧美| 啪啪啪啪啪啪啪啪啪啪黄色| 黄色录像鸡巴插进去| 亚洲欧美在线视频第一页| 天天摸天天干天天操科普| 强行扒开双腿猛烈进入免费版| 亚洲精品 欧美日韩| 只有精品亚洲视频在线观看| 夜夜骑夜夜操夜夜奸| 亚洲自拍偷拍精品网| 欧美一区二区中文字幕电影| 精品人人人妻人人玩日产欧| 这里有精品成人国产99| 大骚逼91抽插出水视频| 11久久久久久久久久久| 社区自拍揄拍尻屁你懂的| av在线资源中文字幕| 最新黄色av网站在线观看| 国产97视频在线精品| 亚洲一区二区三区精品乱码| 欧美日韩精品永久免费网址| 爆乳骚货内射骚货内射在线| 国产日韩精品电影7777| 黑人大几巴狂插日本少妇| 粉嫩欧美美人妻小视频| 精品黑人一区二区三区久久国产| 三级av中文字幕在线观看| 国产高潮无码喷水AV片在线观看| 天天色天天舔天天射天天爽| 免费成人va在线观看| 91社福利《在线观看| 国产精品亚洲在线观看| 一个色综合男人天堂| 中文字幕网站你懂的| 天天操夜夜操天天操天天操| 中文字幕日本人妻中出| 边摸边做超爽毛片18禁色戒| 啪啪啪啪啪啪啪免费视频| 久久99久久99精品影院| 久草视频首页在线观看| 国产精彩对白一区二区三区| 91天堂天天日天天操| 日日夜夜大香蕉伊人| gogo国模私拍视频| 亚洲欧美福利在线观看| 插逼视频双插洞国产操逼插洞| 97超碰免费在线视频| 欧美一级色视频美日韩| 91精品高清一区二区三区| 一区二区久久成人网| 国产1区,2区,3区| 在线观看免费视频色97| 国产一区二区欧美三区| 美女少妇亚洲精选av| 91麻豆精品久久久久| 蝴蝶伊人久久中文娱乐网| 久久久人妻一区二区| 涩涩的视频在线观看视频| 无码国产精品一区二区高潮久久4| 黄片色呦呦视频免费看| av中文字幕电影在线看| 日本韩国免费一区二区三区视频 | www天堂在线久久| 91p0rny九色露脸熟女| 午夜极品美女福利视频| 国产精品午夜国产小视频| 一区二区视频视频视频| 可以在线观看的av中文字幕| 日韩人妻丝袜中文字幕| 成人国产影院在线观看| 啊啊好慢点插舔我逼啊啊啊视频| 国产精品久久久黄网站| 国产黄色a级三级三级三级| 好吊操视频这里只有精品| 亚洲特黄aaaa片| 福利视频一区二区三区筱慧 | 岛国青草视频在线观看| 老司机免费福利视频网| 欧美日韩高清午夜蜜桃大香蕉| 一级A一级a爰片免费免会员| 国语对白xxxx乱大交| 亚洲天堂第一页中文字幕| 精品一区二区三区欧美| 在线观看av观看av| 亚洲 人妻 激情 中文| 天天干天天日天天谢综合156| 国产变态另类在线观看| 欧美亚洲少妇福利视频| 日韩精品一区二区三区在线播放| 人妻少妇精品久久久久久| 午夜蜜桃一区二区三区| 十八禁在线观看地址免费| 2020久久躁狠狠躁夜夜躁 | 免费费一级特黄真人片| 亚洲高清国产拍青青草原| 日本av在线一区二区三区| 老司机福利精品免费视频一区二区 | 福利片区一区二体验区| 国产精品黄色的av| 亚洲成人国产综合一区| 亚洲激情偷拍一区二区| jiuse91九色视频| 亚洲欧美激情人妻偷拍| 欧美交性又色又爽又黄麻豆| 91精品高清一区二区三区| 欧美专区第八页一区在线播放| 欧美亚洲中文字幕一区二区三区| 播放日本一区二区三区电影| 亚洲区美熟妇久久久久| 色呦呦视频在线观看视频| www,久久久,com| 中文字幕一区二区三区人妻大片| 亚洲国际青青操综合网站| 亚洲成人三级在线播放| 亚洲精品无码久久久久不卡| 在线观看日韩激情视频| 自拍偷拍日韩欧美一区二区| 91麻豆精品91久久久久同性| 日韩精品一区二区三区在线播放| 熟女在线视频一区二区三区| 三级黄色亚洲成人av| 黄色资源视频网站日韩| 日本av熟女在线视频| 男人的网址你懂的亚洲欧洲av| 扒开腿挺进肉嫩小18禁视频| 人妻素人精油按摩中出| 四虎永久在线精品免费区二区| 日韩激情文学在线视频| 成年人的在线免费视频| 99精品免费久久久久久久久a| 中文字幕 码 在线视频| 天天想要天天操天天干| 97国产在线av精品| 午夜蜜桃一区二区三区| 青青草原色片网站在线观看| 色综合久久五月色婷婷综合| 国产亚洲欧美45p| 97人妻总资源视频| 午夜在线观看一区视频| 成人蜜臀午夜久久一区| 青青社区2国产视频| 久久美欧人妻少妇一区二区三区| 精品区一区二区三区四区人妻| 精品av久久久久久久| 91免费观看国产免费| 水蜜桃一区二区三区在线观看视频 | 91麻豆精品久久久久| 日本成人一区二区不卡免费在线| 黑人变态深video特大巨大| 国产一区二区欧美三区| 91亚洲精品干熟女蜜桃频道| 93视频一区二区三区| 亚洲精品国品乱码久久久久| 亚洲综合一区成人在线| 日韩av有码中文字幕| 亚洲激情偷拍一区二区| 国产精品欧美日韩区二区| 九色精品视频在线播放| chinese国产盗摄一区二区| 涩涩的视频在线观看视频| 成人影片高清在线观看| 黄色中文字幕在线播放| 欧美精品免费aaaaaa| 极品丝袜一区二区三区| 亚洲老熟妇日本老妇| 国产刺激激情美女网站| av中文字幕电影在线看| 女警官打开双腿沦为性奴| 中文字幕在线欧美精品| 日韩视频一区二区免费观看| 婷婷激情四射在线观看视频| 老熟妇xxxhd老熟女| 免费在线黄色观看网站| 99热色原网这里只有精品| 91桃色成人网络在线观看| 日本高清成人一区二区三区| 搡老妇人老女人老熟女| 久久这里有免费精品| 93人妻人人揉人人澡人人| 在线观看视频网站麻豆| 亚洲一区二区三区av网站| 精品国产成人亚洲午夜| 高潮喷水在线视频观看| 中国熟女一区二区性xx| 日本中文字幕一二区视频| 日本xx片在线观看| av天堂资源最新版在线看| 久久综合老鸭窝色综合久久| 在线观看国产网站资源| av完全免费在线观看av| 99热色原网这里只有精品| 99热色原网这里只有精品| 成年午夜影片国产片| 亚洲图片偷拍自拍区| 女生自摸在线观看一区二区三区| 老师让我插进去69AV| 蝴蝶伊人久久中文娱乐网| 91自产国产精品视频| 青娱乐在线免费视频盛宴| 全国亚洲男人的天堂| 国产精品三级三级三级| 成人免费公开视频无毒| 粉嫩av蜜乳av蜜臀| 51国产偷自视频在线播放| 黑人进入丰满少妇视频| 午夜在线精品偷拍一区二| 老司机深夜免费福利视频在线观看| 亚洲美女自偷自拍11页| 日韩激情文学在线视频 | 亚洲视频乱码在线观看| 欧美韩国日本国产亚洲| 中文字幕+中文字幕| 精品国产午夜视频一区二区| 97超碰免费在线视频| 噜噜色噜噜噜久色超碰| 国产清纯美女al在线| 日韩美女搞黄视频免费| 中国把吊插入阴蒂的视频| 九九热99视频在线观看97| 强行扒开双腿猛烈进入免费版| 成人综合亚洲欧美一区| 久久丁香花五月天色婷婷| 北条麻妃av在线免费观看| 天天插天天狠天天操| 成熟熟女国产精品一区| 巨乳人妻日下部加奈被邻居中出| 日本熟妇一区二区x x| 天天操,天天干,天天射| 午夜精品一区二区三区更新| 国产日韩欧美美利坚蜜臀懂色| 蜜桃色婷婷久久久福利在线| 一区二区三区日韩久久| 久久尻中国美女视频| 天堂女人av一区二区| 青青青爽视频在线播放| 激情人妻校园春色亚洲欧美| 日韩一个色综合导航| 成人av电影免费版| 国产日韩一区二区在线看| xxx日本hd高清| 91精品国产黑色丝袜| 人人妻人人人操人人人爽| 中文字母永久播放1区2区3区| 精品久久久久久久久久久99| 男女之间激情网午夜在线| 91试看福利一分钟| 888亚洲欧美国产va在线播放| 久久久久久cao我的性感人妻| 美日韩在线视频免费看| 黑人3p华裔熟女普通话| 中文字幕高清免费在线人妻 | 欧美日韩一区二区电影在线观看| 国产精彩对白一区二区三区| 国产视频精品资源网站| 久草视频 久草视频2| 国产福利小视频二区| 亚洲综合一区成人在线| 天天日天天干天天干天天日| 青青热久免费精品视频在线观看| 亚洲麻豆一区二区三区| 超级碰碰在线视频免费观看| 操的小逼流水的文章| 亚洲图片偷拍自拍区| 欧美一区二区三区四区性视频| 国产成人精品一区在线观看| 亚洲免费在线视频网站| 国产av自拍偷拍盛宴| 色综合久久无码中文字幕波多| 欧美一区二区三区乱码在线播放| 精品一区二区三区三区88| 人人妻人人爱人人草| 欧美在线一二三视频| 很黄很污很色的午夜网站在线观看 | 天天摸天天亲天天舔天天操天天爽 | 动漫精品视频在线观看| 国产janese在线播放| 97成人免费在线观看网站| 91www一区二区三区| 93视频一区二区三区| 午夜毛片不卡免费观看视频| 久精品人妻一区二区三区| 成人动漫大肉棒插进去视频| 欧美亚洲少妇福利视频| 国产麻豆精品人妻av| 2019av在线视频| 91极品大一女神正在播放| 国产午夜激情福利小视频在线| 午夜精品亚洲精品五月色| 中文字幕高清在线免费播放| 在线不卡日韩视频播放| 制服丝袜在线人妻中文字幕| 夜色17s精品人妻熟女| 老师啊太大了啊啊啊尻视频| 伊拉克及约旦宣布关闭领空| 97人人妻人人澡人人爽人人精品| 精品美女在线观看视频在线观看| 在线免费观看国产精品黄色| 啊啊好大好爽啊啊操我啊啊视频 | 免费无码人妻日韩精品一区二区 | 亚洲推理片免费看网站| 2019av在线视频| 伊人开心婷婷国产av| 黄片三级三级三级在线观看| 夜色17s精品人妻熟女| 99精品国产免费久久| 少妇与子乱在线观看| 日本一道二三区视频久久| 一区国内二区日韩三区欧美| 男生用鸡操女生视频动漫| 综合激情网激情五月天| 在线观看操大逼视频| www久久久久久久久久久| 在线成人日韩av电影| 漂亮 人妻被中出中文| 黄色资源视频网站日韩| 免费av岛国天堂网站| 超级福利视频在线观看| gav成人免费播放| 天天躁日日躁狠狠躁躁欧美av| 超碰97人人澡人人| 日本熟妇丰满厨房55| 2022国产精品视频| 熟女人妻一区二区精品视频| 久久尻中国美女视频| 熟女俱乐部一二三区| 嫩草aⅴ一区二区三区| 亚洲一区二区三区久久午夜| 丝袜肉丝一区二区三区四区在线 | 久久久久久久一区二区三| 五十路熟女人妻一区二| 岛国青草视频在线观看| 男人和女人激情视频| 日比视频老公慢点好舒服啊| 男人天堂av天天操| 天天操,天天干,天天射| 唐人色亚洲av嫩草| 亚洲一级美女啪啪啪| 亚洲av天堂在线播放| 久久久精品999精品日本 | 51国产成人精品视频| 亚洲av天堂在线播放| 亚洲国产成人av在线一区| 韩国男女黄色在线观看| 久久精品久久精品亚洲人| av中文字幕在线观看第三页| 国产日韩一区二区在线看| 欧洲国产成人精品91铁牛tv| 国产成人精品一区在线观看| 国产性色生活片毛片春晓精品| 美女福利视频网址导航| 2021久久免费视频| 91国内视频在线观看| 成人30分钟免费视频| 美女av色播在线播放| 日韩av免费观看一区| 亚洲成人激情视频免费观看了| 天天色天天爱天天爽| 黄色资源视频网站日韩| 夜色福利视频在线观看| 精品人人人妻人人玩日产欧| 日本男女操逼视频免费看 | 在线免费观看欧美小视频| www日韩a级s片av| 被大鸡吧操的好舒服视频免费| 中文字幕日韩91人妻在线| 和邻居少妇愉情中文字幕| 首之国产AV医生和护士小芳| 九色porny九色9l自拍视频| 综合精品久久久久97| 亚洲狠狠婷婷综合久久app| 亚洲激情偷拍一区二区| 国语对白xxxx乱大交| av黄色成人在线观看| 国产精品一区二区久久久av| 中文字幕成人日韩欧美| 韩国女主播精品视频网站| 青青青青青青青青青青草青青 | 亚洲欧美日韩视频免费观看| 青青尤物在线观看视频网站| 在线免费观看日本片| www,久久久,com| 大鸡吧插入女阴道黄色片| 亚洲欧美人精品高清| 国产女人叫床高潮大片视频| 夜色撩人久久7777| 99热99re在线播放| 亚洲成av人无码不卡影片一| 久久久超爽一二三av| 最新中文字幕乱码在线| 性欧美日本大妈母与子| 操操网操操伊剧情片中文字幕网| 97超碰国语国产97超碰| 日韩特级黄片高清在线看| 99精品国产aⅴ在线观看| 国产极品精品免费视频| 直接观看免费黄网站| 午夜在线观看一区视频| 亚洲卡1卡2卡三卡四老狼| 日韩美在线观看视频黄| 一级A一级a爰片免费免会员| 欧美激情精品在线观看| 伊人情人综合成人久久网小说| 真实国模和老外性视频| 青青草国内在线视频精选| 日韩精品中文字幕播放| 国产精品污污污久久| 亚洲免费福利一区二区三区| 福利在线视频网址导航| 天天色天天舔天天射天天爽| 天天干天天日天天谢综合156| 肏插流水妹子在线乐播下载| 97资源人妻免费在线视频| 国产使劲操在线播放| 天天摸天天干天天操科普 | 亚洲免费在线视频网站| 国产高清在线观看1区2区| 高潮喷水在线视频观看| 97成人免费在线观看网站| 一区二区久久成人网| 五月天久久激情视频| 中国熟女@视频91| 美女张开腿让男生操在线看| 888亚洲欧美国产va在线播放| 激情五月婷婷综合色啪| 在线成人日韩av电影| 国产成人午夜精品福利| 传媒在线播放国产精品一区| 在线观看911精品国产| 欧美伊人久久大香线蕉综合| 欧美特色aaa大片| 99热国产精品666| 亚洲精品福利网站图片| 亚洲一区二区三区偷拍女厕91| 日本裸体熟妇区二区欧美| 久草极品美女视频在线观看| 午夜国产福利在线观看| 最新中文字幕乱码在线| 大陆胖女人与丈夫操b国语高清| 丝袜长腿第一页在线| 成人av免费不卡在线观看| 国产老熟女伦老熟妇ⅹ| 国产之丝袜脚在线一区二区三区| 亚洲成人av一区久久| 老司机福利精品免费视频一区二区| 99国内精品永久免费视频| 国产在线一区二区三区麻酥酥| 98精产国品一二三产区区别| 人妻3p真实偷拍一二区| 五月激情婷婷久久综合网| 91试看福利一分钟| 国产精品成久久久久三级蜜臀av| 国产精品久久久久网| 国产91久久精品一区二区字幕| av网站色偷偷婷婷网男人的天堂| 精品久久久久久久久久久99| 亚洲人妻视频在线网| 最后99天全集在线观看| 激情五月婷婷免费视频| 日美女屁股黄邑视频| 美女日逼视频免费观看| 午夜免费体验区在线观看| 免费在线播放a级片| 国产精品精品精品999| 婷婷综合蜜桃av在线| 啊用力插好舒服视频| 亚洲美女美妇久久字幕组| 久久久久久性虐视频| 亚洲av在线观看尤物| 99热99这里精品6国产| 久久精品国产999| 日本少妇人妻xxxxxhd| 国产女孩喷水在线观看| 亚洲区美熟妇久久久久| 熟女妇女老妇一二三区| 亚洲欧美另类手机在线| av老司机亚洲一区二区| 久草视频在线一区二区三区资源站 | 欧美男同性恋69视频| 免费费一级特黄真人片 | 国产刺激激情美女网站| 一区二区三区久久久91| 亚洲成人三级在线播放| 97资源人妻免费在线视频| 黑人大几巴狂插日本少妇| 日本阿v视频在线免费观看| 人人妻人人澡人人爽人人dvl| 狠狠的往里顶撞h百合| av大全在线播放免费| 狠狠躁夜夜躁人人爽天天天天97| 大陆精品一区二区三区久久| 肏插流水妹子在线乐播下载| 中文字幕日韩91人妻在线| 福利视频网久久91| 好吊操视频这里只有精品| 在线新三级黄伊人网| 美女小视频网站在线| 国产精品久久久久久久久福交| 视频一区二区三区高清在线| 午夜精品在线视频一区| 99热99re在线播放| 99热这里只有国产精品6| 亚洲国产成人在线一区| 亚洲中文精品字幕在线观看 | 老司机免费福利视频网| 国产日韩av一区二区在线| 最新中文字幕乱码在线| 一区二区麻豆传媒黄片| 1769国产精品视频免费观看| 天天日夜夜操天天摸| 2022国产精品视频| 9l人妻人人爽人人爽| 国产成人精品福利短视频| 亚洲成人激情视频免费观看了 | 91人妻精品一区二区在线看| 国产精品久久久久国产三级试频| 亚洲高清视频在线不卡| 久久香蕉国产免费天天| 2020国产在线不卡视频 | 99一区二区在线观看| 成人动漫大肉棒插进去视频| 97青青青手机在线视频| 男女啪啪啪啪啪的网站| 国产亚洲视频在线观看| 亚洲国产精品中文字幕网站| 91久久精品色伊人6882| 日本免费午夜视频网站| 国产女人被做到高潮免费视频| 大鸡巴操b视频在线| 在线观看一区二区三级| 免费一级特黄特色大片在线观看 | 欧美视频中文一区二区三区| www天堂在线久久| 91‖亚洲‖国产熟女| 亚洲欧美成人综合在线观看| 一二三中文乱码亚洲乱码one | 国产男女视频在线播放| 天堂av在线官网中文| 亚洲综合图片20p| 熟女少妇激情五十路| 人妻丝袜诱惑我操她视频| 偷拍自拍国产在线视频| 在线国产精品一区二区三区| 在线视频免费观看网| 在线观看av2025| 91社福利《在线观看| 2o22av在线视频| 人人爱人人妻人人澡39| 日韩欧美一级aa大片| 亚洲公开视频在线观看| 玖玖一区二区在线观看| 国产精品探花熟女在线观看| 国产va在线观看精品| 91精品视频在线观看免费| 日本三极片视频网站观看| 国产精品3p和黑人大战| 夫妻在线观看视频91| 97超碰国语国产97超碰| 98精产国品一二三产区区别| 中国黄片视频一区91| 天天日天天爽天天爽| 18禁无翼鸟成人在线| 亚洲国产中文字幕啊啊啊不行了 | 国产亚洲欧美另类在线观看| av久久精品北条麻妃av观看| 黑人巨大的吊bdsm| 久久久精品欧洲亚洲av| 97人妻无码AV碰碰视频| 亚洲高清国产一区二区三区| 真实国产乱子伦一区二区| 亚洲精品久久综合久| 亚洲av琪琪男人的天堂| 日韩欧美国产一区不卡| 在线 中文字幕 一区| 伊人网中文字幕在线视频| 国产成人精品久久二区91| 久久久久久久亚洲午夜综合福利| av天堂加勒比在线| 亚洲av男人天堂久久| 99亚洲美女一区二区三区| 日韩黄色片在线观看网站| 偷青青国产精品青青在线观看| 99久久99一区二区三区| 国产麻豆国语对白露脸剧情| 精品久久久久久久久久久久人妻| 青青青视频手机在线观看| 色婷婷久久久久swag精品| 国产精品黄页网站视频| 一区二区三区四区五区性感视频| 欧美在线精品一区二区三区视频| 欧美一级片免费在线成人观看| 五十路av熟女松本翔子| jiujiure精品视频在线| 亚洲免费视频欧洲免费视频| 午夜精品久久久久久99热| 精品美女久久久久久| 成熟丰满熟妇高潮xx×xx| 天堂va蜜桃一区入口| 97人妻人人澡爽人人精品| 亚洲国产在人线放午夜| 国产麻豆剧果冻传媒app| 2020国产在线不卡视频| 天天操,天天干,天天射| 91传媒一区二区三区| 丝袜国产专区在线观看| 日韩精品激情在线观看| 成年人黄色片免费网站| 国产一级精品综合av| 亚洲中文精品人人免费| 国产黄色a级三级三级三级| 啪啪啪18禁一区二区三区| 亚洲日产av一区二区在线| 久久久久久久久久一区二区三区| 欧美日韩高清午夜蜜桃大香蕉| 早川濑里奈av黑人番号| 蜜桃视频在线欧美一区| 精品人妻一二三区久久| 亚洲av日韩高清hd| 日韩北条麻妃一区在线| 亚洲伊人久久精品影院一美女洗澡| 一本一本久久a久久精品综合不卡| 欧美色呦呦最新网址| 天天操天天污天天射| 国产精品视频欧美一区二区| 精品久久婷婷免费视频| 国产精品sm调教视频| 日本韩国免费一区二区三区视频| 大鸡吧插逼逼视频免费看| 曰本无码人妻丰满熟妇啪啪| 天天操天天弄天天射| 人妻久久久精品69系列| 中国把吊插入阴蒂的视频| 综合国产成人在线观看| 亚洲乱码中文字幕在线| 十八禁在线观看地址免费| 99精品免费观看视频| 国产熟妇一区二区三区av| 五十路丰满人妻熟妇| 丝袜长腿第一页在线| 亚洲成人线上免费视频观看| 五色婷婷综合狠狠爱| 自拍偷拍日韩欧美一区二区| 国产又色又刺激在线视频| 手机看片福利盒子日韩在线播放| 东京热男人的av天堂| 清纯美女在线观看国产| 快点插进来操我逼啊视频| 国产精品三级三级三级| 经典国语激情内射视频| 国产精品免费不卡av| 亚洲最大黄了色网站| 亚洲无码一区在线影院| 欧美日韩v中文在线| 日韩av有码中文字幕| 午夜精品一区二区三区更新| 精品一区二区三区在线观看| 亚洲精品一区二区三区老狼| av老司机精品在线观看| 国产男女视频在线播放| 日本特级片中文字幕| 欧美成一区二区三区四区| 国产精品手机在线看片| 天天日天天摸天天爱| 孕妇奶水仑乱A级毛片免费看| 肏插流水妹子在线乐播下载| 国产综合高清在线观看| 国产欧美精品免费观看视频| 在线观看国产网站资源| 日韩欧美一级精品在线观看| 日日日日日日日日夜夜夜夜夜夜| 欧美另类一区二区视频| 年轻的人妻被夫上司侵犯| 国产成人小视频在线观看无遮挡| 一级黄色片夫妻性生活| 在线免费观看视频一二区| 2o22av在线视频| 欧美精品亚洲精品日韩在线| 直接能看的国产av| 熟女91pooyn熟女| 91国偷自产一区二区三区精品| 国产又粗又硬又大视频| 丝袜肉丝一区二区三区四区在线 | 福利在线视频网址导航| 岳太深了紧紧的中文字幕| 美女av色播在线播放| 骚货自慰被发现爆操| 亚洲成人av一区在线| aⅴ五十路av熟女中出| 亚洲区欧美区另类最新章节| 91久久人澡人人添人人爽乱| 性感美女福利视频网站| 91久久人澡人人添人人爽乱| 中文字幕免费在线免费| 久久三久久三久久三久久| 天天干狠狠干天天操| 亚洲va国产va欧美精品88| 直接观看免费黄网站| 超级碰碰在线视频免费观看| 亚洲欧美精品综合图片小说 | 99久久久无码国产精品性出奶水 | 国产熟妇人妻ⅹxxxx麻豆| 亚洲免费国产在线日韩| 亚洲高清国产自产av| 欧美一区二区三区啪啪同性| 中文字幕1卡1区2区3区| 美女日逼视频免费观看| 91大屁股国产一区二区| 国产刺激激情美女网站| 视频 一区二区在线观看| 午夜激情久久不卡一区二区| 黄色av网站免费在线| 男人的天堂av日韩亚洲| 欧美另类一区二区视频| 福利视频广场一区二区| 黄色三级网站免费下载| 玖玖一区二区在线观看| 粉嫩av蜜乳av蜜臀 | 午夜精品一区二区三区4| 免费在线看的黄片视频| 狠狠的往里顶撞h百合| 99热碰碰热精品a中文| 国产精品自偷自拍啪啪啪| 人妻少妇亚洲精品中文字幕| av久久精品北条麻妃av观看| aiss午夜免费视频| 男人的天堂av日韩亚洲| 天堂av在线最新版在线| 美女少妇亚洲精选av| 亚洲成人三级在线播放 | 青青草成人福利电影| 欧美麻豆av在线播放| 亚洲欧美成人综合在线观看| 端庄人妻堕落挣扎沉沦| 亚洲图片偷拍自拍区| 亚洲综合在线观看免费| 日韩写真福利视频在线观看| 超污视频在线观看污污污| 欧美黄片精彩在线免费观看| 国产精品久久久久久久女人18| chinese国产盗摄一区二区| 亚洲精品午夜久久久久| 综合精品久久久久97| 中文字幕在线欧美精品| 丝袜亚洲另类欧美变态| 毛茸茸的大外阴中国视频| 大陆精品一区二区三区久久| 黑人大几巴狂插日本少妇| 亚洲蜜臀av一区二区三区九色| 日本www中文字幕| 亚洲av第国产精品| 在线观看免费av网址大全| 91精品国产综合久久久蜜| 黄页网视频在线免费观看| 欧美怡红院视频在线观看| 亚洲一区av中文字幕在线观看| 免费在线观看视频啪啪| 成人av在线资源网站| 国产日本欧美亚洲精品视| 国产熟妇一区二区三区av| 国产免费高清视频视频| 美女少妇亚洲精选av| 熟女俱乐部一二三区| 摧残蹂躏av一二三区| 美女张开腿让男生操在线看| 国产大鸡巴大鸡巴操小骚逼小骚逼| 亚洲在线一区二区欧美| 国产高清在线在线视频| 日韩伦理短片在线观看| 亚洲精品在线资源站| 久久这里有免费精品| 亚洲av日韩高清hd| 色综合久久久久久久久中文| 在线 中文字幕 一区| 老司机福利精品免费视频一区二区 | 国产精品亚洲在线观看| 青青草视频手机免费在线观看| 国产成人自拍视频播放| 青青尤物在线观看视频网站| 岛国av高清在线成人在线| 最新欧美一二三视频| 老鸭窝日韩精品视频观看| 91九色porny国产蝌蚪视频| 18禁无翼鸟成人在线| 久久久久久99国产精品| 欧美专区第八页一区在线播放| 中文字幕成人日韩欧美| 中文字幕一区二区人妻电影冢本| 亚洲av日韩av第一区二区三区| 青青青aaaa免费| 日韩在线中文字幕色| 激情五月婷婷综合色啪| 亚洲av第国产精品| 免费啪啪啪在线观看视频| 在线不卡日韩视频播放| 青青草在观免费国产精品| 大鸡巴插入美女黑黑的阴毛| 日本性感美女三级视频| 鸡巴操逼一级黄色气| 日韩加勒比东京热二区| 黄色黄色黄片78在线| 天天色天天舔天天射天天爽 | 99精品国产免费久久| 亚洲高清免费在线观看视频| 精品亚洲在线免费观看| 中文字幕成人日韩欧美| 天堂av在线最新版在线| 日本一区精品视频在线观看| 亚洲中文字幕乱码区| 国产女孩喷水在线观看| 成人18禁网站在线播放| 日本黄色特一级视频| 97人妻人人澡爽人人精品| av破解版在线观看| 强行扒开双腿猛烈进入免费版| 综合一区二区三区蜜臀| 青娱乐最新视频在线| 中文字幕在线一区精品| 国产性生活中老年人视频网站| av手机在线免费观看日韩av| 99精品亚洲av无码国产另类 | 好太好爽好想要免费| 人妻丝袜诱惑我操她视频| 成人乱码一区二区三区av| av一区二区三区人妻| 99的爱精品免费视频| 大屁股肉感人妻中文字幕在线| 熟女91pooyn熟女| 大黑人性xxxxbbbb| 青青青青青青草国产| 亚洲成人熟妇一区二区三区| 黄色成人在线中文字幕| 人妻另类专区欧美制服| 黄色av网站免费在线| 欧美视频一区免费在线| 亚洲免费福利一区二区三区| 欧美黑人性暴力猛交喷水| 青青青青青手机视频| 久久免看30视频口爆视频| 99久久激情婷婷综合五月天| 亚洲1卡2卡三卡4卡在线观看 | sw137 中文字幕 在线| 亚洲一区自拍高清免费视频| 成人av免费不卡在线观看| 亚洲激情,偷拍视频| 青青青青青青青青青青草青青 | 成人av亚洲一区二区| 亚洲精品久久综合久| 精品成人啪啪18免费蜜臀| 五十路丰满人妻熟妇| 日韩亚国产欧美三级涩爱| 欧美日韩中文字幕欧美| 插逼视频双插洞国产操逼插洞| 男女之间激情网午夜在线| 美女 午夜 在线视频 | 天天日天天玩天天摸| 国产免费av一区二区凹凸四季| 无码精品一区二区三区人| 日韩精品中文字幕福利| 9久在线视频只有精品| 5528327男人天堂| 精品乱子伦一区二区三区免费播| 亚洲精品午夜久久久久| 国产卡一卡二卡三乱码手机| 又粗又硬又猛又黄免费30| 欧美在线一二三视频| 中文字幕高清资源站| 国产在线观看黄色视频| 久久久久久久久久一区二区三区| 中文字幕AV在线免费看 | 久青青草视频手机在线免费观看| 午夜激情精品福利视频| 日本三极片视频网站观看| 91在线视频在线精品3| 在线免费观看日本片| 亚洲欧美一区二区三区电影| av日韩在线观看大全| 日韩午夜福利精品试看| 欧美乱妇无乱码一区二区| 三级等保密码要求条款| av老司机亚洲一区二区| av资源中文字幕在线观看| 唐人色亚洲av嫩草| 男人操女人逼逼视频网站| 亚洲成人国产av在线| 超级av免费观看一区二区三区| 青青草精品在线视频观看| 少妇系列一区二区三区视频| av男人天堂狠狠干| 午夜的视频在线观看| 国产成人精品av网站| 国产成人精品一区在线观看| 中文 成人 在线 视频| 国产精品福利小视频a| 亚洲精品国品乱码久久久久| av亚洲中文天堂字幕网| 大香蕉日本伊人中文在线| 91极品大一女神正在播放| 最新日韩av传媒在线| 搡老熟女一区二区在线观看| 亚洲最大黄了色网站| 大香蕉伊人国产在线| 99一区二区在线观看| 午夜在线观看一区视频| 一区二区三区麻豆福利视频| 欧美日韩亚洲国产无线码| 亚洲丝袜老师诱惑在线观看| 亚洲av可乐操首页| 日本欧美视频在线观看三区| 久久久久久久久久久久久97| 精品一区二区三四区| 成人综合亚洲欧美一区| 老有所依在线观看完整版| 亚洲男人让女人爽的视频| 在线免费观看黄页视频| 99热这里只有精品中文| 日韩a级精品一区二区| 免费黄页网站4188| 伊人开心婷婷国产av| 最近中文2019年在线看| 精品视频一区二区三区四区五区| 99国产精品窥熟女精品| 漂亮 人妻被中出中文| 日韩精品电影亚洲一区| 2025年人妻中文字幕乱码在线| 久久久精品欧洲亚洲av| 97黄网站在线观看| 欧美精品资源在线观看| 日日操综合成人av| 美女福利视频网址导航| 40道精品招牌菜特色| 夏目彩春在线中文字幕| 91精品国产观看免费| 岛国一区二区三区视频在线| 久久久久久久久久久免费女人| 岛国青草视频在线观看| 大鸡巴操b视频在线| 91老师蜜桃臀大屁股| 日本少妇的秘密免费视频| 日本免费午夜视频网站| 国产三级片久久久久久久| 亚洲人一区二区中文字幕| 93视频一区二区三区| 欧美专区日韩专区国产专区| 欧美成人精品在线观看| 日本在线一区二区不卡视频| 欧美xxx成人在线| 狠狠躁夜夜躁人人爽天天天天97| 亚洲伊人久久精品影院一美女洗澡 | av中文字幕国产在线观看| 2020韩国午夜女主播在线| 成人免费公开视频无毒 | 91久久国产成人免费网站| 国产成人午夜精品福利| 91麻豆精品传媒国产黄色片| 搞黄色在线免费观看| 亚洲国产欧美一区二区三区久久 | 亚洲人妻30pwc| 亚洲免费成人a v| 青青伊人一精品视频| 日曰摸日日碰夜夜爽歪歪| 91精品资源免费观看| 青青青视频手机在线观看| av天堂中文免费在线| 绝色少妇高潮3在线观看| 国产va在线观看精品| 日本韩国在线观看一区二区| 久草免费人妻视频在线| 91在线视频在线精品3| av一本二本在线观看| 亚洲久久午夜av一区二区| 精品国产亚洲av一淫| 日韩美女福利视频网| 欧美视频中文一区二区三区| 国际av大片在线免费观看| jul—619中文字幕在线| 啪啪啪18禁一区二区三区 | 欧美一区二区三区久久久aaa| 青青青青操在线观看免费| 男女啪啪啪啪啪的网站| 久久机热/这里只有| 欧美香蕉人妻精品一区二区| 521精品视频在线观看| 亚洲成人av在线一区二区| 久草视频福利在线首页| 99精品国产自在现线观看| 一区二区三区四区五区性感视频 | av男人天堂狠狠干| xxx日本hd高清| 五十路熟女av天堂| 十八禁在线观看地址免费| 欧美国产亚洲中英文字幕| 99一区二区在线观看| 天天日天天干天天舔天天射| 成人性爱在线看四区| 最近的中文字幕在线mv视频| 区一区二区三国产中文字幕| 亚洲天堂成人在线观看视频网站| 日韩影片一区二区三区不卡免费| 亚洲男人在线天堂网| 青青青青草手机在线视频免费看| 精品视频中文字幕在线播放| 成年人啪啪视频在线观看| 97人妻夜夜爽二区欧美极品| 欧美偷拍亚洲一区二区| 蜜桃视频在线欧美一区| 亚洲推理片免费看网站| 99久久中文字幕一本人| 久久免费看少妇高潮完整版| 亚洲麻豆一区二区三区| 久久h视频在线观看| 亚洲视频乱码在线观看| 久久久超爽一二三av| 天天插天天狠天天操| 91免费黄片可看视频| 精品av国产一区二区三区四区| 国产熟妇一区二区三区av| mm131美女午夜爽爽爽| 午夜国产免费福利av| 人妻少妇性色欲欧美日韩| 国产乱弄免费视频观看| 天天操天天干天天日狠狠插| 大鸡巴操b视频在线| 人妻丝袜诱惑我操她视频| 密臀av一区在线观看| 在线视频国产欧美日韩| 动色av一区二区三区| 日韩精品中文字幕福利| 成年人该看的视频黄免费| 护士特殊服务久久久久久久| 亚洲午夜高清在线观看| 色哟哟在线网站入口| 一区二区三区日本伦理| 亚洲av极品精品在线观看| 91天堂精品一区二区| 99久久中文字幕一本人| 亚洲综合一区成人在线| 新婚人妻聚会被中出| 大香蕉伊人中文字幕| 久久精品国产23696| 国产一区成人在线观看视频| 亚洲av自拍天堂网| 亚洲高清国产拍青青草原| 干逼又爽又黄又免费的视频| 国产精品女邻居小骚货| 天天草天天色天天干| 亚洲老熟妇日本老妇| 欧美在线精品一区二区三区视频| 夜色17s精品人妻熟女| 涩涩的视频在线观看视频| 91一区精品在线观看| 亚洲熟女综合色一区二区三区四区 | 色av色婷婷人妻久久久精品高清| 天天干天天操天天玩天天射| 东游记中文字幕版哪里可以看到| 天天操夜夜骑日日摸| 免费在线福利小视频| 在线亚洲天堂色播av电影| 含骚鸡巴玩逼逼视频| 人人人妻人人澡人人| 欧美视频不卡一区四区| 又粗又硬又猛又黄免费30| 韩国爱爱视频中文字幕| 久草视频在线免播放| 久久久噜噜噜久久熟女av| 国产97在线视频观看| 精品一线二线三线日本| 国产精品久久久久国产三级试频| av黄色成人在线观看| 美女张开两腿让男人桶av| 亚洲免费va在线播放| av男人天堂狠狠干| 天天摸天天日天天操| 亚洲自拍偷拍精品网| 日本在线不卡免费视频| 天天摸天天亲天天舔天天操天天爽| 日本又色又爽又黄又粗| 成人性黑人一级av| 天天操天天爽天天干| 国产精品成久久久久三级蜜臀av | 国产精品三级三级三级| 偷拍美女一区二区三区| 五十路熟女人妻一区二区9933| 97精品视频在线观看| 91极品新人『兔兔』精品新作| 女生自摸在线观看一区二区三区| 男女啪啪啪啪啪的网站| 91在线视频在线精品3| 激情五月婷婷免费视频| 成人av天堂丝袜在线观看 | 91九色porny国产蝌蚪视频| 亚洲欧美成人综合在线观看| 成人网18免费视频版国产 | 91破解版永久免费| 激情啪啪啪啪一区二区三区 | 亚洲av色香蕉一区二区三区| 成人福利视频免费在线| 色吉吉影音天天干天天操| 早川濑里奈av黑人番号| 人妻熟女在线一区二区| 91福利在线视频免费观看| 在线观看亚洲人成免费网址| 狠狠操操操操操操操操操| 少妇系列一区二区三区视频| 日本性感美女写真视频| 欧美另类z0z变态| 国产成人自拍视频播放| 亚洲成人精品女人久久久| 国产片免费观看在线观看| 久久丁香花五月天色婷婷| av天堂中文免费在线| 大肉大捧一进一出好爽在线视频| 国产卡一卡二卡三乱码手机| yy96视频在线观看| 喷水视频在线观看这里只有精品| 国产性生活中老年人视频网站| 含骚鸡巴玩逼逼视频| 婷婷久久久综合中文字幕| 亚洲国产精品久久久久久6| 阴茎插到阴道里面的视频| 精品suv一区二区69| 亚洲成人激情av在线| 又色又爽又黄又刺激av网站| 亚洲欧美清纯唯美另类| 偷拍自拍 中文字幕| 亚洲成人激情av在线| 78色精品一区二区三区| 91‖亚洲‖国产熟女| 国产亚洲成人免费在线观看| 插小穴高清无码中文字幕| 亚洲精品 日韩电影| 9久在线视频只有精品| 中文 成人 在线 视频| 在线观看成人国产电影| 国产普通话插插视频| 曰本无码人妻丰满熟妇啪啪| 国产精品国产三级国产精东 | 夜夜躁狠狠躁日日躁麻豆内射 | 日韩av有码一区二区三区4| 大鸡巴插入美女黑黑的阴毛| 精品美女久久久久久| 天天日天天日天天射天天干| 福利视频网久久91| 制丝袜业一区二区三区| 免费人成黄页网站在线观看国产| 老司机免费福利视频网| 老有所依在线观看完整版| 91九色porny国产在线| 久久精品美女免费视频| 91九色porny国产在线| jul—619中文字幕在线| 社区自拍揄拍尻屁你懂的| 97精品成人一区二区三区| 亚洲精品国偷自产在线观看蜜桃| 在线观看av亚洲情色| 天天射,天天操,天天说| 40道精品招牌菜特色| 2020av天堂网在线观看| 亚洲蜜臀av一区二区三区九色 | 伊人开心婷婷国产av| 99精品视频之69精品视频| 欧洲日韩亚洲一区二区三区| 亚洲精品麻豆免费在线观看| 狍和女人的王色毛片| 亚洲另类在线免费观看| 久久久久久久一区二区三| 人妻无码色噜噜狠狠狠狠色| 天天操天天干天天插| 美洲精品一二三产区区别| weyvv5国产成人精品的视频| av日韩在线观看大全| 91久久综合男人天堂| 国产三级精品三级在线不卡| 888欧美视频在线| 中文字幕 亚洲av| www天堂在线久久| 亚洲国产欧美一区二区丝袜黑人| 成人亚洲国产综合精品| 久久久精品999精品日本 | 久久丁香花五月天色婷婷| 最新中文字幕免费视频| 97色视频在线观看| brazzers欧熟精品系列| 国产自拍在线观看成人| 国产亚洲精品视频合集| 年轻的人妻被夫上司侵犯| 国产在线观看黄色视频| 国产白袜脚足J棉袜在线观看| 国产精品久久久黄网站| 亚洲av香蕉一区区二区三区犇| 亚洲高清国产自产av| 欧美香蕉人妻精品一区二区| 精品视频一区二区三区四区五区| 国产普通话插插视频| 性感美女高潮视频久久久| 啊啊好慢点插舔我逼啊啊啊视频| 日本性感美女三级视频| 又黄又刺激的午夜小视频| 精品高潮呻吟久久av| 欧美在线精品一区二区三区视频 | 国产成人精品一区在线观看| 一区二区三区蜜臀在线| 欧美在线偷拍视频免费看| 91国偷自产一区二区三区精品| av在线资源中文字幕| 亚洲精品成人网久久久久久小说| 硬鸡巴动态操女人逼视频| 在线观看欧美黄片一区二区三区| 成人性爱在线看四区| 人妻少妇性色欲欧美日韩| 春色激情网欧美成人| 日本五十路熟新垣里子| 青青青青操在线观看免费| 在线制服丝袜中文字幕| 2018在线福利视频| 国产成人综合一区2区| 91人妻人人做人人爽在线| 国产精品国产三级国产精东| 伊人综合免费在线视频| 99精品久久久久久久91蜜桃| 亚洲av黄色在线网站| 欧美第一页在线免费观看视频| 国产在线观看黄色视频| 国产成人精品亚洲男人的天堂| 欧美成人黄片一区二区三区 | 亚洲天堂av最新网址| 成人激情文学网人妻| 免费黄色成人午夜在线网站| 国产不卡av在线免费| 亚洲一区二区三区精品乱码| 77久久久久国产精产品| 青青草原网站在线观看| 大鸡吧插入女阴道黄色片| 亚洲av可乐操首页| 久久精品国产23696| 日韩美在线观看视频黄| 五月天中文字幕内射| 成人国产影院在线观看| 亚洲av日韩精品久久久| 免费在线看的黄片视频| 93人妻人人揉人人澡人人| 99精品亚洲av无码国产另类| 亚洲精品在线资源站| 黑人性生活视频免费看| 亚洲国产成人无码麻豆艾秋| 粉嫩小穴流水视频在线观看| 18禁网站一区二区三区四区| 中文字幕第三十八页久久| 91老熟女连续高潮对白| 亚洲的电影一区二区三区| 国产亚洲视频在线观看| 黄色录像鸡巴插进去| 制服丝袜在线人妻中文字幕| 91精品国产黑色丝袜| 在线免费观看日本伦理| 偷拍自拍亚洲视频在线观看| 日韩三级黄色片网站| 国产自拍在线观看成人| 2o22av在线视频| 亚洲区欧美区另类最新章节| 免费岛国喷水视频在线观看 | 黄色片黄色片wyaa| 久久精品亚洲成在人线a| 97香蕉碰碰人妻国产樱花| 97年大学生大白天操逼| 91av精品视频在线| 亚洲精品麻豆免费在线观看| 亚洲熟妇久久无码精品| 日韩二区视频一线天婷婷五| 亚洲欧美福利在线观看| 午夜美女少妇福利视频| 国产在线拍揄自揄视频网站| 99国内小视频在现欢看| av中文字幕在线观看第三页| 自拍偷拍vs一区二区三区| 亚洲 清纯 国产com| 国产视频网站国产视频| 偷偷玩弄新婚人妻h视频| 免费av岛国天堂网站| 狠狠操操操操操操操操操| 晚上一个人看操B片| 国产精品一区二区三区蜜臀av| 国产一区av澳门在线观看| 免费黄页网站4188| 啊啊啊想要被插进去视频| 日韩精品中文字幕在线| 日韩熟女av天堂系列| 91麻豆精品秘密入口在线观看| 国产老熟女伦老熟妇ⅹ| 亚洲激情偷拍一区二区| 性欧美激情久久久久久久| 红杏久久av人妻一区| 97超碰最新免费在线观看| 亚洲 色图 偷拍 欧美| 久草电影免费在线观看| www日韩毛片av| 91麻豆精品91久久久久同性| 中文乱理伦片在线观看| 白嫩白嫩美女极品国产在线观看 | 日本三极片中文字幕| 中文字幕人妻三级在线观看| 大黑人性xxxxbbbb| av老司机精品在线观看| 亚洲在线观看中文字幕av| 青青在线视频性感少妇和隔壁黑丝| 人人妻人人爱人人草| 日本免费视频午夜福利视频| 97人妻夜夜爽二区欧美极品| 欧美男人大鸡吧插女人视频| 欧美伊人久久大香线蕉综合| 99热色原网这里只有精品| 国产综合视频在线看片| 福利一二三在线视频观看| 11久久久久久久久久久| 国产亚洲精品视频合集| 中文字幕日本人妻中出| 美女在线观看日本亚洲一区| 久久尻中国美女视频| 国产美女一区在线观看| av在线资源中文字幕| 最新国产精品网址在线观看| 亚洲成人国产综合一区| 天天日天天干天天要| av在线免费观看亚洲天堂| av在线免费资源站| 日韩精品中文字幕播放| 日本性感美女三级视频| 免费福利av在线一区二区三区| 激情色图一区二区三区| 中文字幕人妻av在线观看| 亚洲另类图片蜜臀av| 国产熟妇一区二区三区av| 在线观看国产网站资源| 久久综合老鸭窝色综合久久| 538精品在线观看视频| 天天日天天鲁天天操| 9色在线视频免费观看| 成年人啪啪视频在线观看| 鸡巴操逼一级黄色气| 亚洲精品国偷自产在线观看蜜桃| 国产亚洲精品视频合集| 超级av免费观看一区二区三区| 中文字幕高清资源站| 国产视频一区二区午夜| 日韩不卡中文在线视频网站| 天天日天天天天天天天天天天| 把腿张开让我插进去视频| 国产高潮无码喷水AV片在线观看| 在线观看av观看av| 亚洲人妻国产精品综合| 国产精品中文av在线播放| 成人影片高清在线观看| 韩国三级aaaaa高清视频| av在线免费观看亚洲天堂| 老有所依在线观看完整版| 蜜臀av久久久久久久| 久久永久免费精品人妻专区| 色婷婷精品大在线观看| 大陆精品一区二区三区久久| 亚洲卡1卡2卡三卡四老狼| 三上悠亚和黑人665番号| 99久久成人日韩欧美精品| 欧美精品免费aaaaaa| 在线观看亚洲人成免费网址| 天堂中文字幕翔田av| 黄色片年轻人在线观看| 亚洲精品无码久久久久不卡| 中文字幕 亚洲av| 亚洲av无码成人精品区辽| 亚洲va天堂va国产va久| 2022天天干天天操| 国产精品视频男人的天堂| 日韩美女搞黄视频免费| tube69日本少妇| 老熟妇凹凸淫老妇女av在线观看| 成人福利视频免费在线| 在线可以看的视频你懂的| 又色又爽又黄又刺激av网站| 97香蕉碰碰人妻国产樱花| 亚洲高清视频在线不卡| 亚洲人妻视频在线网| 亚洲精品午夜久久久久| 白白操白白色在线免费视频| 美女av色播在线播放| 偷拍3456eee| 女生被男生插的视频网站| 亚洲av男人天堂久久| 中国视频一区二区三区| 美女福利视频网址导航| 免费一级黄色av网站| 亚洲中文字幕综合小综合| 早川濑里奈av黑人番号| 午夜影院在线观看视频羞羞羞| 福利视频网久久91| 欧美精品免费aaaaaa| 青青青青爽手机在线| 换爱交换乱高清大片| 国产精选一区在线播放| 亚洲自拍偷拍综合色| 淫秽激情视频免费观看| 人妻熟女中文字幕aⅴ在线| 亚洲 欧美 自拍 偷拍 在线| 91免费福利网91麻豆国产精品| 91she九色精品国产| nagger可以指黑人吗| 日本性感美女三级视频| 人妻自拍视频中国大陆| 在线观看一区二区三级| 91国内视频在线观看| 99久久成人日韩欧美精品| 欧美男人大鸡吧插女人视频| 国产精品国产精品一区二区| 制丝袜业一区二区三区| 蜜臀av久久久久久久| 久久亚洲天堂中文对白| 啊啊啊视频试看人妻| 国产乱子伦精品视频潮优女| 青娱乐最新视频在线| 成人蜜桃美臀九一一区二区三区| 熟女在线视频一区二区三区| 日美女屁股黄邑视频| 中文字幕第三十八页久久| 美女 午夜 在线视频| 久久免看30视频口爆视频| 五十路丰满人妻熟妇| 中文字幕在线第一页成人 | 极品粉嫩小泬白浆20p主播| 国产一区二区三免费视频| gav成人免费播放| 三级等保密码要求条款| 日本黄在免费看视频| 国产在线自在拍91国语自产精品| 国产精品视频资源在线播放| 国产黄色片在线收看| 少妇一区二区三区久久久| 青青色国产视频在线| 91超碰青青中文字幕| 午夜美女福利小视频| 亚洲国产欧美一区二区三区久久 | 欧美一区二区三区高清不卡tv| 78色精品一区二区三区| 国产中文字幕四区在线观看| 国产内射中出在线观看| 80电影天堂网官网| 亚洲欧美色一区二区| 国产美女精品福利在线| 人妻在线精品录音叫床| 2012中文字幕在线高清| 适合午夜一个人看的视频| 亚洲欧美成人综合视频| 欧美精产国品一二三产品价格| 十八禁在线观看地址免费| 激情伦理欧美日韩中文字幕| 日本www中文字幕| 人人在线视频一区二区| 懂色av蜜桃a v| 久久精品国产999| 一级a看免费观看网站| 天天日天天摸天天爱| 亚洲一区二区三区精品视频在线| 男人天堂最新地址av| 欧美精品欧美极品欧美视频| 色哟哟在线网站入口| 国产精品人妻66p| 精品久久久久久久久久久a√国产| 中文字幕+中文字幕| 自拍偷拍一区二区三区图片| 啊啊好大好爽啊啊操我啊啊视频| 亚洲精品高清自拍av| 免费成人av中文字幕| 亚洲国产精品免费在线观看| 国产精品国产三级国产精东| 中文字幕网站你懂的| 3337p日本欧洲大胆色噜噜| 色狠狠av线不卡香蕉一区二区| 亚洲av无码成人精品区辽| 日本精品视频不卡一二三| 涩爱综合久久五月蜜臀| 亚洲午夜高清在线观看| 日本少妇在线视频大香蕉在线观看| 中文字幕乱码人妻电影| 经典国语激情内射视频| 中文字幕乱码av资源| 国产精品久久久黄网站| 国产精品人妻66p| 女同性ⅹxx女同hd| 亚洲国产成人在线一区| 精品国产亚洲av一淫| 人人妻人人澡人人爽人人dvl| 91社福利《在线观看| 午夜久久香蕉电影网| 天堂女人av一区二区| 亚洲在线一区二区欧美| 亚洲综合图片20p| 亚洲成人情色电影在线观看| 19一区二区三区在线播放| 又色又爽又黄的美女裸体| 免费大片在线观看视频网站| 婷婷综合亚洲爱久久| 黑人大几巴狂插日本少妇| 亚洲日本一区二区三区|