精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

從Helm到 Operator:Kubernetes應用管理的進化

云計算 云原生
helm 的本質上和 kubectl apply yaml 一樣的,只是我們在定義 value.yaml 時幫我們處理了許多不需要用戶低頻修改的參數。

Helm 的作用

在開始前需要先對 kubernetes  Operator 有個簡單的認識。

以為我們在編寫部署一些簡單 Deployment 的時候只需要自己編寫一個 yaml 文件然后 kubectl apply 即可。

apiVersion: apps/v1  
kind: Deployment  
metadata:  
  labels:  
    app: k8s-combat  
  name: k8s-combat  
spec:  
  replicas: 1  
  selector:  
    matchLabels:  
      app: k8s-combat  
  template:  
    metadata:  
      labels:  
        app: k8s-combat  
    spec:  
      containers:  
        - name: k8s-combat  
          image: crossoverjie/k8s-combat:v1  
          imagePullPolicy: Always  
          resources:  
            limits:  
              cpu: "1"  
              memory: 300Mi  
            requests:  
              cpu: "0.1"  
              memory: 30Mi
kubectl apply -f deployment.yaml

這對于一些并不復雜的項目來說完全夠用了,但組件一多就比較麻煩了。

這里以 Apache Pulsar 為例:它的核心組件有:

  • Broker
  • Proxy
  • Zookeeper
  • Bookkeeper
  • Prometheus(可選)
  • Grafana(可選) 等組件,每個組件的啟動還有這依賴關系。

必須需要等 Zookeeper 和 Bookkeeper 啟動之后才能將流量放進來。

此時如何還繼續使用 yaml 文件一個個部署就會非常繁瑣,好在社區有提供 Helm 一鍵安裝程序,使用它我們只需要在一個同意的 yaml 里簡單的配置一些組件,配置就可以由 helm 來部署整個復雜的 Pulsar 系統。

components:  
  # zookeeper  
  zookeeper: true  
  # bookkeeper  
  bookkeeper: true  
  # bookkeeper - autorecovery  
  autorecovery: true  
  # broker  
  broker: true  
  # functions  
  functions: false  
  # proxy  
  proxy: true  
  # toolset  
  toolset: true  
  # pulsar manager  
  pulsar_manager: false  
monitoring:  
  # monitoring - prometheus  
  prometheus: true  
  # monitoring - grafana  
  grafana: true  
  # monitoring - node_exporter  
  node_exporter: true  
  # alerting - alert-manager  
  alert_manager: false

比如在 helm 的 yaml 中我們可以選擇使用哪些 components,以及是否啟用監控組件。

最后直接使用這個文件進行安裝:

helm install pulsar apache/pulsar \
 --values charts/pulsar/values.yaml \
 --set namespace=pulsar \
    --set initialize=true

它就會自動生成各個組件的 yaml 文件,然后統一執行。

所以 helm 的本質上和 kubectl apply yaml 一樣的,只是我們在定義 value.yaml 時幫我們處理了許多不需要用戶低頻修改的參數。

我們可以使用 helm 將要執行的 yaml 輸出后人工審核

helm install pulsar apache/pulsar --dry-run --debug > debug.yaml

Operator 是什么

Helm 的痛點

Helm 雖然可以幫我們部署或者升級一個大型應用,但他卻沒法幫我們運維這個應用。

舉個例子:比如我希望當 Pulsar Broker 的流量或者內存達到某個閾值后就指定擴容 Broker,閑時再自動回收。

或者某個 Bookkeeper 的磁盤使用率達到閾值后可以自動擴容磁盤,這些僅僅使用 Helm 時都是無法實現的。

以上這些需求我們目前也是通過監控系統發出報警,然后再由人工處理。

其中最大的痛點就是進行升級:

  • 升級ZK
  • 關閉auto recovery
  • 升級Bookkeeper
  • 升級Broker
  • 升級Proxy
  • 開啟auto recovery

因為每次升級是有先后順序的,需要依次觀察每個組件運行是否正常才能往后操作。

如果有 Operator 理性情況下下我們只需要更新一下鏡像版本,它就可以自動執行以上的所有步驟最后將集群升級完畢。

所以相對于 Helm 來說 Operator 是可以站在一個更高的視角俯視整個應用系統,它能發現系統哪個地方需要它從而直接修復。

CRD(Custom Resource Definitions)

而提到 Operator 那就不得不提到 CRD(Custom Resource Definitions)翻譯過來就是自定義資源。

