国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

基于Docker+K8S+GitLab/SVN+Jenkins+Harbor搭建持續(xù)集成交付環(huán)境的詳細(xì)教程

 更新時(shí)間:2021年05月12日 17:19:23   作者:冰河團(tuán)隊(duì)  
K8S全稱是Kubernetes,是一個(gè)全新的基于容器技術(shù)的分布式架構(gòu)領(lǐng)先方案,這篇文章主要介紹了基于Docker+K8S+GitLab/SVN+Jenkins+Harbor搭建持續(xù)集成交付環(huán)境(環(huán)境搭建篇),對(duì)docker K8S持續(xù)集成交付環(huán)境相關(guān)知識(shí)感興趣的朋友一起看看吧

環(huán)境搭建概述

親愛的家人們可以到鏈接:http://xiazai.jb51.net/202105/yuanma/javayaml_jb51.rar  下載所需要的yaml文件。

1.K8S是什么?

K8S全稱是Kubernetes,是一個(gè)全新的基于容器技術(shù)的分布式架構(gòu)領(lǐng)先方案,基于容器技術(shù),目的是實(shí)現(xiàn)資源管理的自動(dòng)化,以及跨多個(gè)數(shù)據(jù)中心的資源利用率的最大化。

如果我們的系統(tǒng)設(shè)計(jì)遵循了kubernetes的設(shè)計(jì)思想,那么傳統(tǒng)系統(tǒng)架構(gòu)中那些和業(yè)務(wù)沒有多大關(guān)系的底層代碼或功能模塊,都可以使用K8S來管理,我們不必再費(fèi)心于負(fù)載均衡的選型和部署實(shí)施問題,不必再考慮引入或自己開發(fā)一個(gè)復(fù)雜的服務(wù)治理框架,不必再頭疼與服務(wù)監(jiān)控和故障處理模塊的開發(fā)??傊褂胟ubernetes提供的解決方案,會(huì)大大減少開發(fā)成本,同時(shí)可以將精力更加集中于業(yè)務(wù)本身,而且由于kubernetes提供了強(qiáng)大的自動(dòng)化機(jī)制,所以系統(tǒng)后期的運(yùn)維難度和運(yùn)維成本大幅降低。

2.為什么要用K8S?

Docker 這個(gè)新興的容器化技術(shù)當(dāng)前已經(jīng)被很多公司所采用,其從單機(jī)走向集群已成必然,而云計(jì)算的蓬勃發(fā)展正在加速這一進(jìn)程。Kubernetes 作為當(dāng)前唯一被業(yè)界廣泛認(rèn)可和看好的 Docker 分布式系統(tǒng)解決方案??梢灶A(yù)見,在未來幾年內(nèi),會(huì)有大量的新系統(tǒng)選擇它,不管是運(yùn)行在企業(yè)本地服務(wù)器上還是被托管到公有云上。

3.使用K8S有哪些好處?

使用Kubernetes就是在全面部署微服務(wù)架構(gòu)。微服務(wù)架構(gòu)的核心就是將一個(gè)巨大的單體應(yīng)用分解為很多小的互相連接的微服務(wù),一個(gè)微服務(wù)背后可能有多個(gè)實(shí)例副本在支撐,副本的數(shù)量可能會(huì)隨著系統(tǒng)的負(fù)荷變化而進(jìn)行調(diào)整,內(nèi)嵌的負(fù)載均衡器在 k8s 平臺(tái)中有多個(gè)實(shí)例副本在支撐,副本的數(shù)量可能會(huì)隨著系統(tǒng)的負(fù)荷變化而進(jìn)行調(diào)整,內(nèi)嵌的負(fù)載均衡器 在k8s 平臺(tái)中發(fā)揮了重要的作用。微服務(wù)架構(gòu)使得每個(gè)服務(wù)都可以由專門的開發(fā)團(tuán)隊(duì)來開發(fā),開發(fā)者可以自由選擇開發(fā)技術(shù),這對(duì)于大規(guī)模團(tuán)隊(duì)來說很有價(jià)值。另外,每個(gè)微服務(wù)獨(dú)立開發(fā)、升級(jí)、擴(kuò)展,使得系統(tǒng)具備很高的穩(wěn)定性和快速迭代進(jìn)化能力。

4.環(huán)境構(gòu)成

整套環(huán)境的搭建包含:Docker環(huán)境的搭建、docker-compose環(huán)境的搭建、K8S集群的搭建、GitLab代碼倉庫的搭建、SVN倉庫的搭建、Jenkins自動(dòng)化部署環(huán)境的搭建、Harbor私有倉庫的搭建。

本文檔中,整套環(huán)境的搭建包括:

  • 安裝Docker環(huán)境
  • 安裝docker-compose
  • 安裝K8S集群環(huán)境
  • 重啟K8S集群引起的問題
  • K8S安裝ingress-nginx
  • K8S安裝gitlab代碼倉庫
  • 安裝Harbor私有倉庫
  • 安裝Jenkins
  • 物理機(jī)安裝SVN(推薦)
  • 物理機(jī)安裝Jenkins(推薦)
  • 配置Jenkins運(yùn)行環(huán)境
  • Jenkins發(fā)布Docker項(xiàng)目到K8S

服務(wù)器規(guī)劃

IP 主機(jī)名 節(jié)點(diǎn) 操作系統(tǒng)
192.168.0.10 test10 K8S Master CentOS 8.0.1905
192.168.0.11 test11 K8S Worker CentOS 8.0.1905
192.168.0.12 test12 K8S Worker CentOS 8.0.1905

安裝環(huán)境

軟件名稱 軟件版本 說明
Docker 19.03.8 提供容器環(huán)境
docker-compose 1.25.5 定義和運(yùn)行由多個(gè)容器組成的應(yīng)用
K8S 1.18.2 是一個(gè)開源的,用于管理云平臺(tái)中多個(gè)主機(jī)上的容器化的應(yīng)用,Kubernetes的目標(biāo)是讓部署容器化的應(yīng)用簡單并且高效(powerful),Kubernetes提供了應(yīng)用部署,規(guī)劃,更新,維護(hù)的一種機(jī)制。
GitLab 12.1.6 代碼倉庫
Harbor 1.10.2 私有鏡像倉庫
Jenkins 2.222.3 持續(xù)集成交付

安裝Docker環(huán)境

Docker 是一個(gè)開源的應(yīng)用容器引擎,基于 Go 語言 并遵從 Apache2.0 協(xié)議開源。

Docker 可以讓開發(fā)者打包他們的應(yīng)用以及依賴包到一個(gè)輕量級(jí)、可移植的容器中,然后發(fā)布到任何流行的 Linux 機(jī)器上,也可以實(shí)現(xiàn)虛擬化。

本文檔基于Docker 19.03.8 版本搭建Docker環(huán)境。

在所有服務(wù)器上創(chuàng)建install_docker.sh腳本,腳本內(nèi)容如下所示。

#使用阿里云鏡像中心
export REGISTRY_MIRROR=https://registry.cn-hangzhou.aliyuncs.com
#安裝yum工具
dnf install yum*
#安裝docker環(huán)境
yum install -y yum-utils device-mapper-persistent-data lvm2
#配置Docker的yum源
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
#安裝容器插件
dnf install https://mirrors.aliyun.com/docker-ce/linux/centos/7/x86_64/stable/Packages/containerd.io-1.2.13-3.1.el7.x86_64.rpm
#指定安裝docker 19.03.8版本
yum install -y docker-ce-19.03.8 docker-ce-cli-19.03.8
#設(shè)置Docker開機(jī)啟動(dòng)
systemctl enable docker.service
#啟動(dòng)Docker
systemctl start docker.service
#查看Docker版本
docker version

在每臺(tái)服務(wù)器上為install_docker.sh腳本賦予可執(zhí)行權(quán)限,并執(zhí)行腳本,如下所示。

# 賦予install_docker.sh腳本可執(zhí)行權(quán)限
chmod a+x ./install_docker.sh
# 執(zhí)行install_docker.sh腳本
./install_docker.sh

安裝docker-compose

Compose 是用于定義和運(yùn)行多容器 Docker 應(yīng)用程序的工具。通過 Compose,您可以使用 YML 文件來配置應(yīng)用程序需要的所有服務(wù)。然后,使用一個(gè)命令,就可以從 YML 文件配置中創(chuàng)建并啟動(dòng)所有服務(wù)。

注意:在每臺(tái)服務(wù)器上安裝docker-compose

1.下載docker-compose文件

#下載并安裝docker-compose
curl -L https://github.com/docker/compose/releases/download/1.25.5/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose 

2.為docker-compose文件賦予可執(zhí)行權(quán)限

#賦予docker-compose可執(zhí)行權(quán)限
chmod a+x /usr/local/bin/docker-compose

3.查看docker-compose版本

#查看docker-compose版本
[root@binghe ~]# docker-compose version
docker-compose version 1.25.5, build 8a1c60f6
docker-py version: 4.1.0
CPython version: 3.7.5
OpenSSL version: OpenSSL 1.1.0l  10 Sep 2019

安裝K8S集群環(huán)境

Kubernetes是一個(gè)開源的,用于管理云平臺(tái)中多個(gè)主機(jī)上的容器化的應(yīng)用,Kubernetes的目標(biāo)是讓部署容器化的應(yīng)用簡單并且高效(powerful),Kubernetes提供了應(yīng)用部署,規(guī)劃,更新,維護(hù)的一種機(jī)制。

本文檔基于K8S 1.8.12版本來搭建K8S集群

安裝K8S基礎(chǔ)環(huán)境

在所有服務(wù)器上創(chuàng)建install_k8s.sh腳本文件,腳本文件的內(nèi)容如下所示。

#################配置阿里云鏡像加速器開始########################
mkdir -p /etc/docker
tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://zz3sblpi.mirror.aliyuncs.com"]
}
EOF
systemctl daemon-reload
systemctl restart docker
######################配置阿里云鏡像加速器結(jié)束#########################
#安裝nfs-utils
yum install -y nfs-utils
#安裝wget軟件下載命令
yum install -y wget

#啟動(dòng)nfs-server
systemctl start nfs-server
#配置nfs-server開機(jī)自啟動(dòng)
systemctl enable nfs-server

#關(guān)閉防火墻
systemctl stop firewalld
#取消防火墻開機(jī)自啟動(dòng)
systemctl disable firewalld

#關(guān)閉SeLinux
setenforce 0
sed -i "s/SELINUX=enforcing/SELINUX=disabled/g" /etc/selinux/config

# 關(guān)閉 swap
swapoff -a
yes | cp /etc/fstab /etc/fstab_bak
cat /etc/fstab_bak |grep -v swap > /etc/fstab

############################修改 /etc/sysctl.conf開始###########################
# 如果有配置,則修改
sed -i "s#^net.ipv4.ip_forward.*#net.ipv4.ip_forward=1#g"  /etc/sysctl.conf
sed -i "s#^net.bridge.bridge-nf-call-ip6tables.*#net.bridge.bridge-nf-call-ip6tables=1#g"  /etc/sysctl.conf
sed -i "s#^net.bridge.bridge-nf-call-iptables.*#net.bridge.bridge-nf-call-iptables=1#g"  /etc/sysctl.conf
sed -i "s#^net.ipv6.conf.all.disable_ipv6.*#net.ipv6.conf.all.disable_ipv6=1#g"  /etc/sysctl.conf
sed -i "s#^net.ipv6.conf.default.disable_ipv6.*#net.ipv6.conf.default.disable_ipv6=1#g"  /etc/sysctl.conf
sed -i "s#^net.ipv6.conf.lo.disable_ipv6.*#net.ipv6.conf.lo.disable_ipv6=1#g"  /etc/sysctl.conf
sed -i "s#^net.ipv6.conf.all.forwarding.*#net.ipv6.conf.all.forwarding=1#g"  /etc/sysctl.conf
# 可能沒有,追加
echo "net.ipv4.ip_forward = 1" >> /etc/sysctl.conf
echo "net.bridge.bridge-nf-call-ip6tables = 1" >> /etc/sysctl.conf
echo "net.bridge.bridge-nf-call-iptables = 1" >> /etc/sysctl.conf
echo "net.ipv6.conf.all.disable_ipv6 = 1" >> /etc/sysctl.conf
echo "net.ipv6.conf.default.disable_ipv6 = 1" >> /etc/sysctl.conf
echo "net.ipv6.conf.lo.disable_ipv6 = 1" >> /etc/sysctl.conf
echo "net.ipv6.conf.all.forwarding = 1"  >> /etc/sysctl.conf
############################修改 /etc/sysctl.conf結(jié)束###########################
# 執(zhí)行命令使修改后的/etc/sysctl.conf文件生效
sysctl -p

################# 配置K8S的yum源開始#############################
cat <<EOF > /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
baseurl=http://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=0
repo_gpgcheck=0
gpgkey=http://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg
       http://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF
################# 配置K8S的yum源結(jié)束#############################

# 卸載舊版本K8S
yum remove -y kubelet kubeadm kubectl

# 安裝kubelet、kubeadm、kubectl,這里我安裝的是1.18.2版本,你也可以安裝1.17.2版本
yum install -y kubelet-1.18.2 kubeadm-1.18.2 kubectl-1.18.2

# 修改docker Cgroup Driver為systemd
# # 將/usr/lib/systemd/system/docker.service文件中的這一行 ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock
# # 修改為 ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock --exec-opt native.cgroupdriver=systemd
# 如果不修改,在添加 worker 節(jié)點(diǎn)時(shí)可能會(huì)碰到如下錯(cuò)誤
# [WARNING IsDockerSystemdCheck]: detected "cgroupfs" as the Docker cgroup driver. The recommended driver is "systemd". 
# Please follow the guide at https://kubernetes.io/docs/setup/cri/
sed -i "s#^ExecStart=/usr/bin/dockerd.*#ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock --exec-opt native.cgroupdriver=systemd#g" /usr/lib/systemd/system/docker.service

# 設(shè)置 docker 鏡像,提高 docker 鏡像下載速度和穩(wěn)定性
# 如果訪問 https://hub.docker.io 速度非常穩(wěn)定,也可以跳過這個(gè)步驟,一般不需配置
# curl -sSL https://kuboard.cn/install-script/set_mirror.sh | sh -s ${REGISTRY_MIRROR}

# 重新加載配置文件
systemctl daemon-reload
#重啟 docker
systemctl restart docker
# 將kubelet設(shè)置為開機(jī)啟動(dòng)并啟動(dòng)kubelet
systemctl enable kubelet && systemctl start kubelet
# 查看docker版本
docker version

在每臺(tái)服務(wù)器上為install_k8s.sh腳本賦予可執(zhí)行權(quán)限,并執(zhí)行腳本

# 賦予install_k8s.sh腳本可執(zhí)行權(quán)限
chmod a+x ./install_k8s.sh
# 運(yùn)行install_k8s.sh腳本
./install_k8s.sh

初始化Master節(jié)點(diǎn)

只在test10服務(wù)器上執(zhí)行的操作。

1.初始化Master節(jié)點(diǎn)的網(wǎng)絡(luò)環(huán)境

注意:下面的命令需要在命令行手動(dòng)執(zhí)行。

# 只在 master 節(jié)點(diǎn)執(zhí)行
# export 命令只在當(dāng)前 shell 會(huì)話中有效,開啟新的 shell 窗口后,如果要繼續(xù)安裝過程,請(qǐng)重新執(zhí)行此處的 export 命令
export MASTER_IP=192.168.0.10
# 替換 k8s.master 為 您想要的 dnsName
export APISERVER_NAME=k8s.master
# Kubernetes 容器組所在的網(wǎng)段,該網(wǎng)段安裝完成后,由 kubernetes 創(chuàng)建,事先并不存在于物理網(wǎng)絡(luò)中
export POD_SUBNET=172.18.0.1/16
echo "${MASTER_IP}    ${APISERVER_NAME}" >> /etc/hosts

2.初始化Master節(jié)點(diǎn)

在test10服務(wù)器上創(chuàng)建init_master.sh腳本文件,文件內(nèi)容如下所示。

#!/bin/bash
# 腳本出錯(cuò)時(shí)終止執(zhí)行
set -e

if [ ${#POD_SUBNET} -eq 0 ] || [ ${#APISERVER_NAME} -eq 0 ]; then
  echo -e "\033[31;1m請(qǐng)確保您已經(jīng)設(shè)置了環(huán)境變量 POD_SUBNET 和 APISERVER_NAME \033[0m"
  echo 當(dāng)前POD_SUBNET=$POD_SUBNET
  echo 當(dāng)前APISERVER_NAME=$APISERVER_NAME
  exit 1
fi


# 查看完整配置選項(xiàng) https://godoc.org/k8s.io/kubernetes/cmd/kubeadm/app/apis/kubeadm/v1beta2
rm -f ./kubeadm-config.yaml
cat <<EOF > ./kubeadm-config.yaml
apiVersion: kubeadm.k8s.io/v1beta2
kind: ClusterConfiguration
kubernetesVersion: v1.18.2
imageRepository: registry.cn-hangzhou.aliyuncs.com/google_containers
controlPlaneEndpoint: "${APISERVER_NAME}:6443"
networking:
  serviceSubnet: "10.96.0.0/16"
  podSubnet: "${POD_SUBNET}"
  dnsDomain: "cluster.local"
EOF

# kubeadm init
# 初始化kebeadm
kubeadm init --config=kubeadm-config.yaml --upload-certs

# 配置 kubectl
rm -rf /root/.kube/
mkdir /root/.kube/
cp -i /etc/kubernetes/admin.conf /root/.kube/config

# 安裝 calico 網(wǎng)絡(luò)插件
# 參考文檔 https://docs.projectcalico.org/v3.13/getting-started/kubernetes/self-managed-onprem/onpremises
echo "安裝calico-3.13.1"
rm -f calico-3.13.1.yaml
wget https://kuboard.cn/install-script/calico/calico-3.13.1.yaml
kubectl apply -f calico-3.13.1.yaml

賦予init_master.sh腳本文件可執(zhí)行權(quán)限并執(zhí)行腳本。

# 賦予init_master.sh文件可執(zhí)行權(quán)限
chmod a+x ./init_master.sh
# 運(yùn)行init_master.sh腳本
./init_master.sh

3.查看Master節(jié)點(diǎn)的初始化結(jié)果

(1)確保所有容器組處于Running狀態(tài)

# 執(zhí)行如下命令,等待 3-10 分鐘,直到所有的容器組處于 Running 狀態(tài)
watch kubectl get pod -n kube-system -o wide

具體執(zhí)行如下所示。

[root@test10 ~]# watch kubectl get pod -n kube-system -o wide
Every 2.0s: kubectl get pod -n kube-system -o wide                                                                                                                          test10: Sun May 10 11:01:32 2020

NAME                                       READY   STATUS    RESTARTS   AGE    IP                NODE        NOMINATED NODE   READINESS GATES          
calico-kube-controllers-5b8b769fcd-5dtlp   1/1     Running   0          118s   172.18.203.66     test10   <none>           <none>          
calico-node-fnv8g                          1/1     Running   0          118s   192.168.0.10   test10   <none>           <none>          
coredns-546565776c-27t7h                   1/1     Running   0          2m1s   172.18.203.67     test10   <none>           <none>          
coredns-546565776c-hjb8z                   1/1     Running   0          2m1s   172.18.203.65     test10   <none>           <none>          
etcd-test10                             1/1     Running   0          2m7s   192.168.0.10   test10   <none>           <none>          
kube-apiserver-test10                   1/1     Running   0          2m7s   192.168.0.10   test10   <none>           <none>          
kube-controller-manager-test10          1/1     Running   0          2m7s   192.168.0.10   test10   <none>           <none>          
kube-proxy-dvgsr                           1/1     Running   0          2m1s   192.168.0.10   test10   <none>           <none>          
kube-scheduler-test10                   1/1     Running   0          2m7s   192.168.0.10   test10   <none> 

(2) 查看 Master 節(jié)點(diǎn)初始化結(jié)果

# 查看Master節(jié)點(diǎn)的初始化結(jié)果
kubectl get nodes -o wide

具體執(zhí)行如下所示。

[root@test10 ~]# kubectl get nodes -o wide
NAME        STATUS   ROLES    AGE     VERSION   INTERNAL-IP       EXTERNAL-IP   OS-IMAGE                KERNEL-VERSION         CONTAINER-RUNTIME
test10   Ready    master   3m28s   v1.18.2   192.168.0.10   <none>        CentOS Linux 8 (Core)   4.18.0-80.el8.x86_64   docker://19.3.8

初始化Worker節(jié)點(diǎn)

1.獲取join命令參數(shù)

在Master節(jié)點(diǎn)(test10服務(wù)器)上執(zhí)行如下命令獲取join命令參數(shù)。

kubeadm token create --print-join-command

具體執(zhí)行如下所示。

[root@test10 ~]# kubeadm token create --print-join-command
W0510 11:04:34.828126   56132 configset.go:202] WARNING: kubeadm cannot validate component configs for API groups [kubelet.config.k8s.io kubeproxy.config.k8s.io]
kubeadm join k8s.master:6443 --token 8nblts.62xytoqufwsqzko2     --discovery-token-ca-cert-hash sha256:1717cc3e34f6a56b642b5751796530e367aa73f4113d09994ac3455e33047c0d 

其中,有如下一行輸出。

kubeadm join k8s.master:6443 --token 8nblts.62xytoqufwsqzko2     --discovery-token-ca-cert-hash sha256:1717cc3e34f6a56b642b5751796530e367aa73f4113d09994ac3455e33047c0d 

這行代碼就是獲取到的join命令。

注意:join命令中的token的有效時(shí)間為 2 個(gè)小時(shí),2小時(shí)內(nèi),可以使用此 token 初始化任意數(shù)量的 worker 節(jié)點(diǎn)。

2.初始化Worker節(jié)點(diǎn)

針對(duì)所有的 worker 節(jié)點(diǎn)執(zhí)行,在這里,就是在test11服務(wù)器和test12服務(wù)器上執(zhí)行。

在命令分別手動(dòng)執(zhí)行如下命令。

# 只在 worker 節(jié)點(diǎn)執(zhí)行
# 192.168.0.10 為 master 節(jié)點(diǎn)的內(nèi)網(wǎng) IP
export MASTER_IP=192.168.0.10
# 替換 k8s.master 為初始化 master 節(jié)點(diǎn)時(shí)所使用的 APISERVER_NAME
export APISERVER_NAME=k8s.master
echo "${MASTER_IP}    ${APISERVER_NAME}" >> /etc/hosts

# 替換為 master 節(jié)點(diǎn)上 kubeadm token create 命令輸出的join
kubeadm join k8s.master:6443 --token 8nblts.62xytoqufwsqzko2     --discovery-token-ca-cert-hash sha256:1717cc3e34f6a56b642b5751796530e367aa73f4113d09994ac3455e33047c0d 

具體執(zhí)行如下所示。

[root@test11 ~]# export MASTER_IP=192.168.0.10
[root@test11 ~]# export APISERVER_NAME=k8s.master
[root@test11 ~]# echo "${MASTER_IP}    ${APISERVER_NAME}" >> /etc/hosts
[root@test11 ~]# kubeadm join k8s.master:6443 --token 8nblts.62xytoqufwsqzko2     --discovery-token-ca-cert-hash sha256:1717cc3e34f6a56b642b5751796530e367aa73f4113d09994ac3455e33047c0d 
W0510 11:08:27.709263   42795 join.go:346] [preflight] WARNING: JoinControlPane.controlPlane settings will be ignored when control-plane flag is not set.
[preflight] Running pre-flight checks
        [WARNING FileExisting-tc]: tc not found in system path
