国产无遮挡裸体免费直播视频,久久精品国产蜜臀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)論

国产黄网站在线观看播放| 欧美日韩不卡一区不区二区| 人妻少妇性色欲欧美日韩| www日韩a级s片av| 性感美女高潮视频久久久| 人妻久久无码中文成人| 国产女孩喷水在线观看| 亚洲中文字幕国产日韩| 欧美日韩人妻久久精品高清国产| 国产一区二区火爆视频| 成人av免费不卡在线观看| 亚洲精品国产久久久久久| 久久麻豆亚洲精品av| 国产日韩av一区二区在线| 日本欧美视频在线观看三区| 国产女人露脸高潮对白视频| 亚洲av自拍偷拍综合| 天堂av在线官网中文| 狠狠躁夜夜躁人人爽天天久天啪| 亚洲欧美清纯唯美另类| 中文字幕日韩精品就在这里| 欧美成人黄片一区二区三区| 亚洲最大免费在线观看| 亚洲免费国产在线日韩| 视频一区二区在线免费播放| 91久久精品色伊人6882| 在线国产精品一区二区三区| 狠狠躁夜夜躁人人爽天天久天啪| 亚洲欧美激情人妻偷拍| 天天干天天搞天天摸| 欧美aa一级一区三区四区| 在线观看欧美黄片一区二区三区| 欧美色婷婷综合在线| 丝袜长腿第一页在线| 97青青青手机在线视频 | 人妻少妇精品久久久久久| 国产亚洲视频在线二区| 任你操视频免费在线观看| 人妻少妇中文有码精品| 成人伊人精品色xxxx视频| 亚洲va天堂va国产va久| 亚洲国产免费av一区二区三区| 四川乱子伦视频国产vip| 传媒在线播放国产精品一区| 中文字幕熟女人妻久久久| 婷婷综合亚洲爱久久| 国产真实灌醉下药美女av福利| 97人妻无码AV碰碰视频| 成人高潮aa毛片免费| 晚上一个人看操B片| 中文字幕+中文字幕| 超碰在线观看免费在线观看| 日韩熟女av天堂系列| 深夜男人福利在线观看| 精品国产污污免费网站入口自| 国产亚洲欧美45p| 午夜婷婷在线观看视频| 水蜜桃一区二区三区在线观看视频| 这里只有精品双飞在线播放| 亚洲综合在线观看免费| 欧美80老妇人性视频| 中文字幕第一页国产在线| 青青青视频自偷自拍38碰| 亚洲av黄色在线网站| 中文字幕网站你懂的| 人妻少妇中文有码精品| 伊人综合免费在线视频| 日日日日日日日日夜夜夜夜夜夜| 国产美女精品福利在线| 白嫩白嫩美女极品国产在线观看| 国产普通话插插视频| 99精品免费观看视频| 大香蕉大香蕉在线有码 av| 国产午夜亚洲精品麻豆| 日韩美女综合中文字幕pp| 专门看国产熟妇的网站| 天天干天天操天天扣| 日本xx片在线观看| brazzers欧熟精品系列| 亚洲男人让女人爽的视频| 国产亚洲欧美45p| 1000部国产精品成人观看视频| 日本阿v视频在线免费观看| 日韩欧美一级aa大片| 在线观看av2025| 欧美一区二区三区乱码在线播放| 一二三区在线观看视频| 日本少妇人妻xxxxx18| 91老熟女连续高潮对白| 五十路熟女人妻一区二区9933| 黑人变态深video特大巨大| 97香蕉碰碰人妻国产樱花| 超碰公开大香蕉97| 黄色片一级美女黄色片| 91精品国产91青青碰| 久久这里只有精彩视频免费| 国产黄色a级三级三级三级| 在线播放一区二区三区Av无码| 777奇米久久精品一区| 传媒在线播放国产精品一区| aaa久久久久久久久| 婷婷六月天中文字幕| 自拍偷拍亚洲另类色图| 美女福利视频导航网站| 啊啊啊视频试看人妻| 国产1区,2区,3区| 又色又爽又黄的美女裸体| 国产 在线 免费 精品| 91人妻精品一区二区在线看| 亚洲少妇人妻无码精品| 亚洲男人让女人爽的视频| 国产又色又刺激在线视频 | 蝴蝶伊人久久中文娱乐网| 国产精品久久久久久久女人18| 在线免费观看靠比视频的网站| 久久香蕉国产免费天天| 日本高清撒尿pissing| 一区二区三区欧美日韩高清播放| 亚洲欧美福利在线观看| 2020久久躁狠狠躁夜夜躁| av在线资源中文字幕| 亚洲 欧美 精品 激情 偷拍| 亚洲护士一区二区三区| 丝袜国产专区在线观看| 加勒比视频在线免费观看| 偷拍自拍 中文字幕| 日韩中文字幕精品淫| 又黄又刺激的午夜小视频| 日本后入视频在线观看| 亚洲粉嫩av一区二区三区| 久久精品国产23696| 免费看国产又粗又猛又爽又黄视频| 国产91嫩草久久成人在线视频| 国产视频网站一区二区三区| 馒头大胆亚洲一区二区| 午夜久久香蕉电影网| 国产之丝袜脚在线一区二区三区 | 国内自拍第一页在线观看| 亚洲av天堂在线播放| 亚洲欧美清纯唯美另类| 青青擦在线视频国产在线| 国产精品中文av在线播放| 日本18禁久久久久久| 国产精品久久9999| 一区二区三区的久久的蜜桃的视频| 日本熟妇喷水xxx| 国产剧情演绎系列丝袜高跟| 9国产精品久久久久老师| 国产精品久久综合久久| 中文字幕在线观看极品视频| 中文字幕日本人妻中出| 欧美一区二区三区久久久aaa| 人人妻人人人操人人人爽| 天天草天天色天天干| 免费在线黄色观看网站| 天天爽夜夜爽人人爽QC| 欧美另类一区二区视频| 精品av国产一区二区三区四区| 日韩av有码一区二区三区4| 自拍偷拍亚洲精品第2页| 色综合久久久久久久久中文| 51国产成人精品视频| 92福利视频午夜1000看| 亚洲无线观看国产高清在线| 亚洲成高清a人片在线观看| 精品国产在线手机在线| av成人在线观看一区| 日本高清在线不卡一区二区| 精品久久久久久久久久久久人妻| 亚洲国产最大av综合| 色综合色综合色综合色| 欧美久久一区二区伊人| 亚洲中文字幕国产日韩| 快点插进来操我逼啊视频| 男女啪啪视频免费在线观看| 揄拍成人国产精品免费看视频| 97黄网站在线观看| 欧美日韩不卡一区不区二区| 91麻豆精品91久久久久同性 | 99热久久极品热亚洲| 亚洲国产欧美一区二区三区久久| 欧美黄片精彩在线免费观看| 东游记中文字幕版哪里可以看到| 同居了嫂子在线播高清中文| brazzers欧熟精品系列| 亚洲人妻国产精品综合| 岛国一区二区三区视频在线| 国产女孩喷水在线观看| 久久精品国产亚洲精品166m| 超碰公开大香蕉97| 大陆胖女人与丈夫操b国语高清| 精品91自产拍在线观看一区| 成人30分钟免费视频| 香蕉91一区二区三区| 又粗又硬又猛又黄免费30| 天天日天天舔天天射进去| 大香蕉日本伊人中文在线| 性感美女福利视频网站| 久久久久久cao我的性感人妻| 天天插天天狠天天操| 中文字幕一区二区三区人妻大片| 青青草在观免费国产精品| 18禁无翼鸟成人在线| 久久农村老妇乱69系列| 久久久久久性虐视频| 麻豆性色视频在线观看| 综合精品久久久久97| 爆乳骚货内射骚货内射在线 | 激情五月婷婷免费视频| 91福利在线视频免费观看| chinese国产盗摄一区二区| 在线视频免费观看网| 91免费放福利在线观看| 免费无码人妻日韩精品一区二区| 午夜精品福利91av| 午夜美女福利小视频| 巨乳人妻日下部加奈被邻居中出| 任我爽精品视频在线播放| 国产精品三级三级三级| 中文字幕+中文字幕| 动色av一区二区三区| 一区二区免费高清黄色视频| 一级a看免费观看网站| 久久久久久9999久久久久| 91亚洲国产成人精品性色| 黑人巨大的吊bdsm| 9国产精品久久久久老师| 免费在线观看污污视频网站| 黑人乱偷人妻中文字幕| 在线观看国产免费麻豆| 中文字幕日韩人妻在线三区| 欧美激情电影免费在线| av天堂中文免费在线| 100%美女蜜桃视频| 激情五月婷婷综合色啪| 欧美老妇精品另类不卡片| 日韩午夜福利精品试看| 国产一区二区三免费视频| 亚洲专区激情在线观看视频| 亚洲国产美女一区二区三区软件 | 啪啪啪18禁一区二区三区| 色天天天天射天天舔| 国产欧美日韩在线观看不卡| 亚洲一区二区久久久人妻| 久久丁香婷婷六月天| 国产成人一区二区三区电影网站| chinese国产盗摄一区二区| 国产chinesehd精品麻豆| 亚洲av日韩av网站| 日韩人妻在线视频免费| 亚洲在线一区二区欧美| 天天摸天天日天天操| 亚洲人妻国产精品综合| 中文字幕—97超碰网| brazzers欧熟精品系列| 日本少妇在线视频大香蕉在线观看 | 偷拍自拍视频图片免费| 亚洲乱码中文字幕在线| 999久久久久999| 国产乱弄免费视频观看| 亚洲精品精品国产综合| 这里有精品成人国产99| 狠狠操操操操操操操操操| av欧美网站在线观看| 91国产在线视频免费观看| 2025年人妻中文字幕乱码在线| 在线观看日韩激情视频| 亚洲一区二区三区五区| 黄网十四区丁香社区激情五月天| 亚洲伊人色一综合网| 亚洲成av人无码不卡影片一| 中文字幕+中文字幕| 91传媒一区二区三区| 欧美精品黑人性xxxx| 亚洲欧美激情国产综合久久久 | 直接观看免费黄网站| 日韩欧美中文国产在线| 亚洲色偷偷综合亚洲AV伊人| 端庄人妻堕落挣扎沉沦| 大学生A级毛片免费视频| 中文字幕无码日韩专区免费| 欧美少妇性一区二区三区| 午夜美女少妇福利视频| 91欧美在线免费观看| 9l人妻人人爽人人爽| 老司机免费福利视频网| 扒开让我视频在线观看| 中文字幕在线免费第一页| 国产超码片内射在线| 精品视频一区二区三区四区五区| 亚洲人妻视频在线网| 日韩精品中文字幕福利| 精品黑人一区二区三区久久国产| 午夜免费体验区在线观看| 99一区二区在线观看| 2021年国产精品自拍| 成人激情文学网人妻| jiuse91九色视频| 欧美成人精品欧美一级黄色| 亚国产成人精品久久久| 五月天色婷婷在线观看视频免费| 国产视频网站一区二区三区| 国产精品久久9999| 91欧美在线免费观看| 青青草亚洲国产精品视频| 亚洲成人av一区在线| 国产使劲操在线播放| 99热久久这里只有精品| 中文字幕在线一区精品| chinese国产盗摄一区二区| 日本脱亚入欧是指什么| rct470中文字幕在线| 福利午夜视频在线合集| 成人H精品动漫在线无码播放| 亚洲综合乱码一区二区| 99re6热在线精品| 美女在线观看日本亚洲一区| 国产麻豆剧果冻传媒app| 国产精品久久久久网| 91精品综合久久久久3d动漫| 成熟丰满熟妇高潮xx×xx| 日韩二区视频一线天婷婷五| 亚洲精品高清自拍av| 国产一级精品综合av| 日本韩国亚洲综合日韩欧美国产| 一区二区三区四区视频在线播放| 激情啪啪啪啪一区二区三区| 日韩剧情片电影在线收看| 亚洲综合在线视频可播放| 精品人妻伦一二三区久 | 精品人妻一二三区久久| 黄色大片男人操女人逼| 欧美综合婷婷欧美综合| 自拍偷拍日韩欧美一区二区| 国产成人无码精品久久久电影 | 中文字幕在线观看极品视频| 91社福利《在线观看| 亚洲精品色在线观看视频| 久久热久久视频在线观看| 中国熟女一区二区性xx| 国产黄色高清资源在线免费观看| 亚洲欧美另类自拍偷拍色图| 夏目彩春在线中文字幕| 国产麻豆乱子伦午夜视频观看| 欧美黑人与人妻精品| 成人蜜桃美臀九一一区二区三区| 青青操免费日综合视频观看| 91麻豆精品久久久久| 中文字幕国产专区欧美激情| 亚洲老熟妇日本老妇| 国产伊人免费在线播放| 99精品久久久久久久91蜜桃| 午夜久久香蕉电影网| 精品av久久久久久久| av中文字幕网址在线| okirakuhuhu在线观看| 青青青视频自偷自拍38碰| 青娱乐蜜桃臀av色| 日本后入视频在线观看| 欧洲亚洲欧美日韩综合| 91一区精品在线观看| 伊人日日日草夜夜草| 福利一二三在线视频观看| 最新中文字幕乱码在线| 久草视频中文字幕在线观看| 国产精品久久综合久久| 日本美女成人在线视频| 成年人黄色片免费网站| 超碰中文字幕免费观看| 性色av一区二区三区久久久| 国产精品女邻居小骚货| 老司机福利精品视频在线| 久久久久久久99精品| 免费成人va在线观看| 久久久久久9999久久久久| 2020国产在线不卡视频| 99国内精品永久免费视频| 中文字幕熟女人妻久久久| 热思思国产99re| 蜜桃专区一区二区在线观看| 国产免费高清视频视频| 男人的天堂一区二区在线观看| 99久久中文字幕一本人| 一区二区三区av高清免费| 天干天天天色天天日天天射| sejizz在线视频| 五色婷婷综合狠狠爱| 大鸡巴后入爆操大屁股美女| 欧美视频不卡一区四区| 97人人模人人爽人人喊| 国产精品久久久久久久精品视频| 亚洲久久午夜av一区二区| 国产黑丝高跟鞋视频在线播放| 日本脱亚入欧是指什么| 欧美日韩国产一区二区三区三州| 大鸡巴操娇小玲珑的女孩逼| 日本熟妇喷水xxx| 日韩人妻xxxxx| 天天日天天干天天要| 人妻无码中文字幕专区| 91成人精品亚洲国产| 免费黄高清无码国产| 欧美精品久久久久久影院| 国产午夜亚洲精品麻豆| 婷婷六月天中文字幕| 性色蜜臀av一区二区三区| 色在线观看视频免费的| 日本人妻少妇18—xx| 特黄老太婆aa毛毛片| 国产亚洲四十路五十路| 激情国产小视频在线| 色哟哟国产精品入口| 中文字幕人妻被公上司喝醉在线| 综合色区亚洲熟妇shxstz| 天天日天天日天天射天天干| 国产在线观看免费人成短视频| 日韩欧美中文国产在线| 久久久麻豆精亚洲av麻花| 日本少妇的秘密免费视频| 经典亚洲伊人第一页| 91精品国产观看免费| 福利视频网久久91| 夜夜骑夜夜操夜夜奸| 粉嫩欧美美人妻小视频| 男女之间激情网午夜在线| 懂色av蜜桃a v| rct470中文字幕在线| 一区二区三区蜜臀在线| 精品suv一区二区69| 免费人成黄页网站在线观看国产| 性色av一区二区三区久久久| 女同互舔一区二区三区| 中文字幕一区二区三区人妻大片| 粉嫩av蜜乳av蜜臀| 超碰在线中文字幕一区二区| 日韩精品啪啪视频一道免费| 青草亚洲视频在线观看| 偷拍美女一区二区三区| 国产美女午夜福利久久| 日韩成人性色生活片| 欧美一区二区中文字幕电影| 熟女在线视频一区二区三区| 欧美viboss性丰满| 大屁股熟女一区二区三区| 亚洲综合在线视频可播放| 亚欧在线视频你懂的| 日韩人妻xxxxx| 久久麻豆亚洲精品av| 精品欧美一区二区vr在线观看 | 国产又粗又硬又大视频| 好吊视频—区二区三区| 三上悠亚和黑人665番号| 大胸性感美女羞爽操逼毛片| 亚洲国产成人最新资源| 中文字幕网站你懂的| 黄色成人在线中文字幕| 啊啊啊视频试看人妻| 日韩av有码中文字幕| 中文字幕一区二区亚洲一区| 亚洲国际青青操综合网站| 天堂av中文在线最新版| 亚洲国产在线精品国偷产拍| 大陆精品一区二区三区久久| 免费看国产又粗又猛又爽又黄视频| 5528327男人天堂| 瑟瑟视频在线观看免费视频| 孕妇奶水仑乱A级毛片免费看| 9l人妻人人爽人人爽| 女生被男生插的视频网站| 亚洲精品 日韩电影| 国产熟妇乱妇熟色T区| 男人和女人激情视频| 抽查舔水白紧大视频| 亚洲蜜臀av一区二区三区九色| 午夜大尺度无码福利视频| 青春草视频在线免费播放| 国产一区二区视频观看| 乱亲女秽乱长久久久| 在线观看av亚洲情色| 特级欧美插插插插插bbbbb| 国产日韩精品免费在线| 欧美80老妇人性视频| 100%美女蜜桃视频| 国产亚洲国产av网站在线| 国产精品自偷自拍啪啪啪| aⅴ精产国品一二三产品| 人妻无码色噜噜狠狠狠狠色| 亚洲欧美激情中文字幕| 5528327男人天堂| 亚洲欧洲av天堂综合| 黑人3p华裔熟女普通话| 国产精品自拍偷拍a| 欧美在线偷拍视频免费看| 丰满少妇翘臀后进式| 2021年国产精品自拍| 国产综合高清在线观看| 青青草原网站在线观看| 91精品国产高清自在线看香蕉网| 91精品国产观看免费| 九一传媒制片厂视频在线免费观看| 欧美成人精品欧美一级黄色| 国产黄色a级三级三级三级| 91av中文视频在线| 91小伙伴中女熟女高潮| 毛片av在线免费看| 精品一区二区亚洲欧美| 亚洲高清国产拍青青草原| 这里有精品成人国产99| 国产精品黄色的av| 日韩av熟妇在线观看| 18禁网站一区二区三区四区| 好吊操视频这里只有精品| 在线免费观看视频一二区| 亚洲午夜电影在线观看| 国产视频一区在线观看| 青青热久免费精品视频在线观看| 护士特殊服务久久久久久久| 男女啪啪视频免费在线观看| 91麻豆精品91久久久久同性| 午夜精品福利91av| 天天日天天鲁天天操| 天天日天天日天天擦| 91精品综合久久久久3d动漫| 在线免费观看av日韩| 久草视频 久草视频2| 一区二区视频在线观看视频在线| 视频一区 视频二区 视频| 亚洲成av人无码不卡影片一| 欧亚日韩一区二区三区观看视频 | 99热久久这里只有精品8| 91社福利《在线观看| 久久这里只有精彩视频免费| 人妻少妇亚洲精品中文字幕| 天天日天天透天天操| 五月激情婷婷久久综合网| 人妻激情图片视频小说| 欧美日韩人妻久久精品高清国产| 国产又粗又硬又猛的毛片视频| 天天日天天操天天摸天天舔| 免费在线观看视频啪啪| 99精品视频在线观看免费播放| 免费国产性生活视频| 免费啪啪啪在线观看视频| 伊人网中文字幕在线视频| 亚洲麻豆一区二区三区| 岛国毛片视频免费在线观看| 在线免费91激情四射| 亚洲欧美精品综合图片小说 | 精品一区二区三区三区88 | 国产大鸡巴大鸡巴操小骚逼小骚逼| 9色在线视频免费观看| 好男人视频在线免费观看网站| 91大神福利视频网| 日本成人不卡一区二区| 绝色少妇高潮3在线观看| 日本少妇人妻xxxxxhd| 18禁免费av网站| 2020久久躁狠狠躁夜夜躁 | 国产一区成人在线观看视频| 日韩美女精品视频在线观看网站 | 中文字幕乱码人妻电影| 熟女少妇激情五十路| 黄色男人的天堂视频| 人妻少妇av在线观看| 亚洲国产成人最新资源| av中文字幕国产在线观看| 亚洲精品av在线观看| 久久精品国产亚洲精品166m| 国产欧美日韩第三页| 毛片av在线免费看| 天天干天天插天天谢| 鸡巴操逼一级黄色气| 精品国产亚洲av一淫| 天天干天天操天天爽天天摸| 国产91精品拍在线观看| 99精品视频在线观看婷婷| 高清一区二区欧美系列| 亚洲福利精品福利精品福利| 极品丝袜一区二区三区| 日本三极片视频网站观看| 一区二区视频在线观看视频在线| 一区二区三区精品日本| ka0ri在线视频| 亚洲精品无码久久久久不卡| 久久久久久久久久性潮| 亚洲一级 片内射视正片| 天天插天天狠天天操| 免费国产性生活视频| 夜夜操,天天操,狠狠操| 大鸡巴操b视频在线| 99精品视频在线观看免费播放| 五十路老熟女码av| 精品黑人一区二区三区久久国产 | 农村胖女人操逼视频| 日辽宁老肥女在线观看视频| 亚洲国产成人最新资源| av网址国产在线观看| 日本韩国免费一区二区三区视频| 天堂中文字幕翔田av| 在线观看免费岛国av| 精品成人午夜免费看| 青青青青爽手机在线| 欧美精品伦理三区四区| 99热久久这里只有精品| 亚洲粉嫩av一区二区三区| 1769国产精品视频免费观看| 91九色porny国产蝌蚪视频| 国产无遮挡裸体免费直播视频| 91久久人澡人人添人人爽乱| 人妻在线精品录音叫床| 丝袜美腿视频诱惑亚洲无| 夜色撩人久久7777| 国产又粗又猛又爽又黄的视频美国| 人妻熟女中文字幕aⅴ在线| 人人妻人人人操人人人爽| 黄色资源视频网站日韩| 最新中文字幕免费视频| 在线观看视频 你懂的| 日韩欧美亚洲熟女人妻| 亚洲av黄色在线网站| 亚洲一区二区三区久久受| 福利午夜视频在线观看| av黄色成人在线观看| 欧美天堂av无线av欧美| 日本高清在线不卡一区二区| 日韩亚洲高清在线观看| 美女张开腿让男生操在线看| 一二三中文乱码亚洲乱码one| 欧美精品中文字幕久久二区| 涩涩的视频在线观看视频| 在线视频免费观看网| 57pao国产一区二区| av乱码一区二区三区| 青娱乐蜜桃臀av色| 亚洲日本一区二区三区 | 小穴多水久久精品免费看| 91亚洲手机在线视频播放| 老熟妇xxxhd老熟女| 91she九色精品国产| 天天操夜夜操天天操天天操| 人妻丝袜榨强中文字幕| 黑人性生活视频免费看| 午夜福利人人妻人人澡人人爽| 97精品人妻一区二区三区精品| 亚洲成人午夜电影在线观看| www骚国产精品视频| 久草电影免费在线观看| 在线观看视频一区麻豆| 国产+亚洲+欧美+另类| 肏插流水妹子在线乐播下载| 韩国黄色一级二级三级| 91人妻精品一区二区久久| 黄色视频成年人免费观看| 97人妻总资源视频| 亚洲激情,偷拍视频| 一区二区视频在线观看免费观看 | 亚洲区美熟妇久久久久| 国产高清精品极品美女| 精品乱子伦一区二区三区免费播| 最近中文2019年在线看| 淫秽激情视频免费观看| 老师啊太大了啊啊啊尻视频| 国产黄网站在线观看播放| 91中文字幕最新合集| 精品一区二区三区三区色爱| 蜜桃久久久久久久人妻| 在线观看视频一区麻豆| 人人超碰国字幕观看97| 欧美日韩不卡一区不区二区| 91福利在线视频免费观看| 天天日夜夜干天天操| 天天躁夜夜躁日日躁a麻豆| 狠狠嗨日韩综合久久| 午夜精品久久久久麻豆影视| 午夜国产福利在线观看| 唐人色亚洲av嫩草| 又大又湿又爽又紧A视频| 孕妇奶水仑乱A级毛片免费看| 亚洲成人熟妇一区二区三区 | 又黄又刺激的午夜小视频| 日本韩国在线观看一区二区| AV天堂一区二区免费试看| 黄色男人的天堂视频| 国产真实灌醉下药美女av福利| 亚洲成人三级在线播放| 91she九色精品国产| eeuss鲁片一区二区三区| 人妻爱爱 中文字幕| 狠狠操操操操操操操操操| 日本免费视频午夜福利视频| 97青青青手机在线视频 | chinese国产盗摄一区二区| 中文字幕一区的人妻欧美日韩| 成人av亚洲一区二区| 亚洲护士一区二区三区| 美女福利写真在线观看视频| 欧美精品激情在线最新观看视频| 丰满的子国产在线观看| 日日夜夜狠狠干视频| 福利视频一区二区三区筱慧| 亚洲的电影一区二区三区| 91麻豆精品久久久久| 午夜精品久久久久麻豆影视| 国产视频网站一区二区三区 | 中文字幕乱码人妻电影| 99re久久这里都是精品视频| 六月婷婷激情一区二区三区| 激情啪啪啪啪一区二区三区 | 哥哥姐姐综合激情小说| 青青草成人福利电影| 性感美女高潮视频久久久| 丝袜肉丝一区二区三区四区在线| 成人av天堂丝袜在线观看 | 老司机免费福利视频网| 人妻丰满熟妇综合网| 国产精品久久久久网| 一区二区三区日韩久久| 成年人黄视频在线观看| 伊人情人综合成人久久网小说| 精品一区二区三区欧美| 日韩精品中文字幕播放| 91免费黄片可看视频| ka0ri在线视频| 狠狠嗨日韩综合久久| 亚洲一区二区三区五区| 欧美日韩熟女一区二区三区| 一级a看免费观看网站| 亚洲无码一区在线影院| 视频久久久久久久人妻| 中文字幕在线欧美精品| 男人操女人逼逼视频网站| 日本熟妇色熟妇在线观看| 婷婷久久久久深爱网| 亚洲自拍偷拍综合色| 欧美男人大鸡吧插女人视频| 国产综合视频在线看片| 91老师蜜桃臀大屁股| 欧美黑人性猛交xxxxⅹooo| 亚洲精品乱码久久久本| 男生用鸡操女生视频动漫| 青娱乐在线免费视频盛宴| 播放日本一区二区三区电影| 青青青青青免费视频| 丝袜国产专区在线观看| 亚洲精品一区二区三区老狼| 亚洲第一黄色在线观看| 国产在线观看黄色视频| 欧美成人精品欧美一级黄色| 天天做天天干天天操天天射| 天天干天天搞天天摸| 人妻久久久精品69系列| 久久艹在线观看视频| 久久艹在线观看视频| 欧美成人一二三在线网| 亚洲 中文 自拍 无码| 精品91高清在线观看| 国产女孩喷水在线观看| 久久久噜噜噜久久熟女av| 日本女大学生的黄色小视频| 激情综合治理六月婷婷| 亚洲最大黄了色网站| 亚洲福利午夜久久久精品电影网| 国产三级片久久久久久久| 男女之间激情网午夜在线| 在线免费观看视频一二区| 欧美亚洲中文字幕一区二区三区| 日本免费视频午夜福利视频| 国产大鸡巴大鸡巴操小骚逼小骚逼 | 欧美亚洲自偷自拍 在线| aaa久久久久久久久| 日本av熟女在线视频| 91免费观看在线网站| 国产一区二区火爆视频| 1区2区3区不卡视频| 欧美日韩国产一区二区三区三州| 狍和女人的王色毛片| aiss午夜免费视频| 青青青艹视频在线观看| 视频 一区二区在线观看| 国产夫妻视频在线观看免费| 亚洲成人激情视频免费观看了| 亚洲精品色在线观看视频| 欧美 亚洲 另类综合| 日韩欧美国产精品91| 亚洲精品色在线观看视频| 日韩av免费观看一区| 性欧美日本大妈母与子| 亚洲熟妇无码一区二区三区| 亚洲综合另类欧美久久| 欧美成人精品在线观看| 久久农村老妇乱69系列| 免费无毒热热热热热热久| av一区二区三区人妻| 摧残蹂躏av一二三区| 区一区二区三国产中文字幕| www天堂在线久久| 亚洲中文字幕国产日韩| 天堂va蜜桃一区入口| 久久尻中国美女视频| 亚洲va欧美va人人爽3p| mm131美女午夜爽爽爽| 熟女人妻在线中出观看完整版| 天天干天天插天天谢| 亚洲一区二区三区在线高清| 熟女视频一区,二区,三区| 日本五十路熟新垣里子| 亚洲国产最大av综合| 国产日韩精品免费在线| 欧美精产国品一二三产品区别大吗| 天天色天天操天天透| 免费男阳茎伸入女阳道视频| 高潮喷水在线视频观看| 国产熟妇乱妇熟色T区| 一区二区三区欧美日韩高清播放| 国产va精品免费观看| 亚洲的电影一区二区三区 | 国产美女午夜福利久久| 欧美成人一二三在线网| 亚洲人一区二区中文字幕| 欧美伊人久久大香线蕉综合| 亚洲美女美妇久久字幕组| 亚洲精品一区二区三区老狼| 男人靠女人的逼视频| 青青热久免费精品视频在线观看| 啪啪啪操人视频在线播放| 欧美成人黄片一区二区三区 | 人妻无码色噜噜狠狠狠狠色| 亚洲av极品精品在线观看| 天天干天天日天天谢综合156| 538精品在线观看视频| 欧美亚洲国产成人免费在线| 色婷婷六月亚洲综合香蕉| 无码日韩人妻精品久久| 97精品综合久久在线| 亚洲av香蕉一区区二区三区犇| 夜夜嗨av一区二区三区中文字幕| 晚上一个人看操B片| 亚洲 中文 自拍 无码| 国产精品视频资源在线播放 | 黑人3p华裔熟女普通话| 国产精品一区二区久久久av| 51国产成人精品视频| 超黄超污网站在线观看| 亚洲伊人久久精品影院一美女洗澡 | 欧美日韩v中文在线| 日本www中文字幕| 亚洲欧美成人综合视频| 午夜91一区二区三区| 100%美女蜜桃视频| 国产精品伦理片一区二区| 中文字幕成人日韩欧美| 免费一级黄色av网站| 日韩三级黄色片网站| 日本成人不卡一区二区| 亚洲视频乱码在线观看| 人妻丝袜榨强中文字幕| 久久精品国产亚洲精品166m| 超碰公开大香蕉97| 在线网站你懂得老司机| 五月天久久激情视频| 黑人性生活视频免费看| 任你操视频免费在线观看| 久久尻中国美女视频| 人妻久久久精品69系列| 亚洲欧洲一区二区在线观看| 涩爱综合久久五月蜜臀| 精品亚洲国产中文自在线| 高潮喷水在线视频观看| 91精品视频在线观看免费| 午夜成午夜成年片在线观看 | 日本啪啪啪啪啪啪啪| 老司机免费视频网站在线看| 中文字幕在线观看国产片| 欧亚乱色一区二区三区| 日韩激情文学在线视频| 很黄很污很色的午夜网站在线观看| 天天色天天操天天透| 首之国产AV医生和护士小芳| 国产精品熟女久久久久浪潮| 偷拍自拍亚洲美腿丝袜| 国产麻豆国语对白露脸剧情| 欧美日韩不卡一区不区二区| 熟女国产一区亚洲中文字幕| 中文字幕 人妻精品| 伊人精品福利综合导航| 日本人妻精品久久久久久| 亚洲中文字幕国产日韩| 人人人妻人人澡人人| 日韩三级黄色片网站| 久久久久久国产精品| 18禁网站一区二区三区四区| 孕妇奶水仑乱A级毛片免费看 | 大香蕉大香蕉大香蕉大香蕉大香蕉 | 亚洲伊人色一综合网| 任我爽精品视频在线播放| 人人在线视频一区二区| 98精产国品一二三产区区别| 很黄很污很色的午夜网站在线观看 | 亚洲免费视频欧洲免费视频| 欧美成人黄片一区二区三区 | 亚洲推理片免费看网站| 91综合久久亚洲综合| 免费岛国喷水视频在线观看| 天天操夜夜骑日日摸| 亚洲另类图片蜜臀av| 国产免费高清视频视频| 91社福利《在线观看| 日本最新一二三区不卡在线| 午夜在线精品偷拍一区二| 社区自拍揄拍尻屁你懂的| 中文字幕第三十八页久久| 青春草视频在线免费播放| 天天色天天爱天天爽| 免费69视频在线看| 欧美亚洲牲夜夜综合久久| 一区二区在线观看少妇| 99热久久这里只有精品8| 人妻无码色噜噜狠狠狠狠色| 最近中文2019年在线看| 国产无遮挡裸体免费直播视频| 日本熟妇色熟妇在线观看| 国产黄色大片在线免费播放| 在线国产中文字幕视频| 100%美女蜜桃视频| gogo国模私拍视频| yellow在线播放av啊啊啊| 沙月文乃人妻侵犯中文字幕在线| 北条麻妃肉色丝袜视频| 欧美天堂av无线av欧美| 特黄老太婆aa毛毛片| 中文字幕熟女人妻久久久| 日本免费午夜视频网站| 成人性爱在线看四区| 亚洲激情唯美亚洲激情图片| 欧美国品一二三产区区别| 国产日本精品久久久久久久| 91久久人澡人人添人人爽乱| 午夜久久香蕉电影网| 麻豆精品成人免费视频| 久久久久五月天丁香社区| 2020中文字幕在线播放| 国产亚洲视频在线观看| 免费看国产av网站| 国产品国产三级国产普通话三级| 亚洲一区自拍高清免费视频| 偷偷玩弄新婚人妻h视频| 色av色婷婷人妻久久久精品高清| 免费无码人妻日韩精品一区二区| 91天堂天天日天天操| 日韩欧美一级精品在线观看| 中文字幕日韩精品日本| 青娱乐在线免费视频盛宴| 中文字幕在线观看国产片| 亚洲女人的天堂av| 亚洲av一妻不如妾| 人妻av无码专区久久绿巨人| 亚洲精品国品乱码久久久久 | 亚洲欧美人精品高清| 亚洲一区二区三区久久受| 日韩中文字幕精品淫| 午夜大尺度无码福利视频| 婷婷六月天中文字幕| 亚洲天堂精品福利成人av| 天天做天天干天天操天天射| 亚洲少妇高潮免费观看| 国产成人精品一区在线观看| 国产黄色片在线收看| 一区二区三区日韩久久| 国产露脸对白在线观看| 免费手机黄页网址大全| 亚洲少妇高潮免费观看| 天天色天天操天天透| 五十路在线观看完整版| 欧美激情电影免费在线| 亚洲精品麻豆免费在线观看| 日本少妇人妻xxxxx18| 九色porny九色9l自拍视频| 中文字幕网站你懂的| 性色av一区二区三区久久久| 久久久久久99国产精品| 精彩视频99免费在线| 激情伦理欧美日韩中文字幕 | 视频二区在线视频观看| 男人的网址你懂的亚洲欧洲av| 中文字幕 码 在线视频| 亚洲欧美成人综合视频| 免费黄页网站4188| 欧美va不卡视频在线观看| 亚洲特黄aaaa片| 91成人精品亚洲国产| 最新黄色av网站在线观看| 亚洲av自拍天堂网| 亚洲第一伊人天堂网| 2020韩国午夜女主播在线| 丰满的子国产在线观看| 加勒比视频在线免费观看| 欧美香蕉人妻精品一区二区| 无套猛戳丰满少妇人妻| 亚洲少妇人妻无码精品| 中文字幕 人妻精品| 亚洲精品国产久久久久久| 全国亚洲男人的天堂| 成人av电影免费版| 国产亚洲成人免费在线观看| 在线观看911精品国产| 在线免费观看黄页视频| 鸡巴操逼一级黄色气| 黄色视频成年人免费观看| 桃色视频在线观看一区二区| 国产一区二区三免费视频| 日韩近亲视频在线观看| 无码日韩人妻精品久久| 成年人黄色片免费网站| 日美女屁股黄邑视频| 91香蕉成人app下载| 亚洲国产香蕉视频在线播放| 黑人性生活视频免费看| 99热久久极品热亚洲| 午夜激情久久不卡一区二区 | 天天干天天操天天玩天天射| 午夜精品亚洲精品五月色| 亚洲激情偷拍一区二区| 日韩三级电影华丽的外出| 天天摸天天亲天天舔天天操天天爽 | 亚洲精品国产久久久久久| 在线观看av观看av| 青青青青青青草国产| 91老师蜜桃臀大屁股| 亚洲熟女女同志女同| 中文字幕之无码色多多| 熟女妇女老妇一二三区| 中文字幕中文字幕 亚洲国产| 欧美黑人性猛交xxxxⅹooo| 91she九色精品国产| 日韩欧美中文国产在线 | 亚洲一区二区三区uij| 精品人人人妻人人玩日产欧| 啊慢点鸡巴太大了啊舒服视频| 国产97视频在线精品| 经典av尤物一区二区| 亚洲视频乱码在线观看| 一区二区三区四区视频在线播放| 边摸边做超爽毛片18禁色戒 | 男人插女人视频网站| 国产精品探花熟女在线观看| 午夜精品九一唐人麻豆嫩草成人| 天天操,天天干,天天射| 免费手机黄页网址大全| 天天日天天敢天天干| 国产精品福利小视频a| 超碰97人人澡人人| 亚洲精品午夜久久久久| 亚洲午夜电影在线观看| av网址国产在线观看| 男生舔女生逼逼视频| 宅男噜噜噜666免费观看| 福利视频网久久91| 九色porny九色9l自拍视频| 亚洲一区制服丝袜美腿| 精品91高清在线观看| 欧美亚洲自偷自拍 在线| 精品久久久久久久久久中文蒉 | 美女张开腿让男生操在线看| eeuss鲁片一区二区三区| 日韩美女搞黄视频免费| 日韩写真福利视频在线观看| 国产综合精品久久久久蜜臀| 亚洲男人的天堂a在线| 精品一区二区三区在线观看| 在线观看av2025| 91麻豆精品秘密入口在线观看| 专门看国产熟妇的网站| 天天干天天操天天爽天天摸| 中文字幕一区的人妻欧美日韩| 国产成人无码精品久久久电影| 中文字幕熟女人妻久久久| 深夜男人福利在线观看| 男生用鸡操女生视频动漫 | 91国内精品自线在拍白富美| 亚洲伊人色一综合网| 欧美偷拍亚洲一区二区| 亚洲综合色在线免费观看| 国产午夜福利av导航| 国产麻豆91在线视频| 在线视频免费观看网| av无限看熟女人妻另类av| 2017亚洲男人天堂| av天堂中文字幕最新| 国产亚洲精品欧洲在线观看| 99精品国自产在线人| 日本乱人一区二区三区| 天天做天天爽夜夜做少妇| 免费成人va在线观看| 粗大的内捧猛烈进出爽大牛汉子| 国产日本精品久久久久久久| 亚洲中文精品人人免费| 99久久超碰人妻国产| avjpm亚洲伊人久久| 亚洲一区二区三区五区 | 美女吃鸡巴操逼高潮视频| 国产精品成久久久久三级蜜臀av| 亚欧在线视频你懂的| 在线观看亚洲人成免费网址| 久久麻豆亚洲精品av| 亚洲1区2区3区精华液| 美女福利写真在线观看视频| 日本午夜久久女同精女女| 亚洲国产40页第21页| 日韩亚国产欧美三级涩爱| 日韩一个色综合导航| 午夜频道成人在线91| 一区国内二区日韩三区欧美| 熟女妇女老妇一二三区| 大屁股肉感人妻中文字幕在线| 夏目彩春在线中文字幕| aaa久久久久久久久| 精品国产乱码一区二区三区乱| 亚洲av男人天堂久久| 2012中文字幕在线高清| 国产日韩欧美视频在线导航| 91九色国产porny蝌蚪| 国产97在线视频观看| 亚洲超碰97人人做人人爱| 亚洲精品麻豆免费在线观看| 婷婷综合蜜桃av在线| 同居了嫂子在线播高清中文| 亚洲无线观看国产高清在线| 性色av一区二区三区久久久| 一区国内二区日韩三区欧美| 国产视频网站一区二区三区| 久久精品亚洲成在人线a| 婷婷久久一区二区字幕网址你懂得| 欧美亚洲国产成人免费在线| 视频一区 二区 三区 综合| 自拍偷拍亚洲精品第2页| 中文字幕在线观看极品视频| av视屏免费在线播放| 日韩a级黄色小视频| 亚洲av黄色在线网站| 午夜久久久久久久精品熟女| 国产精品国色综合久久| 福利午夜视频在线观看| 中国产一级黄片免费视频播放| 免费男阳茎伸入女阳道视频 | 成人动漫大肉棒插进去视频| 欧美日韩激情啪啪啪| 超级福利视频在线观看| 内射久久久久综合网| 2022天天干天天操| 中文字幕+中文字幕| 女蜜桃臀紧身瑜伽裤| 亚洲一区二区人妻av| 在线视频免费观看网| 亚洲护士一区二区三区| 久久久久久久精品成人热| 91国内视频在线观看| 夜色福利视频在线观看| 久草视频在线免播放| 大胸性感美女羞爽操逼毛片| 人妻熟女中文字幕aⅴ在线| 天天色天天操天天舔| 亚洲视频在线视频看视频在线| 国产超码片内射在线| 国产精品亚洲а∨天堂免| 亚洲一区自拍高清免费视频| 日韩av有码中文字幕| 91麻豆精品91久久久久同性 | 久草视频中文字幕在线观看| 天天做天天干天天操天天射| 国产视频一区二区午夜| sejizz在线视频| 成人精品视频99第一页| 五月精品丁香久久久久福利社| 久久热这里这里只有精品| 精品美女久久久久久| 日韩北条麻妃一区在线| 瑟瑟视频在线观看免费视频| 欧美日韩人妻久久精品高清国产 | 伊人情人综合成人久久网小说| 欧美成人一二三在线网| 青青尤物在线观看视频网站| 成人24小时免费视频| 天堂女人av一区二区| 视频二区在线视频观看| 99国内精品永久免费视频| 一二三中文乱码亚洲乱码one| 在线免费91激情四射 | 男人天堂最新地址av| 天天草天天色天天干| 天天爽夜夜爽人人爽QC| 只有精品亚洲视频在线观看| 密臀av一区在线观看| 国产精品自拍偷拍a| 一区二区熟女人妻视频| 综合国产成人在线观看| 一区二区三区在线视频福利| 天天艹天天干天天操| 国产真实乱子伦a视频| 亚洲一区二区三区精品乱码| 含骚鸡巴玩逼逼视频| 免费岛国喷水视频在线观看| 99热久久这里只有精品| 欧美精产国品一二三区| 91大神福利视频网| 污污小视频91在线观看| 欧美黄色录像免费看的| 日本少妇精品免费视频| 黄网十四区丁香社区激情五月天| 91av精品视频在线| 91天堂天天日天天操| 色综合色综合色综合色| 色哟哟国产精品入口| 国产综合精品久久久久蜜臀| 日韩人妻xxxxx| 91精品视频在线观看免费| 久久久精品999精品日本 | 天堂资源网av中文字幕| 亚洲精品在线资源站| 亚洲午夜电影在线观看| 91中文字幕最新合集| 99久久激情婷婷综合五月天| av男人天堂狠狠干| 久久久制服丝袜中文字幕| 欧美专区日韩专区国产专区| 日日夜夜狠狠干视频| 午夜在线精品偷拍一区二| 午夜精品一区二区三区福利视频| 天天操天天干天天日狠狠插| asmr福利视频在线观看| 日本成人一区二区不卡免费在线| 国产一级精品综合av| 黄色无码鸡吧操逼视频| 综合精品久久久久97| 成人av天堂丝袜在线观看 | 国产成人精品亚洲男人的天堂| 欧美日韩人妻久久精品高清国产| 夜色撩人久久7777| 日韩a级精品一区二区| 国产卡一卡二卡三乱码手机| 日韩精品中文字幕福利| 国产黄色a级三级三级三级| 国产精品黄页网站视频| 国产一区av澳门在线观看| 精品亚洲中文字幕av| 特大黑人巨大xxxx| 亚洲综合乱码一区二区| 国产精品大陆在线2019不卡| 欧美黄片精彩在线免费观看| 天堂av在线播放免费| 精产国品久久一二三产区区别| 国产精品自拍偷拍a| 老鸭窝在线观看一区| 偷拍自拍视频图片免费| 99精品国自产在线人| 91国产在线免费播放| 日本熟妇色熟妇在线观看| 久精品人妻一区二区三区| 久青青草视频手机在线免费观看| 超级av免费观看一区二区三区| 2021天天色天天干| 亚洲 自拍 色综合图| 超碰公开大香蕉97| 91久久精品色伊人6882| 黑人性生活视频免费看| 中国视频一区二区三区| 精品一区二区三四区| 伊人开心婷婷国产av| 中文字幕在线视频一区二区三区| 天天干天天啪天天舔| 午夜成午夜成年片在线观看| 国产高清在线在线视频| 激情图片日韩欧美人妻| 国产污污污污网站在线| 在线观看av亚洲情色| 91色网站免费在线观看| 亚洲一区二区三区五区 | 毛茸茸的大外阴中国视频| 丰满的子国产在线观看| 国产精品系列在线观看一区二区| 精品久久久久久久久久久久人妻 | 区一区二区三国产中文字幕| 19一区二区三区在线播放| 97小视频人妻一区二区| 中文字幕日韩精品就在这里| 大香蕉玖玖一区2区| 男人和女人激情视频| 国产日本欧美亚洲精品视| 午夜频道成人在线91| 免费黄页网站4188| 国产成人一区二区三区电影网站| 91亚洲精品干熟女蜜桃频道 | 视频 一区二区在线观看| 亚洲综合一区成人在线| 自拍偷拍亚洲另类色图| sejizz在线视频| 天天日天天干天天爱| 中文字幕高清免费在线人妻| 中文字幕在线观看国产片| 女警官打开双腿沦为性奴| 亚洲国产精品免费在线观看| 久久午夜夜伦痒痒想咳嗽P| 国产97在线视频观看| 午夜精品亚洲精品五月色| 日韩加勒比东京热二区| 国产精品国产三级国产午| japanese五十路熟女熟妇| 一个色综合男人天堂| 久精品人妻一区二区三区| 天天摸天天日天天操| 久久艹在线观看视频| 天天操天天爽天天干| 亚洲1卡2卡三卡4卡在线观看| 日本熟女精品一区二区三区| 换爱交换乱高清大片| 亚洲变态另类色图天堂网| 人妻在线精品录音叫床| 色狠狠av线不卡香蕉一区二区| 国产大学生援交正在播放| 40道精品招牌菜特色| 91中文字幕最新合集| 中国熟女一区二区性xx| 国产美女一区在线观看| 38av一区二区三区| 天天日天天舔天天射进去| 插小穴高清无码中文字幕| 天天艹天天干天天操| 中文字幕人妻一区二区视频| 国产成人一区二区三区电影网站| 国产日韩av一区二区在线| 国产性生活中老年人视频网站| 在线观看av2025| 91‖亚洲‖国产熟女| 亚洲中文字幕人妻一区| 天天夜天天日天天日| 亚洲国产香蕉视频在线播放| av在线观看网址av| 欧美性感尤物人妻在线免费看| 亚洲成人线上免费视频观看| 国产精品一区二区av国| 玖玖一区二区在线观看| 大香蕉伊人中文字幕| 最新日韩av传媒在线| 日韩影片一区二区三区不卡免费| 成人av免费不卡在线观看| 日日摸夜夜添夜夜添毛片性色av| 欧美成人综合色在线噜噜| 亚洲欧美综合另类13p| 99的爱精品免费视频| 性色蜜臀av一区二区三区| 国产精品久久久久久久女人18| 美女av色播在线播放| yy6080国产在线视频| 天天干天天操天天摸天天射| 精品人妻一二三区久久| 中文字幕日韩精品就在这里| 男女之间激情网午夜在线| 成人福利视频免费在线| 夜夜骑夜夜操夜夜奸| 亚洲欧美综合在线探花| 和邻居少妇愉情中文字幕| 亚洲 欧美 自拍 偷拍 在线| 大鸡吧插入女阴道黄色片| 超碰中文字幕免费观看| 亚洲欧美人精品高清| 日韩a级精品一区二区| 亚洲推理片免费看网站| jul—619中文字幕在线| 91九色porny蝌蚪国产成人| 男人的网址你懂的亚洲欧洲av| 亚洲成人熟妇一区二区三区 | 亚洲一区制服丝袜美腿| 亚洲一级av无码一级久久精品| 人妻熟女在线一区二区| 93视频一区二区三区| 日韩精品电影亚洲一区| nagger可以指黑人吗| 国产精品成久久久久三级蜜臀av| 天天摸天天亲天天舔天天操天天爽| 欧美精产国品一二三区| 精品亚洲国产中文自在线| 亚洲国产成人在线一区| 最新激情中文字幕视频| 亚洲熟妇久久无码精品| 欧美精品中文字幕久久二区| 中文字幕av男人天堂| 午夜婷婷在线观看视频| 青草久久视频在线观看| 麻豆性色视频在线观看| 中文字幕在线欧美精品| 精品一区二区三区三区色爱| 国产视频一区二区午夜| 天天操,天天干,天天射| 日韩精品中文字幕福利| 夫妻在线观看视频91| 天天色天天操天天舔| 日日夜夜狠狠干视频| 亚洲成人av一区在线| 国产在线91观看免费观看| 国产欧美精品一区二区高清| 人妻熟女中文字幕aⅴ在线| 熟女少妇激情五十路| 嫩草aⅴ一区二区三区| 在线观看免费视频色97| 成人国产影院在线观看| 国产成人自拍视频在线免费观看 | 成人国产影院在线观看| 日本免费视频午夜福利视频| 天美传媒mv视频在线观看| 美女av色播在线播放| 日韩三级电影华丽的外出 | 亚洲国产中文字幕啊啊啊不行了 | 在线免费视频 自拍| 亚洲第一黄色在线观看| 人人妻人人爱人人草| 欧美亚洲免费视频观看| 国产日韩av一区二区在线| 伊人情人综合成人久久网小说| 一区二区三区另类在线| 91麻豆精品秘密入口在线观看| 姐姐的朋友2在线观看中文字幕 | 啊啊啊想要被插进去视频| 人人人妻人人澡人人| 亚洲av黄色在线网站| av在线免费观看亚洲天堂| 91桃色成人网络在线观看| 日韩欧美中文国产在线| 青青青激情在线观看视频| 国产一区二区欧美三区| 啊啊好大好爽啊啊操我啊啊视频 | 亚洲人一区二区中文字幕| 午夜美女福利小视频| 天天操天天爽天天干| 亚洲另类图片蜜臀av| 午夜国产福利在线观看| 亚洲欧美久久久久久久久| 小泽玛利亚视频在线观看| 欧美xxx成人在线| 专门看国产熟妇的网站| www天堂在线久久| wwwxxx一级黄色片| 国产亚洲视频在线二区| 国际av大片在线免费观看| 成人午夜电影在线观看 久久| 国产在线观看黄色视频| 亚洲综合另类精品小说| 国产成人自拍视频在线免费观看| 精内国产乱码久久久久久| 91免费观看在线网站| 亚洲人妻av毛片在线| 91中文字幕免费在线观看| 日韩黄色片在线观看网站| 五十路av熟女松本翔子| 亚洲午夜高清在线观看| 中文字幕无码一区二区免费| 日视频免费在线观看| 亚洲美女美妇久久字幕组| 亚洲一区二区三区久久午夜| jiuse91九色视频| 大陆胖女人与丈夫操b国语高清| 欧美一区二区三区激情啪啪啪| yy6080国产在线视频| 最近中文2019年在线看| 高潮视频在线快速观看国家快速| 中文字幕中文字幕 亚洲国产| 老师让我插进去69AV| 中文字幕亚洲久久久| 天天日天天鲁天天操| 婷婷综合亚洲爱久久| 国产变态另类在线观看| 欲满人妻中文字幕在线| 和邻居少妇愉情中文字幕| 中文字幕之无码色多多| 播放日本一区二区三区电影| 国产精品一区二区av国| 久久久精品999精品日本| 亚洲国产免费av一区二区三区 | 色av色婷婷人妻久久久精品高清| 国产品国产三级国产普通话三级| 开心 色 六月 婷婷| 99国内小视频在现欢看| 欧美精品中文字幕久久二区| 久久综合老鸭窝色综合久久| 国产成人一区二区三区电影网站 | 中文字幕日本人妻中出| 最新国产亚洲精品中文在线| 久草福利电影在线观看| 桃色视频在线观看一区二区| 一区二区三区四区视频| 中文字幕在线视频一区二区三区 | 11久久久久久久久久久| 精品国产在线手机在线| 密臀av一区在线观看| 日本熟妇喷水xxx| 玩弄人妻熟妇性色av少妇| 欧美美女人体视频一区| 91人妻精品一区二区在线看| 99av国产精品欲麻豆| 亚洲日产av一区二区在线| 日本特级片中文字幕| 亚洲欧洲av天堂综合| 91chinese在线视频| 中文字幕亚洲中文字幕| 91高清成人在线视频| 91久久人澡人人添人人爽乱| 久久丁香婷婷六月天| 亚洲欧美综合另类13p| 亚洲中文精品字幕在线观看| 亚洲精品高清自拍av| 欧美色婷婷综合在线| 黑人借宿ntr人妻的沦陷2| 国产精品黄片免费在线观看| 国产精品久久综合久久| 欧美天堂av无线av欧美| 蜜桃色婷婷久久久福利在线| 日韩a级精品一区二区| 亚洲午夜电影之麻豆| 欧美亚洲国产成人免费在线| 做爰视频毛片下载蜜桃视频1| 色天天天天射天天舔| 中国熟女一区二区性xx| 少妇人妻久久久久视频黄片| 老司机福利精品免费视频一区二区| 大香蕉福利在线观看| 最近的中文字幕在线mv视频| 中文字幕中文字幕人妻| 护士特殊服务久久久久久久| 国产精品一二三不卡带免费视频| aaa久久久久久久久| 97年大学生大白天操逼| 欧美乱妇无乱码一区二区| 午夜国产福利在线观看| 国产揄拍高清国内精品对白| 丰满的继坶3中文在线观看| 91亚洲国产成人精品性色| 亚洲高清一区二区三区视频在线| jiuse91九色视频| 高清成人av一区三区| 夜夜操,天天操,狠狠操| 成人蜜臀午夜久久一区| 97超碰最新免费在线观看| 亚洲另类在线免费观看| 天天躁夜夜躁日日躁a麻豆| 国产自拍黄片在线观看| 青青社区2国产视频| 欧美亚洲自偷自拍 在线| 一个色综合男人天堂| 蜜臀av久久久久久久| 老熟妇凹凸淫老妇女av在线观看 | 亚洲日本一区二区久久久精品| 淫秽激情视频免费观看| 国产黄色片蝌蚪九色91| 男人靠女人的逼视频| 天天日天天透天天操| 日韩中文字幕福利av| 免费手机黄页网址大全| 青青草原网站在线观看| 日本熟女精品一区二区三区| 黄片大全在线观看观看| 91成人精品亚洲国产| 99精品视频在线观看婷婷| 大黑人性xxxxbbbb| 中文字幕最新久久久| 馒头大胆亚洲一区二区| 日韩激情文学在线视频| 国产无遮挡裸体免费直播视频| 精品一线二线三线日本| 好了av中文字幕在线| 欧洲精品第一页欧洲精品亚洲| 美女少妇亚洲精选av| 亚洲国产精品中文字幕网站| 国产污污污污网站在线| 中文字幕人妻av在线观看| 亚洲欧美久久久久久久久| 亚洲一区二区三区精品乱码| 人人妻人人爽人人澡人人精品| 9色在线视频免费观看| 欧美日韩人妻久久精品高清国产 | 不卡一区一区三区在线| 99久久久无码国产精品性出奶水 | 999久久久久999| 亚洲一区自拍高清免费视频| 在线免费观看欧美小视频| 这里只有精品双飞在线播放| 国产成人自拍视频播放| 91亚洲国产成人精品性色| 偷拍3456eee| 国产精品视频一区在线播放| 亚洲一区久久免费视频| 中文字日产幕乱六区蜜桃 | 日本少妇在线视频大香蕉在线观看 | 国产午夜激情福利小视频在线| 精品久久久久久久久久久久人妻| yellow在线播放av啊啊啊| 久久www免费人成一看片| 人人妻人人人操人人人爽| 日本女人一级免费片| 中文字幕 亚洲av| 天天日天天添天天爽| 大尺度激情四射网站| 久久麻豆亚洲精品av| 九九视频在线精品播放| 91试看福利一分钟| 亚洲黄色av网站免费播放| 久精品人妻一区二区三区 | 2018最新中文字幕在线观看| 国产在线拍揄自揄视频网站| 99热久久这里只有精品| 538精品在线观看视频| 超碰97免费人妻麻豆| 91极品大一女神正在播放| 午夜频道成人在线91| 中文字幕一区二区自拍| 欧美伊人久久大香线蕉综合| 四川乱子伦视频国产vip| 精品黑人一区二区三区久久国产| 91老熟女连续高潮对白| 国产熟妇一区二区三区av| 亚洲国产精品久久久久久6| 国产女人叫床高潮大片视频| 亚洲2021av天堂| 日本精品视频不卡一二三| 中文字幕综合一区二区| 午夜精品一区二区三区城中村| 亚洲公开视频在线观看| 青青草原网站在线观看| 一色桃子久久精品亚洲 | 日韩二区视频一线天婷婷五| 亚洲福利天堂久久久久久| 青青草人人妻人人妻| 在线观看911精品国产| 大陆胖女人与丈夫操b国语高清 | 日本免费一级黄色录像| 欧美日本aⅴ免费视频| 55夜色66夜色国产精品站| 桃色视频在线观看一区二区| 欧美日韩中文字幕欧美| 午夜婷婷在线观看视频| 天天日天天鲁天天操| 男人靠女人的逼视频| 啪啪啪啪啪啪啪啪啪啪黄色| 日韩美女精品视频在线观看网站 | 日本熟妇喷水xxx| 免费在线看的黄片视频| av在线资源中文字幕| 美女吃鸡巴操逼高潮视频| 日韩一区二区电国产精品| 福利片区一区二体验区| 丰满的子国产在线观看| 岛国av高清在线成人在线| 久久精品在线观看一区二区| 日本丰满熟妇大屁股久久| 成人av在线资源网站| 视频一区二区三区高清在线| 日韩在线视频观看有码在线| 久久久久久9999久久久久| 大鸡巴插入美女黑黑的阴毛| 人妻丝袜诱惑我操她视频| 成年午夜免费无码区| 亚洲av自拍偷拍综合| 欧美日韩不卡一区不区二区| 亚洲欧美一卡二卡三卡| 丰满的继坶3中文在线观看| 青青青激情在线观看视频| 亚洲欧美久久久久久久久| www骚国产精品视频| 很黄很污很色的午夜网站在线观看 | 国产女孩喷水在线观看| 亚洲av香蕉一区区二区三区犇| 亚洲中文字幕校园春色| 欧美日韩人妻久久精品高清国产 | 中国熟女@视频91| 精品老妇女久久9g国产| 天天射夜夜操综合网| 亚洲中文字幕国产日韩| 男女啪啪啪啪啪的网站| 国产一区成人在线观看视频| 黄色成年网站午夜在线观看| 中文字幕一区二区自拍| 国产白袜脚足J棉袜在线观看| 鸡巴操逼一级黄色气| 阴茎插到阴道里面的视频| 最新国产亚洲精品中文在线| 欧美成一区二区三区四区| 欧美成人一二三在线网| 最新国产亚洲精品中文在线| 成人免费公开视频无毒| 97香蕉碰碰人妻国产樱花| 午夜久久香蕉电影网| 欧美一区二区中文字幕电影 | 狠狠操狠狠操免费视频| 中英文字幕av一区| 粉嫩欧美美人妻小视频| 超pen在线观看视频公开97| 午夜精品久久久久麻豆影视| 日本熟妇一区二区x x| 精品亚洲国产中文自在线| 午夜在线一区二区免费| 狠狠躁狠狠爱网站视频| 最新欧美一二三视频| 亚洲欧美一区二区三区电影| 护士特殊服务久久久久久久| 在线不卡成人黄色精品| 精品人妻一二三区久久| 欧美精产国品一二三产品区别大吗| 不卡一区一区三区在线| 国产精品一区二区三区蜜臀av | 可以免费看的www视频你懂的| 亚洲一区二区三区五区| 97人妻夜夜爽二区欧美极品| 五十路息与子猛烈交尾视频| 免费av岛国天堂网站| 熟女视频一区,二区,三区| 一级黄片大鸡巴插入美女| 中文字幕视频一区二区在线观看| 日韩人妻丝袜中文字幕| 国产黑丝高跟鞋视频在线播放| 欧美专区第八页一区在线播放| 国产精品大陆在线2019不卡| 国产精品人妻熟女毛片av久| 亚洲嫩模一区二区三区| 国产日韩欧美视频在线导航| 国产视频网站一区二区三区| 18禁美女黄网站色大片下载| 国产清纯美女al在线| 亚洲午夜电影在线观看| 可以在线观看的av中文字幕| 国产又色又刺激在线视频 | 极品粉嫩小泬白浆20p主播| 夫妻在线观看视频91| 久久尻中国美女视频| 青娱乐蜜桃臀av色| 亚洲综合一区二区精品久久| 青青青青青青青青青国产精品视频| 福利国产视频在线观看| 亚洲欧美另类手机在线| 天天色天天操天天舔| 国产日本精品久久久久久久| 精品一区二区三四区| 四川乱子伦视频国产vip| 午夜成午夜成年片在线观看| 欧洲国产成人精品91铁牛tv| 在线观看一区二区三级| 成年女人免费播放视频| 一个色综合男人天堂| 99久久久无码国产精品性出奶水| 快插进小逼里大鸡吧视频| 国产日韩精品一二三区久久久 | 亚洲熟妇久久无码精品| 噜噜色噜噜噜久色超碰| 色花堂在线av中文字幕九九 | 亚洲老熟妇日本老妇| 久草视频在线一区二区三区资源站 | 亚洲国产中文字幕啊啊啊不行了| 成年人黄色片免费网站| 青青社区2国产视频| 人人人妻人人澡人人| 国产男女视频在线播放| 超级碰碰在线视频免费观看| 五十路熟女人妻一区二| 国产在线观看黄色视频| 亚洲 人妻 激情 中文| 亚洲 自拍 色综合图| 日韩在线视频观看有码在线| 一级黄色av在线观看| 男人操女人的逼免费视频| 淫秽激情视频免费观看| 在线免费观看欧美小视频| 2021最新热播中文字幕| 亚洲高清国产拍青青草原| 国产精品视频欧美一区二区| 91成人精品亚洲国产| 中文字幕 亚洲av| 激情五月婷婷免费视频| 白嫩白嫩美女极品国产在线观看 | 黄页网视频在线免费观看| 无码中文字幕波多野不卡| 中文字幕日本人妻中出| 啪啪啪操人视频在线播放| 成年女人免费播放视频| 欧美爆乳肉感大码在线观看| 亚国产成人精品久久久| 日本三极片视频网站观看| 精品一区二区三区欧美| 欧美一区二区三区啪啪同性| 91国内精品自线在拍白富美| 免费成人av中文字幕| 护士小嫩嫩又紧又爽20p| 青草亚洲视频在线观看| 成人性黑人一级av| 快插进小逼里大鸡吧视频| 亚洲欧美另类手机在线| 九色porny九色9l自拍视频| 九色精品视频在线播放| 年轻的人妻被夫上司侵犯| 欧美中文字幕一区最新网址| av中文字幕在线观看第三页| 中文字幕人妻av在线观看| 熟女视频一区,二区,三区| 国产av一区2区3区| 蜜桃视频入口久久久| 成人av免费不卡在线观看| 青青青青青青青青青青草青青| 日本免费一级黄色录像| 青青青青草手机在线视频免费看| 97人妻色免费视频| 少妇人妻真实精品视频| 五色婷婷综合狠狠爱| 成年人黄视频在线观看| 大屁股熟女一区二区三区| 哥哥姐姐综合激情小说| 久久三久久三久久三久久| 天天日天天舔天天射进去| 中文字幕一区二区人妻电影冢本| 午夜青青草原网在线观看| 国产一区二区火爆视频| 在线成人日韩av电影| 女同久久精品秋霞网| 社区自拍揄拍尻屁你懂的| 国产三级影院在线观看| 国产女人露脸高潮对白视频| 日韩欧美制服诱惑一区在线| av无限看熟女人妻另类av| 国产夫妻视频在线观看免费| 综合精品久久久久97| 午夜精品久久久久麻豆影视| 中文字幕人妻被公上司喝醉在线| brazzers欧熟精品系列| 欧美久久一区二区伊人| 女人精品内射国产99| 欧美日韩在线精品一区二区三| 日韩人妻xxxxx| 中国黄色av一级片| 99国产精品窥熟女精品| 韩国AV无码不卡在线播放| 亚洲嫩模一区二区三区| 91极品大一女神正在播放| 日本一区二区三区免费小视频| 熟女人妻在线观看视频| 精品一区二区三区午夜| 中文字幕人妻熟女在线电影| 岛国一区二区三区视频在线| 亚洲成人三级在线播放| 精品久久久久久高潮| 中文字幕日韩91人妻在线| 女生自摸在线观看一区二区三区| 第一福利视频在线观看| 91人妻精品久久久久久久网站| 天天干天天啪天天舔| 国产在线免费观看成人| 老司机你懂得福利视频| 日韩av免费观看一区| 午夜精品一区二区三区城中村| 欧美日韩情色在线观看| 婷婷久久久综合中文字幕| 大鸡巴操b视频在线| xxx日本hd高清| 亚洲一区二区三区uij| 中文字幕乱码人妻电影| 国产使劲操在线播放| 久久热久久视频在线观看| 国产福利小视频大全| 亚洲精品 欧美日韩| 国产精品黄页网站视频| 日美女屁股黄邑视频| 亚洲av日韩精品久久久久久hd| 在线免费观看靠比视频的网站 | 亚洲高清一区二区三区视频在线| eeuss鲁片一区二区三区| 一区二区免费高清黄色视频| 天天日天天干天天搡| 啪啪啪啪啪啪啪免费视频| 午夜大尺度无码福利视频| 超级碰碰在线视频免费观看| 在线视频这里只有精品自拍| 1000部国产精品成人观看视频| 快插进小逼里大鸡吧视频| 国产精品视频欧美一区二区| 人妻丝袜榨强中文字幕| 免费观看污视频网站| 91av中文视频在线| 国产麻豆乱子伦午夜视频观看| 国产精品系列在线观看一区二区 | 99热久久这里只有精品8| 成人国产激情自拍三区| 91精品一区二区三区站长推荐| 亚洲自拍偷拍综合色| 天天做天天干天天舔| 国产精品成久久久久三级蜜臀av | 亚洲卡1卡2卡三卡四老狼| 天天操夜夜操天天操天天操 | 新97超碰在线观看| 蝴蝶伊人久久中文娱乐网| 偷拍自拍亚洲视频在线观看| 黑人巨大精品欧美视频| 国产三级片久久久久久久| 91国内精品久久久久精品一| 天天操天天爽天天干| av一区二区三区人妻| 国产精品国产三级麻豆| 国产实拍勾搭女技师av在线| 在线观看日韩激情视频| h国产小视频福利在线观看| 免费看国产av网站| 久久国产精品精品美女| av在线观看网址av| 任我爽精品视频在线播放| 东游记中文字幕版哪里可以看到| 国产熟妇人妻ⅹxxxx麻豆| 中文字幕在线视频一区二区三区| 91国内精品久久久久精品一| 亚洲精品av在线观看| 欧美国产亚洲中英文字幕| 亚洲女人的天堂av| 日韩欧美在线观看不卡一区二区| 一区二区三区四区五区性感视频| 亚洲 欧美 精品 激情 偷拍| 动漫黑丝美女的鸡巴| 日韩加勒比东京热二区| 在线免费观看亚洲精品电影| 三上悠亚和黑人665番号| 宅男噜噜噜666免费观看| 国产精品亚洲а∨天堂免| 三上悠亚和黑人665番号| 欧美亚洲少妇福利视频| 护士小嫩嫩又紧又爽20p| 色综合久久五月色婷婷综合| 国产中文精品在线观看| 超黄超污网站在线观看| 亚洲成人线上免费视频观看| 国产中文精品在线观看| 在线免费观看日本伦理| 精品视频一区二区三区四区五区| 亚洲第一黄色在线观看| 40道精品招牌菜特色| 午夜福利资源综合激情午夜福利资 | 亚洲综合色在线免费观看| 国产va在线观看精品| 人妻自拍视频中国大陆| 做爰视频毛片下载蜜桃视频1| 一区二区三区蜜臀在线| 国产chinesehd精品麻豆| 福利视频广场一区二区| 日本熟女精品一区二区三区| 一区二区三区久久久91| av在线免费观看亚洲天堂| 一区二区三区毛片国产一区| 好男人视频在线免费观看网站| 五月天中文字幕内射| 亚洲午夜电影之麻豆| 亚洲图片欧美校园春色| 国产亚洲欧美另类在线观看| 精品国产午夜视频一区二区| 激情国产小视频在线| 欧美一级片免费在线成人观看| 中文字幕av第1页中文字幕| 日本午夜福利免费视频| 国产va精品免费观看| av在线免费中文字幕| 一区二区三区的久久的蜜桃的视频| 国产品国产三级国产普通话三级| 少妇与子乱在线观看| 国产精品视频一区在线播放| 亚洲1069综合男同| 日韩av中文在线免费观看| 黄色成年网站午夜在线观看| 午夜精品一区二区三区更新| 青青草原色片网站在线观看| 久久久久五月天丁香社区| 在线视频国产欧美日韩| 日本熟妇一区二区x x| 偷青青国产精品青青在线观看| 色综合久久久久久久久中文| 在线免费观看99视频| 在线视频这里只有精品自拍| 国产精品sm调教视频| 欧美亚洲一二三区蜜臀| 天天日天天爽天天干| 久久这里只有精彩视频免费| 欧美一区二区三区在线资源| 日韩欧美在线观看不卡一区二区 | 免费人成黄页网站在线观看国产| 亚洲推理片免费看网站| 国产女人叫床高潮大片视频| 视频一区二区三区高清在线| 伊人精品福利综合导航| 青青青青青青青青青国产精品视频 | 亚洲高清国产一区二区三区| 天天操天天干天天插| 久久精品国产亚洲精品166m| 精品美女久久久久久| 午夜福利人人妻人人澡人人爽| 色婷婷六月亚洲综合香蕉| 4个黑人操素人视频网站精品91 | 欧美精品一区二区三区xxxx| 直接能看的国产av| 春色激情网欧美成人| 国产黄网站在线观看播放| xxx日本hd高清| 亚洲最大黄了色网站| 亚洲欧美在线视频第一页| 蜜桃臀av蜜桃臀av| 好了av中文字幕在线| 小泽玛利亚视频在线观看| 男生用鸡操女生视频动漫 | 97精品视频在线观看| 在线观看av亚洲情色| 麻豆性色视频在线观看| 国产亚洲四十路五十路| 亚洲综合另类精品小说| 一区二区三区av高清免费| 亚洲一级av大片免费观看| 成人蜜臀午夜久久一区| 一区二区三区激情在线| 高清一区二区欧美系列| 男人和女人激情视频| 瑟瑟视频在线观看免费视频| 超碰97人人做人人爱| 在线新三级黄伊人网| 亚洲精品乱码久久久久久密桃明| 91亚洲国产成人精品性色| 老司机福利精品视频在线| 亚洲国产在线精品国偷产拍| 18禁美女黄网站色大片下载| 欲满人妻中文字幕在线| 日本丰满熟妇BBXBBXHD| 亚洲欧美清纯唯美另类| 国产视频一区二区午夜| 一个色综合男人天堂| 沙月文乃人妻侵犯中文字幕在线| 女同性ⅹxx女同h偷拍| 一区二区三区 自拍偷拍| 伊人综合免费在线视频| 欧美视频中文一区二区三区| 91大神福利视频网| 美女日逼视频免费观看| 粉嫩欧美美人妻小视频| 午夜dv内射一区区| 18禁污污污app下载| 久久久久久97三级| 日日夜夜狠狠干视频| 大陆精品一区二区三区久久| 人妻凌辱欧美丰满熟妇| 91麻豆精品传媒国产黄色片| 国产97在线视频观看| 中文字幕人妻一区二区视频| 婷婷综合亚洲爱久久| 人妻另类专区欧美制服| 亚洲成人国产综合一区| 伊人开心婷婷国产av| 日韩不卡中文在线视频网站| 日本黄在免费看视频| 国产精品亚洲在线观看| 北条麻妃av在线免费观看| 黄工厂精品视频在线观看| 亚洲欧美一区二区三区爱爱动图 | 亚洲欧美综合在线探花| 狠狠躁狠狠爱网站视频 | 国产精品伦理片一区二区| 狍和女人的王色毛片| 在线免费观看国产精品黄色| av中文字幕电影在线看| 久久热这里这里只有精品| 久久久久五月天丁香社区| 国产卡一卡二卡三乱码手机| aⅴ五十路av熟女中出| 美女小视频网站在线| 男生用鸡操女生视频动漫 | 亚洲午夜福利中文乱码字幕| 免费福利av在线一区二区三区| 在线观看视频 你懂的| 精品国产污污免费网站入口自| 日本高清在线不卡一区二区| 偷拍自拍 中文字幕| 自拍偷拍 国产资源| 岛国一区二区三区视频在线| 91亚洲国产成人精品性色| 97精品成人一区二区三区| 99亚洲美女一区二区三区| 无码中文字幕波多野不卡| 亚洲国产欧美国产综合在线| 亚洲天堂成人在线观看视频网站| 搞黄色在线免费观看| 中文字幕无码一区二区免费| 午夜国产免费福利av| 最新中文字幕免费视频| 日韩北条麻妃一区在线| 欧亚乱色一区二区三区| 黄色av网站免费在线| 日本熟妇色熟妇在线观看| 国产美女精品福利在线| 岛国免费大片在线观看| 最新的中文字幕 亚洲| 日本一区二区三区免费小视频| 天天操天天插天天色| av在线观看网址av| 久久久久久国产精品| 亚洲最大免费在线观看| 国产麻豆精品人妻av| 精品一区二区三区三区色爱| 欧美中文字幕一区最新网址| 日比视频老公慢点好舒服啊| 国产精品一区二区av国| 天天日天天爽天天干| 成人av在线资源网站| 狠狠躁狠狠爱网站视频 | 国产视频网站一区二区三区 | 欧美老鸡巴日小嫩逼| 亚洲一区二区激情在线| 欧美精品伦理三区四区| 亚洲综合在线观看免费| 成人性黑人一级av| 欧美viboss性丰满| 日韩欧美制服诱惑一区在线| 一区二区视频在线观看免费观看 | 色婷婷综合激情五月免费观看| 综合精品久久久久97| 国产黄色a级三级三级三级| 亚洲在线免费h观看网站| 日韩欧美国产精品91| 成年人黄色片免费网站| 91快播视频在线观看| 午夜dv内射一区区| 福利在线视频网址导航| 成人av免费不卡在线观看| 97青青青手机在线视频| 人妻少妇中文有码精品| 在线观看视频网站麻豆| 色天天天天射天天舔| 沙月文乃人妻侵犯中文字幕在线| 19一区二区三区在线播放| 边摸边做超爽毛片18禁色戒 | 在线免费观看欧美小视频| 成人午夜电影在线观看 久久| av中文字幕国产在线观看| 亚洲av午夜免费观看| 肏插流水妹子在线乐播下载| 日韩视频一区二区免费观看| 日韩人妻丝袜中文字幕| 亚洲国产最大av综合| 成年人黄视频在线观看| 9l人妻人人爽人人爽| 亚洲特黄aaaa片| 男生舔女生逼逼视频| 天天综合天天综合天天网| 大香蕉福利在线观看| 中文字幕一区二区三区人妻大片| 日本男女操逼视频免费看| 最新国产精品拍在线观看| 精彩视频99免费在线| 男女第一次视频在线观看| 北条麻妃高跟丝袜啪啪| 男女之间激情网午夜在线| 欧美日本在线观看一区二区| 亚洲麻豆一区二区三区| 日比视频老公慢点好舒服啊| 影音先锋女人av噜噜色| 国产在线观看黄色视频| 青青青青青免费视频| 欧美男人大鸡吧插女人视频| 中文字幕第三十八页久久| 中文字幕无码一区二区免费| 在线免费观看黄页视频| 中文字幕熟女人妻久久久| 日韩黄色片在线观看网站| 欧美亚洲国产成人免费在线| 亚洲欧美在线视频第一页| 亚洲va国产va欧美va在线| 一区二区三区麻豆福利视频| 美女张开两腿让男人桶av| 中文字幕日本人妻中出| 婷婷久久一区二区字幕网址你懂得| 日本丰满熟妇大屁股久久| 国产日本欧美亚洲精品视| 国产成人精品av网站| 97超碰国语国产97超碰| 欧美一级片免费在线成人观看| 中字幕人妻熟女人妻a62v网| 人妻久久久精品69系列| 中文字幕1卡1区2区3区| 欧美 亚洲 另类综合| 中字幕人妻熟女人妻a62v网| 91精品国产91久久自产久强| 亚洲变态另类色图天堂网| 国产黄色大片在线免费播放| 日韩a级精品一区二区| 激情内射在线免费观看| 亚洲成人免费看电影| av中文字幕网址在线| 91久久国产成人免费网站| 人妻无码中文字幕专区| 人人妻人人澡人人爽人人dvl| 欧美亚洲少妇福利视频| 换爱交换乱高清大片| 国产伊人免费在线播放| 中文字幕综合一区二区| 日韩精品电影亚洲一区| 亚洲午夜电影之麻豆| av乱码一区二区三区| 97色视频在线观看| 高清成人av一区三区| 日韩av有码一区二区三区4| 欧美精品久久久久久影院| 噜噜色噜噜噜久色超碰| 一区二区在线观看少妇| 无码日韩人妻精品久久| caoporn蜜桃视频| 人妻丝袜诱惑我操她视频| 国产综合高清在线观看| 国产亚洲成人免费在线观看| 91欧美在线免费观看| 偷拍自拍 中文字幕| 丝袜美腿视频诱惑亚洲无| 中文字幕成人日韩欧美| 一区二区三区久久中文字幕| 亚洲高清免费在线观看视频| 亚洲欧美另类手机在线| 午夜极品美女福利视频| 美女大bxxxx内射| 中文字幕最新久久久| 精品老妇女久久9g国产| 91免费福利网91麻豆国产精品 | 大鸡吧插逼逼视频免费看| 99精品国产aⅴ在线观看| 色97视频在线播放| 日本a级视频老女人| av天堂资源最新版在线看| 9色在线视频免费观看| 沙月文乃人妻侵犯中文字幕在线| 婷婷六月天中文字幕| 国产污污污污网站在线| 天天干狠狠干天天操| 日本女人一级免费片| 国产免费高清视频视频| 夜女神免费福利视频| 久久久久国产成人精品亚洲午夜| 99精品免费观看视频| 夜色福利视频在线观看| 婷婷五月亚洲综合在线| av中文字幕电影在线看| 黑人乱偷人妻中文字幕| 9色在线视频免费观看| 国产精品视频男人的天堂| 19一区二区三区在线播放| 国产精彩福利精品视频| 日韩精品激情在线观看| 伊人综合免费在线视频| 久久机热/这里只有| 中文字幕视频一区二区在线观看| 亚洲国产精品美女在线观看| 精品久久婷婷免费视频| 欧美日韩一级黄片免费观看| 农村胖女人操逼视频| 啊啊好慢点插舔我逼啊啊啊视频| 无忧传媒在线观看视频| 99热国产精品666| 亚洲乱码中文字幕在线| 亚洲一区二区三区精品乱码| 国产普通话插插视频| 国产一区二区神马久久| 水蜜桃国产一区二区三区| 亚洲少妇高潮免费观看| 午夜精品一区二区三区更新| 热久久只有这里有精品| 日日日日日日日日夜夜夜夜夜夜| 国产一区av澳门在线观看| 中文字幕一区二区亚洲一区| 国产精品黄页网站视频| 日辽宁老肥女在线观看视频| 男人天堂最新地址av| 精品欧美一区二区vr在线观看| 动色av一区二区三区| AV天堂一区二区免费试看| 欧美另类一区二区视频| 视频在线亚洲一区二区| 神马午夜在线观看视频| 精品久久久久久久久久久久人妻| 少妇被强干到高潮视频在线观看| 亚洲特黄aaaa片| 国产麻豆剧传媒精品国产av蜜桃| 国产精彩对白一区二区三区| 97色视频在线观看| 扒开让我视频在线观看| 国语对白xxxx乱大交| 狠狠鲁狠狠操天天晚上干干| 黄色成人在线中文字幕| 偷拍自拍亚洲美腿丝袜| 国产熟妇一区二区三区av| 日韩人妻在线视频免费| 日本女大学生的黄色小视频| 久久精品美女免费视频| 中文字幕最新久久久| 国产男女视频在线播放| 激情国产小视频在线| 国产成人一区二区三区电影网站| 一区二区在线观看少妇| 亚洲1区2区3区精华液| 啊啊啊想要被插进去视频| 在线观看免费岛国av| 少妇被强干到高潮视频在线观看| 欧美亚洲免费视频观看| 2020av天堂网在线观看| 一区二区三区四区中文| 国产一级精品综合av| 阴茎插到阴道里面的视频| 特级无码毛片免费视频播放| 天天操天天操天天碰| 亚洲欧美成人综合在线观看| 日韩精品二区一区久久| 久久午夜夜伦痒痒想咳嗽P| 99精品国产aⅴ在线观看| 亚洲精品 欧美日韩| 天天日天天干天天要| 熟女人妻在线观看视频| 日噜噜噜夜夜噜噜噜天天噜噜噜 | 国产精品视频男人的天堂| 97人妻色免费视频| 免费观看丰满少妇做受| 久久久精品精品视频视频| 精品老妇女久久9g国产| 黑人乱偷人妻中文字幕| 91大神福利视频网| 日本xx片在线观看| 全国亚洲男人的天堂| 中文字幕一区二区自拍| 欧美日韩一级黄片免费观看| 国产污污污污网站在线| 又黄又刺激的午夜小视频| 日本少妇高清视频xxxxx| 欧美一级色视频美日韩| 欧美性受xx黑人性猛交| 亚洲成人熟妇一区二区三区| 黄色成年网站午夜在线观看| 日本高清撒尿pissing| 欧美成人一二三在线网| 久久久久久99国产精品| 亚洲视频乱码在线观看| 一个色综合男人天堂| 91精品视频在线观看免费| 亚洲成a人片777777| 国产精品一二三不卡带免费视频 | 福利午夜视频在线观看| 熟女91pooyn熟女| 欧美在线一二三视频| 99精品久久久久久久91蜜桃| 天堂av在线官网中文| avjpm亚洲伊人久久| 孕妇奶水仑乱A级毛片免费看| 欧美精品亚洲精品日韩在线| 日韩av中文在线免费观看| 2021最新热播中文字幕| 黄色中文字幕在线播放| 福利视频广场一区二区| 精品黑人一区二区三区久久国产| 1024久久国产精品| 97精品人妻一区二区三区精品| 风流唐伯虎电视剧在线观看 | 风流唐伯虎电视剧在线观看 | 自拍偷拍亚洲精品第2页| 91香蕉成人app下载| 一区二区三区美女毛片| 97精品成人一区二区三区| 国产亚洲精品视频合集| 18禁污污污app下载| 久久久久久国产精品| 大香蕉伊人国产在线| 夜色撩人久久7777| 国产janese在线播放| 欧美 亚洲 另类综合| 欧美一级色视频美日韩| 国产又大又黄免费观看| 日日夜夜精品一二三| 五十路老熟女码av| 综合精品久久久久97| 91大神福利视频网| 一区二区三区四区视频在线播放 | 91免费福利网91麻豆国产精品| 日韩剧情片电影在线收看| 久久久精品精品视频视频| 97精品成人一区二区三区| 亚洲欧美在线视频第一页| 影音先锋女人av噜噜色| 性感美女高潮视频久久久| 天天操天天污天天射| 亚洲国产中文字幕啊啊啊不行了 | 五十路在线观看完整版| 北条麻妃av在线免费观看| av完全免费在线观看av| 青青青视频手机在线观看| 极品丝袜一区二区三区| 国产va在线观看精品| 欧美亚洲自偷自拍 在线| 不卡精品视频在线观看| 伊人成人综合开心网| 在线播放一区二区三区Av无码| 色噜噜噜噜18禁止观看| 色呦呦视频在线观看视频| 懂色av蜜桃a v| 久久久久久九九99精品| 国产+亚洲+欧美+另类| 在线观看成人国产电影| 80电影天堂网官网| 午夜福利人人妻人人澡人人爽| 在线视频免费观看网| 天天操天天干天天艹| 天天干天天日天天谢综合156| 国产综合高清在线观看| 中文字日产幕乱六区蜜桃| av老司机精品在线观看| 国产精彩福利精品视频| 天天操天天爽天天干| 92福利视频午夜1000看| 好太好爽好想要免费| 天天躁日日躁狠狠躁av麻豆| 51国产成人精品视频| 和邻居少妇愉情中文字幕| 成人av免费不卡在线观看| 久久久久国产成人精品亚洲午夜| 男人插女人视频网站| 日比视频老公慢点好舒服啊| 午夜精品福利一区二区三区p| 人人妻人人爽人人添夜| 岛国av高清在线成人在线| 91人妻精品久久久久久久网站| 亚洲伊人久久精品影院一美女洗澡 | eeuss鲁片一区二区三区| 成人资源在线观看免费官网| 天天日天天透天天操| 经典国语激情内射视频| 九九热99视频在线观看97|