這是 kubernetes 提供的一個 API 擴展機制,類似于內置的 Deployment/StatefulSet/Services 資源,CRD 是一種自定義的資源。

這里以我們常用的 prometheus-operator 和 VictoriaMetrics-operator 為例:

Prometheus:

  • **Prometheus**:用于定義 Prometheus 的 Deployment
  • **Alertmanager**:用于定義 Alertmanager
  • **ScrapeConfig**:用于定會抓取規則
apiVersion: monitoring.coreos.com/v1alpha1
kind: ScrapeConfig
metadata:
  name: static-config
  namespace: my-namespace
  labels:
    prometheus: system-monitoring-prometheus
spec:
  staticConfigs:
    - labels:
        job: prometheus
      targets:
        - prometheus.demo.do.prometheus.io:9090

使用時的一個很大區別就是資源的 kind: ScrapeConfig 為自定義的類型。

VictoriaMetrics 的 CRD:

  • VMPodScrape:Pod 的抓取規則
  • VMCluster:配置 VM 集群
  • VMAlert:配置 VM 的告警規則
  • 等等
# vmcluster.yaml
apiVersion: operator.victoriametrics.com/v1beta1
kind: VMCluster
metadata:
  name: demo
spec:
  retentionPeriod: "1"
  replicationFactor: 2
  vmstorage:
    replicaCount: 2
    storageDataPath: "/vm-data"
    storage:
      volumeClaimTemplate:
        spec:
          resources:
            requests:
              storage: "10Gi"
    resources:
      limits:
        cpu: "1"
        memory: "1Gi"
  vmselect:
    replicaCount: 2
    cacheMountPath: "/select-cache"
    storage:
      volumeClaimTemplate:
        spec:
          resources:
            requests:
              storage: "1Gi"
    resources:
      limits:
        cpu: "1"
        memory: "1Gi"
      requests:
        cpu: "0.5"
        memory: "500Mi"
  vminsert:
    replicaCount: 2

以上是用于創建一個 VM 集群的 CRD 資源,應用之后就會自動創建一個集群。

Operator 原理

Operator 通常是運行在 kubernetes API server 的 webhook 之上,簡單來說就是在一些內置資源的關鍵節點 API-server 會調用我們注冊的一個 webhook,在這個 webhook 中我們根據我們的 CRD 做一些自定義的操作。

理論上我們可以使用任何語言都可以寫 Operator,只需要能處理 api-server 的回調即可。

只是 Go 語言有很多成熟的工具,比如常用的 kubebuilder 和 operator-sdk.

他們內置了許多命令行工具,可以幫我們節省需要工作量。

這里以 operator-sdk 為例:

$ operator-sdk create webhook --group cache --version v1alpha1 --kind Memcached --defaulting --programmatic-validation

會直接幫我們創建好一個標準的 operator 項目:

├── Dockerfile
├── Makefile
├── PROJECT
├── api
│   └── v1alpha1
│       ├── memcached_webhook.go
│       ├── webhook_suite_test.go
├── config
│   ├── certmanager
│   │   ├── certificate.yaml
│   │   ├── kustomization.yaml
│   │   └── kustomizeconfig.yaml
│   ├── default
│   │   ├── manager_webhook_patch.yaml
│   │   └── webhookcainjection_patch.yaml
│   └── webhook
│       ├── kustomization.yaml
│       ├── kustomizeconfig.yaml
│       └── service.yaml
├── go.mod
├── go.sum
└── main.go

其中 Makefile 中包含了開發過程中常用的工具鏈(包括根據聲明的結構體自動生成 CRD 資源、部署k8s 環境測試等等)、Dockerfile 等等。

這樣我們就只需要專注于開發業務邏輯即可。

因為我前段時間給 https://github.com/open-telemetry/opentelemetry-operator 貢獻過兩個 feature,所以就以這個 Operator 為例:

它有一個 CRD: kind: Instrumentation,在這個 CRD 中可以將 OpenTelemetry 的 agent 注入到應用中。

apiVersion: opentelemetry.io/v1alpha1  
kind: Instrumentation  
metadata:  
  name: instrumentation-test-order
  namespace: test  