[preflight] Reading configuration from the cluster...
[preflight] FYI: You can look at this config file with 'kubectl -n kube-system get cm kubeadm-config -oyaml'
[kubelet-start] Downloading configuration for the kubelet from the "kubelet-config-1.18" ConfigMap in the kube-system namespace
[kubelet-start] Writing kubelet configuration to file "/var/lib/kubelet/config.yaml"
[kubelet-start] Writing kubelet environment file with flags to file "/var/lib/kubelet/kubeadm-flags.env"
[kubelet-start] Starting the kubelet
[kubelet-start] Waiting for the kubelet to perform the TLS Bootstrap...

This node has joined the cluster:
* Certificate signing request was sent to apiserver and a response was received.
* The Kubelet was informed of the new secure connection details.

Run 'kubectl get nodes' on the control-plane to see this node join the cluster.

根據(jù)輸出結(jié)果可以看出,Worker節(jié)點(diǎn)加入了K8S集群。

注意:kubeadm join…就是master 節(jié)點(diǎn)上 kubeadm token create 命令輸出的join。

3.查看初始化結(jié)果

在Master節(jié)點(diǎn)(test10服務(wù)器)執(zhí)行如下命令查看初始化結(jié)果。

kubectl get nodes -o wide

具體執(zhí)行如下所示。

[root@test10 ~]# kubectl get nodes
NAME        STATUS   ROLES    AGE     VERSION
test10   Ready    master   20m     v1.18.2
test11   Ready    <none>   2m46s   v1.18.2
test12   Ready    <none>   2m46s   v1.18.2

注意:kubectl get nodes命令后面加上-o wide參數(shù)可以輸出更多的信息。

重啟K8S集群引起的問題

1.Worker節(jié)點(diǎn)故障不能啟動(dòng)

Master 節(jié)點(diǎn)的 IP 地址發(fā)生變化,導(dǎo)致 worker 節(jié)點(diǎn)不能啟動(dòng)。需要重新安裝K8S集群,并確保所有節(jié)點(diǎn)都有固定的內(nèi)網(wǎng) IP 地址。

2.Pod崩潰或不能正常訪問

重啟服務(wù)器后使用如下命令查看Pod的運(yùn)行狀態(tài)。

#查看所有pod的運(yùn)行情況
kubectl get pods --all-namespaces

發(fā)現(xiàn)很多 Pod 不在 Running 狀態(tài),此時(shí),需要使用如下命令刪除運(yùn)行不正常的Pod。

kubectl delete pod <pod-name> -n <pod-namespece>

注意:如果Pod 是使用 Deployment、StatefulSet 等控制器創(chuàng)建的,K8S 將創(chuàng)建新的 Pod 作為替代,重新啟動(dòng)的 Pod 通常能夠正常工作。

其中,pod-name表示運(yùn)行在K8S中的pod的名稱,pod-namespece表示命名空間。例如,需要?jiǎng)h除pod名稱為pod-test,命名空間為pod-test-namespace的pod,可以使用下面的命令。

kubectl delete pod pod-test -n pod-test-namespace

K8S安裝ingress-nginx

作為反向代理將外部流量導(dǎo)入集群內(nèi)部,將 Kubernetes 內(nèi)部的 Service 暴露給外部,在 Ingress 對(duì)象中通過域名匹配 Service,這樣就可以直接通過域名訪問到集群內(nèi)部的服務(wù)了。相對(duì)于 traefik 來說,nginx-ingress 性能更加優(yōu)秀。

注意:在Master節(jié)點(diǎn)(test10服務(wù)器上執(zhí)行)

1.創(chuàng)建ingress-nginx命名空間

創(chuàng)建ingress-nginx-namespace.yaml文件,主要的作用是創(chuàng)建ingress-nginx命名空間,文件內(nèi)容如下所示。

apiVersion: v1
kind: Namespace
metadata:
  name: ingress-nginx
  labels:
    name: ingress-nginx

執(zhí)行如下命令創(chuàng)建ingress-nginx命名空間。

kubectl apply -f ingress-nginx-namespace.yaml

2.安裝ingress controller

創(chuàng)建ingress-nginx-mandatory.yaml文件,主要的作用是安裝ingress-nginx。文件內(nèi)容如下所示。

apiVersion: v1
kind: Namespace
metadata:
  name: ingress-nginx

---

apiVersion: apps/v1
kind: Deployment
metadata:
  name: default-http-backend
  labels:
    app.kubernetes.io/name: default-http-backend
    app.kubernetes.io/part-of: ingress-nginx
  namespace: ingress-nginx
spec:
  replicas: 1
  selector:
    matchLabels:
      app.kubernetes.io/name: default-http-backend
      app.kubernetes.io/part-of: ingress-nginx
  template:
    metadata:
      labels:
        app.kubernetes.io/name: default-http-backend
        app.kubernetes.io/part-of: ingress-nginx
    spec:
      terminationGracePeriodSeconds: 60
      containers:
        - name: default-http-backend
          # Any image is permissible as long as:
          # 1. It serves a 404 page at /
          # 2. It serves 200 on a /healthz endpoint
          image: registry.cn-qingdao.aliyuncs.com/kubernetes_xingej/defaultbackend-amd64:1.5
          livenessProbe:
            httpGet:
              path: /healthz
              port: 8080
              scheme: HTTP
            initialDelaySeconds: 30
            timeoutSeconds: 5
          ports:
            - containerPort: 8080
          resources:
            limits:
              cpu: 10m
              memory: 20Mi
            requests:
              cpu: 10m
              memory: 20Mi

---
apiVersion: v1
kind: Service
metadata:
  name: default-http-backend
  namespace: ingress-nginx
  labels:
    app.kubernetes.io/name: default-http-backend
    app.kubernetes.io/part-of: ingress-nginx
spec:
  ports:
    - port: 80
      targetPort: 8080
  selector:
    app.kubernetes.io/name: default-http-backend
    app.kubernetes.io/part-of: ingress-nginx

---

kind: ConfigMap
apiVersion: v1
metadata:
  name: nginx-configuration
  namespace: ingress-nginx
  labels:
    app.kubernetes.io/name: ingress-nginx
    app.kubernetes.io/part-of: ingress-nginx

---

kind: ConfigMap
apiVersion: v1
metadata:
  name: tcp-services
  namespace: ingress-nginx
  labels:
    app.kubernetes.io/name: ingress-nginx
    app.kubernetes.io/part-of: ingress-nginx

---

kind: ConfigMap
apiVersion: v1
metadata:
  name: udp-services
  namespace: ingress-nginx
  labels:
    app.kubernetes.io/name: ingress-nginx
    app.kubernetes.io/part-of: ingress-nginx

---

apiVersion: v1
kind: ServiceAccount
metadata:
  name: nginx-ingress-serviceaccount
  namespace: ingress-nginx
  labels:
    app.kubernetes.io/name: ingress-nginx
    app.kubernetes.io/part-of: ingress-nginx

---
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: ClusterRole
metadata:
  name: nginx-ingress-clusterrole
  labels:
    app.kubernetes.io/name: ingress-nginx
    app.kubernetes.io/part-of: ingress-nginx
rules:
  - apiGroups:
      - ""
    resources:
      - configmaps
      - endpoints
      - nodes
      - pods
      - secrets
    verbs:
      - list
      - watch
  - apiGroups:
      - ""
    resources:
      - nodes
    verbs:
      - get
  - apiGroups:
      - ""
    resources:
      - services
    verbs:
      - get
      - list
      - watch
  - apiGroups:
      - "extensions"
    resources:
      - ingresses
    verbs:
      - get
      - list
      - watch
  - apiGroups:
      - ""
    resources:
      - events
    verbs:
      - create
      - patch
  - apiGroups:
      - "extensions"
    resources:
      - ingresses/status
    verbs:
      - update

---
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: Role
metadata:
  name: nginx-ingress-role
  namespace: ingress-nginx
  labels:
    app.kubernetes.io/name: ingress-nginx
    app.kubernetes.io/part-of: ingress-nginx
rules:
  - apiGroups:
      - ""
    resources:
      - configmaps
      - pods
      - secrets
      - namespaces
    verbs:
      - get
  - apiGroups:
      - ""
    resources:
      - configmaps
    resourceNames:
      # Defaults to "<election-id>-<ingress-class>"
      # Here: "<ingress-controller-leader>-<nginx>"
      # This has to be adapted if you change either parameter
      # when launching the nginx-ingress-controller.
      - "ingress-controller-leader-nginx"
    verbs:
      - get
      - update
  - apiGroups:
      - ""
    resources:
      - configmaps
    verbs:
      - create
  - apiGroups:
      - ""
    resources:
      - endpoints
    verbs:
      - get

---
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: RoleBinding
metadata:
  name: nginx-ingress-role-nisa-binding
  namespace: ingress-nginx
  labels:
    app.kubernetes.io/name: ingress-nginx
    app.kubernetes.io/part-of: ingress-nginx
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: Role
  name: nginx-ingress-role
subjects:
  - kind: ServiceAccount
    name: nginx-ingress-serviceaccount
    namespace: ingress-nginx

---
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: ClusterRoleBinding
metadata:
  name: nginx-ingress-clusterrole-nisa-binding
  labels:
    app.kubernetes.io/name: ingress-nginx
    app.kubernetes.io/part-of: ingress-nginx
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: nginx-ingress-clusterrole
subjects:
  - kind: ServiceAccount
    name: nginx-ingress-serviceaccount
    namespace: ingress-nginx

---

apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-ingress-controller
  namespace: ingress-nginx
  labels:
    app.kubernetes.io/name: ingress-nginx
    app.kubernetes.io/part-of: ingress-nginx
spec:
  replicas: 1
  selector:
    matchLabels:
      app.kubernetes.io/name: ingress-nginx
      app.kubernetes.io/part-of: ingress-nginx
  template:
    metadata:
      labels:
        app.kubernetes.io/name: ingress-nginx
        app.kubernetes.io/part-of: ingress-nginx
      annotations:
        prometheus.io/port: "10254"
        prometheus.io/scrape: "true"
    spec:
      serviceAccountName: nginx-ingress-serviceaccount
      containers:
        - name: nginx-ingress-controller
          image: registry.cn-qingdao.aliyuncs.com/kubernetes_xingej/nginx-ingress-controller:0.20.0
          args:
            - /nginx-ingress-controller
            - --default-backend-service=$(POD_NAMESPACE)/default-http-backend
            - --configmap=$(POD_NAMESPACE)/nginx-configuration
            - --tcp-services-configmap=$(POD_NAMESPACE)/tcp-services
            - --udp-services-configmap=$(POD_NAMESPACE)/udp-services
            - --publish-service=$(POD_NAMESPACE)/ingress-nginx
            - --annotations-prefix=nginx.ingress.kubernetes.io
          securityContext:
            capabilities:
              drop:
                - ALL
              add:
                - NET_BIND_SERVICE
            # www-data -> 33
            runAsUser: 33
          env:
            - name: POD_NAME
              valueFrom:
                fieldRef:
                  fieldPath: metadata.name
            - name: POD_NAMESPACE
              valueFrom:
                fieldRef:
                  fieldPath: metadata.namespace
          ports:
            - name: http
              containerPort: 80
            - name: https
              containerPort: 443
          livenessProbe:
            failureThreshold: 3
            httpGet:
              path: /healthz
              port: 10254
              scheme: HTTP
            initialDelaySeconds: 10
            periodSeconds: 10
            successThreshold: 1
            timeoutSeconds: 1
          readinessProbe:
            failureThreshold: 3
            httpGet:
              path: /healthz
              port: 10254
              scheme: HTTP
            periodSeconds: 10
            successThreshold: 1
            timeoutSeconds: 1

---

執(zhí)行如下命令安裝ingress controller。

kubectl apply -f ingress-nginx-mandatory.yaml

3.安裝K8S SVC:ingress-nginx

主要是用來用于暴露pod:nginx-ingress-controller。

創(chuàng)建service-nodeport.yaml文件,文件內(nèi)容如下所示。

apiVersion: v1
kind: Service
metadata:
  name: ingress-nginx
  namespace: ingress-nginx
  labels:
    app.kubernetes.io/name: ingress-nginx
    app.kubernetes.io/part-of: ingress-nginx
spec:
  type: NodePort
  ports:
    - name: http
      port: 80
      targetPort: 80
      protocol: TCP
      nodePort: 30080
    - name: https
      port: 443
      targetPort: 443
      protocol: TCP
      nodePort: 30443
  selector:
    app.kubernetes.io/name: ingress-nginx
    app.kubernetes.io/part-of: ingress-nginx

執(zhí)行如下命令安裝。

kubectl apply -f service-nodeport.yaml

4.訪問K8S SVC:ingress-nginx

查看ingress-nginx命名空間的部署情況,如下所示。

[root@test10 k8s]# kubectl get pod -n ingress-nginx
NAME                                        READY   STATUS    RESTARTS   AGE
default-http-backend-796ddcd9b-vfmgn        1/1     Running   1          10h
nginx-ingress-controller-58985cc996-87754   1/1     Running   2          10h

在命令行服務(wù)器命令行輸入如下命令查看ingress-nginx的端口映射情況。

kubectl get svc -n ingress-nginx 

具體如下所示。

[root@test10 k8s]# kubectl get svc -n ingress-nginx 
NAME                   TYPE        CLUSTER-IP    EXTERNAL-IP   PORT(S)                      AGE
default-http-backend   ClusterIP   10.96.247.2   <none>        80/TCP                       7m3s
ingress-nginx          NodePort    10.96.40.6    <none>        80:30080/TCP,443:30443/TCP   4m35s

所以,可以通過Master節(jié)點(diǎn)(test10服務(wù)器)的IP地址和30080端口號(hào)來訪問ingress-nginx,如下所示。

[root@test10 k8s]# curl 192.168.0.10:30080       
default backend - 404

也可以在瀏覽器打開http://192.168.0.10:30080 來訪問ingress-nginx,如下所示。

K8S安裝gitlab代碼倉庫

GitLab是由GitLabInc.開發(fā),使用MIT許可證的基于網(wǎng)絡(luò)的Git倉庫管理工具,且具有Wiki和issue跟蹤功能。使用Git作為代碼管理工具,并在此基礎(chǔ)上搭建起來的web服務(wù)。

注意:在Master節(jié)點(diǎn)(test10服務(wù)器上執(zhí)行)

1.創(chuàng)建k8s-ops命名空間

創(chuàng)建k8s-ops-namespace.yaml文件,主要作用是創(chuàng)建k8s-ops命名空間。文件內(nèi)容如下所示。

apiVersion: v1
kind: Namespace
metadata:
  name: k8s-ops
  labels:
    name: k8s-ops

執(zhí)行如下命令創(chuàng)建命名空間。

kubectl apply -f k8s-ops-namespace.yaml 

2.安裝gitlab-redis

創(chuàng)建gitlab-redis.yaml文件,文件的內(nèi)容如下所示。

apiVersion: apps/v1
kind: Deployment
metadata:
  name: redis
  namespace: k8s-ops
  labels:
    name: redis
spec:
  selector:
    matchLabels:
      name: redis
  template:
    metadata:
      name: redis
      labels:
        name: redis
    spec:
      containers:
      - name: redis
        image: sameersbn/redis
        imagePullPolicy: IfNotPresent
        ports:
        - name: redis
          containerPort: 6379
        volumeMounts:
        - mountPath: /var/lib/redis
          name: data
        livenessProbe:
          exec:
            command:
            - redis-cli
            - ping
          initialDelaySeconds: 30
          timeoutSeconds: 5
        readinessProbe:
          exec:
            command:
            - redis-cli
            - ping
          initialDelaySeconds: 10
          timeoutSeconds: 5
      volumes:
      - name: data
        hostPath:
          path: /data1/docker/xinsrv/redis

---
apiVersion: v1
kind: Service
metadata:
  name: redis
  namespace: k8s-ops
  labels:
    name: redis
spec:
  ports:
    - name: redis
      port: 6379
      targetPort: redis
  selector:
    name: redis

首先,在命令行執(zhí)行如下命令創(chuàng)建/data1/docker/xinsrv/redis目錄。

mkdir -p /data1/docker/xinsrv/redis

執(zhí)行如下命令安裝gitlab-redis。

kubectl apply -f gitlab-redis.yaml 

3.安裝gitlab-postgresql

創(chuàng)建gitlab-postgresql.yaml,文件內(nèi)容如下所示。

apiVersion: apps/v1
kind: Deployment
metadata:
  name: postgresql
  namespace: k8s-ops
  labels:
    name: postgresql
spec:
  selector:
    matchLabels:
      name: postgresql
  template:
    metadata:
      name: postgresql
      labels:
        name: postgresql
    spec:
      containers:
      - name: postgresql
        image: sameersbn/postgresql
        imagePullPolicy: IfNotPresent
        env:
        - name: DB_USER
          value: gitlab
        - name: DB_PASS
          value: passw0rd
        - name: DB_NAME
          value: gitlab_production
        - name: DB_EXTENSION
          value: pg_trgm
        ports:
        - name: postgres
          containerPort: 5432
        volumeMounts:
        - mountPath: /var/lib/postgresql
          name: data
        livenessProbe:
          exec:
            command:
            - pg_isready
            - -h
            - localhost
            - -U
            - postgres
          initialDelaySeconds: 30
          timeoutSeconds: 5
        readinessProbe:
          exec:
            command:
            - pg_isready
            - -h
            - localhost
            - -U
            - postgres
          initialDelaySeconds: 5
          timeoutSeconds: 1
      volumes:
      - name: data
        hostPath:
          path: /data1/docker/xinsrv/postgresql
---
apiVersion: v1
kind: Service
metadata:
  name: postgresql
  namespace: k8s-ops
  labels:
    name: postgresql
spec:
  ports:
    - name: postgres
      port: 5432
      targetPort: postgres
  selector:
    name: postgresql

首先,執(zhí)行如下命令創(chuàng)建/data1/docker/xinsrv/postgresql目錄。

mkdir -p /data1/docker/xinsrv/postgresql

接下來,安裝gitlab-postgresql,如下所示。

kubectl apply -f gitlab-postgresql.yaml

4.安裝gitlab

(1)配置用戶名和密碼

首先,在命令行使用base64編碼為用戶名和密碼進(jìn)行轉(zhuǎn)碼,本示例中,使用的用戶名為admin,密碼為admin.1231

轉(zhuǎn)碼情況如下所示。

[root@test10 k8s]# echo -n 'admin' | base64 
YWRtaW4=
[root@test10 k8s]# echo -n 'admin.1231' | base64 
YWRtaW4uMTIzMQ==

轉(zhuǎn)碼后的用戶名為:YWRtaW4= 密碼為:YWRtaW4uMTIzMQ==

也可以對(duì)base64編碼后的字符串解碼,例如,對(duì)密碼字符串解碼,如下所示。

[root@test10 k8s]# echo 'YWRtaW4uMTIzMQ==' | base64 --decode 
admin.1231

接下來,創(chuàng)建secret-gitlab.yaml文件,主要是用戶來配置GitLab的用戶名和密碼,文件內(nèi)容如下所示。

apiVersion: v1
kind: Secret
metadata:
  namespace: k8s-ops
  name: git-user-pass
type: Opaque
data:
  username: YWRtaW4=
  password: YWRtaW4uMTIzMQ==

執(zhí)行配置文件的內(nèi)容,如下所示。

kubectl create -f ./secret-gitlab.yaml

(2)安裝GitLab

創(chuàng)建gitlab.yaml文件,文件的內(nèi)容如下所示。

apiVersion: apps/v1
kind: Deployment
metadata:
  name: gitlab
  namespace: k8s-ops
  labels:
    name: gitlab
