国产无遮挡裸体免费直播视频,久久精品国产蜜臀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天堂中文字幕最新| 亚洲av在线观看尤物| 国产普通话插插视频| 国产av自拍偷拍盛宴| 国产综合高清在线观看| 高清一区二区欧美系列| 中文字幕在线观看国产片| 精品av国产一区二区三区四区| 国产成人一区二区三区电影网站| 亚洲av黄色在线网站| 国产欧美精品免费观看视频| 中文字幕人妻被公上司喝醉在线| 天天干天天搞天天摸| 天天操天天干天天插| 少妇高潮无套内谢麻豆| 亚洲2021av天堂| 日韩欧美一级精品在线观看| 亚洲福利精品视频在线免费观看| 国产免费av一区二区凹凸四季| heyzo蜜桃熟女人妻| 老司机免费视频网站在线看| 91免费观看在线网站| 亚洲另类伦春色综合小| 哥哥姐姐综合激情小说 | 韩国爱爱视频中文字幕| 班长撕开乳罩揉我胸好爽| 免费看国产又粗又猛又爽又黄视频| 91国语爽死我了不卡| 久久久久国产成人精品亚洲午夜| 5528327男人天堂| 在线网站你懂得老司机| 99精品国产自在现线观看| 国产又大又黄免费观看| 超碰在线观看免费在线观看| 男大肉棒猛烈插女免费视频| 午夜免费观看精品视频| 亚洲免费成人a v| 91福利在线视频免费观看| 国产精品视频欧美一区二区| 巨乳人妻日下部加奈被邻居中出 | 国产普通话插插视频| 99re久久这里都是精品视频| 一级黄色片夫妻性生活| 欧美日韩国产一区二区三区三州| www骚国产精品视频| 精品久久久久久高潮| 天天操天天操天天碰| 中国产一级黄片免费视频播放| 欧美男同性恋69视频| 第一福利视频在线观看| 中文字日产幕乱六区蜜桃| 偷拍自拍福利视频在线观看| 成熟熟女国产精品一区| 大香蕉福利在线观看| 香蕉片在线观看av| 国内自拍第一页在线观看| 亚洲综合图片20p| 扒开腿挺进肉嫩小18禁视频| 3344免费偷拍视频| 日韩亚国产欧美三级涩爱| 欧美日韩不卡一区不区二区| 亚洲国产成人在线一区| av完全免费在线观看av| 女同性ⅹxx女同h偷拍| 日辽宁老肥女在线观看视频| 日本一道二三区视频久久| 东游记中文字幕版哪里可以看到| 久久久91蜜桃精品ad| 天码人妻一区二区三区在线看| 日韩成人性色生活片| 亚洲专区激情在线观看视频| 天天日夜夜操天天摸| 免费在线看的黄片视频| 青娱乐蜜桃臀av色| 91成人在线观看免费视频| 91麻豆精品久久久久| 啊慢点鸡巴太大了啊舒服视频| 国产熟妇一区二区三区av | 91‖亚洲‖国产熟女| 国产精品污污污久久| 精品国产亚洲av一淫| 日本一道二三区视频久久| 美女视频福利免费看| 久碰精品少妇中文字幕av| 一级黄色片夫妻性生活| 中文字幕1卡1区2区3区| 人妻丰满熟妇综合网| 一二三中文乱码亚洲乱码one| 午夜在线观看一区视频| 亚洲av人人澡人人爽人人爱 | 久久机热/这里只有| 国产精品人妻66p| 92福利视频午夜1000看 | 日本午夜爽爽爽爽爽视频在线观看| 欧美一区二区三区高清不卡tv| 91中文字幕免费在线观看| 东京热男人的av天堂| 国产精品久久久久久美女校花| 97瑟瑟超碰在线香蕉| 欧美中国日韩久久精品| 亚洲精品 日韩电影| 污污小视频91在线观看| 人妻自拍视频中国大陆| 精品一区二区三区欧美| 国产日韩欧美视频在线导航 | 大香蕉伊人中文字幕| 91p0rny九色露脸熟女| 欧美日韩国产一区二区三区三州| 国产午夜无码福利在线看| 操操网操操伊剧情片中文字幕网| 国产欧美精品免费观看视频| 精品成人午夜免费看| 日本精品视频不卡一二三| 在线视频这里只有精品自拍| 久久久久久久久久性潮| 国产视频网站国产视频| av大全在线播放免费| 97人妻人人澡爽人人精品| 国产亚洲精品欧洲在线观看| 国产va在线观看精品| 天天爽夜夜爽人人爽QC| 男大肉棒猛烈插女免费视频| 激情五月婷婷综合色啪| 天天日夜夜操天天摸| 国产精品久久久久网| 日本啪啪啪啪啪啪啪| 久久农村老妇乱69系列| 自拍偷拍亚洲另类色图| 涩爱综合久久五月蜜臀| 韩国三级aaaaa高清视频| 91p0rny九色露脸熟女| 老司机午夜精品视频资源| 青青青青青青草国产| 欧美日韩熟女一区二区三区| 老司机免费视频网站在线看| 天堂av中文在线最新版| 哥哥姐姐综合激情小说| 岛国免费大片在线观看 | 欧美成人精品欧美一级黄色| 国产日韩精品免费在线| 日本在线不卡免费视频| 美女吃鸡巴操逼高潮视频| 亚洲精品国偷自产在线观看蜜桃| 男女第一次视频在线观看| 免费在线播放a级片| 福利视频广场一区二区| 国产精品入口麻豆啊啊啊| 性生活第二下硬不起来| av亚洲中文天堂字幕网| 日本一区精品视频在线观看| 日本乱人一区二区三区| 不戴胸罩引我诱的隔壁的人妻| 93人妻人人揉人人澡人人| 青青青青草手机在线视频免费看| 黄色的网站在线免费看| 337p日本大胆欧美人| 国产揄拍高清国内精品对白| 色综合久久五月色婷婷综合| 午夜国产免费福利av| 国产精品免费不卡av| 欲乱人妻少妇在线视频裸| 亚洲人妻30pwc| 国产麻豆国语对白露脸剧情| 岛国一区二区三区视频在线| v888av在线观看视频| 扒开让我视频在线观看| 亚洲av无码成人精品区辽| 免费在线福利小视频| av中文在线天堂精品| av日韩在线观看大全| 久久久久久久久久一区二区三区| 天天干天天爱天天色| 欧美另类重口味极品在线观看| 男人天堂av天天操| 欧美怡红院视频在线观看| 亚洲va天堂va国产va久| 五十路人妻熟女av一区二区| 精品久久久久久久久久久a√国产| 久久久久久久久久性潮| 人妻av无码专区久久绿巨人| 青青草成人福利电影| 青青热久免费精品视频在线观看| 玖玖一区二区在线观看| 欧美日韩人妻久久精品高清国产 | 青青青视频手机在线观看| 久久精品在线观看一区二区| 久久机热/这里只有| 1024久久国产精品| 可以在线观看的av中文字幕| 91人妻精品一区二区在线看| 亚洲中文精品字幕在线观看| 2025年人妻中文字幕乱码在线 | 亚洲国产免费av一区二区三区| 久久久麻豆精亚洲av麻花| 视频在线亚洲一区二区| 神马午夜在线观看视频| 四川乱子伦视频国产vip| 午夜精品一区二区三区4| 成年人黄色片免费网站| 欧美美女人体视频一区| 国产黄网站在线观看播放| 成年午夜影片国产片| 精品国产午夜视频一区二区| 五月精品丁香久久久久福利社| 欧洲欧美日韩国产在线| 国产精品自拍在线视频| 美女大bxxxx内射| 免费在线福利小视频| 亚洲欧美综合另类13p| 天天干天天操天天玩天天射| 国产一线二线三线的区别在哪| 日本av熟女在线视频| 天天插天天色天天日| 欧美成一区二区三区四区| 熟女少妇激情五十路| 青青青青在线视频免费观看| 亚洲欧美一区二区三区爱爱动图| 黑人解禁人妻叶爱071| 久久久久91精品推荐99| 欧美精品一区二区三区xxxx| 日韩黄色片在线观看网站| 国产在线拍揄自揄视频网站| 福利片区一区二体验区| 五月天中文字幕内射| 亚洲图片欧美校园春色| 91av中文视频在线| 午夜精品一区二区三区城中村| 19一区二区三区在线播放| 精品黑人一区二区三区久久国产| 久草视频福利在线首页| sspd152中文字幕在线| av中文字幕在线导航| 欧美日本在线观看一区二区| 国产三级精品三级在线不卡| 欧美日本aⅴ免费视频| 欧美区一区二区三视频| 99精品国产aⅴ在线观看| 熟女视频一区,二区,三区 | 日韩av有码一区二区三区4| 五月天中文字幕内射| 一区二区三区四区中文| 欧美视频中文一区二区三区| 中文字幕人妻av在线观看| 亚洲卡1卡2卡三卡四老狼| 亚洲国产40页第21页| 五色婷婷综合狠狠爱| 91啪国自产中文字幕在线| 国产高潮无码喷水AV片在线观看| 天天干夜夜操啊啊啊| 久久丁香婷婷六月天| 超黄超污网站在线观看| av欧美网站在线观看| 国产日韩精品一二三区久久久| 超碰97人人澡人人| 大鸡八强奸视频在线观看| 含骚鸡巴玩逼逼视频| 综合页自拍视频在线播放| 国产揄拍高清国内精品对白 | 久久尻中国美女视频| 国产亚州色婷婷久久99精品| 五十路人妻熟女av一区二区| 超级碰碰在线视频免费观看| 丰满熟女午夜福利视频| 伊人综合aⅴ在线网| 国产又大又黄免费观看| 亚洲精品亚洲人成在线导航| 大鸡巴后入爆操大屁股美女| 欧美伊人久久大香线蕉综合| 久青青草视频手机在线免费观看| 欧美成人综合视频一区二区| 国产一区二区在线欧美| 日本少妇高清视频xxxxx | 超黄超污网站在线观看| 国产福利在线视频一区| 亚洲欧美国产综合777| 国产久久久精品毛片| 99热国产精品666| 97年大学生大白天操逼| 99热久久这里只有精品| 亚洲国产精品免费在线观看| 成人av免费不卡在线观看| 在线观看日韩激情视频| 日本少妇在线视频大香蕉在线观看| 欧美老妇精品另类不卡片| 日本午夜久久女同精女女| 黄色成人在线中文字幕| 五月激情婷婷久久综合网| 午夜国产福利在线观看| 久久这里只有精品热视频| 欧美精品免费aaaaaa| 被大鸡吧操的好舒服视频免费| 爱有来生高清在线中文字幕| 五十路熟女人妻一区二| 亚洲高清国产拍青青草原| 在线观看黄色成年人网站| 国产密臀av一区二区三| 日韩欧美亚洲熟女人妻| 人人妻人人澡欧美91精品| 欧美va不卡视频在线观看| 韩国黄色一级二级三级| 最新91精品视频在线| 欧美精品一区二区三区xxxx| 美女视频福利免费看| 欧美成人精品欧美一级黄色| 人妻自拍视频中国大陆| 亚洲精品福利网站图片| 亚洲av第国产精品| 亚洲国产在线精品国偷产拍 | 亚洲av极品精品在线观看| 亚洲av成人网在线观看| 福利视频一区二区三区筱慧| 成人30分钟免费视频| 日韩国产乱码中文字幕| aⅴ五十路av熟女中出| 成年人该看的视频黄免费| 日本高清撒尿pissing| 在线免费91激情四射| 中文字幕一区二区三区蜜月 | 国产精品精品精品999| 精品成人啪啪18免费蜜臀| 日本精品美女在线观看| 中国黄色av一级片| 特大黑人巨大xxxx| 日本性感美女写真视频| 日本少妇精品免费视频| 免费观看污视频网站| 日本熟妇一区二区x x| 精品人妻伦一二三区久| 99一区二区在线观看| 999九九久久久精品| 熟女妇女老妇一二三区| 亚洲欧美激情中文字幕| 欧美偷拍自拍色图片| 久久机热/这里只有| 都市家庭人妻激情自拍视频| 中文字幕 亚洲av| 欧美爆乳肉感大码在线观看| 最新的中文字幕 亚洲| 欧美黄色录像免费看的| 日韩在线视频观看有码在线| 曰本无码人妻丰满熟妇啪啪| 午夜成午夜成年片在线观看| 亚洲熟女久久久36d| 性色蜜臀av一区二区三区| 免费观看成年人视频在线观看| 欧美日韩v中文在线| 极品丝袜一区二区三区| 一色桃子人妻一区二区三区| 丝袜肉丝一区二区三区四区在线| 激情人妻校园春色亚洲欧美| 熟女国产一区亚洲中文字幕| 日本欧美视频在线观看三区| 中文字幕日韩精品就在这里| 中文字幕第一页国产在线| 老司机福利精品免费视频一区二区 | 激情人妻校园春色亚洲欧美| 人妻无码色噜噜狠狠狠狠色| 岛国青草视频在线观看| 亚洲熟妇无码一区二区三区| 青青草精品在线视频观看| 天天干夜夜操啊啊啊| 白白操白白色在线免费视频| 亚洲一区av中文字幕在线观看| 国产精品熟女久久久久浪潮| www天堂在线久久| 丝袜长腿第一页在线| 91一区精品在线观看| 99精品视频在线观看免费播放| 日韩成人免费电影二区| 91国产在线免费播放| 亚洲欧美激情国产综合久久久 | 人人妻人人澡欧美91精品| 在线免费91激情四射| 1000部国产精品成人观看视频| 99视频精品全部15| 国产第一美女一区二区三区四区| 91免费福利网91麻豆国产精品 | 中文 成人 在线 视频| 天天日天天干天天要 | 男人和女人激情视频| 亚洲精品亚洲人成在线导航| 2022天天干天天操| 哥哥姐姐综合激情小说| 国产免费高清视频视频| 亚洲国产在线精品国偷产拍| 天天干狠狠干天天操| 啊啊好慢点插舔我逼啊啊啊视频| 瑟瑟视频在线观看免费视频| jiuse91九色视频| 免费男阳茎伸入女阳道视频| 动漫av网站18禁| 97国产在线av精品| 日日操夜夜撸天天干| 韩国一级特黄大片做受| 国产实拍勾搭女技师av在线| 国产精品3p和黑人大战| 色av色婷婷人妻久久久精品高清| 男女啪啪啪啪啪的网站| 人妻熟女中文字幕aⅴ在线| 亚洲 欧美 自拍 偷拍 在线| 一二三中文乱码亚洲乱码one| 亚洲女人的天堂av| 天干天天天色天天日天天射| 色在线观看视频免费的| 亚洲av成人免费网站| 成人综合亚洲欧美一区| 青青青激情在线观看视频| 青青青青视频在线播放| 色婷婷精品大在线观看| 夏目彩春在线中文字幕| 黄片色呦呦视频免费看| 又粗又长 明星操逼小视频 | 青青青青草手机在线视频免费看 | 男人的天堂av日韩亚洲| 日本午夜爽爽爽爽爽视频在线观看 | 大胸性感美女羞爽操逼毛片| 抽查舔水白紧大视频| 成人国产小视频在线观看| 成年午夜影片国产片| 97国产精品97久久| 色97视频在线播放| 亚洲欧美日韩视频免费观看| 国产精品伦理片一区二区| 宅男噜噜噜666免费观看| 国产熟妇一区二区三区av| 综合页自拍视频在线播放| 自拍偷拍vs一区二区三区| 99热色原网这里只有精品| 亚洲精品 欧美日韩| 亚洲va国产va欧美精品88| 天天通天天透天天插| 色综合天天综合网国产成人| 日韩一区二区电国产精品| 日本精品视频不卡一二三| 亚洲综合一区二区精品久久| 老鸭窝在线观看一区| 北条麻妃肉色丝袜视频| 日韩a级黄色小视频| 偷偷玩弄新婚人妻h视频| 成人免费毛片aaaa| 少妇露脸深喉口爆吞精| 亚洲欧洲一区二区在线观看| 欧美成人精品欧美一级黄色| 久久久久五月天丁香社区| 性感美女福利视频网站| 成年人黄色片免费网站| 国产美女一区在线观看| 九九热99视频在线观看97| 福利午夜视频在线合集| 黑人3p华裔熟女普通话| 国产密臀av一区二区三| 天天日天天操天天摸天天舔| 亚洲福利精品视频在线免费观看| 天天日天天干天天干天天日| 国产老熟女伦老熟妇ⅹ| 天天干天天爱天天色| 亚洲 中文 自拍 无码| 精品一区二区三区三区色爱| 91综合久久亚洲综合| 干逼又爽又黄又免费的视频| 国产麻豆剧果冻传媒app| 青青青青青操视频在线观看| 国产亚洲欧美视频网站| 成人区人妻精品一区二视频| 一区二区三区综合视频| 97人人模人人爽人人喊| 天天日天天透天天操| 久久热久久视频在线观看| 18禁美女无遮挡免费| 黄色视频在线观看高清无码| 日韩少妇人妻精品无码专区| 亚洲色偷偷综合亚洲AV伊人| 中国熟女@视频91| 精产国品久久一二三产区区别| gay gay男男瑟瑟在线网站| 欧美交性又色又爽又黄麻豆| 天天日夜夜干天天操| 久久www免费人成一看片| 少妇深喉口爆吞精韩国| 特大黑人巨大xxxx| 欧美日韩精品永久免费网址| 亚洲日产av一区二区在线| 日本成人一区二区不卡免费在线| 国产精品黄片免费在线观看| 麻豆精品成人免费视频| 狠狠操操操操操操操操操| 黄色无码鸡吧操逼视频| 久久热久久视频在线观看| 欧美日韩熟女一区二区三区| 国产精品大陆在线2019不卡| 日本啪啪啪啪啪啪啪| 中文人妻AV久久人妻水| 姐姐的朋友2在线观看中文字幕| 亚洲码av无色中文| 亚洲成人三级在线播放| 男人和女人激情视频| 91久久精品色伊人6882| 岛国一区二区三区视频在线| 美女少妇亚洲精选av| www日韩a级s片av| 国产综合精品久久久久蜜臀| 91超碰青青中文字幕| 欧美日韩亚洲国产无线码| 人人在线视频一区二区| 91免费福利网91麻豆国产精品| 中文字幕 码 在线视频| 成人网18免费视频版国产| 国产亚洲国产av网站在线| 亚洲成人国产综合一区| 日韩加勒比东京热二区| 国产乱子伦一二三区| 日韩午夜福利精品试看| 亚洲av琪琪男人的天堂| 只有精品亚洲视频在线观看| 天天日天天透天天操| 国产精品人久久久久久| 经典av尤物一区二区| 国产janese在线播放| 日韩中文字幕精品淫| 红杏久久av人妻一区| 亚洲欧美另类手机在线| www久久久久久久久久久| 欧美黑人性猛交xxxxⅹooo| 久久丁香婷婷六月天| 在线观看亚洲人成免费网址| 亚洲在线观看中文字幕av| 年轻的人妻被夫上司侵犯| 在线观看视频污一区| 成年人该看的视频黄免费| 国产在线一区二区三区麻酥酥| 日韩欧美国产一区ab| 成人亚洲国产综合精品| 亚洲一级美女啪啪啪| 欧美日韩人妻久久精品高清国产 | yy6080国产在线视频| 美女视频福利免费看| 男人天堂最新地址av| 日韩在线中文字幕色| 日本后入视频在线观看| 黄网十四区丁香社区激情五月天| 11久久久久久久久久久| 亚洲精品福利网站图片| 懂色av蜜桃a v| 黄片三级三级三级在线观看| 国产精品黄片免费在线观看| 亚洲综合另类精品小说| 亚洲精品国产综合久久久久久久久| 亚洲成人情色电影在线观看| 精品黑人一区二区三区久久国产| 欧美激情电影免费在线| 国产成人自拍视频在线免费观看| 成熟熟女国产精品一区| 久久机热/这里只有| 国产在线观看黄色视频| 欧美精品一区二区三区xxxx| av在线观看网址av| 国产精品人妻一区二区三区网站| 免费无毒热热热热热热久| 国产精品系列在线观看一区二区| 成年女人免费播放视频| yy6080国产在线视频| 日本xx片在线观看| 国产午夜激情福利小视频在线| 午夜dv内射一区区| 亚洲av第国产精品| 婷婷激情四射在线观看视频| 美女少妇亚洲精选av| 亚洲精品国偷自产在线观看蜜桃| 日韩中文字幕福利av| 国产极品精品免费视频| 黄色资源视频网站日韩| 午夜影院在线观看视频羞羞羞| 精品高跟鞋丝袜一区二区| 9国产精品久久久久老师| 国产一区自拍黄视频免费观看 | 欧美精品伦理三区四区| 日韩av有码一区二区三区4| 天天干天天插天天谢| 成人性爱在线看四区| 天堂女人av一区二区| 中英文字幕av一区| 自拍偷区二区三区麻豆| 三级黄色亚洲成人av| 99久久激情婷婷综合五月天| 中文字幕无码一区二区免费| 在线免费观看日本片| av中文字幕福利网| chinese国产盗摄一区二区| 青草久久视频在线观看| 视频在线亚洲一区二区| 亚洲av色香蕉一区二区三区| 九九视频在线精品播放| 亚洲精品欧美日韩在线播放| 亚洲一区自拍高清免费视频| 日韩一个色综合导航| 青青热久免费精品视频在线观看| 天天日天天添天天爽| 91av中文视频在线| 日韩美女综合中文字幕pp| 小泽玛利亚视频在线观看| 偷拍自拍亚洲美腿丝袜| 18禁精品网站久久| AV天堂一区二区免费试看| 国产精品久久综合久久| 日韩中文字幕在线播放第二页 | 大陆精品一区二区三区久久| 国产福利小视频大全| 国产亚洲精品欧洲在线观看| 国产一区二区火爆视频| 精品高跟鞋丝袜一区二区| 最后99天全集在线观看| 香港一级特黄大片在线播放| 亚洲成人av一区在线| 北条麻妃高跟丝袜啪啪| 国产精品国产精品一区二区| 亚洲天堂精品福利成人av| 免费高清自慰一区二区三区网站 | 超碰97人人做人人爱| 国内资源最丰富的网站| 2020中文字幕在线播放| 天天草天天色天天干| 午夜毛片不卡免费观看视频 | 2020久久躁狠狠躁夜夜躁| 成年女人免费播放视频| 国产1区,2区,3区| 揄拍成人国产精品免费看视频| 美女吃鸡巴操逼高潮视频| 亚洲激情av一区二区| 制丝袜业一区二区三区| 大陆胖女人与丈夫操b国语高清 | 精品国产在线手机在线| 欧美香蕉人妻精品一区二区| 天天操天天污天天射| 欧美日本国产自视大全| 在线免费观看日本片| 亚洲无码一区在线影院| 国产日本欧美亚洲精品视| 色婷婷六月亚洲综合香蕉| 中文字幕高清在线免费播放| 国产激情av网站在线观看| 日本脱亚入欧是指什么| 黑人3p华裔熟女普通话| 黄色成年网站午夜在线观看| 亚洲国产精品中文字幕网站| 亚洲 中文字幕在线 日韩| 国产在线一区二区三区麻酥酥| 国产美女精品福利在线| 最新国产亚洲精品中文在线| 日本熟妇色熟妇在线观看| 又大又湿又爽又紧A视频| 又粗又硬又猛又爽又黄的| 男人和女人激情视频| 国产清纯美女al在线| 大学生A级毛片免费视频| 天堂资源网av中文字幕| 黑人解禁人妻叶爱071| 丝袜国产专区在线观看| 中文字幕av第1页中文字幕| 沙月文乃人妻侵犯中文字幕在线| 亚洲一级 片内射视正片| 欧美成人黄片一区二区三区| 好男人视频在线免费观看网站| 欧美成人精品在线观看| 少妇与子乱在线观看| 午夜成午夜成年片在线观看| 中文字母永久播放1区2区3区| 91传媒一区二区三区| 日本在线不卡免费视频| 天堂av中文在线最新版| 欧美色婷婷综合在线| 欲满人妻中文字幕在线| 在线免费观看欧美小视频| 97超碰国语国产97超碰| 精品一线二线三线日本| 丝袜美腿欧美另类 中文字幕| 日韩精品激情在线观看| 亚洲中文精品字幕在线观看| 91九色porny国产蝌蚪视频| 中文字幕日韩精品日本| 中国老熟女偷拍第一页| 国产乱子伦精品视频潮优女| 亚洲成高清a人片在线观看| 漂亮 人妻被中出中文| gav成人免费播放| 精品一区二区三四区| 精品区一区二区三区四区人妻| 国产精品午夜国产小视频 | av俺也去在线播放| 亚洲欧美色一区二区| 亚洲成人熟妇一区二区三区| 青青青青草手机在线视频免费看| 少妇高潮一区二区三区| gogo国模私拍视频| 97小视频人妻一区二区| 亚洲国产成人在线一区| 欧美3p在线观看一区二区三区| 老司机午夜精品视频资源| 免费成人av中文字幕| chinese国产盗摄一区二区| 瑟瑟视频在线观看免费视频| 日本精品视频不卡一二三| 美洲精品一二三产区区别| 欧美精产国品一二三产品价格| 久碰精品少妇中文字幕av| 国产熟妇人妻ⅹxxxx麻豆| 视频啪啪啪免费观看| 久久丁香花五月天色婷婷| 久久综合老鸭窝色综合久久| 久久机热/这里只有| 精品老妇女久久9g国产| 免费成人av中文字幕| 在线视频免费观看网| 懂色av蜜桃a v| 丰满的继坶3中文在线观看| 国产视频网站国产视频| 初美沙希中文字幕在线| 91精品国产黑色丝袜| 91人妻精品一区二区久久| 久久精品国产亚洲精品166m| 国产综合高清在线观看| 玖玖一区二区在线观看| 久碰精品少妇中文字幕av | 同居了嫂子在线播高清中文| 9久在线视频只有精品| 天天日天天鲁天天操| 特大黑人巨大xxxx| 久久久久久9999久久久久| 青青在线视频性感少妇和隔壁黑丝| 亚洲丝袜老师诱惑在线观看| aⅴ五十路av熟女中出| 中国熟女一区二区性xx| 白嫩白嫩美女极品国产在线观看| 国产精品视频男人的天堂| 中文字幕高清在线免费播放| 久草视频在线免播放| 100%美女蜜桃视频| 一区二区视频在线观看视频在线| 五色婷婷综合狠狠爱| 亚洲av第国产精品| 亚洲福利精品视频在线免费观看 | 开心 色 六月 婷婷| 国产亚洲精品视频合集| 亚洲天堂成人在线观看视频网站| 动漫黑丝美女的鸡巴| 亚洲偷自拍高清视频| 日本黄色特一级视频| 国产日韩欧美视频在线导航| 亚洲一区自拍高清免费视频| 爱爱免费在线观看视频| 亚洲男人的天堂a在线| 在线观看视频网站麻豆| 天堂女人av一区二区| 精品suv一区二区69| av中文字幕福利网| 日本免费视频午夜福利视频| 国产又粗又猛又爽又黄的视频美国| 天天日天天做天天日天天做| 2o22av在线视频| 98精产国品一二三产区区别| 成人av在线资源网站| 国产麻豆乱子伦午夜视频观看| huangse网站在线观看| 日本韩国免费一区二区三区视频| jiuse91九色视频| 激情五月婷婷免费视频| 青青青国产免费视频| 亚洲福利天堂久久久久久| 欧美精品中文字幕久久二区| 亚洲 国产 成人 在线| 日本一区美女福利视频| 国产亚洲视频在线二区| 91桃色成人网络在线观看| 色吉吉影音天天干天天操| 在线免费观看99视频| 国产日韩欧美视频在线导航 | 中国视频一区二区三区| 欧美日韩高清午夜蜜桃大香蕉| 不戴胸罩引我诱的隔壁的人妻| 亚洲超碰97人人做人人爱| 在线免费观看日本伦理| 99热99这里精品6国产| 2021久久免费视频| 亚洲成人激情视频免费观看了| 岛国毛片视频免费在线观看| 93视频一区二区三区| 国产之丝袜脚在线一区二区三区| 人妻爱爱 中文字幕| 日本av高清免费网站| 韩国爱爱视频中文字幕| 精品国产在线手机在线| 亚洲国产在线精品国偷产拍| 大黑人性xxxxbbbb| 蜜桃专区一区二区在线观看| 欧亚日韩一区二区三区观看视频| 亚洲av无乱一区二区三区性色| 老熟妇xxxhd老熟女| 色综合色综合色综合色| 欧美在线精品一区二区三区视频| 国产精品一区二区三区蜜臀av| 天堂va蜜桃一区入口| 欧美视频一区免费在线| 黄色视频在线观看高清无码| 亚洲一区二区三区精品视频在线 | 韩国AV无码不卡在线播放| 国产在线自在拍91国语自产精品| 中文字幕 人妻精品| 国产精品视频一区在线播放| 亚洲男人让女人爽的视频| 日韩影片一区二区三区不卡免费| 熟女少妇激情五十路| 亚洲av色香蕉一区二区三区| 亚洲另类图片蜜臀av| 熟女人妻三十路四十路人妻斩| 自拍偷拍vs一区二区三区| 久久美欧人妻少妇一区二区三区| 啊啊好慢点插舔我逼啊啊啊视频| 日本阿v视频在线免费观看| 亚洲欧美福利在线观看| 国产第一美女一区二区三区四区| 国产性生活中老年人视频网站| 夜夜嗨av一区二区三区中文字幕| 插小穴高清无码中文字幕| 色花堂在线av中文字幕九九 | 日本韩国亚洲综合日韩欧美国产| 日本少妇高清视频xxxxx| 福利一二三在线视频观看| 动漫黑丝美女的鸡巴| 青青色国产视频在线| 国产精品视频资源在线播放| 精品91高清在线观看| 精品人人人妻人人玩日产欧| 日本性感美女视频网站| 最新日韩av传媒在线| 一区国内二区日韩三区欧美| 欧美黑人性暴力猛交喷水| 国产福利在线视频一区| 国产高潮无码喷水AV片在线观看| 伊人开心婷婷国产av| 亚洲女人的天堂av| 激情啪啪啪啪一区二区三区| 白嫩白嫩美女极品国产在线观看| 九色视频在线观看免费| 久草视频首页在线观看| 天美传媒mv视频在线观看| 亚洲男人在线天堂网| 亚洲午夜电影在线观看| 午夜免费观看精品视频| 亚洲欧美一卡二卡三卡| 亚洲 中文 自拍 另类 欧美| 欧美xxx成人在线| 成人国产小视频在线观看| av无限看熟女人妻另类av| 亚洲成a人片777777| 五十路av熟女松本翔子| 中英文字幕av一区| 91小伙伴中女熟女高潮| 中文人妻AV久久人妻水| 天天射,天天操,天天说| av完全免费在线观看av| 久草视频在线一区二区三区资源站| 在线 中文字幕 一区| 最新欧美一二三视频| 欧美黑人性猛交xxxxⅹooo| 久久免费看少妇高潮完整版| 欧美在线精品一区二区三区视频| 国产精品久久久黄网站| 欧美80老妇人性视频| 日韩成人综艺在线播放| www,久久久,com| 午夜精品一区二区三区4| 色综合色综合色综合色| 视频在线亚洲一区二区| 高潮喷水在线视频观看| 天天日天天天天天天天天天天 | 欧美地区一二三专区| 粉嫩欧美美人妻小视频| 欧美日韩亚洲国产无线码| 婷婷激情四射在线观看视频| 中文字幕第一页国产在线| 人人妻人人爽人人澡人人精品| 亚洲 中文 自拍 另类 欧美| 天天操天天爽天天干| 欧美色呦呦最新网址| 中文字幕日韩精品就在这里| 中文字幕之无码色多多| 精品久久久久久久久久中文蒉| 动漫av网站18禁| 中文字幕,亚洲人妻| japanese日本熟妇另类| 家庭女教师中文字幕在线播放| 久久精品亚洲成在人线a| 国产熟妇一区二区三区av| 欧美日韩熟女一区二区三区| 在线视频免费观看网| 成人免费做爰高潮视频| 亚洲伊人久久精品影院一美女洗澡| 国产日韩av一区二区在线| 97超碰人人搞人人| 日韩欧美高清免费在线| 精品国产亚洲av一淫| 最后99天全集在线观看| 在线观看免费av网址大全| 欧美成人一二三在线网| 国产使劲操在线播放| 天堂中文字幕翔田av| 丝袜美腿视频诱惑亚洲无| 人妻少妇亚洲精品中文字幕| 18禁美女羞羞免费网站| 国产在线观看免费人成短视频| 日本韩国亚洲综合日韩欧美国产 | 亚洲欧美国产麻豆综合| 风流唐伯虎电视剧在线观看| 久久机热/这里只有| 欧美日韩亚洲国产无线码| 欧美精产国品一二三区| 一区二区三区另类在线| 亚洲 色图 偷拍 欧美| 天天操,天天干,天天射| 91极品大一女神正在播放| 亚洲成高清a人片在线观看| 韩国一级特黄大片做受| 新97超碰在线观看| 日本高清在线不卡一区二区| 97瑟瑟超碰在线香蕉| 国产三级片久久久久久久| 中文字幕一区二 区二三区四区 | 亚洲成人熟妇一区二区三区| 天天日天天天天天天天天天天| 伊人综合aⅴ在线网| 日本韩国免费福利精品| 91精品高清一区二区三区| 久久一区二区三区人妻欧美| 91国语爽死我了不卡| 日本人竟这样玩学生妹| 中文字幕人妻av在线观看| 人妻丝袜诱惑我操她视频| 少妇人妻真实精品视频| 午夜在线精品偷拍一区二| 午夜精品一区二区三区更新| 亚洲公开视频在线观看| 久草视频首页在线观看 | 午夜福利资源综合激情午夜福利资| 视频一区 视频二区 视频| 黄片色呦呦视频免费看| 蜜臀成人av在线播放| 人人在线视频一区二区| 日韩欧美国产精品91| 中文字幕在线乱码一区二区| 亚洲欧美精品综合图片小说| 玩弄人妻熟妇性色av少妇| 黄色av网站免费在线| 国产精品入口麻豆啊啊啊| 18禁污污污app下载| 免费看国产av网站| 在线免费观看黄页视频| 中文字幕在线观看国产片| 精品一区二区三四区| 精品人妻一二三区久久| 大鸡巴操娇小玲珑的女孩逼| 亚洲护士一区二区三区| 91免费观看国产免费| 亚洲女人的天堂av| 蜜桃视频在线欧美一区| 国产黄色片在线收看| 99精品国自产在线人| 九一传媒制片厂视频在线免费观看 | 美女福利写真在线观看视频| 中文字幕日韩精品日本| 日本午夜爽爽爽爽爽视频在线观看 | 中文字母永久播放1区2区3区| 蜜桃视频入口久久久| 久久久久久久一区二区三| 中文字幕在线乱码一区二区| 亚洲一区二区三区精品乱码| 中文字幕日韩精品日本| 国产又粗又硬又大视频| 日视频免费在线观看| 大学生A级毛片免费视频| 大香蕉大香蕉在线看| 日韩成人综艺在线播放| 午夜激情久久不卡一区二区| 亚洲av无女神免非久久| 国产精品国产三级国产精东| 欧美va不卡视频在线观看| 做爰视频毛片下载蜜桃视频1| 日本人妻少妇18—xx| 11久久久久久久久久久| 一区二区三区日韩久久| 国产高清精品一区二区三区| 五十路息与子猛烈交尾视频| 欧美亚洲国产成人免费在线| 国产精品手机在线看片| 天天干夜夜操天天舔| 亚洲 欧美 自拍 偷拍 在线| 日韩美女综合中文字幕pp| 肏插流水妹子在线乐播下载| 偷青青国产精品青青在线观看| 国产aⅴ一线在线观看| av亚洲中文天堂字幕网| 亚洲成人av一区在线| 久久久久久性虐视频| 成年人免费看在线视频| 亚洲人妻30pwc| 婷婷午夜国产精品久久久| 国产普通话插插视频| 成人高潮aa毛片免费| 精品区一区二区三区四区人妻| 中国无遮挡白丝袜二区精品| 人妻自拍视频中国大陆| 国产内射中出在线观看| 熟女妇女老妇一二三区| 亚洲一区二区三区久久受| 99热久久极品热亚洲| 97精品综合久久在线| 亚洲一级美女啪啪啪| 亚洲成人精品女人久久久| 在线观看欧美黄片一区二区三区 | 亚洲高清国产自产av| 91久久国产成人免费网站| 乱亲女秽乱长久久久| 一级a看免费观看网站| 国产福利小视频大全| 国产自拍在线观看成人| 久精品人妻一区二区三区| 伊人综合aⅴ在线网| 欧美aa一级一区三区四区| 东京热男人的av天堂| 国产日韩一区二区在线看| 91国产在线视频免费观看| 最新国产精品拍在线观看| 亚洲美女美妇久久字幕组| 综合色区亚洲熟妇shxstz| 日本xx片在线观看| 欧美黑人性猛交xxxxⅹooo| 天天日夜夜干天天操| 亚洲综合自拍视频一区| 干逼又爽又黄又免费的视频| 亚洲成人av一区久久| 黄色片黄色片wyaa| 日韩一个色综合导航| www骚国产精品视频| 亚洲熟女久久久36d| 国产精品国产三级国产精东| 黄色大片男人操女人逼| 国产av自拍偷拍盛宴| 国产视频精品资源网站| 日本熟妇一区二区x x| 国产九色91在线观看精品| 国产伊人免费在线播放| 粉嫩欧美美人妻小视频| 久久美欧人妻少妇一区二区三区| yy6080国产在线视频| 国产性感美女福利视频| 午夜av一区二区三区| 国产视频在线视频播放| 日韩欧美国产精品91| 91中文字幕最新合集| 国产成人小视频在线观看无遮挡| 国产使劲操在线播放| 一色桃子人妻一区二区三区| 中文字幕av男人天堂| 久久麻豆亚洲精品av| 密臀av一区在线观看| 欧美性受xx黑人性猛交| 亚洲另类图片蜜臀av| 天天操夜夜操天天操天天操 | 日本高清成人一区二区三区| 老司机福利精品视频在线| 欧美成人黄片一区二区三区| 欧美精产国品一二三产品价格| 精品一区二区三区三区色爱| 中文人妻AV久久人妻水| www天堂在线久久| 偷偷玩弄新婚人妻h视频| 国产精品福利小视频a| 91福利视频免费在线观看| 国产中文字幕四区在线观看| 男女啪啪啪啪啪的网站| 东京干手机福利视频| 国产精品3p和黑人大战| 熟妇一区二区三区高清版| 内射久久久久综合网| 美女被肏内射视频网站| 亚洲日产av一区二区在线| 国产精品国产三级麻豆| 18禁免费av网站| 欧美va亚洲va天堂va| 国产91久久精品一区二区字幕| 亚洲精品久久视频婷婷| 人妻丝袜榨强中文字幕| 色在线观看视频免费的| 亚洲熟女久久久36d| 真实国模和老外性视频| 姐姐的朋友2在线观看中文字幕| 风流唐伯虎电视剧在线观看| 自拍偷拍亚洲精品第2页| 国产又粗又硬又大视频| 亚洲超碰97人人做人人爱| 亚洲高清自偷揄拍自拍| 国产极品美女久久久久久| 51精品视频免费在线观看| 亚洲欧美成人综合在线观看| 91中文字幕最新合集| 午夜青青草原网在线观看| 精品久久久久久久久久中文蒉| 超碰在线观看免费在线观看| 国产妇女自拍区在线观看| 亚洲国产最大av综合| 91chinese在线视频| 成熟丰满熟妇高潮xx×xx | 天天爽夜夜爽人人爽QC| 夜女神免费福利视频| 婷婷色国产黑丝少妇勾搭AV| 人人人妻人人澡人人| 国产夫妻视频在线观看免费| 亚洲中文字字幕乱码| 日韩一区二区电国产精品| 黄色视频在线观看高清无码 | 亚洲另类在线免费观看| 中文字幕乱码人妻电影| 啊啊啊想要被插进去视频| 日韩av大胆在线观看| 和邻居少妇愉情中文字幕| 国产日本欧美亚洲精品视| 日本熟妇一区二区x x| 天天操天天弄天天射| 美日韩在线视频免费看| 免费看国产又粗又猛又爽又黄视频 | 天堂av狠狠操蜜桃| 人妻最新视频在线免费观看| 人妻无码中文字幕专区| 一区二区熟女人妻视频| 亚洲精品国偷自产在线观看蜜桃| 一区二区三区四区视频| 91色秘乱一区二区三区| 中文字幕AV在线免费看 | 久精品人妻一区二区三区| 中文字幕午夜免费福利视频| 经典亚洲伊人第一页| 国产黄色片在线收看| 家庭女教师中文字幕在线播放| 天天射夜夜操狠狠干| xxx日本hd高清| 伊人综合免费在线视频| 天天操天天污天天射| 日本一二三中文字幕| 国产chinesehd精品麻豆| 中文字幕之无码色多多| 中文字幕在线一区精品| 一区二区三区久久久91| 国产大鸡巴大鸡巴操小骚逼小骚逼| 国产之丝袜脚在线一区二区三区 | 综合页自拍视频在线播放| 在线 中文字幕 一区| 日韩亚洲高清在线观看| 91欧美在线免费观看| 2020中文字幕在线播放| 日日日日日日日日夜夜夜夜夜夜| 九色精品视频在线播放| 成年女人免费播放视频| weyvv5国产成人精品的视频| 人人妻人人澡欧美91精品| 国产精品视频一区在线播放| 日本少妇的秘密免费视频| aⅴ五十路av熟女中出| 操人妻嗷嗷叫视频一区二区| 男人的天堂在线黄色| 小泽玛利亚视频在线观看| 中文字幕 人妻精品| av一本二本在线观看| 男人操女人的逼免费视频| 福利午夜视频在线观看| 国产精品中文av在线播放| 97国产福利小视频合集| 青青青青青免费视频| 五十路人妻熟女av一区二区| 国产实拍勾搭女技师av在线| 五十路丰满人妻熟妇| 国产三级片久久久久久久| 日韩熟女系列一区二区三区| 亚洲精品成人网久久久久久小说| 亚洲色偷偷综合亚洲AV伊人| 天天干天天日天天干天天操| 97人人妻人人澡人人爽人人精品| 中文字幕午夜免费福利视频| 青青青青青青草国产| 99视频精品全部15| 国产精品福利小视频a| 天天日天天干天天插舔舔| 一色桃子久久精品亚洲| 超级碰碰在线视频免费观看| 少妇人妻真实精品视频| 欧美日韩在线精品一区二区三| 天天操天天污天天射| 亚洲av成人免费网站| 国产亚洲精品视频合集| 看一级特黄a大片日本片黑人| 五十路老熟女码av| 中文字幕av一区在线观看| 亚洲av一妻不如妾| 国产精品黄片免费在线观看| 久久精品亚洲成在人线a| 欧美韩国日本国产亚洲| 男人靠女人的逼视频| 视频一区二区综合精品| 福利午夜视频在线合集| 亚洲av可乐操首页| 国产精品久久久黄网站| 成人sm视频在线观看| 天天日夜夜干天天操| 偷拍自拍亚洲美腿丝袜| 成人性黑人一级av| 亚洲推理片免费看网站| 人妻少妇亚洲一区二区| 久青青草视频手机在线免费观看 | 在线观看国产免费麻豆| av天堂中文免费在线| 欧美地区一二三专区| 丝袜肉丝一区二区三区四区在线看| 伊人日日日草夜夜草| 天天操天天弄天天射| 啪啪啪啪啪啪啪啪av| 成人色综合中文字幕| jiujiure精品视频在线| 蜜桃精品久久久一区二区| 欧美日本在线视频一区| 91精品资源免费观看| 亚洲精品乱码久久久本| 91久久精品色伊人6882| 成年人午夜黄片视频资源| 免费看美女脱光衣服的视频| 专门看国产熟妇的网站| 国产1区,2区,3区| 啊慢点鸡巴太大了啊舒服视频| 93视频一区二区三区| 国产福利在线视频一区| 亚洲一区自拍高清免费视频| 美女被肏内射视频网站| 成人精品视频99第一页| 日本在线不卡免费视频| 啪啪啪操人视频在线播放| 色av色婷婷人妻久久久精品高清| 女警官打开双腿沦为性奴| 天天日天天爽天天干| 国产高清在线在线视频| 偷拍自拍亚洲视频在线观看| 嫩草aⅴ一区二区三区| 视频一区 视频二区 视频| 2021久久免费视频| 精彩视频99免费在线| 桃色视频在线观看一区二区| 精品一区二区三区三区色爱| 国产卡一卡二卡三乱码手机| 骚逼被大屌狂草视频免费看| 在线免费观看国产精品黄色| 人妻自拍视频中国大陆| 天天日天天干天天爱| 国产真实灌醉下药美女av福利| 午夜大尺度无码福利视频| 黑人巨大的吊bdsm| yellow在线播放av啊啊啊| 久久久制服丝袜中文字幕| 中文字幕中文字幕人妻| 亚洲免费在线视频网站| 国产精彩对白一区二区三区| 中英文字幕av一区| 一级黄色片夫妻性生活| 日本熟妇色熟妇在线观看| 偷拍自拍国产在线视频| 国产大学生援交正在播放| 欧美亚洲国产成人免费在线| 老司机99精品视频在线观看| 日本裸体熟妇区二区欧美| 在线成人日韩av电影| 人人妻人人澡人人爽人人dvl| 色哟哟在线网站入口| 五月天中文字幕内射| 搞黄色在线免费观看| 亚洲欧美激情人妻偷拍| 国产精品国产三级麻豆| 亚洲欧美综合在线探花| 在线免费观看靠比视频的网站| 中文亚洲欧美日韩无线码| 精品一区二区三区三区88 | av线天堂在线观看| 精彩视频99免费在线| 综合页自拍视频在线播放| 中文字日产幕乱六区蜜桃| 小泽玛利亚视频在线观看| 沈阳熟妇28厘米大战黑人| 蜜桃精品久久久一区二区| 久久美欧人妻少妇一区二区三区| 中文字日产幕乱六区蜜桃 | 大香蕉玖玖一区2区| 亚洲免费成人a v| 操人妻嗷嗷叫视频一区二区| 91免费黄片可看视频| 亚洲一区二区三区精品视频在线 | 丝袜国产专区在线观看| 国产真实灌醉下药美女av福利| yy96视频在线观看| 日本三极片视频网站观看| 亚洲成人情色电影在线观看| 青青伊人一精品视频| 亚洲成人av在线一区二区| 国产精品大陆在线2019不卡| 91小伙伴中女熟女高潮| 国产免费高清视频视频| 久久久久国产成人精品亚洲午夜| 天堂av中文在线最新版| 亚洲中文字字幕乱码| 98视频精品在线观看| 国产精品一区二区三区蜜臀av| 噜噜色噜噜噜久色超碰| 在线播放 日韩 av| 色花堂在线av中文字幕九九| 91传媒一区二区三区| 亚洲在线免费h观看网站| 激情人妻校园春色亚洲欧美 | 午夜dv内射一区区| 亚洲国际青青操综合网站| 在线视频免费观看网| 亚洲一区二区三区偷拍女厕91| 少妇露脸深喉口爆吞精| 男生用鸡操女生视频动漫| 日本免费午夜视频网站| 一区二区三区综合视频| 成人蜜臀午夜久久一区| 欧美精品 日韩国产| 久草视频在线看免费| 在线观看av2025| 欧美日本在线观看一区二区| 成人性黑人一级av| 国产精品污污污久久| 欧美女同性恋免费a| 亚洲特黄aaaa片| 桃色视频在线观看一区二区| 日韩一个色综合导航| 精品视频国产在线观看| tube69日本少妇| 欧美久久久久久三级网| 国产高清在线在线视频| 任你操视频免费在线观看| 午夜91一区二区三区| 亚洲av黄色在线网站| 91国内精品自线在拍白富美| 一区二区三区综合视频| 日本人妻少妇18—xx| 亚洲一区二区三区在线高清| 日本性感美女三级视频| 2020中文字幕在线播放| 亚洲av第国产精品| 欧美成人精品欧美一级黄色| av资源中文字幕在线观看| 欧美女同性恋免费a| 久草视频在线看免费| 精品久久久久久高潮| av中文字幕在线观看第三页| 白白操白白色在线免费视频| 啪啪啪操人视频在线播放| 中文字幕av第1页中文字幕| 日韩三级电影华丽的外出| 2020韩国午夜女主播在线| 久久精品久久精品亚洲人| 五十路息与子猛烈交尾视频| 欧美精品免费aaaaaa| 521精品视频在线观看| 99的爱精品免费视频| 欧美日本国产自视大全| 亚洲在线免费h观看网站| 一区二区视频在线观看免费观看 | www日韩毛片av| 国产av国片精品一区二区| 精彩视频99免费在线| 天天操天天干天天艹| 成年午夜影片国产片| 视频一区二区在线免费播放| 欧美亚洲中文字幕一区二区三区| 无忧传媒在线观看视频| 亚洲蜜臀av一区二区三区九色| 夜夜操,天天操,狠狠操| 91社福利《在线观看| 中文字幕亚洲久久久| 午夜精品九一唐人麻豆嫩草成人| 久青青草视频手机在线免费观看| 啊用力插好舒服视频| 黄色片黄色片wyaa| 福利午夜视频在线观看| av在线shipin| 午夜美女少妇福利视频| 亚洲欧美成人综合在线观看| 亚洲av在线观看尤物| 国产美女精品福利在线| 香港一级特黄大片在线播放 | 大香蕉福利在线观看| 视频啪啪啪免费观看| 一区二区三区四区视频| 欧美精品免费aaaaaa| 中文字幕网站你懂的| 国产熟妇乱妇熟色T区| 日韩欧美高清免费在线| 免费在线福利小视频| 亚洲特黄aaaa片| 二区中出在线观看老师| yy96视频在线观看| 亚洲av可乐操首页| 亚洲2021av天堂| 免费岛国喷水视频在线观看| 久久久久久久亚洲午夜综合福利| 亚洲伊人av天堂有码在线| 亚洲精品ww久久久久久| 视频在线免费观看你懂得| 婷婷六月天中文字幕| 亚洲图库另类图片区| 久久久久国产成人精品亚洲午夜| av视网站在线观看| 国产精品一区二区久久久av| 黄色视频在线观看高清无码| 欧美一级片免费在线成人观看| 欧美另类z0z变态| 中文字幕av第1页中文字幕| 在线播放一区二区三区Av无码| 91超碰青青中文字幕| 换爱交换乱高清大片| 香蕉av影视在线观看| heyzo蜜桃熟女人妻| 日韩成人综艺在线播放| 中国熟女@视频91| 日本一二三中文字幕| 最新97国产在线视频| 91精品高清一区二区三区| 抽查舔水白紧大视频| 亚洲欧美久久久久久久久| 含骚鸡巴玩逼逼视频| 91‖亚洲‖国产熟女| 日本av熟女在线视频| 日韩国产乱码中文字幕| 美女av色播在线播放| 精品国产在线手机在线| 婷婷午夜国产精品久久久| 国产密臀av一区二区三| 亚洲精品亚洲人成在线导航| 玖玖一区二区在线观看| 中文字幕日韩人妻在线三区| 日韩欧美一级aa大片| 天天操天天操天天碰| 日韩视频一区二区免费观看| 激情国产小视频在线| 国产V亚洲V天堂无码欠欠| 国产精品入口麻豆啊啊啊| 成人色综合中文字幕| 免费无毒热热热热热热久| 大鸡巴插入美女黑黑的阴毛| 999九九久久久精品| 日本18禁久久久久久| 亚洲免费va在线播放| 精品黑人巨大在线一区| 人妻在线精品录音叫床| 一区二区三区视频,福利一区二区 丰满的子国产在线观看 | 欧美在线偷拍视频免费看| 久久久久久久一区二区三| 中文字幕在线第一页成人| 久久久久91精品推荐99| 日韩亚洲高清在线观看| 黄色黄色黄片78在线| 2019av在线视频| 性色蜜臀av一区二区三区| 在线观看操大逼视频| 啪啪啪啪啪啪啪啪av| 亚洲国产精品美女在线观看| 一区二区三区四区中文| 97人妻无码AV碰碰视频| 亚洲国产成人在线一区| 日韩av有码中文字幕| 偷拍3456eee| 免费黄页网站4188| 亚洲欧洲av天堂综合| 欧美性感尤物人妻在线免费看| 9久在线视频只有精品| 五十路av熟女松本翔子| 日美女屁股黄邑视频| 欧美交性又色又爽又黄麻豆| 亚洲一区二区三区av网站| 欧美韩国日本国产亚洲| 一区二区三区国产精选在线播放 | 青娱乐蜜桃臀av色| 888欧美视频在线| 人妻少妇性色欲欧美日韩| 美日韩在线视频免费看| 一级黄片久久久久久久久| 美女福利视频导航网站| 日本人竟这样玩学生妹| 91九色porny国产在线| 亚洲国产欧美国产综合在线| 色狠狠av线不卡香蕉一区二区 | 第一福利视频在线观看| 污污小视频91在线观看| 日本脱亚入欧是指什么| 色哟哟国产精品入口| 久草视频 久草视频2| 免费看高清av的网站| 男女第一次视频在线观看| 99的爱精品免费视频| 一区二区三区四区五区性感视频| 日韩中文字幕福利av| av无限看熟女人妻另类av| 国产午夜亚洲精品麻豆| 97国产在线观看高清| 91亚洲精品干熟女蜜桃频道| 白嫩白嫩美女极品国产在线观看 | 男人天堂色男人av| 天天躁日日躁狠狠躁躁欧美av | 国产麻豆精品人妻av| 天天操天天插天天色| 久久热久久视频在线观看| 亚洲第17页国产精品| 水蜜桃一区二区三区在线观看视频 | 中文亚洲欧美日韩无线码| 19一区二区三区在线播放| 亚洲欧美自拍另类图片| 亚洲乱码中文字幕在线| 无码精品一区二区三区人| 都市家庭人妻激情自拍视频| 亚洲福利精品福利精品福利| 亚洲中文字幕国产日韩| 中国产一级黄片免费视频播放| 亚洲视频在线视频看视频在线| 经典亚洲伊人第一页| 中文人妻AV久久人妻水| 大白屁股精品视频国产| 精品国产午夜视频一区二区| 天天射,天天操,天天说| 天天日天天干天天干天天日| 黄工厂精品视频在线观看| 超黄超污网站在线观看| 动漫黑丝美女的鸡巴| 中文人妻AV久久人妻水| jul—619中文字幕在线| 一区二区视频在线观看免费观看| 社区自拍揄拍尻屁你懂的| 成人高潮aa毛片免费| 97超碰人人搞人人| 日本xx片在线观看| 97人妻人人澡爽人人精品| 日本最新一二三区不卡在线| 青青青国产片免费观看视频| 久久久久久久久久久免费女人| 天天做天天爽夜夜做少妇| 伊人精品福利综合导航| 欧美黑人性暴力猛交喷水| 女生被男生插的视频网站| 日韩三级黄色片网站| 深田咏美亚洲一区二区| 天天摸天天亲天天舔天天操天天爽| 天天操天天射天天操天天天| 天天草天天色天天干| 日本高清成人一区二区三区| 亚洲免费国产在线日韩| 好吊操视频这里只有精品| 九色porny九色9l自拍视频| 日本少妇高清视频xxxxx | 精品视频一区二区三区四区五区| 欧美视频一区免费在线| 亚洲av日韩av第一区二区三区| 97年大学生大白天操逼| 午夜激情高清在线观看| 青青青青青手机视频| 久久精品36亚洲精品束缚| www天堂在线久久| 中国黄片视频一区91| 国产精品人妻一区二区三区网站| 偷拍3456eee| 亚洲精品三级av在线免费观看| 午夜极品美女福利视频| 视频一区二区综合精品| 精品一区二区亚洲欧美| 国产真实乱子伦a视频| 午夜福利人人妻人人澡人人爽| 亚洲人妻av毛片在线| 好吊操视频这里只有精品| 夜女神免费福利视频| 精品国产亚洲av一淫| 欧美一区二区中文字幕电影| 亚洲一区二区三区uij| 超碰中文字幕免费观看| 天天色天天操天天舔| 视频一区二区综合精品| 国产一区成人在线观看视频| 亚洲成人激情视频免费观看了| 真实国模和老外性视频| 自拍 日韩 欧美激情| 热思思国产99re| 日韩欧美亚洲熟女人妻| 日韩欧美一级精品在线观看| 绯色av蜜臀vs少妇| 久久热久久视频在线观看| 国产熟妇乱妇熟色T区| 国产a级毛久久久久精品| 高潮视频在线快速观看国家快速| 自拍偷拍亚洲欧美在线视频| 国产女人露脸高潮对白视频| 日韩激情文学在线视频| 中文字幕在线免费第一页| 日本少妇人妻xxxxx18| 性色蜜臀av一区二区三区| 一级黄色片夫妻性生活| 色天天天天射天天舔| 狠狠的往里顶撞h百合| 青青草亚洲国产精品视频| 欧美韩国日本国产亚洲| 亚洲欧美成人综合在线观看| 亚洲综合在线视频可播放| 亚洲国产精品免费在线观看| 黑人变态深video特大巨大| 成人30分钟免费视频| 精品国产成人亚洲午夜| 青草久久视频在线观看| 国产精选一区在线播放| 玖玖一区二区在线观看| avjpm亚洲伊人久久| 亚洲欧美一区二区三区爱爱动图| 亚洲一级美女啪啪啪| 成人H精品动漫在线无码播放| 亚洲免费在线视频网站| 人妻丝袜av在线播放网址| 亚洲av日韩av网站| 2018在线福利视频| 亚洲免费av在线视频| 最新91九色国产在线观看| 影音先锋女人av噜噜色| 宅男噜噜噜666免费观看| 人妻丝袜av在线播放网址| av俺也去在线播放| 快插进小逼里大鸡吧视频| 中文字幕第三十八页久久| 精彩视频99免费在线| 精品久久久久久久久久久99| 国产亚洲天堂天天一区| 老司机免费福利视频网| 国产精品成人xxxx| 亚洲欧美色一区二区| 亚洲国产欧美国产综合在线| 亚洲国产精品中文字幕网站| 91久久综合男人天堂| 亚洲第17页国产精品| 国产91精品拍在线观看| 国产97在线视频观看| 免费观看国产综合视频| 在线播放一区二区三区Av无码| 亚洲图库另类图片区| 精产国品久久一二三产区区别| 国产麻豆剧传媒精品国产av蜜桃| 啪啪啪啪啪啪啪啪av| 色吉吉影音天天干天天操 | 国产精品久久久久久久久福交| 亚洲 色图 偷拍 欧美| 日韩av熟妇在线观看| 国产精品黄色的av| 欧美韩国日本国产亚洲| 亚洲青青操骚货在线视频| 大鸡吧插入女阴道黄色片| av天堂加勒比在线| 亚洲另类伦春色综合小| 51国产成人精品视频| 老司机福利精品免费视频一区二区 | av网址在线播放大全| 99一区二区在线观看| v888av在线观看视频| 色97视频在线播放| 欧美精品国产综合久久| 国产精品污污污久久| 黄色录像鸡巴插进去| 国产亚洲精品欧洲在线观看| av久久精品北条麻妃av观看 | a v欧美一区=区三区| 狠狠地躁夜夜躁日日躁| 少妇露脸深喉口爆吞精| 一区二区三区蜜臀在线| 久久艹在线观看视频| 国产精品日韩欧美一区二区| 亚洲激情av一区二区| 亚洲国产欧美一区二区丝袜黑人| 免费看美女脱光衣服的视频| 男人天堂色男人av| 一区二区熟女人妻视频| 一区二区三区 自拍偷拍| 91高清成人在线视频| 亚洲精品色在线观看视频| 国产卡一卡二卡三乱码手机| 亚洲推理片免费看网站| 97超碰最新免费在线观看| 午夜蜜桃一区二区三区| 久久久久久久亚洲午夜综合福利| 欧美香蕉人妻精品一区二区| 亚洲国产第一页在线观看| 成熟丰满熟妇高潮xx×xx| 欧美精品亚洲精品日韩在线| 91精品一区二区三区站长推荐| 一区二区三区四区五区性感视频| 一色桃子久久精品亚洲| 五十路熟女av天堂| 中文字幕在线乱码一区二区| 国产精品免费不卡av| 婷婷综合蜜桃av在线| 天天操天天干天天日狠狠插| sejizz在线视频| 国产麻豆91在线视频| 一区二区三区的久久的蜜桃的视频| 亚洲精品欧美日韩在线播放| 中文字幕奴隷色的舞台50| 日本熟妇一区二区x x| 大陆精品一区二区三区久久| 国产精品一区二区久久久av| 日本精品视频不卡一二三| 欧美精品欧美极品欧美视频| 少妇ww搡性bbb91| 青青青青青免费视频| 亚洲图片偷拍自拍区| 中文字幕 码 在线视频| 亚洲 图片 欧美 图片| 婷婷综合亚洲爱久久| 天天日天天玩天天摸| 亚洲中文字幕综合小综合| 五月婷婷在线观看视频免费| 国产精品大陆在线2019不卡| 97人妻总资源视频| 一区二区三区蜜臀在线| 男人和女人激情视频| av日韩在线观看大全| 亚洲卡1卡2卡三卡四老狼| 国内精品在线播放第一页| 欧美亚洲免费视频观看| 家庭女教师中文字幕在线播放| 五月天久久激情视频| av大全在线播放免费| 91p0rny九色露脸熟女| 少妇与子乱在线观看| 亚洲va欧美va人人爽3p| 100%美女蜜桃视频| 99热这里只有精品中文| 午夜激情精品福利视频| 久久精品美女免费视频| 伊人精品福利综合导航| 国产成人午夜精品福利| 日日操综合成人av| 欧美激情精品在线观看| 加勒比视频在线免费观看| 91试看福利一分钟| 97国产在线av精品| av一本二本在线观看| 精品人人人妻人人玩日产欧| 男女啪啪啪啪啪的网站| 欧美日本在线观看一区二区| 精品一区二区三四区| 精品首页在线观看视频| 99的爱精品免费视频| 天天操夜夜骑日日摸| 国产普通话插插视频| 午夜影院在线观看视频羞羞羞| 国产精品亚洲а∨天堂免| wwwxxx一级黄色片| 欧美亚洲中文字幕一区二区三区| 91天堂天天日天天操| www,久久久,com| 果冻传媒av一区二区三区| 亚洲 国产 成人 在线| 3337p日本欧洲大胆色噜噜| 午夜精品亚洲精品五月色| 熟女91pooyn熟女| 亚洲午夜电影之麻豆| 中文人妻AV久久人妻水| 亚洲欧美福利在线观看| 又粗又硬又猛又爽又黄的| 四川五十路熟女av| 婷婷久久一区二区字幕网址你懂得| 香蕉片在线观看av| 国产揄拍高清国内精品对白| 日本熟女精品一区二区三区| 香港一级特黄大片在线播放 | 第一福利视频在线观看| 又粗又硬又猛又黄免费30| 97人人模人人爽人人喊| 老司机99精品视频在线观看| 操人妻嗷嗷叫视频一区二区 | 精产国品久久一二三产区区别| 日本高清撒尿pissing| 天天躁日日躁狠狠躁躁欧美av| 老司机福利精品免费视频一区二区 | 日本熟女精品一区二区三区| 偷青青国产精品青青在线观看 | 免费在线观看视频啪啪| 天天色天天舔天天射天天爽 | 中出中文字幕在线观看| 大肉大捧一进一出好爽在线视频| 午夜国产免费福利av| 美女骚逼日出水来了| 女警官打开双腿沦为性奴| 硬鸡巴动态操女人逼视频| 欧美日韩熟女一区二区三区| japanese五十路熟女熟妇| 大鸡巴插入美女黑黑的阴毛| 天堂女人av一区二区| 99国内精品永久免费视频| 日噜噜噜夜夜噜噜噜天天噜噜噜| 521精品视频在线观看| 青春草视频在线免费播放| 欧美性受xx黑人性猛交| 女同互舔一区二区三区| 国产va在线观看精品| 男人操女人逼逼视频网站| 亚洲av色图18p| 亚洲国际青青操综合网站 | 美女张开两腿让男人桶av| 老司机深夜免费福利视频在线观看| 2020中文字幕在线播放| 欧美成人猛片aaaaaaa| av亚洲中文天堂字幕网| 91小伙伴中女熟女高潮| 日本一道二三区视频久久| 亚洲高清国产一区二区三区| 3337p日本欧洲大胆色噜噜| 欧美亚洲少妇福利视频| 黄色男人的天堂视频| 日本一区精品视频在线观看| 天天躁夜夜躁日日躁a麻豆| 国产精品久久久久久久久福交 | 欧美韩国日本国产亚洲| 亚洲高清自偷揄拍自拍| 福利在线视频网址导航| 亚洲精品在线资源站| 国产一区二区神马久久| 岛国黄色大片在线观看| 家庭女教师中文字幕在线播放| 亚洲中文精品字幕在线观看| 天天日天天日天天擦| 日本人竟这样玩学生妹| 91久久国产成人免费网站| 欧美精品免费aaaaaa| 国产午夜福利av导航| 91久久人澡人人添人人爽乱| 精品高跟鞋丝袜一区二区| 久草极品美女视频在线观看| 亚洲在线免费h观看网站| 女同久久精品秋霞网| 神马午夜在线观看视频| 青青青青青青草国产| 99热碰碰热精品a中文| 深田咏美亚洲一区二区| 久青青草视频手机在线免费观看| 免费成人av中文字幕| 伊拉克及约旦宣布关闭领空| 天天插天天狠天天操| 日韩美女综合中文字幕pp| 亚洲欧洲一区二区在线观看| 自拍 日韩 欧美激情| 第一福利视频在线观看| 天天操夜夜骑日日摸| 日韩剧情片电影在线收看| 女同久久精品秋霞网| 精品一区二区三区三区色爱| 亚洲国产美女一区二区三区软件| 国产高潮无码喷水AV片在线观看| 中国熟女@视频91| 搞黄色在线免费观看| 精品一区二区亚洲欧美| 黑人巨大的吊bdsm| 国产成人一区二区三区电影网站 | 日韩北条麻妃一区在线| 国产精品久久久久国产三级试频 | 国产剧情演绎系列丝袜高跟| 一区二区三区四区视频| 超污视频在线观看污污污| 新婚人妻聚会被中出| 91九色porny国产蝌蚪视频| 91大神福利视频网| 天天日天天天天天天天天天天| 天天插天天狠天天操| 午夜在线观看岛国av,com| 欧美偷拍亚洲一区二区| 做爰视频毛片下载蜜桃视频1| 日韩午夜福利精品试看| 一区二区三区欧美日韩高清播放| 中文字幕在线免费第一页| 国产日韩欧美视频在线导航| 一级黄片大鸡巴插入美女| 黄色片黄色片wyaa| 十八禁在线观看地址免费| 激情五月婷婷综合色啪| 亚洲欧美激情国产综合久久久| 欧美男人大鸡吧插女人视频| 亚洲欧美成人综合视频| 亚洲男人让女人爽的视频| 天天做天天爽夜夜做少妇| 国产九色91在线观看精品| av无限看熟女人妻另类av| 中文乱理伦片在线观看| 激情小视频国产在线| 欧美性受xx黑人性猛交| 国产在线免费观看成人| 中文字幕AV在线免费看 | 极品性荡少妇一区二区色欲| 天天摸天天日天天操| 爱有来生高清在线中文字幕| 日本最新一二三区不卡在线| 精品欧美一区二区vr在线观看| 久久久久久久精品成人热| 国产一级精品综合av| 北条麻妃av在线免费观看| 97超碰免费在线视频| 扒开腿挺进肉嫩小18禁视频| 熟女视频一区,二区,三区| rct470中文字幕在线| 久久久久久久一区二区三| 中文字幕欧美日韩射射一| 蜜臀av久久久久蜜臀av麻豆| 综合色区亚洲熟妇shxstz| 国产精品国产三级国产午| 精品黑人巨大在线一区| 亚洲蜜臀av一区二区三区九色| 色偷偷伊人大杳蕉综合网| 懂色av蜜桃a v| 男人天堂色男人av| 亚洲成人熟妇一区二区三区 | 日本少妇精品免费视频| 97超碰最新免费在线观看| 国产乱子伦一二三区| 91九色国产porny蝌蚪| 国产高清97在线观看视频| 欧美精产国品一二三产品价格| 天天干天天日天天谢综合156| 人妻自拍视频中国大陆| 综合页自拍视频在线播放| 99久久超碰人妻国产| 国产白袜脚足J棉袜在线观看| 日本av在线一区二区三区| 国产乱弄免费视频观看| 久久精品国产23696| 人妻在线精品录音叫床| 亚洲一区二区久久久人妻| 青青青青青操视频在线观看| 亚洲一区二区激情在线| 欧美成一区二区三区四区| 亚洲成高清a人片在线观看| 国产麻豆剧果冻传媒app| 国产成人自拍视频在线免费观看| 日韩欧美制服诱惑一区在线| 亚洲一级av大片免费观看| 最新91精品视频在线| 欧美韩国日本国产亚洲| 粉嫩av蜜乳av蜜臀| 日本午夜福利免费视频| 夜夜骑夜夜操夜夜奸| 国产午夜无码福利在线看| 一区二区三区毛片国产一区| 欧美日韩高清午夜蜜桃大香蕉| 91九色porny蝌蚪国产成人| 午夜在线一区二区免费| 国产精品久久综合久久| 91在线免费观看成人| 青草亚洲视频在线观看| 精品久久久久久高潮| 在线观看免费视频网| 午夜dv内射一区区| 成人亚洲精品国产精品 | 亚洲美女自偷自拍11页| 午夜美女少妇福利视频| 福利视频一区二区三区筱慧| 亚洲成人午夜电影在线观看| 男人的天堂av日韩亚洲| av一本二本在线观看| 女生被男生插的视频网站| 日本人妻少妇18—xx| 一个人免费在线观看ww视频 | 端庄人妻堕落挣扎沉沦| 青青色国产视频在线| 任你操任你干精品在线视频| 99国内小视频在现欢看| 狠狠操狠狠操免费视频| av完全免费在线观看av| 欧美一区二区三区在线资源| 亚洲精品无码久久久久不卡 | 黑人解禁人妻叶爱071| 日韩av熟妇在线观看| 亚洲综合自拍视频一区| 亚洲国产欧美一区二区三区久久| 美日韩在线视频免费看| av天堂资源最新版在线看| 男人在床上插女人视频| 57pao国产一区二区| 中文字幕 人妻精品| 91‖亚洲‖国产熟女| 中文字幕欧美日韩射射一| 极品丝袜一区二区三区| 91国产在线免费播放| 视频一区二区三区高清在线| 国产精品自拍在线视频| 国产chinesehd精品麻豆| 亚洲2021av天堂| 2025年人妻中文字幕乱码在线 | 换爱交换乱高清大片| 天天日天天敢天天干| 亚洲第一黄色在线观看| 2022中文字幕在线| 好男人视频在线免费观看网站| yy6080国产在线视频| 免费高清自慰一区二区三区网站 | 中文字幕高清在线免费播放| av在线shipin| 在线播放一区二区三区Av无码| 又大又湿又爽又紧A视频| 亚洲欧美色一区二区| 中文字母永久播放1区2区3区 | 天天躁日日躁狠狠躁躁欧美av| 人妻在线精品录音叫床| 亚洲成人av一区在线| 综合页自拍视频在线播放| 天天综合天天综合天天网 | 在线免费视频 自拍| 国产熟妇一区二区三区av| 偷拍自拍亚洲视频在线观看| 久久久久久久99精品| 97人妻总资源视频| 中文亚洲欧美日韩无线码| 我想看操逼黄色大片| 一区二区视频在线观看免费观看 | 视频一区二区在线免费播放| 亚洲人妻av毛片在线| 日本裸体熟妇区二区欧美| 天堂女人av一区二区| 在线播放一区二区三区Av无码| 亚洲国产成人在线一区| 大鸡吧插入女阴道黄色片| 国产日韩av一区二区在线| 天天干天天操天天扣| 特大黑人巨大xxxx| 日本性感美女三级视频| 男女之间激情网午夜在线| 国产chinesehd精品麻豆| 国产精品成人xxxx| 精产国品久久一二三产区区别| 亚洲国际青青操综合网站| 中文字幕一区二区人妻电影冢本| 偷拍美女一区二区三区| 无码国产精品一区二区高潮久久4| 欧美黄色录像免费看的| 亚洲国产美女一区二区三区软件 | 91破解版永久免费| 中文字幕在线一区精品| 日日夜夜精品一二三| 免费福利av在线一区二区三区| 美女福利视频导航网站| 班长撕开乳罩揉我胸好爽| 欧美熟妇一区二区三区仙踪林 | 午夜精品亚洲精品五月色| 精品人人人妻人人玩日产欧| 日本特级片中文字幕| 天天操天天弄天天射| 最新国产精品网址在线观看| 91老熟女连续高潮对白| 黄色大片男人操女人逼| 自拍偷拍日韩欧美亚洲| 精品一线二线三线日本| h国产小视频福利在线观看| 亚洲伊人av天堂有码在线| 爱有来生高清在线中文字幕| 99re6热在线精品| 国产使劲操在线播放| 久草视频首页在线观看| 亚洲一区二区三区久久午夜| 中文字幕日韩无敌亚洲精品| 色狠狠av线不卡香蕉一区二区 | av天堂加勒比在线| 东游记中文字幕版哪里可以看到| 大香蕉玖玖一区2区| 国产高清97在线观看视频| 亚洲欧美综合另类13p| 99人妻视频免费在线| 男人靠女人的逼视频| 国产精品久久久久久久久福交| 最近的中文字幕在线mv视频| 蜜桃精品久久久一区二区| 97人人妻人人澡人人爽人人精品| 高潮喷水在线视频观看| 青草亚洲视频在线观看| 老鸭窝日韩精品视频观看| 亚洲图片欧美校园春色| 欧美激情精品在线观看| 99人妻视频免费在线| 亚洲熟女久久久36d| 一区二区三区 自拍偷拍| 又粗又硬又猛又爽又黄的| 绝色少妇高潮3在线观看| 天天草天天色天天干| 天堂av在线播放免费| 日韩视频一区二区免费观看| 青青青青青手机视频| 少妇人妻100系列| 99热这里只有精品中文| 色综合久久五月色婷婷综合| 精彩视频99免费在线| 国产美女午夜福利久久| 国产精品一区二区久久久av| 久久久久久cao我的性感人妻| 中文字幕乱码av资源| 亚洲免费国产在线日韩| 国产真实乱子伦a视频| 国产在线91观看免费观看| 韩国男女黄色在线观看| 欧美成人精品在线观看| 97超碰免费在线视频| 亚洲国产精品黑丝美女| 成年人免费看在线视频| 久久亚洲天堂中文对白| caoporm超碰国产| 中文字幕 码 在线视频| 亚洲福利午夜久久久精品电影网| 在线观看免费岛国av| 成人亚洲国产综合精品| 午夜福利资源综合激情午夜福利资| 国产日韩欧美美利坚蜜臀懂色| 天天想要天天操天天干| 视频一区 二区 三区 综合| 大香蕉玖玖一区2区| 果冻传媒av一区二区三区| av网址国产在线观看| 国产综合精品久久久久蜜臀| 国产妇女自拍区在线观看| 精品一线二线三线日本| 97人妻总资源视频| 精品高跟鞋丝袜一区二区| 91九色porny国产在线| 亚洲综合在线视频可播放| 日本一二三中文字幕| 欧美在线一二三视频| 国产精品自拍偷拍a| 日韩伦理短片在线观看| 亚洲欧美一区二区三区爱爱动图| 亚洲精品乱码久久久久久密桃明| 在线免费观看靠比视频的网站| 成人久久精品一区二区三区 | 又色又爽又黄的美女裸体| 啪啪啪啪啪啪啪免费视频| 日本成人一区二区不卡免费在线| 精品高跟鞋丝袜一区二区| 黄色在线观看免费观看在线| 韩国AV无码不卡在线播放| 午夜在线精品偷拍一区二| 老师啊太大了啊啊啊尻视频| 亚洲国产免费av一区二区三区| 操操网操操伊剧情片中文字幕网| 亚洲人成精品久久久久久久| 99久久中文字幕一本人| 日本韩国免费福利精品| 又粗又硬又猛又爽又黄的| 喷水视频在线观看这里只有精品| 中文字幕乱码人妻电影| 亚洲av黄色在线网站| 亚洲无线观看国产高清在线| 在线视频免费观看网| 18禁美女黄网站色大片下载| 精品91高清在线观看| 人妻无码中文字幕专区| 亚洲av一妻不如妾| 少妇ww搡性bbb91| 在线观看欧美黄片一区二区三区| 国产在线拍揄自揄视频网站| 国产亚洲视频在线二区| 中文字幕 亚洲av| 色av色婷婷人妻久久久精品高清| 日日夜夜精品一二三| av天堂中文字幕最新| 日韩加勒比东京热二区| 老司机欧美视频在线看| 一二三中文乱码亚洲乱码one| 国产精品探花熟女在线观看| 国产高清精品极品美女| 中文字幕第1页av一天堂网| 亚洲一区二区三区五区| 午夜精品福利一区二区三区p | 青青青青青青青在线播放视频| 精彩视频99免费在线| 少妇高潮无套内谢麻豆| 在线观看911精品国产| 99热这里只有国产精品6| 人人超碰国字幕观看97| 红杏久久av人妻一区| 亚洲成人午夜电影在线观看 | 特级无码毛片免费视频播放| 亚洲欧美人精品高清| 91国内精品久久久久精品一| 午夜精品亚洲精品五月色| 欧美黄色录像免费看的| 国产污污污污网站在线| 又粗又硬又猛又爽又黄的| 男人在床上插女人视频| 日本熟妇丰满厨房55| 天天操夜夜操天天操天天操| 亚洲综合另类精品小说| 又粗又硬又猛又爽又黄的| 福利视频广场一区二区| 国产黄色a级三级三级三级| 午夜91一区二区三区| 成人H精品动漫在线无码播放| 天天日天天摸天天爱| 好男人视频在线免费观看网站| 青青在线视频性感少妇和隔壁黑丝 | 中国老熟女偷拍第一页| 97国产福利小视频合集| 丝袜亚洲另类欧美变态| 中文字幕在线观看国产片| 男女啪啪视频免费在线观看| 丝袜肉丝一区二区三区四区在线看| 熟女国产一区亚洲中文字幕| 亚洲一区二区三区五区 | 欧美成人精品欧美一级黄色| 日日夜夜精品一二三| 欧美亚洲少妇福利视频| 一区二区麻豆传媒黄片 | 激情伦理欧美日韩中文字幕| 日本a级视频老女人| 日韩av有码中文字幕| 91快播视频在线观看| 午夜在线观看岛国av,com| 男人的天堂在线黄色| 黄片大全在线观看观看| 国产午夜亚洲精品麻豆| 青青草原网站在线观看| 岛国青草视频在线观看| av手机在线免费观看日韩av| 91免费福利网91麻豆国产精品 | 综合国产成人在线观看| 国产高清在线观看1区2区| av在线播放国产不卡| 18禁精品网站久久| 亚洲的电影一区二区三区| 黄色片一级美女黄色片| AV无码一区二区三区不卡| 激情伦理欧美日韩中文字幕| 亚洲欧美色一区二区| 日本美女成人在线视频| 青青操免费日综合视频观看| 午夜国产福利在线观看| 国产日韩欧美美利坚蜜臀懂色| 极品粉嫩小泬白浆20p主播| 青青擦在线视频国产在线| 亚洲国产成人av在线一区| 一本久久精品一区二区| 成人蜜臀午夜久久一区| 日韩熟女系列一区二区三区| 欧美中国日韩久久精品| 美女张开腿让男生操在线看| 人妻av无码专区久久绿巨人| 老师让我插进去69AV| 欧美成人综合视频一区二区 | 人人妻人人爽人人澡人人精品| 好男人视频在线免费观看网站| 色偷偷伊人大杳蕉综合网| 红桃av成人在线观看| 偷拍自拍亚洲视频在线观看| 美女av色播在线播放| 天天日夜夜操天天摸| 亚洲高清国产拍青青草原| 国产精品日韩欧美一区二区| 99热这里只有国产精品6| 久草视频在线一区二区三区资源站| 午夜在线观看岛国av,com| 欧美精产国品一二三区| 青青草亚洲国产精品视频| 国产极品精品免费视频| 午夜dv内射一区区| 99久久久无码国产精品性出奶水| 男生舔女生逼逼视频| 国产精品久久综合久久| 国产麻豆精品人妻av| 亚洲欧美综合另类13p| 久久精品美女免费视频| 亚洲av日韩高清hd| 亚洲熟女女同志女同| 国产精品人妻一区二区三区网站| 天天操天天弄天天射| 黄色片黄色片wyaa| 91在线视频在线精品3| 91www一区二区三区| 在线播放 日韩 av| 日韩欧美国产一区不卡| 亚洲va天堂va国产va久| 狠狠地躁夜夜躁日日躁| 青青青艹视频在线观看| 人人妻人人澡人人爽人人dvl| 国产乱子伦一二三区| 精品91高清在线观看| 日本黄色三级高清视频| 大鸡吧插逼逼视频免费看 | 东京热男人的av天堂| 男生舔女生逼逼的视频| 中文字幕亚洲久久久| 日本性感美女视频网站| 老鸭窝在线观看一区| 日本精品美女在线观看| 最近中文2019年在线看| 国产精品探花熟女在线观看| 日韩精品中文字幕在线| 日韩av免费观看一区| 亚洲熟妇无码一区二区三区| 硬鸡巴动态操女人逼视频| 天天操天天干天天艹| 国产chinesehd精品麻豆| 2019av在线视频| 国产老熟女伦老熟妇ⅹ| av完全免费在线观看av| 国产麻豆91在线视频| 黑人解禁人妻叶爱071| 人妻爱爱 中文字幕| 91精品高清一区二区三区| 中文字幕1卡1区2区3区| 天天日天天玩天天摸| 青娱乐最新视频在线| 第一福利视频在线观看| 色综合久久久久久久久中文| 伊人精品福利综合导航| 99精品免费久久久久久久久a| 婷婷久久久综合中文字幕| 5528327男人天堂| 亚洲熟女女同志女同| 国产精品自拍视频大全| 久久这里有免费精品| 人妻少妇av在线观看| 国产精品污污污久久| 国产麻豆剧果冻传媒app| 又色又爽又黄的美女裸体| brazzers欧熟精品系列| 日韩激情文学在线视频| 亚洲欧美激情国产综合久久久 | 亚洲欧美综合另类13p| 免费人成黄页网站在线观看国产| 人妻无码色噜噜狠狠狠狠色| 9l人妻人人爽人人爽| 超级av免费观看一区二区三区| 男人操女人逼逼视频网站| 特一级特级黄色网片| 特大黑人巨大xxxx| 亚洲av一妻不如妾| 在线观看操大逼视频| 国产精品3p和黑人大战| 老司机福利精品免费视频一区二区| 欧美另类重口味极品在线观看| www,久久久,com| brazzers欧熟精品系列| 九九视频在线精品播放| 天天日天天透天天操| 18禁精品网站久久| 激情啪啪啪啪一区二区三区| 日韩一区二区三区三州| 蜜臀av久久久久蜜臀av麻豆| 国产97视频在线精品| 夜夜嗨av蜜臀av| 99久久超碰人妻国产| 久久精品亚洲成在人线a| 天天干夜夜操天天舔| 亚洲男人在线天堂网| 亚洲人妻国产精品综合| 色哟哟在线网站入口| 骚逼被大屌狂草视频免费看| 欧美精品一二三视频| 国产女人露脸高潮对白视频| 国产视频一区二区午夜| 国产片免费观看在线观看| 天天躁日日躁狠狠躁躁欧美av| 久久亚洲天堂中文对白| 色综合天天综合网国产成人| 99热99re在线播放| 欧美日本在线视频一区| 日本熟女50视频免费| 久久www免费人成一看片| 欧美中国日韩久久精品| 天天日天天添天天爽| 91国内视频在线观看| 最新国产亚洲精品中文在线| 国产精品久久久黄网站| 熟女少妇激情五十路| 中文字幕人妻一区二区视频| 黄片大全在线观看观看| 亚洲一区二区久久久人妻| 大鸡巴插入美女黑黑的阴毛| 日本av熟女在线视频| 欧美日韩激情啪啪啪| 人妻少妇一区二区三区蜜桃| 天天干天天操天天扣| 一色桃子人妻一区二区三区| 二区中出在线观看老师| 社区自拍揄拍尻屁你懂的| 香港三日本三韩国三欧美三级| 亚洲 色图 偷拍 欧美| 精品人人人妻人人玩日产欧| 久久久噜噜噜久久熟女av| 久久亚洲天堂中文对白| 在线观看免费岛国av| av亚洲中文天堂字幕网| 国产日韩av一区二区在线| 一区二区三区四区视频| 日韩中文字幕在线播放第二页| 欧美性受xx黑人性猛交| 精品美女久久久久久| 国产黄色a级三级三级三级| 大香蕉伊人中文字幕| 亚洲va国产va欧美va在线| 天天干天天搞天天摸| 熟女国产一区亚洲中文字幕| 青春草视频在线免费播放| 亚洲Av无码国产综合色区| 999久久久久999| 国产极品精品免费视频| 国产精品视频资源在线播放| 黄色片黄色片wyaa| japanese日本熟妇另类| 国产三级精品三级在线不卡| weyvv5国产成人精品的视频| 人人超碰国字幕观看97| 东京干手机福利视频| 午夜激情精品福利视频| 天天干天天搞天天摸| 777奇米久久精品一区| 成年人午夜黄片视频资源| 亚洲伊人色一综合网| 色呦呦视频在线观看视频| 国产精品免费不卡av| 中文字幕日韩精品就在这里| 久久精品在线观看一区二区|