spec:  
  env:  
    - name: OTEL_SERVICE_NAME  
      value: order
  selector:  
    matchLabels:  
      app: order  
  java:  
    image: autoinstrumentation-java:2.4.0-release  
    extensions:  
      - image: autoinstrumentation-java:2.4.0-release  
        dir: /extensions  
  
    env:  
      - name: OTEL_RESOURCE_ATTRIBUTES  
        value: service.name=order  
      - name: OTEL_INSTRUMENTATION_MESSAGING_EXPERIMENTAL_RECEIVE_TELEMETRY_ENABLED  
        value: "true"  
      - name: OTEL_TRACES_EXPORTER  
        value: otlp  
      - name: OTEL_METRICS_EXPORTER  
        value: otlp  
      - name: OTEL_LOGS_EXPORTER  
        value: none  
      - name: OTEL_EXPORTER_OTLP_ENDPOINT  
        value: http://open-telemetry-opentelemetry-collector.otel.svc.cluster.local:4317  
      - name: OTEL_EXPORTER_OTLP_COMPRESSION  
        value: gzip  
      - name: OTEL_EXPERIMENTAL_EXPORTER_OTLP_RETRY_ENABLED  
        value: "true"

它的運行規則是當我們的 Pod 在啟動過程中會判斷 Pod 的注解中是否開啟了注入 OpenTelemetry 的配置。

如果開啟則會將我們在 CRD 中自定義的鏡像里的 javaagent 復制到業務容器中,同時會將下面的那些環境變量也一起加入的業務容器中。

要達到這樣的效果就需要我們注冊一個回調 endpoint。

mgr.GetWebhookServer().Register("/mutate-v1-pod", &webhook.Admission{  
    Handler: podmutation.NewWebhookHandler(cfg, ctrl.Log.WithName("pod-webhook"), decoder, mgr.GetClient(),  
       []podmutation.PodMutator{  
          sidecar.NewMutator(logger, cfg, mgr.GetClient()),  
          instrumentation.NewMutator(logger, mgr.GetClient(), mgr.GetEventRecorderFor("opentelemetry-operator"), cfg),  
       }),})

當 Pod 創建或有新的變更請求時就會回調我們的接口。

func (pm *instPodMutator) Mutate(ctx context.Context, ns corev1.Namespace, pod corev1.Pod) (corev1.Pod, error) {  
    logger := pm.Logger.WithValues("namespace", pod.Namespace, "name", pod.Name)
    }

在這個接口中我們就可以拿到 Pod 的信息,然后再獲取 CRD Instrumentation 做我們的業務邏輯。

var otelInsts v1alpha1.InstrumentationList  
if err := pm.Client.List(ctx, &otelInsts, client.InNamespace(ns.Name)); err != nil {  
    return nil, err  
}


// 從 CRD 中將數據復制到業務容器中。
pod.Spec.InitContainers = append(pod.Spec.InitContainers, corev1.Container{
 Name:      javaInitContainerName,
 Image:     javaSpec.Image,
 Command:   []string{"cp", "/javaagent.jar", javaInstrMountPath + "/javaagent.jar"},
 Resources: javaSpec.Resources,
 VolumeMounts: []corev1.VolumeMount{{
  Name:      javaVolumeName,
  MountPath: javaInstrMountPath,
 }},
})

for i, extension := range javaSpec.Extensions {
 pod.Spec.InitContainers = append(pod.Spec.InitContainers, corev1.Container{
  Name:      initContainerName + fmt.Sprintf("-extension-%d", i),
  Image:     extension.Image,
  Command:   []string{"cp", "-r", extension.Dir + "/.", javaInstrMountPath + "/extensions"},
  Resources: javaSpec.Resources,
  VolumeMounts: []corev1.VolumeMount{{
   Name:      javaVolumeName,
   MountPath: javaInstrMountPath,
  }},
 })
}

不過需要注意的是想要在測試環境中測試 operator 是需要安裝一個 cert-manage,這樣 webhook 才能正常的回調。

要使得 CRD 生效,我們還得先將 CRD 安裝進 kubernetes 集群中,不過這些 operator-sdk 這類根據已經考慮周到了。

我們只需要定義好 CRD 的結構體:

然后使用 Makefile 中的工具 make bundle 就會自動將結構體轉換為 CRD。

參考鏈接:

  • https://github.com/VictoriaMetrics/operator。
  • https://github.com/prometheus-operator/prometheus-operator。
責任編輯:姜華 來源: crossoverJie
相關推薦

2024-03-05 10:34:33

KubernetesPod云原生

2013-04-17 11:18:11

編程語言

2023-05-06 08:00:00

KubernetesK8s數據服務自動化