spec:
  selector:
    matchLabels:
      name: gitlab
  template:
    metadata:
      name: gitlab
      labels:
        name: gitlab
    spec:
      containers:
      - name: gitlab
        image: sameersbn/gitlab:12.1.6
        imagePullPolicy: IfNotPresent
        env:
        - name: TZ
          value: Asia/Shanghai
        - name: GITLAB_TIMEZONE
          value: Beijing
        - name: GITLAB_SECRETS_DB_KEY_BASE
          value: long-and-random-alpha-numeric-string
        - name: GITLAB_SECRETS_SECRET_KEY_BASE
          value: long-and-random-alpha-numeric-string
        - name: GITLAB_SECRETS_OTP_KEY_BASE
          value: long-and-random-alpha-numeric-string
        - name: GITLAB_ROOT_PASSWORD
          valueFrom:
            secretKeyRef:
              name: git-user-pass
              key: password
        - name: GITLAB_ROOT_EMAIL
          value: 12345678@qq.com
        - name: GITLAB_HOST
          value: gitlab.binghe.com
        - name: GITLAB_PORT
          value: "80"
        - name: GITLAB_SSH_PORT
          value: "30022"
        - name: GITLAB_NOTIFY_ON_BROKEN_BUILDS
          value: "true"
        - name: GITLAB_NOTIFY_PUSHER
          value: "false"
        - name: GITLAB_BACKUP_SCHEDULE
          value: daily
        - name: GITLAB_BACKUP_TIME
          value: 01:00
        - name: DB_TYPE
          value: postgres
        - name: DB_HOST
          value: postgresql
        - name: DB_PORT
          value: "5432"
        - name: DB_USER
          value: gitlab
        - name: DB_PASS
          value: passw0rd
        - name: DB_NAME
          value: gitlab_production
        - name: REDIS_HOST
          value: redis
        - name: REDIS_PORT
          value: "6379"
        ports:
        - name: http
          containerPort: 80
        - name: ssh
          containerPort: 22
        volumeMounts:
        - mountPath: /home/git/data
          name: data
        livenessProbe:
          httpGet:
            path: /
            port: 80
          initialDelaySeconds: 180
          timeoutSeconds: 5
        readinessProbe:
          httpGet:
            path: /
            port: 80
          initialDelaySeconds: 5
          timeoutSeconds: 1
      volumes:
      - name: data
        hostPath:
          path: /data1/docker/xinsrv/gitlab
---
apiVersion: v1
kind: Service
metadata:
  name: gitlab
  namespace: k8s-ops
  labels:
    name: gitlab
spec:
  ports:
    - name: http
      port: 80
      nodePort: 30088
    - name: ssh
      port: 22
      targetPort: ssh
      nodePort: 30022
  type: NodePort
  selector:
    name: gitlab

---
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: gitlab
  namespace: k8s-ops
  annotations:
    kubernetes.io/ingress.class: traefik
spec:
  rules:
  - host: gitlab.binghe.com
    http:
      paths:
      - backend:
          serviceName: gitlab
          servicePort: http

注意:在配置GitLab時(shí),監(jiān)聽主機(jī)時(shí),不能使用IP地址,需要使用主機(jī)名或者域名,上述配置中,我使用的是gitlab.binghe.com主機(jī)名。

在命令行執(zhí)行如下命令創(chuàng)建/data1/docker/xinsrv/gitlab目錄。

mkdir -p /data1/docker/xinsrv/gitlab

安裝GitLab,如下所示。

kubectl apply -f gitlab.yaml

5.安裝完成

查看k8s-ops命名空間部署情況,如下所示。

[root@test10 k8s]# kubectl get pod -n k8s-ops
NAME                          READY   STATUS    RESTARTS   AGE
gitlab-7b459db47c-5vk6t       0/1     Running   0          11s
postgresql-79567459d7-x52vx   1/1     Running   0          30m
redis-67f4cdc96c-h5ckz        1/1     Running   1          10h

也可以使用如下命令查看。

[root@test10 k8s]# kubectl get pod --namespace=k8s-ops
NAME                          READY   STATUS    RESTARTS   AGE
gitlab-7b459db47c-5vk6t       0/1     Running   0          36s
postgresql-79567459d7-x52vx   1/1     Running   0          30m
redis-67f4cdc96c-h5ckz        1/1     Running   1          10h

二者效果一樣。

接下來,查看GitLab的端口映射,如下所示。

[root@test10 k8s]# kubectl get svc -n k8s-ops
NAME         TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)                     AGE
gitlab       NodePort    10.96.153.100   <none>        80:30088/TCP,22:30022/TCP   2m42s
postgresql   ClusterIP   10.96.203.119   <none>        5432/TCP                    32m
redis        ClusterIP   10.96.107.150   <none>        6379/TCP                    10h

此時(shí),可以看到,可以通過Master節(jié)點(diǎn)(test10)的主機(jī)名gitlab.binghe.com和端口30088就能夠訪問GitLab。由于我這里使用的是虛擬機(jī)來搭建相關(guān)的環(huán)境,在本機(jī)訪問虛擬機(jī)映射的gitlab.binghe.com時(shí),需要配置本機(jī)的hosts文件,在本機(jī)的hosts文件中加入如下配置項(xiàng)。

192.168.0.10 gitlab.binghe.com

注意:在Windows操作系統(tǒng)中,hosts文件所在的目錄如下。

C:\Windows\System32\drivers\etc

接下來,就可以在瀏覽器中通過鏈接:http://gitlab.binghe.com:30088 來訪問GitLab了,如下所示。

此時(shí),可以通過用戶名root和密碼admin.1231來登錄GitLab了。

注意:這里的用戶名是root而不是admin,因?yàn)閞oot是GitLab默認(rèn)的超級(jí)用戶。

到此,K8S安裝gitlab完成。

安裝Harbor私有倉庫

Habor是由VMWare公司開源的容器鏡像倉庫。事實(shí)上,Habor是在Docker Registry上進(jìn)行了相應(yīng)的企業(yè)級(jí)擴(kuò)展,從而獲得了更加廣泛的應(yīng)用,這些新的企業(yè)級(jí)特性包括:管理用戶界面,基于角色的訪問控制 ,AD/LDAP集成以及審計(jì)日志等,足以滿足基本企業(yè)需求。

注意:這里將Harbor私有倉庫安裝在Master節(jié)點(diǎn)(test10服務(wù)器)上,實(shí)際生產(chǎn)環(huán)境中建議安裝在其他服務(wù)器。

1.下載Harbor的離線安裝版本

wget https://github.com/goharbor/harbor/releases/download/v1.10.2/harbor-offline-installer-v1.10.2.tgz

2.解壓Harbor的安裝包

tar -zxvf harbor-offline-installer-v1.10.2.tgz

解壓成功后,會(huì)在服務(wù)器當(dāng)前目錄生成一個(gè)harbor目錄。

3.配置Harbor

注意:這里,我將Harbor的端口修改成了1180,如果不修改Harbor的端口,默認(rèn)的端口是80。

(1)修改harbor.yml文件

cd harbor
vim harbor.yml

修改的配置項(xiàng)如下所示。

hostname: 192.168.0.10
http:
  port: 1180
harbor_admin_password: binghe123
###并把https注釋掉,不然在安裝的時(shí)候會(huì)報(bào)錯(cuò):ERROR:root:Error: The protocol is https but attribute ssl_cert is not set
#https:
  #port: 443
  #certificate: /your/certificate/path
  #private_key: /your/private/key/path

(2)修改daemon.json文件

修改/etc/docker/daemon.json文件,沒有的話就創(chuàng)建,在/etc/docker/daemon.json文件中添加如下內(nèi)容。

[root@binghe~]# cat /etc/docker/daemon.json
{
  "registry-mirrors": ["https://zz3sblpi.mirror.aliyuncs.com"],
  "insecure-registries":["192.168.0.10:1180"]
}

也可以在服務(wù)器上使用 ip addr 命令查看本機(jī)所有的IP地址段,將其配置到/etc/docker/daemon.json文件中。這里,我配置后的文件內(nèi)容如下所示。

{
    "registry-mirrors": ["https://zz3sblpi.mirror.aliyuncs.com"],
    "insecure-registries":["192.168.175.0/16","172.17.0.0/16", "172.18.0.0/16", "172.16.29.0/16", "192.168.0.10:1180"]
}

4.安裝并啟動(dòng)harbor

配置完成后,輸入如下命令即可安裝并啟動(dòng)Harbor

[root@binghe harbor]# ./install.sh 

5.登錄Harbor并添加賬戶

安裝成功后,在瀏覽器地址欄輸入http://192.168.0.10:1180打開鏈接,輸入用戶名admin和密碼binghe123,登錄系統(tǒng)。

接下來,我們選擇用戶管理,添加一個(gè)管理員賬戶,為后續(xù)打包Docker鏡像和上傳Docker鏡像做準(zhǔn)備。

密碼為Binghe123。點(diǎn)擊確,此時(shí),賬戶binghe還不是管理員,此時(shí)選中binghe賬戶,點(diǎn)擊“設(shè)置為管理員”。

此時(shí),binghe賬戶就被設(shè)置為管理員了。到此,Harbor的安裝就完成了。

6.修改Harbor端口

如果安裝Harbor后,大家需要修改Harbor的端口,可以按照如下步驟修改Harbor的端口,這里,我以將80端口修改為1180端口為例

(1)修改harbor.yml文件

cd harbor
vim harbor.yml

修改的配置項(xiàng)如下所示。

hostname: 192.168.0.10
http:
  port: 1180
harbor_admin_password: binghe123
###并把https注釋掉,不然在安裝的時(shí)候會(huì)報(bào)錯(cuò):ERROR:root:Error: The protocol is https but attribute ssl_cert is not set
#https:
  #port: 443
  #certificate: /your/certificate/path
  #private_key: /your/private/key/path

(2)修改docker-compose.yml文件

vim docker-compose.yml

修改的配置項(xiàng)如下所示。

ports:
      - 1180:80

(3)修改config.yml文件

cd common/config/registry
vim config.yml

修改的配置項(xiàng)如下所示。

realm: http://192.168.0.10:1180/service/token

(4)重啟Docker

systemctl daemon-reload
systemctl restart docker.service

(5)重啟Harbor

[root@binghe harbor]# docker-compose down
Stopping harbor-log ... done
Removing nginx             ... done
Removing harbor-portal     ... done
Removing harbor-jobservice ... done
Removing harbor-core       ... done
Removing redis             ... done
Removing registry          ... done
Removing registryctl       ... done
Removing harbor-db         ... done
Removing harbor-log        ... done
Removing network harbor_harbor
 
[root@binghe harbor]# ./prepare
prepare base dir is set to /mnt/harbor
Clearing the configuration file: /config/log/logrotate.conf
Clearing the configuration file: /config/nginx/nginx.conf
Clearing the configuration file: /config/core/env
Clearing the configuration file: /config/core/app.conf
Clearing the configuration file: /config/registry/root.crt
Clearing the configuration file: /config/registry/config.yml
Clearing the configuration file: /config/registryctl/env
Clearing the configuration file: /config/registryctl/config.yml
Clearing the configuration file: /config/db/env
Clearing the configuration file: /config/jobservice/env
Clearing the configuration file: /config/jobservice/config.yml
Generated configuration file: /config/log/logrotate.conf
Generated configuration file: /config/nginx/nginx.conf
Generated configuration file: /config/core/env
Generated configuration file: /config/core/app.conf
Generated configuration file: /config/registry/config.yml
Generated configuration file: /config/registryctl/env
Generated configuration file: /config/db/env
Generated configuration file: /config/jobservice/env
Generated configuration file: /config/jobservice/config.yml
loaded secret from file: /secret/keys/secretkey
Generated configuration file: /compose_location/docker-compose.yml
Clean up the input dir
 
[root@binghe harbor]# docker-compose up -d
Creating network "harbor_harbor" with the default driver
Creating harbor-log ... done
Creating harbor-db   ... done
Creating redis       ... done
Creating registry    ... done
Creating registryctl ... done
Creating harbor-core ... done
Creating harbor-jobservice ... done
Creating harbor-portal     ... done
Creating nginx             ... done
 
[root@binghe harbor]# docker ps -a
CONTAINER ID        IMAGE                                               COMMAND                  CREATED             STATUS                             PORTS

安裝Jenkins(一般的做法)

Jenkins是一個(gè)開源的、提供友好操作界面的持續(xù)集成(CI)工具,起源于Hudson(Hudson是商用的),主要用于持續(xù)、自動(dòng)的構(gòu)建/測試軟件項(xiàng)目、監(jiān)控外部任務(wù)的運(yùn)行(這個(gè)比較抽象,暫且寫上,不做解釋)。Jenkins用Java語言編寫,可在Tomcat等流行的servlet容器中運(yùn)行,也可獨(dú)立運(yùn)行。通常與版本管理工具(SCM)、構(gòu)建工具結(jié)合使用。常用的版本控制工具有SVN、GIT,構(gòu)建工具有Maven、Ant、Gradle。

1.安裝nfs(之前安裝過的話,可以省略此步)

使用 nfs 最大的問題就是寫權(quán)限,可以使用 kubernetes 的 securityContext/runAsUser 指定 jenkins 容器中運(yùn)行 jenkins 的用戶 uid,以此來指定 nfs 目錄的權(quán)限,讓 jenkins 容器可寫;也可以不限制,讓所有用戶都可以寫。這里為了簡單,就讓所有用戶可寫了。

如果之前已經(jīng)安裝過nfs,則這一步可以省略。找一臺(tái)主機(jī),安裝 nfs,這里,我以在Master節(jié)點(diǎn)(test10服務(wù)器)上安裝nfs為例。

在命令行輸入如下命令安裝并啟動(dòng)nfs。

yum install nfs-utils -y
systemctl start nfs-server
systemctl enable nfs-server

2.創(chuàng)建nfs共享目錄

在Master節(jié)點(diǎn)(test10服務(wù)器)上創(chuàng)建 /opt/nfs/jenkins-data目錄作為nfs的共享目錄,如下所示。

mkdir -p /opt/nfs/jenkins-data

接下來,編輯/etc/exports文件,如下所示。

vim /etc/exports

在/etc/exports文件文件中添加如下一行配置。

/opt/nfs/jenkins-data 192.168.175.0/24(rw,all_squash)

這里的 ip 使用 kubernetes node 節(jié)點(diǎn)的 ip 范圍,后面的 all_squash 選項(xiàng)會(huì)將所有訪問的用戶都映射成 nfsnobody 用戶,不管你是什么用戶訪問,最終都會(huì)壓縮成 nfsnobody,所以只要將 /opt/nfs/jenkins-data 的屬主改為 nfsnobody,那么無論什么用戶來訪問都具有寫權(quán)限。

這個(gè)選項(xiàng)在很多機(jī)器上由于用戶 uid 不規(guī)范導(dǎo)致啟動(dòng)進(jìn)程的用戶不同,但是同時(shí)要對(duì)一個(gè)共享目錄具有寫權(quán)限時(shí)很有效。

接下來,為 /opt/nfs/jenkins-data目錄授權(quán),并重新加載nfs,如下所示。

#為/opt/nfs/jenkins-data/目錄授權(quán)
chown -R 1000 /opt/nfs/jenkins-data/
#重新加載nfs-server
systemctl reload nfs-server

在K8S集群中任意一個(gè)節(jié)點(diǎn)上使用如下命令進(jìn)行驗(yàn)證:

#查看nfs系統(tǒng)的目錄權(quán)限
showmount -e NFS_IP

如果能夠看到 /opt/nfs/jenkins-data 就表示 ok 了。

具體如下所示。

[root@test10 ~]# showmount -e 192.168.0.10
Export list for 192.168.0.10:
/opt/nfs/jenkins-data 192.168.175.0/24

[root@test11 ~]# showmount -e 192.168.0.10
Export list for 192.168.0.10:
/opt/nfs/jenkins-data 192.168.175.0/24

3.創(chuàng)建PV

Jenkins 其實(shí)只要加載對(duì)應(yīng)的目錄就可以讀取之前的數(shù)據(jù),但是由于 deployment 無法定義存儲(chǔ)卷,因此我們只能使用 StatefulSet。

首先創(chuàng)建 pv,pv 是給 StatefulSet 使用的,每次 StatefulSet 啟動(dòng)都會(huì)通過 volumeClaimTemplates 這個(gè)模板去創(chuàng)建 pvc,因此必須得有 pv,才能供 pvc 綁定。

創(chuàng)建jenkins-pv.yaml文件,文件內(nèi)容如下所示。

apiVersion: v1
kind: PersistentVolume
metadata:
  name: jenkins
spec:
  nfs:
    path: /opt/nfs/jenkins-data
    server: 192.168.0.10
  accessModes: ["ReadWriteOnce"]
  capacity:
    storage: 1Ti

我這里給了 1T存儲(chǔ)空間,可以根據(jù)實(shí)際配置。

執(zhí)行如下命令創(chuàng)建pv。

kubectl apply -f jenkins-pv.yaml 

4.創(chuàng)建serviceAccount

創(chuàng)建service account,因?yàn)?jenkins 后面需要能夠動(dòng)態(tài)創(chuàng)建 slave,因此它必須具備一些權(quán)限。

創(chuàng)建jenkins-service-account.yaml文件,文件內(nèi)容如下所示。

apiVersion: v1
kind: ServiceAccount
metadata:
  name: jenkins

---
kind: Role
apiVersion: rbac.authorization.k8s.io/v1beta1
metadata:
  name: jenkins
rules:
  - apiGroups: [""]
    resources: ["pods"]
    verbs: ["create", "delete", "get", "list", "patch", "update", "watch"]
  - apiGroups: [""]
    resources: ["pods/exec"]
    verbs: ["create", "delete", "get", "list", "patch", "update", "watch"]
  - apiGroups: [""]
    resources: ["pods/log"]
    verbs: ["get", "list", "watch"]
  - apiGroups: [""]
    resources: ["secrets"]
    verbs: ["get"]

---
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: RoleBinding
metadata:
  name: jenkins
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: Role
  name: jenkins
subjects:
  - kind: ServiceAccount
    name: jenkins

上述配置中,創(chuàng)建了一個(gè) RoleBinding 和一個(gè) ServiceAccount,并且將 RoleBinding 的權(quán)限綁定到這個(gè)用戶上。所以,jenkins 容器必須使用這個(gè) ServiceAccount 運(yùn)行才行,不然 RoleBinding 的權(quán)限它將不具備。

RoleBinding 的權(quán)限很容易就看懂了,因?yàn)?jenkins 需要?jiǎng)?chuàng)建和刪除 slave,所以才需要上面這些權(quán)限。至于 secrets 權(quán)限,則是 https 證書。

執(zhí)行如下命令創(chuàng)建serviceAccount。

kubectl apply -f jenkins-service-account.yaml 

5.安裝Jenkins

創(chuàng)建jenkins-statefulset.yaml文件,文件內(nèi)容如下所示。

apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: jenkins
  labels:
    name: jenkins
spec:
  selector:
    matchLabels:
      name: jenkins
  serviceName: jenkins
  replicas: 1
  updateStrategy:
    type: RollingUpdate
  template:
    metadata:
      name: jenkins
      labels:
        name: jenkins
    spec:
      terminationGracePeriodSeconds: 10
      serviceAccountName: jenkins
      containers:
        - name: jenkins
          image: docker.io/jenkins/jenkins:lts
          imagePullPolicy: IfNotPresent
          ports:
            - containerPort: 8080
            - containerPort: 32100
          resources:
            limits:
              cpu: 4
              memory: 4Gi
            requests:
              cpu: 4
              memory: 4Gi
          env:
            - name: LIMITS_MEMORY
              valueFrom:
                resourceFieldRef:
                  resource: limits.memory
                  divisor: 1Mi
            - name: JAVA_OPTS
              # value: -XX:+UnlockExperimentalVMOptions -XX:+UseCGroupMemoryLimitForHeap -XX:MaxRAMFraction=1 -XshowSettings:vm -Dhudson.slaves.NodeProvisioner.initialDelay=0 -Dhudson.slaves.NodeProvisioner.MARGIN=50 -Dhudson.slaves.NodeProvisioner.MARGIN0=0.85
              value: -Xmx$(LIMITS_MEMORY)m -XshowSettings:vm -Dhudson.slaves.NodeProvisioner.initialDelay=0 -Dhudson.slaves.NodeProvisioner.MARGIN=50 -Dhudson.slaves.NodeProvisioner.MARGIN0=0.85
          volumeMounts:
            - name: jenkins-home
              mountPath: /var/jenkins_home
          livenessProbe:
            httpGet:
              path: /login
              port: 8080
            initialDelaySeconds: 60
            timeoutSeconds: 5
            failureThreshold: 12 # ~2 minutes
          readinessProbe:
            httpGet:
              path: /login
              port: 8080
            initialDelaySeconds: 60
            timeoutSeconds: 5
            failureThreshold: 12 # ~2 minutes
  # pvc 模板,對(duì)應(yīng)之前的 pv
  volumeClaimTemplates:
    - metadata:
        name: jenkins-home
      spec:
        accessModes: ["ReadWriteOnce"]
        resources:
          requests:
            storage: 1Ti

jenkins 部署時(shí)需要注意它的副本數(shù),你的副本數(shù)有多少就要有多少個(gè) pv,同樣,存儲(chǔ)會(huì)有多倍消耗。這里我只使用了一個(gè)副本,因此前面也只創(chuàng)建了一個(gè) pv。

使用如下命令安裝Jenkins。

kubectl apply -f jenkins-statefulset.yaml 

6.創(chuàng)建Service

創(chuàng)建jenkins-service.yaml文件,主要用于后臺(tái)運(yùn)行Jenkins,文件內(nèi)容如下所示。

apiVersion: v1
kind: Service
metadata:
  name: jenkins
spec:
  # type: LoadBalancer
  selector:
    name: jenkins
  # ensure the client ip is propagated to avoid the invalid crumb issue when using LoadBalancer (k8s >=1.7)
  #externalTrafficPolicy: Local
  ports:
    - name: http
      port: 80
      nodePort: 31888
      targetPort: 8080
      protocol: TCP
    - name: jenkins-agent
      port: 32100
      nodePort: 32100
      targetPort: 32100
      protocol: TCP
  type: NodePort

使用如下命令安裝Service。

kubectl apply -f jenkins-service.yaml 

7.安裝 ingress

jenkins 的 web 界面需要從集群外訪問,這里我們選擇的是使用 ingress。創(chuàng)建jenkins-ingress.yaml文件,文件內(nèi)容如下所示。

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: jenkins
spec:
  rules:
    - http:
        paths:
          - path: /
            backend:
              serviceName: jenkins
              servicePort: 31888
      host: jekins.binghe.com

這里,需要注意的是host必須配置為域名或者主機(jī)名,否則會(huì)報(bào)錯(cuò),如下所示。

The Ingress "jenkins" is invalid: spec.rules[0].host: Invalid value: "192.168.0.10": must be a DNS name, not an IP address

使用如下命令安裝ingress。

kubectl apply -f jenkins-ingress.yaml 

最后,由于我這里使用的是虛擬機(jī)來搭建相關(guān)的環(huán)境,在本機(jī)訪問虛擬機(jī)映射的jekins.binghe.com時(shí),需要配置本機(jī)的hosts文件,在本機(jī)的hosts文件中加入如下配置項(xiàng)。

192.168.0.10 jekins.binghe.com

注意:在Windows操作系統(tǒng)中,hosts文件所在的目錄如下。

C:\Windows\System32\drivers\etc

接下來,就可以在瀏覽器中通過鏈接:http://jekins.binghe.com:31888 來訪問Jekins了。

物理機(jī)安裝SVN

Apache Subversion 通常被縮寫成 SVN,是一個(gè)開放源代碼的版本控制系統(tǒng),Subversion 在 2000 年由 CollabNet Inc 開發(fā),現(xiàn)在發(fā)展成為 Apache 軟件基金會(huì)的一個(gè)項(xiàng)目,同樣是一個(gè)豐富的開發(fā)者和用戶社區(qū)的一部分。

SVN相對(duì)于的RCS、CVS,采用了分支管理系統(tǒng),它的設(shè)計(jì)目標(biāo)就是取代CVS?;ヂ?lián)網(wǎng)上免費(fèi)的版本控制服務(wù)多基于Subversion。

這里,以在Master節(jié)點(diǎn)(binghe101服務(wù)器)上安裝SVN為例。

1.使用yum安裝SVN

在命令行執(zhí)行如下命令安裝SVN。

yum -y install subversion 

2.創(chuàng)建SVN庫

依次執(zhí)行如下命令。

#創(chuàng)建/data/svn
mkdir -p /data/svn 
#初始化svn
svnserve -d -r /data/svn
#創(chuàng)建代碼倉庫
svnadmin create /data/svn/test

3.配置SVN

mkdir /data/svn/conf
cp /data/svn/test/conf/* /data/svn/conf/
cd /data/svn/conf/
[root@binghe101 conf]# ll
總用量 20
-rw-r--r-- 1 root root 1080 5月  12 02:17 authz
-rw-r--r-- 1 root root  885 5月  12 02:17 hooks-env.tmpl
-rw-r--r-- 1 root root  309 5月  12 02:17 passwd
-rw-r--r-- 1 root root 4375 5月  12 02:17 svnserve.conf

配置authz文件,

vim authz

配置后的內(nèi)容如下所示。

[aliases]
# joe = /C=XZ/ST=Dessert/L=Snake City/O=Snake Oil, Ltd./OU=Research Institute/CN=Joe Average

[groups]
# harry_and_sally = harry,sally
# harry_sally_and_joe = harry,sally,&joe
SuperAdmin = admin
binghe = admin,binghe

# [/foo/bar]
# harry = rw
# &joe = r
# * =

# [repository:/baz/fuz]
# @harry_and_sally = rw
# * = r

[test:/]
@SuperAdmin=rw
@binghe=rw

配置passwd文件

vim passwd

配置后的內(nèi)容如下所示。

[users]
# harry = harryssecret
# sally = sallyssecret
admin = admin123
binghe = binghe123

配置 svnserve.conf

vim svnserve.conf

配置后的文件如下所示。

### This file controls the configuration of the svnserve daemon, if you
### use it to allow access to this repository.  (If you only allow
### access through http: and/or file: URLs, then this file is
### irrelevant.)

### Visit http://subversion.apache.org/ for more information.

[general]
### The anon-access and auth-access options control access to the
### repository for unauthenticated (a.k.a. anonymous) users and
### authenticated users, respectively.
### Valid values are "write", "read", and "none".
### Setting the value to "none" prohibits both reading and writing;
### "read" allows read-only access, and "write" allows complete 
### read/write access to the repository.
### The sample settings below are the defaults and specify that anonymous
### users have read-only access to the repository, while authenticated
### users have read and write access to the repository.
anon-access = none
auth-access = write
### The password-db option controls the location of the password
### database file.  Unless you specify a path starting with a /,
### the file's location is relative to the directory containing
### this configuration file.
### If SASL is enabled (see below), this file will NOT be used.
### Uncomment the line below to use the default password file.
password-db = /data/svn/conf/passwd
### The authz-db option controls the location of the authorization
### rules for path-based access control.  Unless you specify a path
### starting with a /, the file's location is relative to the
### directory containing this file.  The specified path may be a
### repository relative URL (^/) or an absolute file:// URL to a text
### file in a Subversion repository.  If you don't specify an authz-db,
### no path-based access control is done.
### Uncomment the line below to use the default authorization file.
authz-db = /data/svn/conf/authz
### The groups-db option controls the location of the file with the
### group definitions and allows maintaining groups separately from the
### authorization rules.  The groups-db file is of the same format as the
### authz-db file and should contain a single [groups] section with the
### group definitions.  If the option is enabled, the authz-db file cannot
### contain a [groups] section.  Unless you specify a path starting with
### a /, the file's location is relative to the directory containing this
### file.  The specified path may be a repository relative URL (^/) or an
### absolute file:// URL to a text file in a Subversion repository.
### This option is not being used by default.
# groups-db = groups
### This option specifies the authentication realm of the repository.
### If two repositories have the same authentication realm, they should
### have the same password database, and vice versa.  The default realm
### is repository's uuid.
realm = svn
### The force-username-case option causes svnserve to case-normalize
### usernames before comparing them against the authorization rules in the
### authz-db file configured above.  Valid values are "upper" (to upper-
### case the usernames), "lower" (to lowercase the usernames), and
### "none" (to compare usernames as-is without case conversion, which
### is the default behavior).
# force-username-case = none
### The hooks-env options specifies a path to the hook script environment 
### configuration file. This option overrides the per-repository default
### and can be used to configure the hook script environment for multiple 
### repositories in a single file, if an absolute path is specified.
### Unless you specify an absolute path, the file's location is relative
### to the directory containing this file.
# hooks-env = hooks-env

[sasl]
### This option specifies whether you want to use the Cyrus SASL
### library for authentication. Default is false.
### Enabling this option requires svnserve to have been built with Cyrus
### SASL support; to check, run 'svnserve --version' and look for a line
### reading 'Cyrus SASL authentication is available.'
# use-sasl = true
### These options specify the desired strength of the security layer
### that you want SASL to provide. 0 means no encryption, 1 means
### integrity-checking only, values larger than 1 are correlated
### to the effective key length for encryption (e.g. 128 means 128-bit
### encryption). The values below are the defaults.
# min-encryption = 0
# max-encryption = 256

接下來,將/data/svn/conf目錄下的svnserve.conf文件復(fù)制到/data/svn/test/conf/目錄下。如下所示。

[root@binghe101 conf]# cp /data/svn/conf/svnserve.conf /data/svn/test/conf/
cp:是否覆蓋'/data/svn/test/conf/svnserve.conf'? y

4.啟動(dòng)SVN服務(wù)

(1)創(chuàng)建svnserve.service服務(wù)

創(chuàng)建svnserve.service文件

vim /usr/lib/systemd/system/svnserve.service

文件的內(nèi)容如下所示。

[Unit]
Description=Subversion protocol daemon
After=syslog.target network.target
Documentation=man:svnserve(8)

[Service]
Type=forking
EnvironmentFile=/etc/sysconfig/svnserve
#ExecStart=/usr/bin/svnserve --daemon --pid-file=/run/svnserve/svnserve.pid $OPTIONS
ExecStart=/usr/bin/svnserve --daemon $OPTIONS
PrivateTmp=yes

[Install]
WantedBy=multi-user.target

接下來執(zhí)行如下命令使配置生效。

systemctl daemon-reload

命令執(zhí)行成功后,修改 /etc/sysconfig/svnserve 文件。

vim /etc/sysconfig/svnserve 

修改后的文件內(nèi)容如下所示。

# OPTIONS is used to pass command-line arguments to svnserve.
# 
# Specify the repository location in -r parameter:
OPTIONS="-r /data/svn"

(2)啟動(dòng)SVN

首先查看SVN狀態(tài),如下所示。

[root@test10 conf]# systemctl status svnserve.service
● svnserve.service - Subversion protocol daemon
   Loaded: loaded (/usr/lib/systemd/system/svnserve.service; disabled; vendor preset: disabled)
   Active: inactive (dead)
     Docs: man:svnserve(8)

可以看到,此時(shí)SVN并沒有啟動(dòng),接下來,需要啟動(dòng)SVN。

systemctl start svnserve.service

設(shè)置SVN服務(wù)開機(jī)自啟動(dòng)。

systemctl enable svnserve.service

接下來,就可以下載安裝TortoiseSVN,輸入鏈接svn://192.168.0.10/test 并輸入用戶名binghe,密碼binghe123來連接SVN了。

Docker安裝SVN

拉取SVN鏡像

docker pull docker.io/elleflorio/svn-server

啟動(dòng)SVN容器

docker run -v /usr/local/svn:/home/svn -v /usr/local/svn/passwd:/etc/subversion/passwd -v /usr/local/apache2:/run/apache2 --name svn_server -p 3380:80 -p 3690:3960 -e SVN_REPONAME=repos -d docker.io/elleflorio/svn-server

進(jìn)入SVN容器內(nèi)部

docker exec -it svn_server bash

進(jìn)入容器后,可以參照物理機(jī)安裝SVN的方式配置SVN倉庫。

物理機(jī)安裝Jenkins

注意:安裝Jenkins之前需要安裝JDK和Maven,我這里同樣將Jenkins安裝在Master節(jié)點(diǎn)(binghe101服務(wù)器)。

1.啟用Jenkins庫

運(yùn)行以下命令以下載repo文件并導(dǎo)入GPG密鑰:

wget -O /etc/yum.repos.d/jenkins.repo http://pkg.jenkins-ci.org/redhat-stable/jenkins.repo
rpm --import https://jenkins-ci.org/redhat/jenkins-ci.org.key

2.安裝Jenkins

執(zhí)行如下命令安裝Jenkis。

yum install jenkins

接下來,修改Jenkins默認(rèn)端口,如下所示。

vim /etc/sysconfig/jenkins

修改后的兩項(xiàng)配置如下所示。

JENKINS_JAVA_CMD="/usr/local/jdk1.8.0_212/bin/java"
JENKINS_PORT="18080"

此時(shí),已經(jīng)將Jenkins的端口由8080修改為18080

3.啟動(dòng)Jenkins

在命令行輸入如下命令啟動(dòng)Jenkins。

systemctl start jenkins

配置Jenkins開機(jī)自啟動(dòng)。

systemctl enable jenkins

查看Jenkins的運(yùn)行狀態(tài)。

[root@test10 ~]# systemctl status jenkins
● jenkins.service - LSB: Jenkins Automation Server
   Loaded: loaded (/etc/rc.d/init.d/jenkins; generated)
   Active: active (running) since Tue 2020-05-12 04:33:40 EDT; 28s ago
     Docs: man:systemd-sysv-generator(8)
    Tasks: 71 (limit: 26213)
   Memory: 550.8M

說明,Jenkins啟動(dòng)成功。

配置Jenkins運(yùn)行環(huán)境

1.登錄Jenkins

首次安裝后,需要配置Jenkins的運(yùn)行環(huán)境。首先,在瀏覽器地址欄訪問鏈接http://192.168.0.10:18080,打開Jenkins界面。

根據(jù)提示使用如下命令到服務(wù)器上找密碼值,如下所示。

[root@binghe101 ~]# cat /var/lib/jenkins/secrets/initialAdminPassword
71af861c2ab948a1b6efc9f7dde90776

將密碼71af861c2ab948a1b6efc9f7dde90776復(fù)制到文本框,點(diǎn)擊繼續(xù)。會(huì)跳轉(zhuǎn)到自定義Jenkins頁面,如下所示。

這里,可以直接選擇“安裝推薦的插件”。之后會(huì)跳轉(zhuǎn)到一個(gè)安裝插件的頁面,如下所示。

此步驟可能有下載失敗的情況,可直接忽略。

2.安裝插件

需要安裝的插件

  • Kubernetes Cli Plugin:該插件可直接在Jenkins中使用kubernetes命令行進(jìn)行操作。
  • Kubernetes plugin: 使用kubernetes則需要安裝該插件Kubernetes
  • Continuous Deploy Plugin:kubernetes部署插件,可根據(jù)需要使用

還有更多的插件可供選擇,可點(diǎn)擊 系統(tǒng)管理->管理插件進(jìn)行管理和添加,安裝相應(yīng)的Docker插件、SSH插件、Maven插件。其他的插件可以根據(jù)需要進(jìn)行安裝。如下圖所示。

3.配置Jenkins

(1)配置JDK和Maven

在Global Tool Configuration中配置JDK和Maven,如下所示,打開Global Tool Configuration界面。

接下來就開始配置JDK和Maven了。

由于我在服務(wù)器上將Maven安裝在/usr/local/maven-3.6.3目錄下,所以,需要在“Maven 配置”中進(jìn)行配置,如下圖所示。

接下來,配置JDK,如下所示。

注意:不要勾選“Install automatically”

接下來,配置Maven,如下所示。

注意:不要勾選“Install automatically”

(2)配置SSH

進(jìn)入Jenkins的Configure System界面配置SSH,如下所示。

找到 SSH remote hosts 進(jìn)行配置。

配置完成后,點(diǎn)擊Check connection按鈕,會(huì)顯示 Successfull connection。如下所示。

至此,Jenkins的基本配置就完成了。

Jenkins發(fā)布Docker項(xiàng)目到K8s集群

1.調(diào)整SpringBoot項(xiàng)目的配置

實(shí)現(xiàn),SpringBoot項(xiàng)目中啟動(dòng)類所在的模塊的pom.xml需要引入打包成Docker鏡像的配置,如下所示。

 <properties>
  	 	<docker.repostory>192.168.0.10:1180</docker.repostory>
        <docker.registry.name>test</docker.registry.name>
        <docker.image.tag>1.0.0</docker.image.tag>
        <docker.maven.plugin.version>1.4.10</docker.maven.plugin.version>
  </properties>

<build>
  		<finalName>test-starter</finalName>
		<plugins>
            <plugin>
			    <groupId>org.springframework.boot</groupId>
			    <artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
			
			<!-- docker的maven插件,官網(wǎng):https://github.com/spotify/docker‐maven‐plugin -->
			<!-- Dockerfile maven plugin -->
			<plugin>
			    <groupId>com.spotify</groupId>
			    <artifactId>dockerfile-maven-plugin</artifactId>
			    <version>${docker.maven.plugin.version}</version>
			    <executions>
			        <execution>
			        <id>default</id>
			        <goals>
			            <!--如果package時(shí)不想用docker打包,就注釋掉這個(gè)goal-->
			            <goal>build</goal>
			            <goal>push</goal>
			        </goals>
			        </execution>
			    </executions>
			    <configuration>
			    	<contextDirectory>${project.basedir}</contextDirectory>
			        <!-- harbor 倉庫用戶名及密碼-->
			        <useMavenSettingsForAuth>useMavenSettingsForAuth>true</useMavenSettingsForAuth>
			        <repository>${docker.repostory}/${docker.registry.name}/${project.artifactId}</repository>
			        <tag>${docker.image.tag}</tag>
			        <buildArgs>
			            <JAR_FILE>target/${project.build.finalName}.jar</JAR_FILE>
			        </buildArgs>
			    </configuration>
			</plugin>

        </plugins>
        
		<resources>
			<!-- 指定 src/main/resources下所有文件及文件夾為資源文件 -->
			<resource>
				<directory>src/main/resources</directory>
				<targetPath>${project.build.directory}/classes</targetPath>
				<includes>
					<include>**/*</include>
				</includes>
				<filtering>true</filtering>
			</resource>
		</resources>
	</build>

接下來,在SpringBoot啟動(dòng)類所在模塊的根目錄創(chuàng)建Dockerfile,內(nèi)容示例如下所示。