2022-11-01 12:16:47

Nginx微服務編譯

2023-12-27 06:48:49

KubernetesDevOpsHTTP

2022-08-04 08:00:54

安全管理服務器

2024-01-29 01:15:11

HelmKubernetesKustomize

2024-01-01 21:57:41

kubernetesCRDOperator

2024-05-06 08:08:31

2025-04-29 10:00:00

Kubernete云原生Helm

2022-03-29 09:35:15

FirefoxUI瀏覽器

2023-11-10 15:05:08

Kubernetes云計算

2009-06-01 10:11:55

路由器DIR-685D-Link

2025-08-01 09:41:52

2020-12-03 14:03:29

中臺數智化架構

2025-09-12 16:13:12

2018-12-21 11:01:05

存儲大數據RAID

2019-09-02 13:57:07

Helm Chart工具Kubernetes

2023-10-09 08:14:10

Helm管理應用

2025-08-13 09:13:00

點贊
收藏

51CTO技術棧公眾號

国产精品全国免费观看高清| 色婷婷狠狠五月综合天色拍| 成人网男人的天堂| 亚洲少妇激情视频| 久久综合亚洲精品| 无码人妻精品一区二区50| 亚洲视频国产精品| 欧美国产精品一区二区| 久久久久久久999| 婷婷中文字幕在线观看| 国产小视频在线观看| 极品av少妇一区二区| 欧美高清精品3d| 日韩aⅴ视频一区二区三区| 国产一级视频在线观看| av国产精品| 欧美国产精品久久| 8x拔播拔播x8国产精品| 亚洲av无码专区在线播放中文| 色综合久久影院| 首页国产欧美日韩丝袜| 亚洲黄色在线看| 91黄色在线看| 亚洲产国偷v产偷v自拍涩爱| 99久久.com| 欧美日韩一区国产| 亚洲蜜桃av| 中文字幕永久免费视频| 精品日韩欧美一区| 欧洲亚洲国产日韩| 亚洲视频精选在线| 欧美日韩亚洲综合一区| 久久国产日韩欧美| 五月天婷婷丁香| 伊人久久噜噜噜躁狠狠躁| 亚洲人成精品久久久久久 | 国产秀色在线www免费观看| 久久一区视频| 夜夜嗨av一区二区三区免费区| 久热免费在线观看| 福利小视频在线观看| 日韩成人一级大片| 日韩在线激情视频| 亚洲精品永久视频| 岛国成人毛片| 成人免费视频一区| 456亚洲影院| 国产人妻一区二区| 免费一级欧美在线观看视频| 综合久久综合久久| 国产精品yjizz| 久久国产黄色片| 久草成人在线| 欧美年轻男男videosbes| 强伦女教师2:伦理在线观看| 99在线精品视频免费观看20| 亚洲经典在线| 亚洲视频999| 老司机久久精品| 欧美xxxx免费虐| 2欧美一区二区三区在线观看视频| 日韩免费黄色av| 小早川怜子一区二区的演员表| 日韩成人在线看| 精品电影在线观看| 日本在线成人一区二区| 尤物九九久久国产精品的分类| 久久久一二三四| 人人妻人人澡人人爽人人欧美一区| 国产日韩一区二区三区在线| 一本色道久久综合亚洲精品小说 | 亚洲精品中文字幕乱码三区不卡| 国产视频一区二区三区四区五区| 国产精品theporn| 亚洲欧洲黄色网| 亚洲视频在线不卡| 亚洲精品一区| 亚洲精品成人天堂一二三| 久久免费视频1| 国产美女明星三级做爰| 老**午夜毛片一区二区三区| 久久国产精品网站| 日韩毛片无码永久免费看| 日韩在线网址| 欧美色综合久久| 成人免费播放器| 秋霞影院午夜丰满少妇在线视频| thepron国产精品| 成人精品久久久| 欧美特级黄色片| 亚洲国产mv| 久热99视频在线观看| 大又大又粗又硬又爽少妇毛片 | 国产亚洲精品久久久久婷婷瑜伽| 色噜噜狠狠色综合网图区| 好吊色视频一区二区三区| 欧美美女被草| 色婷婷综合在线| 国产高清av在线播放| a级片国产精品自在拍在线播放| 久久精品视频一区二区| 国产女主播一区二区| 国产内射老熟女aaaa∵| 欧美aaa在线| 日韩av大片免费看| 亚洲高清毛片一区二区| 亚洲日本国产| 欧美精品激情在线观看| 麻豆精品一区二区三区视频| 久久综合电影| 一区二区欧美激情| 日韩人妻无码精品综合区| 欧美韩一区二区| 精品国产乱码久久久久久免费| 午夜天堂在线视频| 91麻豆精品国产91久久久更新资源速度超快 | 日韩精品中文字幕一区二区三区| 在线免费av播放| 国产私拍福利精品视频二区| 色婷婷av一区二区三区gif| 日本一道本久久| 18video性欧美19sex高清| 一区二区欧美国产| 毛片在线视频观看| 欧美videossex| 亚洲一区精品在线| 久久国产午夜精品理论片最新版本| 色呦呦网站在线观看| 一区二区三区四区不卡在线| 成人在线免费观看视频网站| 黄色动漫在线| 夜夜夜精品看看| a级黄色小视频| 国产盗摄——sm在线视频| 欧美日韩性生活视频| 91看片就是不一样| 成人全视频免费观看在线看| 欧美日韩在线播放三区| 亚洲视频第二页| 国产精品xnxxcom| 日韩午夜在线观看视频| 美女露出粉嫩尿囗让男人桶| 成人av婷婷| 亚洲精品久久久久中文字幕欢迎你 | 中国一级黄色录像| 国产美女一区视频| 日韩欧美中文第一页| 成人性做爰aaa片免费看不忠| 成人一区视频| 欧美一区二区三区色| 久久久久亚洲av无码专区首jn| 国内毛片久久| 亚洲欧美日本另类| 欧美xxxooo| 亚洲激情专区| 国产精品看片资源| 国产黄色一区二区| 91最新地址在线播放| 小说区图片区图片区另类灬| 国产剧情在线| 欧美日韩中文字幕| 久久人人爽av| 久久1电影院| 中文字幕亚洲图片| 欧美精品99久久久| 午夜在线播放视频欧美| 91免费的视频在线播放| 五月激情婷婷综合| 中文字幕一区二区视频| 日韩中字在线观看| 久久av影院| 日韩av在线不卡| 香蕉成人在线视频| 国产欧美大片| 91超碰在线免费观看| 巨骚激情综合| 亚洲影视资源网| 男女污污的视频| jizzjizzjizz欧美| 久久久国产影院| 丁香社区五月天| 国产成人超碰人人澡人人澡| 日韩精品极品视频在线观看免费| gratisvideos另类灌满| 欧美日韩精品一区二区天天拍小说 | 在线精品国产亚洲| 亚洲一区第一页| 国产一级理论片| 精品一区二区在线视频| 欧美日本亚洲| 爱看av在线| 欧美一区二区在线播放| 美国黄色特级片| 免费在线观看成人av| 痴汉一区二区三区| 国产激情在线视频| 欧美日韩久久久久久| 天堂久久精品忘忧草| 亚洲欧美日韩精品一区二区| 国产精品日本一区二区| av在线app| 欧美精品久久99| 国产91在线播放九色| 日韩高清电影一区| 日韩videos| 朝桐光一区二区| 国产亚洲xxx| 一级黄色在线视频| 久久久夜色精品亚洲| 国产中文字幕在线免费观看| 中文一区二区三区四区| 欧美精品在线第一页| 国产色在线视频| 亚洲欧美日韩国产综合在线| gogogo高清免费观看在线视频| 青青草97国产精品麻豆| 国产精品久久久久久五月尺 | 精品国产一区二区三区久久| 在线黄色av网站| 中文字幕不卡三区| 亚洲少妇久久久| 手机在线一区二区三区| 成人乱色短篇合集| 成人影院www在线观看| 欧美一区二区黄色| 黄色一级片中国| 国产成人高清在线| 欧美日韩福利在线| 亚洲激情播播| 国产精品美女在线观看| 幼a在线观看| 3atv在线一区二区三区| 久久r这里只有精品| 成人国产在线观看| 波多野结衣家庭教师在线播放| 亚洲最好看的视频| 国产精品久久av| 国产原厂视频在线观看| 日韩你懂的在线观看| 国产精品1234区| 久久久精品天堂| 色婷婷成人在线| 中文字幕亚洲综合久久五月天色无吗'' | 亚洲一区二区三区色| 国产亚洲高清在线观看| 久久久久久美女| 国产无套粉嫩白浆在线2022年| 欧美日韩国产乱码电影| 四虎免费在线视频| 99re热这里只有精品视频| 日本在线视频www| 婷婷久久国产对白刺激五月99| 成人av免费电影| 91精品论坛| 久久久999精品| 老牛影视av牛牛影视av| 91久久精品一区二区| 国产稀缺精品盗摄盗拍| 97成人超碰视| 九九热精品国产| 亚洲二区精品| 亚洲精品成人三区| 国产精品色呦| 国产欧美亚洲精品| 僵尸再翻生在线观看| 日韩在线视频观看| 天天干视频在线| 这里是久久伊人| 91video| 亚洲女子a中天字幕| a级大片在线观看| 国产河南妇女毛片精品久久久 | 久久精品久久久精品美女| 国产妇女馒头高清泬20p多| 97精品一区| 久久国产精品-国产精品| avtt久久| 国产精品久久一| 天堂av在线| 欧美大片在线看| 1024视频在线| 日韩精品极品毛片系列视频| 国产特级黄色片| 欧美无砖专区一中文字| 国产又爽又黄的视频| 亚洲欧美电影一区二区| 91视频免费看片| 久久这里只精品最新地址| 欧美日韩一区二区区别是什么| 日本va欧美va精品| 两根大肉大捧一进一出好爽视频| 午夜久久tv| 婷婷视频在线播放| 国产中文精品久高清在线不| 精品欧美国产| 国产精品极品在线观看| 亚洲综合中文字幕在线观看| 全球最大av网站久久| 日本精品一区二区三区在线播放视频| 俄罗斯一级**毛片在线播放| 久久综合五月天| 久久久久久久久免费视频| 一区二区三区美女xx视频| 三级在线视频| 日韩国产精品一区| 熟妇人妻中文av无码| 精品国产成人系列| 亚洲国产成人在线观看| 欧美一区二区三区四区五区| 91麻豆成人精品国产免费网站| 欧美综合在线视频| 波多野结衣绝顶大高潮| 在线观看视频欧美| 日韩中文字幕高清| 欧美性大战xxxxx久久久| 男人日女人网站| 日韩欧美在线视频观看| 最新中文字幕一区| 欧美性猛交xxxx久久久| 69视频免费看| 欧美在线观看一区| 这里只有精品6| 在线不卡一区二区| 99热精品在线播放| 欧美成人官网二区| 免费观看黄一级视频| 亚洲第一页自拍| 九色在线播放| 最近免费中文字幕视频2019| 日本视频在线播放| 色综合天天综合网国产成人网| 肉体视频在线| 97免费视频在线| 久久久一本精品| 成人免费网视频| 99久久香蕉| 欧美日韩国产精品一卡| 成人高清av| 男插女免费视频| 99亚洲视频| 特级丰满少妇一级| 国产麻豆精品视频| 好男人香蕉影院| 国产日产精品1区| 欧美一级片在线视频| 亚洲高清一区二区三区| 日本免费在线观看视频| 欧美日韩国产影片| 成人毛片在线免费观看| 亚洲免费电影在线观看| 色视频在线免费观看| 欧美激情手机在线视频 | 欧美日韩免费一区二区三区| 亚洲AV无码精品国产| 精品视频偷偷看在线观看| 成年人在线视频| 欧美肥婆姓交大片| 日韩国产激情| 91精品久久久久久蜜桃| 亚洲激情播播| 国产在线观看欧美| 久久九九国产| 91精品国产高清91久久久久久 | 欧美成人在线免费观看| 久久久久亚洲| 国产偷人视频免费| 国产老肥熟一区二区三区| 免费在线观看成年人视频| 亚洲色图在线视频| 免费在线不卡视频| 欧美日韩电影一区| 欧美孕妇孕交| 色综合色综合网色综合| 国产成+人+综合+亚洲欧美| 国产91视觉| 天天天综合网| 别急慢慢来1978如如2| 成人av在线资源| 久久爱一区二区| 色噜噜偷拍精品综合在线| 天堂在线观看av| 欧美另类极品videosbestfree| 国产精品亚洲d| 久久久久网址| 好看的av在线不卡观看| 日本免费色视频| 欧美激情自拍偷拍| 无码视频在线观看| 日韩精品免费电影| 久久一卡二卡| 91在线播放视频| 99久久激情| 中文av一区二区三区| 国产日产精品1区| 五月天婷婷导航| 亚洲精品在线看| 午夜激情在线播放| 精品蜜桃传媒| 亚洲视频成人| 欧美bbbbb性bbbbb视频|