#添加依賴環(huán)境,前提是將Java8的Docker鏡像從官方鏡像倉庫pull下來,然后上傳到自己的Harbor私有倉庫中
FROM 192.168.0.10:1180/library/java:8
#指定鏡像制作作者
MAINTAINER binghe
#運(yùn)行目錄
VOLUME /tmp
#將本地的文件拷貝到容器
ADD target/*jar app.jar
#啟動(dòng)容器后自動(dòng)執(zhí)行的命令
ENTRYPOINT [ "java", "-Djava.security.egd=file:/dev/./urandom", "-jar", "/app.jar" ]

根據(jù)實(shí)際情況,自行修改。

注意:FROM 192.168.0.10:1180/library/java:8的前提是執(zhí)行如下命令。

docker pull java:8
docker tag java:8 192.168.0.10:1180/library/java:8
docker login 192.168.0.10:1180
docker push 192.168.0.10:1180/library/java:8

在SpringBoot啟動(dòng)類所在模塊的根目錄創(chuàng)建yaml文件,錄入叫做test.yaml文件,內(nèi)容如下所示。

apiVersion: apps/v1
kind: Deployment
metadata:
  name: test-starter
  labels:
    app: test-starter
spec:
  replicas: 1
  selector:
    matchLabels:
      app: test-starter
  template:
    metadata:
      labels:
        app: test-starter
    spec:
      containers:
      - name: test-starter
        image: 192.168.0.10:1180/test/test-starter:1.0.0
        ports:
        - containerPort: 8088
      nodeSelector:
        clustertype: node12

---
apiVersion: v1
kind: Service
metadata:
  name: test-starter
  labels:
    app: test-starter
spec:
  ports:
    - name: http
      port: 8088
      nodePort: 30001
  type: NodePort
  selector:
    app: test-starter

2.Jenkins配置發(fā)布項(xiàng)目

將項(xiàng)目上傳到SVN代碼庫,例如地址為svn://192.168.0.10/test

接下來,在Jenkins中配置自動(dòng)發(fā)布。步驟如下所示。

點(diǎn)擊新建Item。

在描述文本框中輸入描述信息,如下所示。

接下來,配置SVN信息。

注意:配置GitLab的步驟與SVN相同,不再贅述。

定位到Jenkins的“構(gòu)建模塊”,使用Execute Shell來構(gòu)建發(fā)布項(xiàng)目到K8S集群。

執(zhí)行的命令依次如下所示。

#刪除本地原有的鏡像,不會(huì)影響Harbor倉庫中的鏡像
docker rmi 192.168.0.10:1180/test/test-starter:1.0.0
#使用Maven編譯、構(gòu)建Docker鏡像,執(zhí)行完成后本地Docker容器中會(huì)重新構(gòu)建鏡像文件
/usr/local/maven-3.6.3/bin/mvn -f ./pom.xml clean install -Dmaven.test.skip=true
#登錄 Harbor倉庫
docker login 192.168.0.10:1180 -u binghe -p Binghe123
#上傳鏡像到Harbor倉庫
docker push 192.168.0.10:1180/test/test-starter:1.0.0
#停止并刪除K8S集群中運(yùn)行的
/usr/bin/kubectl delete -f test.yaml
#將Docker鏡像重新發(fā)布到K8S集群
/usr/bin/kubectl apply -f test.yaml

到此這篇關(guān)于基于Docker+K8S+GitLab/SVN+Jenkins+Harbor搭建持續(xù)集成交付環(huán)境(環(huán)境搭建篇)的文章就介紹到這了,更多相關(guān)docker K8S持續(xù)集成交付環(huán)境內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Docker容器網(wǎng)絡(luò)更改的實(shí)現(xiàn)

    Docker容器網(wǎng)絡(luò)更改的實(shí)現(xiàn)

    本文主要介紹了Docker容器網(wǎng)絡(luò)更改的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • 如何使用cloudflare搭建私人docker鏡像站

    如何使用cloudflare搭建私人docker鏡像站

    這篇文章主要介紹了如何使用cloudflare搭建私人docker鏡像站方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2025-03-03
  • Docker使用run命令部署Nginx的完整指南

    Docker使用run命令部署Nginx的完整指南

    容器化技術(shù)正在徹底改變現(xiàn)代應(yīng)用的部署方式,而 Docker 作為這一領(lǐng)域的先驅(qū),為開發(fā)者提供了快速構(gòu)建、交付和運(yùn)行應(yīng)用的能力,下面小編就為大家介紹一下Docker如何通過run命令部署Nginx吧
    2025-03-03
  • docker?desktop搜索不到images問題的解決辦法

    docker?desktop搜索不到images問題的解決辦法

    這篇文章主要給大家介紹了關(guān)于docker?desktop搜索不到images問題的解決辦法,主要包括檢查網(wǎng)絡(luò)連接、Docker配置、清理緩存和使用其他鏡像源,通過這些方法,用戶可以解決在實(shí)際應(yīng)用中搜索不到Images的問題,需要的朋友可以參考下
    2025-03-03
  • Docker磁盤空間清理的方法實(shí)現(xiàn)

    Docker磁盤空間清理的方法實(shí)現(xiàn)

    在使用Docker的過程中,系統(tǒng)會(huì)逐漸積累一些無用的垃圾文件,占據(jù)寶貴的磁盤空間并影響系統(tǒng)性,本文主要介紹了Docker磁盤空間清理的方法實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-09-09
  • Docker 安裝及配置鏡像加速的實(shí)現(xiàn)

    Docker 安裝及配置鏡像加速的實(shí)現(xiàn)

    這篇文章主要介紹了Docker 安裝及配置鏡像加速的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • docker 查看jvm內(nèi)存占用方式

    docker 查看jvm內(nèi)存占用方式

    這篇文章主要介紹了docker 查看jvm內(nèi)存占用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • Docker Hub運(yùn)行原理及實(shí)現(xiàn)過程解析

    Docker Hub運(yùn)行原理及實(shí)現(xiàn)過程解析

    這篇文章主要介紹了Docker Hub運(yùn)行原理及實(shí)現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10
  • docker使用Dockerfile構(gòu)建鏡像的實(shí)現(xiàn)示例

    docker使用Dockerfile構(gòu)建鏡像的實(shí)現(xiàn)示例

    本文主要介紹了docker使用Dockerfile構(gòu)建鏡像的實(shí)現(xiàn)示例,通過編寫 Dockerfile,您可以定義鏡像的基礎(chǔ)環(huán)境、安裝軟件包、復(fù)制文件、設(shè)置環(huán)境變量等操作,下面就來介紹一下
    2024-01-01
  • Docker服務(wù)的重啟服務(wù)命令詳解(systemctl restart docker)

    Docker服務(wù)的重啟服務(wù)命令詳解(systemctl restart docker)

    這篇文章主要介紹了Docker服務(wù)的重啟服務(wù)命令(systemctl restart docker),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11

最新評(píng)論

精品一线二线三线日本| 天堂中文字幕翔田av| 美洲精品一二三产区区别| 91精品国产综合久久久蜜| av高潮迭起在线观看| 大香蕉伊人中文字幕| 一区二区三区精品日本| 欧美一区二区三区高清不卡tv| 国产变态另类在线观看| 中文字幕免费福利视频6| 国产综合精品久久久久蜜臀| 免费观看成年人视频在线观看| 91人妻精品一区二区在线看| 国产精品精品精品999| 亚洲av日韩av第一区二区三区| 一个人免费在线观看ww视频| av成人在线观看一区| 真实国产乱子伦一区二区| 亚洲免费福利一区二区三区| av日韩在线观看大全| 国产成人精品福利短视频| 人妻素人精油按摩中出| 适合午夜一个人看的视频| 亚洲成人av一区久久| 中文字幕一区二区三区人妻大片| 亚洲国产成人在线一区| 午夜免费体验区在线观看| 又粗又长 明星操逼小视频| 大骚逼91抽插出水视频| 中文字幕一区二区人妻电影冢本| 日韩av有码一区二区三区4 | 欧美精品伦理三区四区| 美女操逼免费短视频下载链接 | 成人高潮aa毛片免费| av老司机亚洲一区二区| 38av一区二区三区| 国内资源最丰富的网站| 中文字幕日本人妻中出| 蜜臀成人av在线播放| 亚洲综合另类欧美久久| 黄片三级三级三级在线观看| 大香蕉玖玖一区2区| 欧美成人一二三在线网| 18禁美女羞羞免费网站| 午夜成午夜成年片在线观看| 少妇人妻100系列| 天堂av在线最新版在线| 午夜毛片不卡在线看| 青青青青青青青青青国产精品视频| 日韩熟女系列一区二区三区| 大白屁股精品视频国产| 91小伙伴中女熟女高潮| 91快播视频在线观看| 超污视频在线观看污污污| 又大又湿又爽又紧A视频| 99av国产精品欲麻豆| 天天日夜夜干天天操| 插小穴高清无码中文字幕| 91av精品视频在线| 国产亚洲欧美另类在线观看| 3344免费偷拍视频| 福利午夜视频在线观看| 国产日本精品久久久久久久| 日本一道二三区视频久久| 日韩一个色综合导航| 污污小视频91在线观看| 欧美一级视频一区二区| 人人在线视频一区二区| 黄片三级三级三级在线观看| 久久一区二区三区人妻欧美| 91传媒一区二区三区| 97资源人妻免费在线视频| 天天躁日日躁狠狠躁躁欧美av| caoporn蜜桃视频| 最新91九色国产在线观看| 爱爱免费在线观看视频| 亚洲 图片 欧美 图片| 伊人情人综合成人久久网小说| 国产麻豆国语对白露脸剧情 | 一本久久精品一区二区| 亚洲av日韩高清hd| 天天射,天天操,天天说| 啪啪啪操人视频在线播放| 九九热99视频在线观看97| 国产一区二区欧美三区| 国产日韩欧美视频在线导航| 蜜臀av久久久久蜜臀av麻豆| 98视频精品在线观看| 天天操天天弄天天射| 一区二区免费高清黄色视频| 一本久久精品一区二区| 欧美80老妇人性视频| 欧美亚洲一二三区蜜臀| 国产黄网站在线观看播放| 亚洲狠狠婷婷综合久久app | 最新日韩av传媒在线| 天天做天天干天天操天天射| 五月婷婷在线观看视频免费| 91精品国产高清自在线看香蕉网 | 少妇人妻二三区视频| 三级等保密码要求条款| 日本脱亚入欧是指什么| 2019av在线视频| 熟女人妻一区二区精品视频| 午夜精品福利91av| 男女之间激情网午夜在线| 91九色porny国产蝌蚪视频| 男人操女人的逼免费视频| 欧美精品一区二区三区xxxx| av男人天堂狠狠干| 成人24小时免费视频| 欧美亚洲免费视频观看| 欧美一级片免费在线成人观看| 欧美精产国品一二三产品价格| 美女被肏内射视频网站| 人人妻人人人操人人人爽| 成人av免费不卡在线观看| 亚洲欧美另类手机在线| 日日操综合成人av| av乱码一区二区三区| 亚洲特黄aaaa片| 巨乳人妻日下部加奈被邻居中出| 日韩a级黄色小视频| 成人国产小视频在线观看| 青草亚洲视频在线观看| 天天日天天日天天擦| 狠狠躁狠狠爱网站视频| 午夜精品亚洲精品五月色| 2020av天堂网在线观看| 快插进小逼里大鸡吧视频| 日本后入视频在线观看| 国产精品熟女久久久久浪潮| 亚洲精品国产在线电影| 成人伊人精品色xxxx视频| 中文字幕av男人天堂| 超碰在线观看免费在线观看| 中文字幕高清在线免费播放| 亚洲精品久久视频婷婷| 国产三级片久久久久久久| 97国产精品97久久| 熟女人妻三十路四十路人妻斩| 91九色porny国产在线| 亚洲av日韩精品久久久| 91国语爽死我了不卡| 性色av一区二区三区久久久| 午夜毛片不卡在线看| 日本精品美女在线观看| 成年人啪啪视频在线观看| 91免费福利网91麻豆国产精品| 免费十精品十国产网站| 中文字幕+中文字幕| 国产精品久久久久久美女校花| 91老熟女连续高潮对白| 人妻久久久精品69系列| 欧美熟妇一区二区三区仙踪林| 久久久久91精品推荐99| 亚洲另类伦春色综合小| 久久久久五月天丁香社区| 性感美女高潮视频久久久| 97国产福利小视频合集| 18禁网站一区二区三区四区| 91福利视频免费在线观看| 日本午夜爽爽爽爽爽视频在线观看 | 亚洲激情偷拍一区二区| 91国产在线免费播放| 黑人3p华裔熟女普通话| 日本福利午夜电影在线观看| 亚洲国产40页第21页| 1769国产精品视频免费观看| 福利视频一区二区三区筱慧| 久久丁香花五月天色婷婷| 99的爱精品免费视频| 特一级特级黄色网片| 51精品视频免费在线观看| 日本www中文字幕| 亚洲精品国偷自产在线观看蜜桃| 亚洲成人熟妇一区二区三区| 免费人成黄页网站在线观看国产| 国产密臀av一区二区三| 日本韩国在线观看一区二区| 日韩一个色综合导航| 亚洲欧美精品综合图片小说| 污污小视频91在线观看| 99热99这里精品6国产| 国产亚洲欧美另类在线观看| 日本欧美视频在线观看三区| 亚洲人人妻一区二区三区| 日本中文字幕一二区视频| 不卡日韩av在线观看| 在线观看的黄色免费网站| 天天日天天干天天插舔舔| 国产成人自拍视频播放| 97欧洲一区二区精品免费| 色综合久久五月色婷婷综合| 国产精品大陆在线2019不卡| 18禁美女黄网站色大片下载| 狠狠嗨日韩综合久久| 一二三区在线观看视频| 日韩成人免费电影二区| 老司机福利精品免费视频一区二区| weyvv5国产成人精品的视频| 白嫩白嫩美女极品国产在线观看| 中文字幕午夜免费福利视频| japanese五十路熟女熟妇| 成年美女黄网站18禁久久| 青青尤物在线观看视频网站| 久久热这里这里只有精品| 青青青青青免费视频| 人人妻人人爱人人草| 中文字幕—97超碰网| 91精品一区二区三区站长推荐| 青青草原网站在线观看| 91天堂精品一区二区| 天天做天天干天天操天天射| 91国内视频在线观看| 成人av免费不卡在线观看| 午夜精品一区二区三区城中村| 黄色成人在线中文字幕| av破解版在线观看| 99精品免费久久久久久久久a| 午夜精品福利一区二区三区p| 经典亚洲伊人第一页| 可以免费看的www视频你懂的| 在线观看一区二区三级| 2022国产综合在线干| 一级a看免费观看网站| 日本熟妇喷水xxx| 18禁美女黄网站色大片下载| 色综合久久无码中文字幕波多| 免费观看国产综合视频| 91色秘乱一区二区三区| 亚洲精品色在线观看视频| 亚洲卡1卡2卡三卡四老狼| 中文字幕一区的人妻欧美日韩| 中文字幕av第1页中文字幕| 亚洲综合色在线免费观看| 熟女视频一区,二区,三区| 色秀欧美视频第一页| 成人色综合中文字幕| 欧美va亚洲va天堂va| 93人妻人人揉人人澡人人| 中国产一级黄片免费视频播放| 青娱乐最新视频在线| a v欧美一区=区三区| 国产在线自在拍91国语自产精品| 98精产国品一二三产区区别| 91国产在线免费播放| 国产夫妻视频在线观看免费| 新婚人妻聚会被中出| 成熟丰满熟妇高潮xx×xx| 91九色porny蝌蚪国产成人| 边摸边做超爽毛片18禁色戒 | 亚洲一区二区激情在线| 国产成人精品亚洲男人的天堂| 久久香蕉国产免费天天| 天天操天天污天天射| 青青在线视频性感少妇和隔壁黑丝| aaa久久久久久久久| 国产精品黄页网站视频| 75国产综合在线视频| 中文字幕在线观看极品视频| 激情国产小视频在线| 国产成人午夜精品福利| 加勒比视频在线免费观看| 中文乱理伦片在线观看| 2018最新中文字幕在线观看| 免费看国产又粗又猛又爽又黄视频| 99热久久这里只有精品| 久久综合老鸭窝色综合久久| 97黄网站在线观看| 99热这里只有国产精品6| 粉嫩av懂色av蜜臀av | 国产密臀av一区二区三| 中文字幕日韩91人妻在线| 在线免费观看欧美小视频| 国产成人午夜精品福利| 人人在线视频一区二区| 久久99久久99精品影院| 中文字幕av第1页中文字幕| 直接能看的国产av| 黄色三级网站免费下载| 中文字幕在线观看极品视频| 日韩中文字幕在线播放第二页| 日本少妇高清视频xxxxx| 成人资源在线观看免费官网 | 成人蜜桃美臀九一一区二区三区| 亚洲精品国产在线电影| 在线视频精品你懂的| 亚洲福利午夜久久久精品电影网| 青青青青爽手机在线| 国产乱子伦一二三区| 色伦色伦777国产精品| 97瑟瑟超碰在线香蕉| 亚洲国产精品久久久久久6| 黑人借宿ntr人妻的沦陷2| 久久艹在线观看视频| 大屁股熟女一区二区三区| 成人网18免费视频版国产| 中文字幕视频一区二区在线观看| 韩国男女黄色在线观看| 人妻丝袜诱惑我操她视频| 77久久久久国产精产品| 日韩美女综合中文字幕pp| 欧洲黄页网免费观看| 日本午夜爽爽爽爽爽视频在线观看| 国产av一区2区3区| 一区二区三区久久久91| 中文字幕+中文字幕| 91免费黄片可看视频| 青青草原色片网站在线观看| 国产精品一区二区三区蜜臀av| 9l人妻人人爽人人爽| 久久热久久视频在线观看| aiss午夜免费视频| 日韩亚洲高清在线观看| 欧美日韩激情啪啪啪| 国产精品入口麻豆啊啊啊| 日韩人妻在线视频免费| 亚洲午夜伦理视频在线| 六月婷婷激情一区二区三区| 亚洲av无乱一区二区三区性色| 天天干天天日天天谢综合156| 五月天久久激情视频| 日韩av熟妇在线观看| 久久久人妻一区二区| 日视频免费在线观看| 国产自拍在线观看成人| 亚洲人成精品久久久久久久| 欧美交性又色又爽又黄麻豆| 国产精品视频资源在线播放| 99热这里只有精品中文| 在线免费观看视频一二区| 亚洲成人国产av在线| 青青草原网站在线观看| 免费在线看的黄片视频| 丝袜亚洲另类欧美变态| 97a片免费在线观看| 午夜精品九一唐人麻豆嫩草成人| 人妻av无码专区久久绿巨人| heyzo蜜桃熟女人妻| 热99re69精品8在线播放| 亚洲精品午夜aaa久久| 婷婷六月天中文字幕| 色哟哟国产精品入口| 国产亚洲成人免费在线观看| 经典国语激情内射视频| 在线观看视频网站麻豆| 成人免费做爰高潮视频| 阴茎插到阴道里面的视频| 欧美女同性恋免费a| 国产精品久久久久久美女校花| 在线可以看的视频你懂的| 欧美aa一级一区三区四区| 国产麻豆乱子伦午夜视频观看| 国产一区成人在线观看视频| 亚洲天堂av最新网址| 在线网站你懂得老司机| 青青青青青手机视频| 最新中文字幕乱码在线| 国产精品久久久久网| 日本又色又爽又黄又粗| 九色精品视频在线播放| 婷婷色国产黑丝少妇勾搭AV| 成人免费做爰高潮视频| 2020中文字幕在线播放| 欧美少妇性一区二区三区| 一级黄片久久久久久久久| 国产黄色片在线收看| 唐人色亚洲av嫩草| 色综合天天综合网国产成人| 性感美女福利视频网站| 成人色综合中文字幕| 999热精品视频在线| 成人30分钟免费视频| 亚洲福利精品福利精品福利| 亚洲av日韩高清hd| 国产实拍勾搭女技师av在线| 制服丝袜在线人妻中文字幕| 91在线免费观看成人| 久久永久免费精品人妻专区| 中文字母永久播放1区2区3区| av天堂中文字幕最新| 亚洲av日韩精品久久久久久hd| www日韩a级s片av| rct470中文字幕在线| 久久久久久99国产精品| 91国内精品久久久久精品一 | 中文字幕国产专区欧美激情| 天天操,天天干,天天射| 欧美专区日韩专区国产专区| 久草视频在线免播放| 国产精品国产三级国产午| ka0ri在线视频| 中文字幕一区二区人妻电影冢本| 中字幕人妻熟女人妻a62v网| 爱有来生高清在线中文字幕| 色哟哟国产精品入口| 中文字幕一区二区自拍| 天天干天天操天天玩天天射| 2020av天堂网在线观看| 内射久久久久综合网| okirakuhuhu在线观看| 欧美男同性恋69视频| 欧美地区一二三专区| 亚洲1069综合男同| 精品国产在线手机在线| jul—619中文字幕在线| 2022国产综合在线干| 亚洲国产精品黑丝美女| 青青擦在线视频国产在线| 蜜桃臀av蜜桃臀av| 东京热男人的av天堂| 自拍偷拍亚洲欧美在线视频| av日韩在线免费播放| 色秀欧美视频第一页| 57pao国产一区二区| 狠狠鲁狠狠操天天晚上干干| 天天摸天天日天天操| 青青草亚洲国产精品视频| 成人亚洲精品国产精品| 亚洲精品高清自拍av| 天堂av狠狠操蜜桃| 天堂女人av一区二区| 亚洲成人黄色一区二区三区| 18禁精品网站久久| 91社福利《在线观看| brazzers欧熟精品系列| 精品欧美一区二区vr在线观看| 日本韩国免费一区二区三区视频| 国产高清97在线观看视频| 99re久久这里都是精品视频| 非洲黑人一级特黄片| 大胸性感美女羞爽操逼毛片| 早川濑里奈av黑人番号| AV天堂一区二区免费试看| 亚洲福利精品视频在线免费观看 | 亚洲成a人片777777| 国产精品久久9999| 国产露脸对白在线观看| 国产精品一区二区av国| 青青操免费日综合视频观看| 国产成人午夜精品福利| 美味人妻2在线播放| 久久热久久视频在线观看| 国产亚洲欧美另类在线观看| 中文字幕AV在线免费看 | 色综合久久无码中文字幕波多| 久久久麻豆精亚洲av麻花| 视频一区二区在线免费播放| 中文字幕免费福利视频6| 66久久久久久久久久久| 女警官打开双腿沦为性奴| 粉嫩av懂色av蜜臀av| 在线视频国产欧美日韩| 中文字幕综合一区二区| 成人资源在线观看免费官网| 这里有精品成人国产99| 日本乱人一区二区三区| 天天操夜夜操天天操天天操| 国产精品伦理片一区二区| 成年女人免费播放视频| 人妻久久无码中文成人| 日本一区二区三区免费小视频| 中文字幕成人日韩欧美| 国产亚洲精品品视频在线| 欧美视频不卡一区四区| 91精品国产黑色丝袜| 在线观看国产免费麻豆| 天天射,天天操,天天说| 日韩欧美一级精品在线观看| 久久久久久久久久久免费女人| 桃色视频在线观看一区二区| 亚洲av男人天堂久久| 亚洲伊人色一综合网| 手机看片福利盒子日韩在线播放| 少妇人妻二三区视频| 免费在线黄色观看网站| 精品亚洲在线免费观看| 欧美另类z0z变态| 亚洲天堂第一页中文字幕| 青青青爽视频在线播放| 日韩熟女av天堂系列| 久久久噜噜噜久久熟女av| 在线观看911精品国产| 亚洲欧美一区二区三区电影| 国产综合高清在线观看| 在线观看欧美黄片一区二区三区| 青青青青青手机视频| 国产一线二线三线的区别在哪| 天天干天天爱天天色| 亚洲 欧美 精品 激情 偷拍| 亚洲国产在人线放午夜| 中文字幕在线观看国产片| 欧美精品资源在线观看| 国产一级麻豆精品免费| 亚洲成人三级在线播放| 日本韩国免费福利精品| 少妇露脸深喉口爆吞精| 啪啪啪18禁一区二区三区| 欧美日韩在线精品一区二区三| 亚洲国产40页第21页| 亚洲免费国产在线日韩| 这里只有精品双飞在线播放| 91片黄在线观看喷潮| 国产高清精品极品美女| 在线免费观看视频一二区| 亚洲最大免费在线观看| 一区二区三区av高清免费| 日本午夜久久女同精女女| 天天日天天操天天摸天天舔 | 欧美美女人体视频一区| 亚洲国产成人最新资源| 老司机深夜免费福利视频在线观看| 午夜激情高清在线观看| 日本真人性生活视频免费看| 午夜精品一区二区三区更新| 成人av久久精品一区二区| 性感美女诱惑福利视频| 国产精品久久久久久久女人18| 欧美另类z0z变态| 国产女人叫床高潮大片视频| 在线新三级黄伊人网| 91麻豆精品91久久久久同性| 狠狠躁狠狠爱网站视频| 国产成人自拍视频在线免费观看| 亚洲欧美综合在线探花| 91福利在线视频免费观看| 女人精品内射国产99| 888亚洲欧美国产va在线播放| 边摸边做超爽毛片18禁色戒| 国产91精品拍在线观看| 99精品视频在线观看婷婷| 成人精品在线观看视频| 日本韩国在线观看一区二区| 中文字幕一区二 区二三区四区 | 好吊操视频这里只有精品| 大胆亚洲av日韩av| 色婷婷久久久久swag精品| 激情五月婷婷综合色啪| 喷水视频在线观看这里只有精品| 99热久久极品热亚洲| 国产剧情演绎系列丝袜高跟| 中文字幕 亚洲av| 91亚洲手机在线视频播放| 亚洲va天堂va国产va久| 国产精品欧美日韩区二区| 国产免费av一区二区凹凸四季| 中文字幕日韩人妻在线三区| 人人超碰国字幕观看97| 免费看国产av网站| 香蕉片在线观看av| 日噜噜噜夜夜噜噜噜天天噜噜噜| 阿v天堂2014 一区亚洲| 偷青青国产精品青青在线观看| 少妇人妻真实精品视频| 偷拍3456eee| 深夜男人福利在线观看| 中文字幕在线免费第一页| 国产三级影院在线观看| 免费黄页网站4188| sw137 中文字幕 在线| 成人H精品动漫在线无码播放| 男人插女人视频网站| 久久麻豆亚洲精品av| 日本av在线一区二区三区| 99热碰碰热精品a中文| 91九色porny国产在线| 香港三日本三韩国三欧美三级| 欧洲黄页网免费观看| 国产成人精品av网站| 国产一区二区久久久裸臀| 黄色大片免费观看网站| 亚洲av无硬久久精品蜜桃| 亚洲乱码中文字幕在线| 成人在线欧美日韩国产| 青青草原网站在线观看| 中文字幕av男人天堂| 51国产偷自视频在线播放| 91天堂精品一区二区| 97人人妻人人澡人人爽人人精品| 五月天久久激情视频| 亚国产成人精品久久久| 天天操,天天干,天天射| 99re国产在线精品| 欧美少妇性一区二区三区| 97香蕉碰碰人妻国产樱花| 亚洲 清纯 国产com| 久久永久免费精品人妻专区 | 欧美色呦呦最新网址| 天天操天天射天天操天天天| 2019av在线视频| 亚洲福利天堂久久久久久| 久久久超爽一二三av| 国产一区成人在线观看视频| 18禁精品网站久久| free性日本少妇| 国产日韩精品电影7777| 亚洲免费在线视频网站| 亚洲综合一区成人在线| 亚洲免费av在线视频| 国产亚洲成人免费在线观看| 大胆亚洲av日韩av| avjpm亚洲伊人久久| 精内国产乱码久久久久久| 伊人情人综合成人久久网小说| av网站色偷偷婷婷网男人的天堂| 97人人模人人爽人人喊| 91亚洲精品干熟女蜜桃频道| 人妻少妇性色欲欧美日韩| 国产高潮无码喷水AV片在线观看| 精品国产高潮中文字幕| 五月精品丁香久久久久福利社| 色花堂在线av中文字幕九九| 国内资源最丰富的网站| 最新激情中文字幕视频| 日本性感美女视频网站| 国产麻豆剧传媒精品国产av蜜桃| 扒开让我视频在线观看| av在线观看网址av| 午夜av一区二区三区| 成年人该看的视频黄免费| 亚洲天堂精品久久久| 免费男阳茎伸入女阳道视频| 99精品免费观看视频| 日本人竟这样玩学生妹| 午夜激情久久不卡一区二区| 老熟妇凹凸淫老妇女av在线观看| 国产乱子伦精品视频潮优女| 77久久久久国产精产品| 亚洲中文精品人人免费| 99热这里只有精品中文| 久久精品亚洲国产av香蕉| 这里有精品成人国产99| 非洲黑人一级特黄片| 97精品视频在线观看| 国产一区av澳门在线观看| 视频久久久久久久人妻| 2021久久免费视频| 成年人免费看在线视频| 欧美性感尤物人妻在线免费看| 亚洲精品av在线观看| 大陆av手机在线观看| 日韩精品啪啪视频一道免费| 99热久久这里只有精品| 亚洲精品亚洲人成在线导航| 午夜91一区二区三区| 免费看高清av的网站| 香蕉91一区二区三区| 亚洲Av无码国产综合色区| av在线免费资源站| 国产麻豆国语对白露脸剧情| 国产视频在线视频播放| 丰满熟女午夜福利视频| gay gay男男瑟瑟在线网站| 夜夜操,天天操,狠狠操| 插逼视频双插洞国产操逼插洞| 18禁精品网站久久| 日本www中文字幕| 国产又粗又硬又猛的毛片视频| 非洲黑人一级特黄片| gogo国模私拍视频| 国产精品久久久黄网站| 激情伦理欧美日韩中文字幕| 国产精品人妻一区二区三区网站| 亚洲一区久久免费视频| 被大鸡吧操的好舒服视频免费| 亚洲av男人天堂久久| 亚洲成人激情av在线| 日本18禁久久久久久| 91快播视频在线观看| 18禁免费av网站| 操日韩美女视频在线免费看| 国产成人精品av网站| 97超碰免费在线视频| 午夜大尺度无码福利视频| 91精品国产综合久久久蜜| 中文字母永久播放1区2区3区 | 又色又爽又黄又刺激av网站| 青青青青草手机在线视频免费看| 欧美精品国产综合久久| 亚洲午夜电影之麻豆| 桃色视频在线观看一区二区| 婷婷色国产黑丝少妇勾搭AV| 水蜜桃国产一区二区三区| 国产又粗又黄又硬又爽| 天天做天天爽夜夜做少妇| 中文字幕av男人天堂| 精品国产成人亚洲午夜| 国产在线自在拍91国语自产精品| 亚洲 人妻 激情 中文| 97国产精品97久久| 亚洲熟女女同志女同| 国产熟妇乱妇熟色T区| 中文字幕日本人妻中出| 激情人妻校园春色亚洲欧美| 扒开让我视频在线观看| 国产一区二区欧美三区 | chinese国产盗摄一区二区| 真实国模和老外性视频| 黄色男人的天堂视频| 亚洲人妻视频在线网| 男生舔女生逼逼的视频| av久久精品北条麻妃av观看| 99久久成人日韩欧美精品| 国产chinesehd精品麻豆| 精品亚洲中文字幕av| 摧残蹂躏av一二三区| 成年人午夜黄片视频资源| 人妻最新视频在线免费观看| 欧美日韩激情啪啪啪| 被大鸡吧操的好舒服视频免费| 中国无遮挡白丝袜二区精品| 香蕉aⅴ一区二区三区| 亚洲综合在线视频可播放| 啪啪啪18禁一区二区三区 | 亚洲自拍偷拍综合色| 男生舔女生逼逼视频| 中文字幕一区的人妻欧美日韩| 揄拍成人国产精品免费看视频| 国产品国产三级国产普通话三级| 青青草人人妻人人妻| 激情综合治理六月婷婷| 欧美精品免费aaaaaa| 午夜久久久久久久99| 91色老99久久九九爱精品| 国产精品国产三级国产精东 | 99精品久久久久久久91蜜桃| 欧美亚洲偷拍自拍色图| 日本三极片中文字幕| 亚洲一区二区三区精品视频在线| 日韩二区视频一线天婷婷五| 黑人性生活视频免费看| 亚洲天堂有码中文字幕视频| 91大神福利视频网| 硬鸡巴动态操女人逼视频| 亚洲av男人的天堂你懂的| 亚洲国产香蕉视频在线播放| 亚洲激情av一区二区| 青青青青视频在线播放| 人妻久久久精品69系列| 91久久人澡人人添人人爽乱| 国产露脸对白在线观看| 国产成人精品久久二区91| 色婷婷精品大在线观看| 国产午夜亚洲精品不卡在线观看| 制服丝袜在线人妻中文字幕| 欧美爆乳肉感大码在线观看 | 日视频免费在线观看| 久久久91蜜桃精品ad| 狠狠的往里顶撞h百合| 中文字幕日韩精品就在这里| 男人的天堂在线黄色| 午夜精品九一唐人麻豆嫩草成人| 在线免费观看视频一二区| 天天操,天天干,天天射| 中文字幕1卡1区2区3区| 天天日天天操天天摸天天舔| 精品成人午夜免费看| 国产乱子伦精品视频潮优女| av网址国产在线观看| 北条麻妃肉色丝袜视频| 黄色视频在线观看高清无码 | 日韩欧美国产精品91| 亚洲成人激情视频免费观看了| 国产chinesehd精品麻豆| 成熟熟女国产精品一区| 天天干天天操天天玩天天射| 1769国产精品视频免费观看| 57pao国产一区二区| 一区二区三区视频,福利一区二区| 在线观看欧美黄片一区二区三区| 日本韩国在线观看一区二区| 亚洲嫩模一区二区三区| sejizz在线视频| 干逼又爽又黄又免费的视频| 一区二区三区在线视频福利| 免费在线观看污污视频网站| 一区二区视频在线观看视频在线| 日本少妇精品免费视频| 93精品视频在线观看| av中文在线天堂精品| 九色视频在线观看免费| 韩国爱爱视频中文字幕| 成熟丰满熟妇高潮xx×xx | 成人精品视频99第一页| 成人av亚洲一区二区| 香蕉91一区二区三区| 五月精品丁香久久久久福利社| 狠狠地躁夜夜躁日日躁| 漂亮 人妻被中出中文| 天天操夜夜操天天操天天操| 色婷婷精品大在线观看| 97少妇精品在线观看| 日韩激情文学在线视频| 都市家庭人妻激情自拍视频| 91人妻精品久久久久久久网站| 国产伦精品一区二区三区竹菊| 青青青青青青青青青青草青青| 国产乱子伦一二三区| 亚洲av人人澡人人爽人人爱| 免费啪啪啪在线观看视频| 播放日本一区二区三区电影| 欧美成人黄片一区二区三区 | 最新91九色国产在线观看| 亚洲成a人片777777| 丰满少妇翘臀后进式| 丰满少妇人妻xxxxx| 成人国产激情自拍三区| 欧美中文字幕一区最新网址| 精品成人啪啪18免费蜜臀| 大鸡巴操娇小玲珑的女孩逼| av新中文天堂在线网址| 国产91精品拍在线观看| 好太好爽好想要免费| 91人妻精品久久久久久久网站| 视频一区二区在线免费播放| 亚洲国产精品免费在线观看| 免费成人av中文字幕| 国产白袜脚足J棉袜在线观看| 哥哥姐姐综合激情小说| 欧美日韩熟女一区二区三区| 亚洲色偷偷综合亚洲AV伊人| 国产精品欧美日韩区二区| 日本黄色特一级视频| 制丝袜业一区二区三区| 成人免费公开视频无毒| 国产精品自拍视频大全| 99久久中文字幕一本人| 中文字幕在线一区精品| 免费在线观看视频啪啪| 天天日天天做天天日天天做| 男人的天堂av日韩亚洲| 国产污污污污网站在线| 五十路熟女人妻一区二区9933| 女蜜桃臀紧身瑜伽裤| 欧美日韩一区二区电影在线观看| 国产精品中文av在线播放| 国产 在线 免费 精品| 天天夜天天日天天日| 日日操综合成人av| 亚洲av第国产精品| 人妻自拍视频中国大陆| 在线观看911精品国产| 亚洲午夜电影之麻豆| 边摸边做超爽毛片18禁色戒| 欧美另类z0z变态| 人妻另类专区欧美制服| 青青青青在线视频免费观看| 中文字幕在线视频一区二区三区| 亚洲欧美综合另类13p| 韩国爱爱视频中文字幕| 美女被肏内射视频网站| 亚洲无线观看国产高清在线| 嫩草aⅴ一区二区三区| 含骚鸡巴玩逼逼视频| 亚洲av日韩精品久久久久久hd| 98视频精品在线观看| rct470中文字幕在线| 国产熟妇人妻ⅹxxxx麻豆| 精品久久久久久高潮| 日韩欧美一级黄片亚洲| 1769国产精品视频免费观看| 欧美男人大鸡吧插女人视频| 黑人巨大的吊bdsm| 欧美专区日韩专区国产专区| 亚洲视频在线视频看视频在线| 天天日天天干天天插舔舔| 97国产福利小视频合集| 欧美激情精品在线观看| 搡老妇人老女人老熟女| 久久精品国产亚洲精品166m| 日本黄在免费看视频| 美味人妻2在线播放| 国产精品午夜国产小视频| 欧美久久久久久三级网| 在线观看操大逼视频| 欧美亚洲国产成人免费在线| 国产性生活中老年人视频网站| 一级A一级a爰片免费免会员| 日韩三级电影华丽的外出| 亚洲美女高潮喷浆视频| 日韩三级黄色片网站| 五十路丰满人妻熟妇| 欧美一级色视频美日韩| 青青青青青手机视频| 国产一区二区神马久久| 中出中文字幕在线观看| 中文字幕免费在线免费| 性感美女高潮视频久久久| 国产精品久久久久久久女人18| 欧美精品资源在线观看| 自拍偷拍亚洲精品第2页| 国产卡一卡二卡三乱码手机| 伊人开心婷婷国产av| 日韩欧美一级黄片亚洲| 老司机午夜精品视频资源| 搡老妇人老女人老熟女| 久青青草视频手机在线免费观看 | 大鸡吧插逼逼视频免费看 | 偷拍美女一区二区三区| 99精品视频在线观看婷婷| 亚洲欧美一区二区三区电影| 亚洲一区二区激情在线| 91免费福利网91麻豆国产精品 | 91人妻精品久久久久久久网站| 熟女在线视频一区二区三区| 日本乱人一区二区三区| 欧亚日韩一区二区三区观看视频| 蜜臀av久久久久久久| 91麻豆精品传媒国产黄色片| 91亚洲手机在线视频播放| 农村胖女人操逼视频| 国产女人被做到高潮免费视频| 成年女人免费播放视频| av男人天堂狠狠干| 又粗又硬又猛又黄免费30| 大香蕉伊人中文字幕| 大学生A级毛片免费视频| 亚洲黄色av网站免费播放| 亚洲日本一区二区三区| 中文字幕,亚洲人妻| 粉嫩av蜜乳av蜜臀| 成人精品在线观看视频| 动漫黑丝美女的鸡巴| 色吉吉影音天天干天天操 | 人妻无码中文字幕专区| av中文字幕网址在线| 大骚逼91抽插出水视频| 中文字幕日韩精品日本| 亚洲av香蕉一区区二区三区犇| 中文字幕最新久久久| 国产精品伦理片一区二区| 国产在线免费观看成人| 青青青青操在线观看免费| 国产剧情演绎系列丝袜高跟| 欧美黑人性猛交xxxxⅹooo| 国产精品三级三级三级| 青青擦在线视频国产在线| 精品一区二区三区欧美| 黄色的网站在线免费看| 亚洲国产精品美女在线观看| 日日夜夜精品一二三| 任你操任你干精品在线视频| 国产剧情演绎系列丝袜高跟| www,久久久,com| 91极品大一女神正在播放| 久久久制服丝袜中文字幕| 日韩人妻丝袜中文字幕| 久久久久久久99精品| 国产中文字幕四区在线观看| 91国产在线视频免费观看| 国产麻豆91在线视频| 北条麻妃肉色丝袜视频| 黄色资源视频网站日韩| 亚洲va天堂va国产va久| 天天日天天干天天干天天日| 亚洲av午夜免费观看| 国产白嫩美女一区二区| 亚洲中文字字幕乱码| 国产成人自拍视频播放| 日韩伦理短片在线观看| 亚洲精品国品乱码久久久久| 亚洲最大黄 嗯色 操 啊| 亚洲欧洲一区二区在线观看| 亚洲伊人色一综合网| 欧美viboss性丰满| 中国视频一区二区三区| 亚洲变态另类色图天堂网| 久久农村老妇乱69系列| 大胸性感美女羞爽操逼毛片| 欧美成人黄片一区二区三区| 日韩不卡中文在线视频网站| 久久永久免费精品人妻专区| 国产大鸡巴大鸡巴操小骚逼小骚逼| 亚洲欧美久久久久久久久| 国产精品一区二区三区蜜臀av| aiss午夜免费视频| 啪啪啪操人视频在线播放| 亚洲 欧美 自拍 偷拍 在线| 好男人视频在线免费观看网站| 欧美日韩一区二区电影在线观看| 九色视频在线观看免费| 欧美视频一区免费在线| 久久久精品999精品日本| 曰本无码人妻丰满熟妇啪啪| 中文字幕第1页av一天堂网| 亚洲国产香蕉视频在线播放| 操的小逼流水的文章| 日本脱亚入欧是指什么| 不卡一区一区三区在线| 久久亚洲天堂中文对白| 丝袜长腿第一页在线| 97国产福利小视频合集| 一二三区在线观看视频| 亚洲综合在线视频可播放| 天堂女人av一区二区| 国产精品久久久久网| 天堂av在线播放免费| 国产性色生活片毛片春晓精品| 亚洲另类综合一区小说| 天天干天天操天天扣| 欧美精产国品一二三产品价格| 888欧美视频在线| 亚洲另类在线免费观看| 午夜精品九一唐人麻豆嫩草成人| 在线观看免费岛国av| 亚洲欧美人精品高清| 偷拍自拍视频图片免费| 成人国产小视频在线观看| 9l人妻人人爽人人爽| 香港三日本三韩国三欧美三级| 啊啊好大好爽啊啊操我啊啊视频 | 日韩av熟妇在线观看| 大香蕉伊人国产在线| 久草视频在线一区二区三区资源站| 最新国产亚洲精品中文在线| 亚洲欧美久久久久久久久| 亚洲精品国品乱码久久久久| 中文字幕人妻一区二区视频| 成年人黄色片免费网站| 超污视频在线观看污污污| 一级黄片久久久久久久久| 日本韩国在线观看一区二区| 欧美亚洲牲夜夜综合久久| 天天日天天爽天天干| 国产va精品免费观看| 五十路av熟女松本翔子| 97香蕉碰碰人妻国产樱花| 69精品视频一区二区在线观看| 欧美精品资源在线观看| 国产福利小视频二区| 天天日天天做天天日天天做| 亚洲精品国产综合久久久久久久久 | 在线不卡日韩视频播放| 精品一线二线三线日本| 精品人人人妻人人玩日产欧| 福利一二三在线视频观看| 在线免费观看国产精品黄色| 人妻激情图片视频小说| 青青青艹视频在线观看| 亚洲精品高清自拍av | 亚洲久久午夜av一区二区| 一级A一级a爰片免费免会员 | 精品久久久久久久久久久a√国产| 日本中文字幕一二区视频| okirakuhuhu在线观看| av中文字幕国产在线观看| 激情五月婷婷综合色啪| brazzers欧熟精品系列| 亚洲一区二区激情在线| 亚洲第一黄色在线观看| 亚洲人一区二区中文字幕| 国产实拍勾搭女技师av在线| 午夜美女少妇福利视频| 成人H精品动漫在线无码播放| 国产乱弄免费视频观看| 午夜精品一区二区三区福利视频| 密臀av一区在线观看| 精品久久久久久久久久久99| 97少妇精品在线观看| 91久久精品色伊人6882| av老司机精品在线观看| 91精品国产黑色丝袜| 三上悠亚和黑人665番号| 亚洲最大黄 嗯色 操 啊| 日本少妇高清视频xxxxx| 精品日产卡一卡二卡国色天香| 韩国爱爱视频中文字幕| 黄色录像鸡巴插进去| 中文字幕国产专区欧美激情| 国产欧美精品免费观看视频| 少妇一区二区三区久久久| 日本高清在线不卡一区二区| 国产视频在线视频播放| 精品亚洲中文字幕av| 欧美交性又色又爽又黄麻豆| 中出中文字幕在线观看| 亚国产成人精品久久久| 免费观看污视频网站| 91精品国产观看免费| 女警官打开双腿沦为性奴| 黑人乱偷人妻中文字幕| 美女骚逼日出水来了| 亚洲精品 欧美日韩| 午夜国产福利在线观看| 99re6热在线精品| 亚洲欧美一区二区三区电影| 特一级特级黄色网片| 天天日天天干天天搡| 国产精品中文av在线播放| 成年人免费看在线视频| 成年人免费看在线视频| 天天射夜夜操狠狠干| 99热这里只有精品中文| 国语对白xxxx乱大交| 人人爱人人妻人人澡39| 久久久久久性虐视频| 在线观看操大逼视频| 直接能看的国产av| 精品乱子伦一区二区三区免费播| 粉嫩av蜜乳av蜜臀| 黄页网视频在线免费观看| 国产高清精品极品美女| 一区二区三区另类在线| 久久这里只有精品热视频 | av在线观看网址av| 51国产成人精品视频| 天堂av在线播放免费| 男人操女人逼逼视频网站| 狠狠地躁夜夜躁日日躁| 日韩北条麻妃一区在线| 偷拍自拍 中文字幕| 国产综合高清在线观看| 日韩美女综合中文字幕pp| 婷婷六月天中文字幕| 91精品高清一区二区三区| 国产+亚洲+欧美+另类| 黄色片一级美女黄色片| 久久www免费人成一看片| 极品粉嫩小泬白浆20p主播 | 五十路熟女人妻一区二区9933| 亚洲精品三级av在线免费观看| 天天干天天日天天谢综合156| 人人爽亚洲av人人爽av| 久久综合老鸭窝色综合久久| 黄色片年轻人在线观看| 亚洲变态另类色图天堂网| 在线制服丝袜中文字幕| 亚洲在线免费h观看网站| 日韩欧美一级aa大片| 早川濑里奈av黑人番号| 男女啪啪视频免费在线观看| 欧美成人精品欧美一级黄色| 日本在线不卡免费视频| 一区二区三区麻豆福利视频| 水蜜桃一区二区三区在线观看视频| 亚洲美女高潮喷浆视频| 18禁美女无遮挡免费| 亚洲欧美激情国产综合久久久 | 亚洲欧美精品综合图片小说| 国产综合高清在线观看| 亚洲人妻视频在线网| 亚洲男人在线天堂网| 午夜福利资源综合激情午夜福利资 | 中文字幕免费在线免费| 国产精品一区二区av国| 欧美在线偷拍视频免费看 | 亚洲成人午夜电影在线观看| 十八禁在线观看地址免费| 自拍 日韩 欧美激情| 欧美成人综合视频一区二区| 久久艹在线观看视频| 又粗又长 明星操逼小视频 | 经典亚洲伊人第一页| 中文字幕av第1页中文字幕| 亚洲一级美女啪啪啪| 自拍 日韩 欧美激情| 91中文字幕免费在线观看| 97年大学生大白天操逼| 丝袜美腿视频诱惑亚洲无| 很黄很污很色的午夜网站在线观看| 青青草成人福利电影| 人妻无码色噜噜狠狠狠狠色| 亚洲偷自拍高清视频| 欧美日韩在线精品一区二区三| 75国产综合在线视频| 91人妻精品久久久久久久网站| 男生用鸡操女生视频动漫| 青青青青青青草国产| 国产一区二区在线欧美| 日韩美女搞黄视频免费| 熟女在线视频一区二区三区| 日韩黄色片在线观看网站| 欧美亚洲牲夜夜综合久久| 久久精品美女免费视频| 久久精品国产23696| 亚洲av香蕉一区区二区三区犇| 精品国产午夜视频一区二区| 国产成人精品亚洲男人的天堂| 中文字幕,亚洲人妻| 污污小视频91在线观看| 亚洲一区二区三区精品视频在线| 伊拉克及约旦宣布关闭领空| 国产视频网站国产视频| 亚洲一级美女啪啪啪| 亚洲av日韩高清hd| 亚洲av黄色在线网站| 成人av免费不卡在线观看| 小穴多水久久精品免费看| 青青在线视频性感少妇和隔壁黑丝| 国产高清在线观看1区2区| 精品人妻每日一部精品| 午夜青青草原网在线观看| 国产一区二区火爆视频| 岛国青草视频在线观看| 中文字幕av一区在线观看| 天天干天天操天天插天天日| 青青草亚洲国产精品视频| 国产91嫩草久久成人在线视频| 精品成人午夜免费看| 国产第一美女一区二区三区四区 | 韩国一级特黄大片做受| 日韩欧美中文国产在线| 精品国产成人亚洲午夜| 福利视频一区二区三区筱慧| 婷婷综合蜜桃av在线| 专门看国产熟妇的网站| gogo国模私拍视频| 青娱乐极品视频青青草| 青青青青爽手机在线| 日韩精品一区二区三区在线播放 | 在线免费观看av日韩| 99热99re在线播放| 国产成人精品福利短视频| 欧美偷拍自拍色图片| 亚洲欧美一卡二卡三卡| 午夜美女少妇福利视频| 最新黄色av网站在线观看| 日本一二三中文字幕| 亚洲国产在人线放午夜| 91精品资源免费观看| 中文字幕一区二区三区蜜月| 国产精品探花熟女在线观看| 亚洲女人的天堂av| 日韩成人性色生活片| 中文字幕人妻被公上司喝醉在线 | 中文字幕熟女人妻久久久| 亚洲av成人网在线观看| 青娱乐在线免费视频盛宴| 在线免费观看国产精品黄色| avjpm亚洲伊人久久| 日韩精品二区一区久久| 中文乱理伦片在线观看| 精内国产乱码久久久久久| 亚洲区欧美区另类最新章节| 国产精品手机在线看片| 超级福利视频在线观看| 美洲精品一二三产区区别| 黄色成年网站午夜在线观看| 97瑟瑟超碰在线香蕉| 在线免费91激情四射 | 女生自摸在线观看一区二区三区 | 欧美亚洲一二三区蜜臀| 欧美另类z0z变态| 人妻熟女在线一区二区| 成年人午夜黄片视频资源| 亚洲一区二区三区在线高清| 天天日天天透天天操| 自拍偷拍亚洲精品第2页| 天天日天天透天天操| 日本精品一区二区三区在线视频。| 熟女俱乐部一二三区| 亚洲中文精品字幕在线观看| 亚洲精品三级av在线免费观看| 亚洲护士一区二区三区| 伊人开心婷婷国产av| 美女日逼视频免费观看| 伊人成人综合开心网| 日韩精品激情在线观看| 精品美女福利在线观看| 亚洲图片欧美校园春色| 狠狠鲁狠狠操天天晚上干干| 最新国产精品网址在线观看| 青青草在观免费国产精品| 日韩视频一区二区免费观看| 蜜臀av久久久久久久| 又粗又长 明星操逼小视频| 国产乱子伦一二三区| 人妻少妇av在线观看| 亚洲va国产va欧美精品88| 热久久只有这里有精品| 亚洲欧美激情人妻偷拍| 黄色无码鸡吧操逼视频| 91麻豆精品秘密入口在线观看| 偷青青国产精品青青在线观看 | 极品性荡少妇一区二区色欲| 57pao国产一区二区| 日韩在线视频观看有码在线| 日韩精品中文字幕播放| 神马午夜在线观看视频| av无限看熟女人妻另类av| 大香蕉大香蕉在线看| 岛国一区二区三区视频在线| v888av在线观看视频| 亚洲国产精品久久久久久6| 国产麻豆精品人妻av| 精品91高清在线观看| 欧美日本在线观看一区二区| 亚洲av可乐操首页| 欧美香蕉人妻精品一区二区| 天堂女人av一区二区| 伊人综合免费在线视频| 2020久久躁狠狠躁夜夜躁 | 大陆胖女人与丈夫操b国语高清 | 爱爱免费在线观看视频| 五十路人妻熟女av一区二区| 黄片色呦呦视频免费看| 亚洲综合乱码一区二区| 可以在线观看的av中文字幕| 2012中文字幕在线高清| 特黄老太婆aa毛毛片| 久草极品美女视频在线观看| 男女之间激情网午夜在线| 欧美在线精品一区二区三区视频 | 91国产资源在线视频| 欧美80老妇人性视频| 久草视频在线免播放| 日本av在线一区二区三区| 亚洲区欧美区另类最新章节| 人人妻人人人操人人人爽| 综合一区二区三区蜜臀| 成人午夜电影在线观看 久久| 欧美一级视频一区二区| 伊人成人在线综合网| 少妇露脸深喉口爆吞精| av无限看熟女人妻另类av| 91国产在线免费播放| av高潮迭起在线观看| 人妻自拍视频中国大陆| 93人妻人人揉人人澡人人| 国产又色又刺激在线视频| 3D动漫精品啪啪一区二区下载| 欧美在线一二三视频| 精品一区二区三四区| 噜噜色噜噜噜久色超碰| 亚洲成a人片777777| 换爱交换乱高清大片| 在线播放国产黄色av| 日韩a级黄色小视频| 久久机热/这里只有| 51国产偷自视频在线播放| 国产九色91在线视频| 成年午夜影片国产片| 久久美欧人妻少妇一区二区三区 | av在线shipin| 人人人妻人人澡人人| 亚洲中文字幕综合小综合| 国产亚洲成人免费在线观看 | 91精品国产高清自在线看香蕉网| 日本后入视频在线观看| 姐姐的朋友2在线观看中文字幕| 在线观看操大逼视频| 日本熟女精品一区二区三区| 丰满熟女午夜福利视频| 精品国产污污免费网站入口自| 亚洲女人的天堂av| 韩国AV无码不卡在线播放| 91极品大一女神正在播放| 女同性ⅹxx女同hd| 亚洲欧美另类手机在线| 91免费观看国产免费| 大香蕉伊人中文字幕| 午夜美女少妇福利视频| 超碰在线中文字幕一区二区| 黄色片一级美女黄色片| 一个色综合男人天堂| 成人网18免费视频版国产| 护士特殊服务久久久久久久| 日韩美女搞黄视频免费| 视频一区二区综合精品| 日韩激情文学在线视频| 色爱av一区二区三区| 在线观看免费视频色97| 欧美 亚洲 另类综合| 国产三级影院在线观看| 北条麻妃av在线免费观看| 国产午夜福利av导航| 青青草在观免费国产精品| 久久久制服丝袜中文字幕| 一区二区麻豆传媒黄片 | 女人精品内射国产99| 国产精品系列在线观看一区二区 | 精品av久久久久久久| 国产欧美精品一区二区高清| 色综合天天综合网国产成人| 精品日产卡一卡二卡国色天香| 91精品视频在线观看免费| 国产精品久久久久国产三级试频| 国产夫妻视频在线观看免费| 成人区人妻精品一区二视频| 亚洲国产精品免费在线观看| 新97超碰在线观看| av乱码一区二区三区| 美女操逼免费短视频下载链接 | 欧美国产亚洲中英文字幕| 99精品视频之69精品视频 | 精品日产卡一卡二卡国色天香 | 精品一区二区三区在线观看| 国产精品人妻66p| 天天干天天插天天谢| 国产欧美精品不卡在线| 91成人在线观看免费视频| 午夜精品在线视频一区| 91亚洲国产成人精品性色| 黄色视频在线观看高清无码| 一级a看免费观看网站| 欧美一级片免费在线成人观看 | 啊用力插好舒服视频| 国产清纯美女al在线| 免费岛国喷水视频在线观看| av老司机亚洲一区二区| 91麻豆精品久久久久| 三上悠亚和黑人665番号| 国产视频在线视频播放| 成人蜜桃美臀九一一区二区三区 | 婷婷色中文亚洲网68| 抽查舔水白紧大视频| 欧美 亚洲 另类综合| 青青青视频自偷自拍38碰| 久久精品久久精品亚洲人| 在线网站你懂得老司机| 国产黄色a级三级三级三级| 久久久久久国产精品| 狠狠躁狠狠爱网站视频| 欧美xxx成人在线| 青青青艹视频在线观看| 欧美怡红院视频在线观看| 麻豆精品成人免费视频| av新中文天堂在线网址| 亚洲中文字幕人妻一区| 五月婷婷在线观看视频免费| 大学生A级毛片免费视频| 国产成人自拍视频播放| 激情啪啪啪啪一区二区三区| 老司机欧美视频在线看| 亚洲综合另类欧美久久| 在线观看av亚洲情色| 18禁美女黄网站色大片下载| 亚洲av一妻不如妾| 亚洲av香蕉一区区二区三区犇| 新97超碰在线观看| 天天日天天爽天天爽| 中英文字幕av一区| 91‖亚洲‖国产熟女| 中文字幕高清免费在线人妻| 中国黄色av一级片| 欧美一区二区三区激情啪啪啪| 熟女国产一区亚洲中文字幕| 青青青青在线视频免费观看| 538精品在线观看视频| 亚洲公开视频在线观看| 亚洲欧美综合在线探花| 人妻少妇av在线观看| 日韩成人性色生活片| 日韩欧美在线观看不卡一区二区 | 综合精品久久久久97| 亚洲一区二区久久久人妻| 伊人综合免费在线视频| 欧美一区二区三区久久久aaa| 黄色视频在线观看高清无码 | 啪啪啪操人视频在线播放| 亚洲精品福利网站图片| 天天艹天天干天天操| 18禁污污污app下载| 中文字幕亚洲中文字幕| 自拍偷拍,中文字幕| 亚洲国产精品美女在线观看| 一区二区三区av高清免费| 精品久久久久久久久久久久人妻 | 国产精品自拍偷拍a| 2025年人妻中文字幕乱码在线| 国产福利小视频二区| 天天日天天天天天天天天天天| 国产精品中文av在线播放 | 欧美综合婷婷欧美综合| 人妻爱爱 中文字幕| 国产精品久久久久国产三级试频| 直接能看的国产av| xxx日本hd高清| 国产午夜亚洲精品麻豆| 中文字幕一区二 区二三区四区 | 黄色在线观看免费观看在线| 亚洲av自拍偷拍综合| 亚洲福利午夜久久久精品电影网| 国产精品欧美日韩区二区| 国产在线91观看免费观看| 人人妻人人澡欧美91精品| 国产视频在线视频播放| 精品老妇女久久9g国产| 岳太深了紧紧的中文字幕| 国产亚洲四十路五十路| 亚洲欧美在线视频第一页| 粉嫩欧美美人妻小视频| 中文字幕一区二区三区人妻大片| 欧美视频一区免费在线| 91国内精品自线在拍白富美| 国产91精品拍在线观看| 免费看美女脱光衣服的视频| 日韩熟女av天堂系列| 国产精品黄页网站视频| 中文字幕AV在线免费看 | 久久久久久久久久一区二区三区| 动漫黑丝美女的鸡巴| av天堂加勒比在线| 一区二区三区视频,福利一区二区| 高清成人av一区三区| 2021天天色天天干| 一区二区三区视频,福利一区二区| 天天摸天天亲天天舔天天操天天爽 | 中文字幕高清资源站| 丝袜长腿第一页在线| 日韩精品激情在线观看| 色狠狠av线不卡香蕉一区二区| 亚洲天堂精品久久久| 精品suv一区二区69| av手机免费在线观看高潮| 亚洲午夜伦理视频在线| 激情内射在线免费观看| 男人的天堂在线黄色| 欧美一区二区三区啪啪同性| 91麻豆精品传媒国产黄色片| 又粗又硬又猛又爽又黄的| 中文字幕无码一区二区免费| 青青青青青青青在线播放视频| 色在线观看视频免费的| 国产成人精品福利短视频| 熟女人妻在线观看视频| 日本后入视频在线观看| 欧美日韩熟女一区二区三区| 狠狠操狠狠操免费视频| 在线不卡日韩视频播放| 亚洲天堂有码中文字幕视频| 天天干天天日天天干天天操| 免费福利av在线一区二区三区| 精品一区二区三区在线观看| 风流唐伯虎电视剧在线观看| 黄色片年轻人在线观看| 国内精品在线播放第一页| 男人在床上插女人视频| 中文字幕奴隷色的舞台50| 亚洲女人的天堂av| 日本免费视频午夜福利视频| 美女福利写真在线观看视频| 最新国产精品拍在线观看| 91九色porny国产在线| 2020久久躁狠狠躁夜夜躁 | 亚洲国产精品久久久久蜜桃| 在线观看视频一区麻豆| 99亚洲美女一区二区三区| 国产一区二区在线欧美| 超碰公开大香蕉97| 久久精品国产23696| 亚洲精品亚洲人成在线导航| 玖玖一区二区在线观看| 阿v天堂2014 一区亚洲| 国产第一美女一区二区三区四区| 18禁美女羞羞免费网站| 国产精品久久久久久美女校花| 99热国产精品666| 亚洲 欧美 自拍 偷拍 在线| 亚洲av自拍偷拍综合| 久草视频在线免播放| 中文字幕av熟女人妻| 中文字幕在线乱码一区二区| 国产精品福利小视频a| 国产精选一区在线播放| 亚洲综合色在线免费观看| 男生舔女生逼逼的视频| 国产不卡av在线免费| 好吊视频—区二区三区| 免费无码人妻日韩精品一区二区| 久精品人妻一区二区三区| 亚洲国产成人在线一区| 久久久久久久精品老熟妇| 少妇一区二区三区久久久| 青青色国产视频在线| 福利视频网久久91| 自拍偷拍 国产资源| 日韩av免费观看一区| 97国产福利小视频合集| 国产伊人免费在线播放| 99热国产精品666| 欧美亚洲国产成人免费在线| 美女大bxxxx内射| 农村胖女人操逼视频| 亚洲一区二区三区精品乱码| 日韩三级电影华丽的外出| 日韩美女综合中文字幕pp| 97国产在线av精品| 久久h视频在线观看| 日韩美女综合中文字幕pp| 中文亚洲欧美日韩无线码| 高潮喷水在线视频观看| 80电影天堂网官网| 婷婷久久一区二区字幕网址你懂得| 青青社区2国产视频| av乱码一区二区三区| 亚洲精品一线二线在线观看| 亚洲激情,偷拍视频| 97小视频人妻一区二区| AV无码一区二区三区不卡| 麻豆性色视频在线观看| 午夜成午夜成年片在线观看| 欧美viboss性丰满| 免费无毒热热热热热热久| 深夜男人福利在线观看| 自拍 日韩 欧美激情| 不卡精品视频在线观看| 欧美成人综合视频一区二区| 91人妻精品一区二区在线看| 熟女人妻在线中出观看完整版| 91人妻精品久久久久久久网站| 亚洲日本一区二区三区 | 中文字幕高清在线免费播放| 中文亚洲欧美日韩无线码| 97人人模人人爽人人喊| 亚洲成人激情av在线| 2012中文字幕在线高清| 亚洲免费成人a v| 操人妻嗷嗷叫视频一区二区| 337p日本大胆欧美人| 亚洲视频在线观看高清| 在线不卡成人黄色精品| 激情五月婷婷免费视频| 中文字幕一区二区三区人妻大片| 国产中文字幕四区在线观看| 国产精品一区二区三区蜜臀av | 亚洲国际青青操综合网站| 成人蜜桃美臀九一一区二区三区| 人人超碰国字幕观看97| 懂色av之国产精品| 国产精品大陆在线2019不卡| 亚洲熟妇无码一区二区三区| lutube在线成人免费看| 精品suv一区二区69| 丝袜长腿第一页在线| 老司机在线精品福利视频| 久久三久久三久久三久久| 日本熟妇色熟妇在线观看| 中文字幕 码 在线视频| 一区二区三区久久久91| 日本少妇的秘密免费视频| 在线视频免费观看网| 亚洲丝袜老师诱惑在线观看| 一个色综合男人天堂| 中文字幕国产专区欧美激情| 婷婷久久久综合中文字幕| 夜夜骑夜夜操夜夜奸| 国产综合视频在线看片| 18禁精品网站久久| 一区二区三区另类在线 | 欧美精品资源在线观看| av天堂加勒比在线| 一区二区久久成人网| 亚洲 中文 自拍 无码| 在线免费91激情四射| 91国语爽死我了不卡| 97青青青手机在线视频| 精品一线二线三线日本| 久草福利电影在线观看| 天天日天天干天天要| 日本乱人一区二区三区| 中文字幕欧美日韩射射一| 小泽玛利亚视频在线观看| 日韩精品一区二区三区在线播放| 日韩午夜福利精品试看| 91在线免费观看成人| 亚洲偷自拍高清视频| 亚洲高清视频在线不卡| 亚洲精品无码久久久久不卡| 成人30分钟免费视频| 婷婷综合亚洲爱久久| chinese国产盗摄一区二区| 97人妻总资源视频| 久久久久久久久久性潮| 国产乱子伦精品视频潮优女| 黄色片年轻人在线观看| 高潮喷水在线视频观看| 欧美黄色录像免费看的| 精品国产高潮中文字幕| 日本在线一区二区不卡视频| 韩国女主播精品视频网站| 97人妻色免费视频| 日本人妻精品久久久久久| 粉嫩av蜜乳av蜜臀| 免费岛国喷水视频在线观看| 久久三久久三久久三久久| 色哟哟在线网站入口| 91破解版永久免费| 欧美亚洲一二三区蜜臀| 五十路息与子猛烈交尾视频 | 国产黄色片在线收看| 女人精品内射国产99| 黑人巨大精品欧美视频| 久久热这里这里只有精品| 91免费观看国产免费| 免费看国产av网站| 97香蕉碰碰人妻国产樱花| 亚洲人人妻一区二区三区| 在线国产日韩欧美视频| 婷婷色国产黑丝少妇勾搭AV | 亚洲欧美另类手机在线 | 阴茎插到阴道里面的视频| 新婚人妻聚会被中出| 一区二区三区毛片国产一区| 中文字幕网站你懂的| 天天操夜夜骑日日摸| 在线免费观看av日韩| 日韩欧美高清免费在线| 亚洲美女自偷自拍11页| 亚洲 清纯 国产com| 国产免费av一区二区凹凸四季| 欧美老鸡巴日小嫩逼| 亚洲欧美人精品高清| 超碰公开大香蕉97| 中文字幕一区二区人妻电影冢本 | av手机免费在线观看高潮| 亚洲国产成人无码麻豆艾秋| 夜色撩人久久7777| 黄色在线观看免费观看在线| 中文字幕高清在线免费播放| 天天操天天插天天色| 久草视频首页在线观看| 爱有来生高清在线中文字幕| 亚洲熟妇久久无码精品| 亚洲av一妻不如妾| 自拍偷拍 国产资源| 日韩欧美中文国产在线 | 一区二区麻豆传媒黄片| 国产免费av一区二区凹凸四季| 在线不卡日韩视频播放| 亚洲av午夜免费观看| 99精品视频之69精品视频| 馒头大胆亚洲一区二区| 年轻的人妻被夫上司侵犯| 在线亚洲天堂色播av电影| 日韩美女福利视频网| 把腿张开让我插进去视频| 国产综合视频在线看片| 欧美viboss性丰满| 中文字幕中文字幕人妻| 91色网站免费在线观看| 色av色婷婷人妻久久久精品高清| 老司机福利精品视频在线| 黑人乱偷人妻中文字幕| 91传媒一区二区三区| 蜜桃视频17c在线一区二区| 国产精品黄大片在线播放| 国产欧美日韩第三页| 91麻豆精品久久久久| 午夜精品福利91av| 免费福利av在线一区二区三区| 婷婷六月天中文字幕| 国产白袜脚足J棉袜在线观看| 亚洲 清纯 国产com| 精品黑人一区二区三区久久国产 | 国产在线91观看免费观看| 日韩美av高清在线| 天天日天天干天天要| 夜女神免费福利视频| 特大黑人巨大xxxx| 日本免费一级黄色录像| 一色桃子人妻一区二区三区| 天天色天天操天天透| 日韩成人免费电影二区| 日本午夜爽爽爽爽爽视频在线观看| 一二三区在线观看视频| 欧美一级色视频美日韩| 欧美va不卡视频在线观看| 免费69视频在线看| 日本免费午夜视频网站| 同居了嫂子在线播高清中文| 六月婷婷激情一区二区三区| 亚洲国际青青操综合网站| 沈阳熟妇28厘米大战黑人| 中文字幕一区二区三区人妻大片| nagger可以指黑人吗| 熟妇一区二区三区高清版| 亚洲男人让女人爽的视频| 欧美亚洲免费视频观看| 91国产在线免费播放| 福利午夜视频在线合集| 国产真实乱子伦a视频| 亚洲变态另类色图天堂网| 视频在线免费观看你懂得| 少妇人妻久久久久视频黄片| 十八禁在线观看地址免费| 久久久噜噜噜久久熟女av| 色花堂在线av中文字幕九九 | 一区二区三区久久久91| 99精品国产免费久久| 国产大学生援交正在播放| 超碰97人人澡人人| 亚洲精品久久综合久| 日韩欧美一级aa大片| 大香蕉日本伊人中文在线| chinese国产盗摄一区二区| 黄片大全在线观看观看| 蜜桃臀av蜜桃臀av| 一本久久精品一区二区| 精品乱子伦一区二区三区免费播| 伊人网中文字幕在线视频| 国产91精品拍在线观看| 天天操,天天干,天天射| a v欧美一区=区三区| 在线免费91激情四射| 大尺度激情四射网站| 强行扒开双腿猛烈进入免费版| 日韩av中文在线免费观看| 日本五十路熟新垣里子| 午夜在线观看岛国av,com| 亚洲熟妇无码一区二区三区| 91麻豆精品秘密入口在线观看| 北条麻妃肉色丝袜视频| 在线观看av2025| 92福利视频午夜1000看| 青青青青爽手机在线| 岛国青草视频在线观看| 人人爱人人妻人人澡39| avjpm亚洲伊人久久| 91精品啪在线免费| 新97超碰在线观看| 亚洲成人av一区在线| 亚洲av日韩高清hd| 国产高潮无码喷水AV片在线观看| 亚洲精品国产综合久久久久久久久| 成人高潮aa毛片免费| 又色又爽又黄的美女裸体| av新中文天堂在线网址| 91麻豆精品传媒国产黄色片| 2022精品久久久久久中文字幕| 亚洲综合一区成人在线| 香蕉aⅴ一区二区三区| 中文人妻AV久久人妻水| 国产在线拍揄自揄视频网站| 欧美老妇精品另类不卡片| 久草福利电影在线观看| 免费高清自慰一区二区三区网站| 日韩一区二区电国产精品| 午夜精品在线视频一区| 插小穴高清无码中文字幕| 亚洲va天堂va国产va久| 风流唐伯虎电视剧在线观看| 91九色porny国产蝌蚪视频| 视频一区 二区 三区 综合| 天码人妻一区二区三区在线看| 538精品在线观看视频| 偷拍自拍亚洲视频在线观看| 青青社区2国产视频| 伊人综合aⅴ在线网| 女生自摸在线观看一区二区三区| 97人妻夜夜爽二区欧美极品| 日韩激情文学在线视频| 红杏久久av人妻一区| 熟女在线视频一区二区三区| 天干天天天色天天日天天射 | 亚洲av色香蕉一区二区三区 | 亚洲 中文 自拍 无码| aiss午夜免费视频| 日本阿v视频在线免费观看| 黄色无码鸡吧操逼视频| 精品乱子伦一区二区三区免费播| 青青青爽视频在线播放| 好吊视频—区二区三区| 亚洲成av人无码不卡影片一| av无限看熟女人妻另类av| aⅴ五十路av熟女中出| 成人av天堂丝袜在线观看| 动漫黑丝美女的鸡巴| 宅男噜噜噜666国产| 999九九久久久精品| 国产精品中文av在线播放| 换爱交换乱高清大片| 99精品国产免费久久| 九九热99视频在线观看97| 天天日天天做天天日天天做| 青青青青青操视频在线观看| 国产91精品拍在线观看| 人人妻人人爱人人草| 又大又湿又爽又紧A视频| 99精品一区二区三区的区| 亚洲变态另类色图天堂网| 亚洲高清视频在线不卡| 男人操女人逼逼视频网站| 精品一区二区三区三区88 | 2020久久躁狠狠躁夜夜躁| 国产日韩一区二区在线看| 日韩av有码一区二区三区4 | 搡老妇人老女人老熟女| 婷婷激情四射在线观看视频| 欧美激情电影免费在线| 精品国产高潮中文字幕| 综合页自拍视频在线播放| 综合激情网激情五月五月婷婷| 亚洲另类综合一区小说| 久久丁香婷婷六月天| 少妇与子乱在线观看| 91破解版永久免费| 国产又色又刺激在线视频| 午夜成午夜成年片在线观看| 自拍偷拍日韩欧美亚洲| 激情五月婷婷综合色啪| 欧美伊人久久大香线蕉综合| 亚洲av日韩精品久久久久久hd| 日韩亚洲高清在线观看| 青青青青青手机视频| 少妇人妻二三区视频| 免费一级黄色av网站| 天天日天天干天天要| 97超碰国语国产97超碰| 在线观看av亚洲情色| 99av国产精品欲麻豆| 亚洲精品成人网久久久久久小说| 国产精品久久9999| 亚洲的电影一区二区三区| 亚洲精品国产久久久久久| 狠狠鲁狠狠操天天晚上干干| 不卡一区一区三区在线| 人妻最新视频在线免费观看| 国产 在线 免费 精品| 亚洲乱码中文字幕在线| 新97超碰在线观看| 亚洲精品福利网站图片| 91综合久久亚洲综合| 五十路息与子猛烈交尾视频| 888欧美视频在线| 欧美va不卡视频在线观看| 免费在线福利小视频| 中国产一级黄片免费视频播放| 午夜dv内射一区区| 国产av国片精品一区二区| 91极品新人『兔兔』精品新作| 一区二区三区欧美日韩高清播放| 亚洲熟妇无码一区二区三区| 国产午夜无码福利在线看| 污污小视频91在线观看| 日韩熟女av天堂系列| 丝袜长腿第一页在线| 日韩av有码中文字幕| 好吊操视频这里只有精品| 在线免费观看日本片| av成人在线观看一区| 成年人的在线免费视频| 欧美一区二区中文字幕电影| 香蕉91一区二区三区| 很黄很污很色的午夜网站在线观看 | 91麻豆精品久久久久| 亚洲蜜臀av一区二区三区九色| 无忧传媒在线观看视频| 亚洲一区制服丝袜美腿| 国产变态另类在线观看| 全国亚洲男人的天堂| 偷拍美女一区二区三区| 日本免费一级黄色录像| 欧美黑人性暴力猛交喷水| 精品首页在线观看视频| 免费观看理论片完整版| 亚洲另类综合一区小说| 国产性生活中老年人视频网站| 99的爱精品免费视频| 亚洲精品久久综合久| 91快播视频在线观看| 天天日天天做天天日天天做| 国产精品中文av在线播放| 97人妻夜夜爽二区欧美极品| 区一区二区三国产中文字幕| 国产老熟女伦老熟妇ⅹ| 天天摸天天干天天操科普| 精品高跟鞋丝袜一区二区| 99精品国产自在现线观看| 亚洲精品三级av在线免费观看| 美女 午夜 在线视频| 亚洲国产精品久久久久蜜桃| 黄页网视频在线免费观看| 99热国产精品666| 91精品国产麻豆国产| 91亚洲精品干熟女蜜桃频道| 久久久久久久久久性潮| av中文字幕电影在线看| 中文字幕免费福利视频6| 日韩美在线观看视频黄| 性色蜜臀av一区二区三区| 日本成人一区二区不卡免费在线| 欧美久久一区二区伊人| 婷婷激情四射在线观看视频| 直接观看免费黄网站| 宅男噜噜噜666免费观看| 国产精品久久综合久久| 国产刺激激情美女网站| av在线shipin| 综合页自拍视频在线播放| rct470中文字幕在线| 成年人黄色片免费网站| 精品一区二区三区在线观看| aiss午夜免费视频| 免费观看污视频网站| 亚洲熟妇x久久av久久| 亚洲一级美女啪啪啪| 一区二区在线观看少妇| 青青青视频自偷自拍38碰| 亚洲国产欧美一区二区三区…| 少妇人妻100系列| 中国熟女一区二区性xx| 五色婷婷综合狠狠爱| 粗大的内捧猛烈进出爽大牛汉子| 色综合久久久久久久久中文| 在线观看成人国产电影| 丰满的继坶3中文在线观看| 国产欧美精品免费观看视频| 老司机免费视频网站在线看| 免费十精品十国产网站| 国产精品国产三级国产精东| 插小穴高清无码中文字幕| 在线免费观看日本伦理| 青青青青青青青在线播放视频| 亚洲欧美精品综合图片小说| 亚洲国产精品免费在线观看| 日韩av有码一区二区三区4| 人妻丝袜精品中文字幕| 天堂va蜜桃一区入口| 中文字幕亚洲中文字幕| av中文字幕电影在线看| 中文字幕无码一区二区免费| 韩国亚洲欧美超一级在线播放视频| 亚洲熟女久久久36d| 熟女视频一区,二区,三区| 国产高清精品一区二区三区| 97色视频在线观看| 91福利在线视频免费观看| 国产aⅴ一线在线观看| 搡老妇人老女人老熟女| 早川濑里奈av黑人番号| 东游记中文字幕版哪里可以看到| 美女福利写真在线观看视频| av男人天堂狠狠干| 日韩在线中文字幕色| 亚洲精品国产综合久久久久久久久 | 福利一二三在线视频观看| 91啪国自产中文字幕在线| 天天干夜夜操天天舔| 亚洲精品精品国产综合| av老司机精品在线观看| 欧美地区一二三专区| tube69日本少妇| 中文字幕av熟女人妻| 天堂av中文在线最新版| 亚洲成人午夜电影在线观看| 国产精品久久久久久久精品视频| 激情色图一区二区三区| 国产真实灌醉下药美女av福利| 国产在线免费观看成人| 亚洲少妇人妻无码精品| 一区二区三区精品日本| 亚洲高清国产一区二区三区| 水蜜桃一区二区三区在线观看视频 | 婷婷午夜国产精品久久久| 男生舔女生逼逼视频| 欧美日本国产自视大全| 亚洲国产成人av在线一区| 亚洲最大黄了色网站| 亚洲免费成人a v| 97a片免费在线观看| 国产福利小视频免费观看| 黄色视频在线观看高清无码 | 精品日产卡一卡二卡国色天香| 欧美性感尤物人妻在线免费看| 不卡日韩av在线观看| 精品国产在线手机在线| 国产精品中文av在线播放| 五月天久久激情视频| 色呦呦视频在线观看视频| 天天操天天干天天日狠狠插| av天堂资源最新版在线看| 亚洲精品无码久久久久不卡| 精品人妻一二三区久久| 91成人精品亚洲国产| 91大屁股国产一区二区| okirakuhuhu在线观看| 人妻少妇性色欲欧美日韩| 91国内精品久久久久精品一| 人妻无码中文字幕专区| 99视频精品全部15| 亚洲精品三级av在线免费观看| 日韩美女搞黄视频免费| 国产激情av网站在线观看| 亚洲欧洲av天堂综合| 1区2区3区不卡视频| 91麻豆精品91久久久久同性| 国产日韩欧美视频在线导航| 亚洲精品亚洲人成在线导航| 边摸边做超爽毛片18禁色戒 | 亚洲国产最大av综合| 3344免费偷拍视频| 亚洲中文字幕校园春色| 日韩美女精品视频在线观看网站 | 青青青爽视频在线播放| 夜夜嗨av蜜臀av| 天天操天天射天天操天天天| 亚洲欧美福利在线观看| 日本午夜久久女同精女女| 9l人妻人人爽人人爽| 日本性感美女三级视频| 国产自拍在线观看成人| 黄色无码鸡吧操逼视频| 日韩欧美在线观看不卡一区二区| 五月婷婷在线观看视频免费 | 肏插流水妹子在线乐播下载| 春色激情网欧美成人| 99一区二区在线观看| 神马午夜在线观看视频| 老司机99精品视频在线观看| 国产无遮挡裸体免费直播视频| 国产精品系列在线观看一区二区 | 国产使劲操在线播放| 亚洲精品欧美日韩在线播放| 日韩美女精品视频在线观看网站| 91老师蜜桃臀大屁股| 青青社区2国产视频| 中文字幕av熟女人妻| 日韩人妻丝袜中文字幕| 国产精品自拍视频大全| 成人综合亚洲欧美一区| 成年人黄色片免费网站| 中文字幕 人妻精品| 11久久久久久久久久久| 成人av免费不卡在线观看| 欧美日韩一区二区电影在线观看| 欧美日韩一区二区电影在线观看| 这里只有精品双飞在线播放| av在线shipin| 年轻的人妻被夫上司侵犯| 日韩激情文学在线视频| 日本熟女50视频免费| 欧洲亚洲欧美日韩综合| 最新欧美一二三视频| 精品黑人巨大在线一区| 免费十精品十国产网站| 99热久久这里只有精品8| 老司机福利精品免费视频一区二区| 国产性色生活片毛片春晓精品 | 夜夜嗨av蜜臀av| av手机免费在线观看高潮| asmr福利视频在线观看| 国产自拍黄片在线观看| 日韩欧美国产精品91| 和邻居少妇愉情中文字幕| 2019av在线视频| 成人色综合中文字幕| 日本熟女精品一区二区三区| 亚洲少妇高潮免费观看| 岛国青草视频在线观看| 97人妻色免费视频| 9l人妻人人爽人人爽| 人人妻人人爽人人澡人人精品| 精品高跟鞋丝袜一区二区| 啊啊好大好爽啊啊操我啊啊视频| 中文字幕免费在线免费| 色噜噜噜噜18禁止观看| 国际av大片在线免费观看| 国产乱子伦精品视频潮优女| 国产不卡av在线免费| 在线观看黄色成年人网站| 欧美色婷婷综合在线| 亚洲一区自拍高清免费视频| 中文字幕日韩精品就在这里| 2021年国产精品自拍| 日韩在线中文字幕色| 青青青视频手机在线观看| 国产高清在线在线视频| 亚洲图片偷拍自拍区| 在线制服丝袜中文字幕| 欧美3p在线观看一区二区三区| 91超碰青青中文字幕| 欧美日本在线观看一区二区| 亚洲欧美国产综合777| 天天爽夜夜爽人人爽QC| 天天综合天天综合天天网| 亚洲精品国偷自产在线观看蜜桃| 国产av国片精品一区二区| 亚洲国产成人无码麻豆艾秋| 午夜极品美女福利视频| 夫妻在线观看视频91| 亚洲一区二区三区在线高清| 美女骚逼日出水来了| 神马午夜在线观看视频| 日韩成人综艺在线播放| 3344免费偷拍视频| 欧美日本国产自视大全| 欧美日韩国产一区二区三区三州 | 午夜频道成人在线91| 国产久久久精品毛片| 最新日韩av传媒在线| 国产精品大陆在线2019不卡| 97国产在线观看高清| 黄色视频在线观看高清无码| 亚洲精品成人网久久久久久小说| 精品91高清在线观看| 日韩二区视频一线天婷婷五| 精品成人啪啪18免费蜜臀| 狠狠的往里顶撞h百合| 久久艹在线观看视频| 日本av熟女在线视频| 天天做天天干天天舔| 欧美爆乳肉感大码在线观看| 亚洲蜜臀av一区二区三区九色| 日本a级视频老女人| 亚洲 图片 欧美 图片| 亚洲 自拍 色综合图| av手机在线观播放网站| 国产精品一区二区av国| 免费在线观看污污视频网站| 人妻少妇亚洲精品中文字幕| 亚洲 中文 自拍 另类 欧美 | 欧美黑人与人妻精品| 成人激情文学网人妻| lutube在线成人免费看| 欧美怡红院视频在线观看| jiuse91九色视频| 干逼又爽又黄又免费的视频| 精品一区二区三区在线观看| 欧美另类一区二区视频| gogo国模私拍视频| 美女少妇亚洲精选av| 国产真实灌醉下药美女av福利| 亚洲欧美成人综合视频| 啪啪啪啪啪啪啪免费视频| 最近中文2019年在线看| 人妻另类专区欧美制服| av中文字幕福利网| 护士小嫩嫩又紧又爽20p| 男人天堂最新地址av| 国产高清在线观看1区2区| 精品欧美一区二区vr在线观看| 亚洲精品欧美日韩在线播放 | 韩国女主播精品视频网站| av高潮迭起在线观看| 国产福利在线视频一区| 日本中文字幕一二区视频| 成人av免费不卡在线观看| 女同性ⅹxx女同h偷拍| 综合一区二区三区蜜臀| 新97超碰在线观看| av黄色成人在线观看| 国产精彩对白一区二区三区| 日日爽天天干夜夜操| xxx日本hd高清| 少妇人妻久久久久视频黄片| 免费黄高清无码国产| 任你操任你干精品在线视频| 成熟熟女国产精品一区| 91麻豆精品传媒国产黄色片| 日本男女操逼视频免费看| 少妇高潮无套内谢麻豆| 成熟熟女国产精品一区| 99热碰碰热精品a中文| 少妇深喉口爆吞精韩国| 性色蜜臀av一区二区三区| 99热99这里精品6国产| 偷偷玩弄新婚人妻h视频| 91精品国产91久久自产久强 | 中文字幕人妻av在线观看| 免费观看成年人视频在线观看| 日韩无码国产精品强奸乱伦| 国产精品国产三级麻豆| 57pao国产一区二区| 日本免费午夜视频网站| 久久久久久久久久久久久97| 久久精品亚洲国产av香蕉| 大香蕉日本伊人中文在线| 女生自摸在线观看一区二区三区| 毛茸茸的大外阴中国视频| 国产露脸对白在线观看| 中文字幕—97超碰网| 鸡巴操逼一级黄色气| 成人伊人精品色xxxx视频| 亚洲成人av在线一区二区| 人妻少妇中文有码精品| 天天射,天天操,天天说| 青青青aaaa免费| 九九视频在线精品播放| 视频在线亚洲一区二区| 免费费一级特黄真人片| 免费看国产又粗又猛又爽又黄视频| 淫秽激情视频免费观看| 人妻在线精品录音叫床| 亚洲狠狠婷婷综合久久app | av一本二本在线观看| 日本丰满熟妇大屁股久久| 任你操任你干精品在线视频| 色综合色综合色综合色| 人妻熟女中文字幕aⅴ在线| 夜色撩人久久7777| 日本黄在免费看视频| 91片黄在线观看喷潮| 操日韩美女视频在线免费看| 天天日天天透天天操| 国产男女视频在线播放| 狠狠躁狠狠爱网站视频 | 99热色原网这里只有精品| 婷婷色中文亚洲网68| 中文字幕av男人天堂| 天天干天天插天天谢| 不卡一区一区三区在线| 人妻在线精品录音叫床| 视频 一区二区在线观看| 国产一区二区在线欧美| 欧美特色aaa大片| 天堂av在线官网中文| 亚洲最大黄 嗯色 操 啊| 日本www中文字幕| 日本少妇精品免费视频| 男人靠女人的逼视频| 黄色大片男人操女人逼| 大尺度激情四射网站| 国产成人精品亚洲男人的天堂| 馒头大胆亚洲一区二区| 天天干天天插天天谢| 欧美精品黑人性xxxx| 中文字幕日韩人妻在线三区| 国产精品视频资源在线播放 | 二区中出在线观看老师| 成年午夜免费无码区| 黑人巨大精品欧美视频| 美女骚逼日出水来了| 亚洲综合色在线免费观看| 精品国产午夜视频一区二区| wwwxxx一级黄色片| 一二三中文乱码亚洲乱码one| 中文字幕熟女人妻久久久| 性欧美日本大妈母与子| 中文字幕免费福利视频6| 欧美怡红院视频在线观看| 亚洲 色图 偷拍 欧美| 天天日天天日天天擦| 91精品国产91青青碰| 国产精品久久久久久久精品视频| 少妇人妻久久久久视频黄片| 青青色国产视频在线| 绝色少妇高潮3在线观看| 色秀欧美视频第一页| 又粗又硬又猛又爽又黄的| 人妻另类专区欧美制服| aaa久久久久久久久| 蜜臀av久久久久蜜臀av麻豆| 91精品一区二区三区站长推荐| 黄色在线观看免费观看在线| 亚洲成人国产综合一区| 高潮喷水在线视频观看| 在线免费91激情四射| 婷婷久久久久深爱网| 亚洲欧洲av天堂综合| 91精品国产麻豆国产| 美女福利写真在线观看视频| 韩国亚洲欧美超一级在线播放视频| 韩国女主播精品视频网站| 天天干天天日天天谢综合156| 中文字幕在线免费第一页| 日本黄色三级高清视频| 91久久综合男人天堂| 亚洲熟女久久久36d| av老司机精品在线观看| 操操网操操伊剧情片中文字幕网| 日韩成人性色生活片| 18禁网站一区二区三区四区| 婷婷久久久久深爱网| 和邻居少妇愉情中文字幕| 青青尤物在线观看视频网站| 少妇高潮一区二区三区| 日韩亚国产欧美三级涩爱| 亚洲欧美清纯唯美另类| 馒头大胆亚洲一区二区| 午夜毛片不卡免费观看视频| 天天插天天色天天日| 2017亚洲男人天堂| 欧美女同性恋免费a| 天天爽夜夜爽人人爽QC| 国产精品自偷自拍啪啪啪| 100%美女蜜桃视频| 伊人成人在线综合网| 人妻另类专区欧美制服| 99国产精品窥熟女精品| 熟女人妻在线中出观看完整版| 韩国爱爱视频中文字幕| 久久久久久性虐视频| 亚洲欧美激情中文字幕| 婷婷色国产黑丝少妇勾搭AV| 大屁股熟女一区二区三区| 视频啪啪啪免费观看| 日韩av中文在线免费观看| 果冻传媒av一区二区三区| 在线观看的黄色免费网站| 91在线视频在线精品3| 欧亚乱色一区二区三区| 免费男阳茎伸入女阳道视频 | 欧美日本在线视频一区| 中文字幕综合一区二区| 日本精品视频不卡一二三| 黄色黄色黄片78在线| 搞黄色在线免费观看| 最新中文字幕免费视频| 亚洲欧美激情人妻偷拍| 五十路丰满人妻熟妇| 亚洲成人国产综合一区| 亚洲免费福利一区二区三区| 搡老熟女一区二区在线观看| 国产成人无码精品久久久电影| 337p日本大胆欧美人| 99热久久这里只有精品| 日本av熟女在线视频| 日日夜夜精品一二三| 一区二区三区av高清免费| 超鹏97历史在线观看| 精品首页在线观看视频| 国产又大又黄免费观看| 人妻少妇中文有码精品| brazzers欧熟精品系列| 精品一区二区三区欧美| 大陆胖女人与丈夫操b国语高清| 人妻另类专区欧美制服| 国产成人精品午夜福利训2021 | 我想看操逼黄色大片| 成人免费公开视频无毒| 偷偷玩弄新婚人妻h视频| 人妻少妇精品久久久久久| 小穴多水久久精品免费看| av一本二本在线观看| 伊人综合免费在线视频| 日本av在线一区二区三区| 在线免费观看视频一二区| 亚洲精品色在线观看视频| 69精品视频一区二区在线观看| 亚洲一区二区三区在线高清| 91国内视频在线观看| 极品性荡少妇一区二区色欲| 2020久久躁狠狠躁夜夜躁 | 一区二区熟女人妻视频| 3344免费偷拍视频| 国产揄拍高清国内精品对白| 中文字幕成人日韩欧美|