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

ELK Stack生產實踐——pod日志采集(EFK方案)

開發 架構
默認情況下fluent-bit通過socket獲取journald日志,但如果使用pod運行fluent-bit時無法獲取journald日志,需要配置journald參數,改為存儲至宿主機本地/var/log/journal目錄下,然后pod掛載宿主機/var/log目錄進而讀取kubelet和container日志。

EFK日志采集方案

方案介紹

  • 實現目標:k8s集群所有節點container和kubelet服務日志采集、k8s集群所有pod日志采集并對自定義應用日志實現過濾和清洗操作。
  • fluent bit采集:相較于fluentd而言,fluent bit更加輕量,且內置了pod日志解析插件和service日志采集功能無需編寫復雜的日志處理配置。因此使用daemonset方式在每個節點部署fluent bit容器,可以最大程度減少資源占用。
  • fluentd處理:雖然fluent bit足夠輕量,但日志解析處理能力弱于fluentd。fluentd支持更多的過濾處理插件,對于常用的數據處理操作,fluentd可以直接通過ruby語法處理,而fluent bit需要開發lua腳本才能實現。
  • fluentd集群方案:使用Fluentd充當日志聚合層,接收fluent-bit日志后統一進行處理操作,最后批量寫入elasticsearch集群。這樣做的好處是當k8s集群規模過大時,避免了過多的fluent-bit連接ES寫入數據,導致ES連接資源消耗過高、網絡擁堵、連接資源競爭等問題。
  • fluent bit+fluentd方案:將日志采集與日志處理拆后分別交由不同的組件負責,最大程度發揮各個組件的優勢,使得配置文件更加清晰易讀,便于后期維護管理。

架構圖

圖片圖片

fluent bit部署與配置

參考文檔

https://docs.fluentbit.io/manual/installation/kubernetes

開啟journal日志持久化

默認情況下fluent-bit通過socket獲取journald日志,但如果使用pod運行fluent-bit時無法獲取journald日志,需要配置journald參數,改為存儲至宿主機本地/var/log/journal目錄下,然后pod掛載宿主機/var/log目錄進而讀取kubelet和container日志。

[root@work1 ~]# vim /etc/systemd/journald.conf
Storage=persistent
[root@work1 ~]# systemctl restart systemd-journald

部署fluent-bit

拉取helm包

[root@master1 ~]# helm repo add fluent https://fluent.github.io/helm-charts
[root@master1 ~]# helm pull fluent/fluent-bit --untar
[root@master1 ~]# cd fluent-bit/
[root@master1 fluent-bit]# ls
Chart.yaml  ci  dashboards  README.md  templates  values.yaml

修改配置

[root@tiaoban fluent-bit]# vim values.yaml
image:
  repository: harbor.local.com/elk/fluentbit # 修改為本地倉庫地址
  tag: v2.1.9 # 指定鏡像版本

config:
 # 默認未配置文件緩沖,新增文件緩沖配置
  service: |
    [SERVICE]
        Daemon Off
        Flush {{ .Values.flush }}
        Log_Level {{ .Values.logLevel }}
        Parsers_File /fluent-bit/etc/parsers.conf
        Parsers_File /fluent-bit/etc/conf/custom_parsers.conf
        HTTP_Server On
        HTTP_Listen 0.0.0.0
        HTTP_Port {{ .Values.metricsPort }}
        Health_Check On
        storage.path              /var/log/flb-storage/ 
        storage.sync              normal               
        storage.checksum          off                   
        storage.backlog.mem_limit 5M 
 
  # 默認配置文件只采集pod和kubelet服務日志,新增containerd日志,并排除Fluentd和Fluent-bit日志采集
  inputs: |
    [INPUT]
        Name systemd
        Tag containerd.service
        Systemd_Filter _SYSTEMD_UNIT=containerd.service
        Read_From_Tail On

    [INPUT]
        Name systemd
        Tag kubelet.service
        Systemd_Filter _SYSTEMD_UNIT=kubelet.service
        Read_From_Tail On

    [INPUT]
        Name tail
        Path /var/log/containers/*.log
        Exclude_Path /var/log/containers/fluent-bit*, /var/log/containers/fluentd-*
        multiline.parser docker, cri
        Tag kube.*
        Mem_Buf_Limit 5MB
        Skip_Long_Lines On
  
  # 原始字段中的time值不是標準時間格式,直接寫入es會報錯,可移除time字段,使用@timestamp標識時間
 filters: |
    [FILTER]
        name        record_modifier
        match       kube.*
        remove_key  time
 
  # 將所有采集到的數據直接轉發至后端fluentd服務。
  outputs: |
    [OUTPUT]
        Name forward
        Match *
        Host fluentd.logging.svc
        Port 8888
        storage.total_limit_size 5M

hotReload:
  enabled: true # 按需開啟配置熱更新
  image:
    repository: harbor.local.com/elk/fluentbit # 修改為本地倉庫地址

部署fluent-bit

[root@tiaoban fluent-bit]# kubectl create ns logging
namespace/logging created
[root@tiaoban fluent-bit]# helm install fluent-bit -n logging . -f values.yaml
NAME: fluent-bit
LAST DEPLOYED: Sat Sep 16 14:46:03 2023
NAMESPACE: logging
STATUS: deployed
REVISION: 1
NOTES:
Get Fluent Bit build information by running these commands:

export POD_NAME=$(kubectl get pods --namespace logging -l "app.kubernetes.io/name=fluent-bit,app.kubernetes.io/instance=fluent-bit" -o jsnotallow="{.items[0].metadata.name}")
kubectl --namespace logging port-forward $POD_NAME 2020:2020
curl http://127.0.0.1:2020

驗證

[root@tiaoban fluent]# cat Dockerfile 
FROM fluent/fluentd:v1.16.2-debian-1.1
USER root
ADD GeoLite2-City.mmdb /fluentd/GeoLite2-City.mmdb
RUN buildDeps="build-essential libgeoip-dev autoconf automake libtool libffi-dev" \
    && sed -i "s@http://deb.debian.org@http://mirrors.aliyun.com@g" /etc/apt/sources.list \
    && apt-get update \
    && apt-get install -y --no-install-recommends $buildDeps \
    && gem sources --add https://gems.ruby-china.com/ --remove https://rubygems.org/ \
    && fluent-gem install fluent-plugin-elasticsearch fluent-plugin-geoip fluent-plugin-rewrite-tag-filter \
    && apt-get autoclean \
    && gem sources --clear-all \
    && rm -rf /var/lib/apt/lists/* \
    && rm -rf /tmp/* /var/tmp/* /usr/lib/ruby/gems/*/cache/*.gem
[root@tiaoban fluent]# docker build -t harbor.local.com/elk/fluentd:fluentd:v1.16.2 .
[root@tiaoban fluent]# docker push harbor.local.com/elk/fluentd:fluentd:v1.16.2

fluentd部署與配置

構建fluentd鏡像

由于fluentd鏡像未安裝elasticsearch、geoip、rewrite-tag-filter插件,如果在pod的init階段在線安裝插件經常會導致拉取超時無法正常啟動。因此需要提前構建包含相關插件的fluentd鏡像,并上傳至harbor倉庫中。

[root@tiaoban fluentd]# cat fluentd-conf.yaml 
apiVersion: v1
kind: ConfigMap
metadata:
  name: fluentd-conf
  namespace: logging
data:
  fluent.conf : |-
    <source>
      @type forward
      port 8888
      bind 0.0.0.0
    </source>

    <match *.service>
      @type elasticsearch
      host elasticsearch-es-http.elk.svc
      port 9200
      default_elasticsearch_version 8
      user elastic
      scheme https
      password 78HOWor95Iiot076O59xq2Am
      ssl_verify false
      data_stream_name logs-${tag}-fluentd
      include_timestamp true
      <buffer>
        @type file
        flush_interval 5s
        path /fluentd/buf/service-logs.*
      </buffer>
    </match>

    <match kube.**>
      @type elasticsearch
      host elasticsearch-es-http.elk.svc
      port 9200
      default_elasticsearch_version 8
      user elastic
      scheme https
      password 78HOWor95Iiot076O59xq2Am
      ssl_verify false
      data_stream_name logs-pod-fluentd
      include_timestamp true
      <buffer>
        @type file
        flush_interval 5s
        path /fluentd/buf/pod-logs.*
      </buffer>
    </match>

fluentd部署配置

fluentd使用deployment控制器部署多副本集群,用于接收fluent bit的數據然后寫入es的數據流中。

  • fluentd-conf.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: fluentd
  namespace: logging
spec:
  replicas: 3
  selector:
    matchLabels:
      app: fluentd
  template:
    metadata:
      labels:
        app: fluentd
    spec:
      containers:
      - name: fluentd
        image: harbor.local.com/elk/fluentd:v1.16.2
        resources:
          limits:
            memory: "128Mi"
            cpu: "500m"
        ports:
        - containerPort: 8888
        volumeMounts:
          - name: fluentd-conf
            mountPath: /fluentd/etc/fluent.conf
            subPath: fluent.conf
      volumes:
        - name: fluentd-conf
          configMap:
            name: fluentd-conf
  • fluentd-svc.yaml
apiVersion: v1
kind: Service
metadata:
  name: fluentd
  namespace: logging
spec:
  selector:
    app: fluentd
  ports:
  - port: 8888
    targetPort: 8888
  • fluentd.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: fluentd
  namespace: logging
spec:
  replicas: 3
  selector:
    matchLabels:
      app: fluentd
  template:
    metadata:
      labels:
        app: fluentd
    spec:
      containers:
      - name: fluentd
        image: harbor.local.com/elk/fluentd:v1.16.2
        resources:
          limits:
            memory: "128Mi"
            cpu: "500m"
        ports:
        - containerPort: 8888
        volumeMounts:
          - name: fluentd-conf
            mountPath: /fluentd/etc/fluent.conf
            subPath: fluent.conf
      volumes:
        - name: fluentd-conf
          configMap:
            name: fluentd-conf

部署fluentd服務

[root@tiaoban fluentd]# ls
Dockerfile  fluentd-conf.yaml  fluentd-svc.yaml  fluentd.yaml  GeoLite2-City.mmdb
[root@tiaoban fluentd]# kubectl apply -f .
configmap/fluentd-conf created
service/fluentd created
deployment.apps/fluentd created

訪問驗證

此時查看kibana索引管理,已成功創建了pod、containerd、kubelet日志數據流。

圖片圖片

service日志處理

雖然我們已經將service日志存儲在了elasticsearch中,但觀察發現默認情況下日志內容都在MESSAGE字段中,通常情況下,我們只會關注日志等級為warning和error的日志,因此我們需要對該字段內容做解析處理。

日志內容分析

觀察container日志可知,MESSAGE中包含了日志時間、日志等級、日志內容三部分內容

圖片圖片

觀察kubelet日志,MESSAGE中包含了日志時間、處理函數、日志內容三部分內容

圖片圖片

新增service日志處理規則

我們可以通過正則匹配插件實現MESSAGE字段值解析操作,需要注意的是正則匹配時一定是所有字段都包含,否則會因為匹配不到而無法過濾處理操作。

  • service-conf.yaml
apiVersion: v1
kind: ConfigMap
metadata:
  name: service-conf
  namespace: logging
data:
  service.conf : |
    <filter containerd.service>
      @type parser
      key_name MESSAGE
      reserve_data true
      <parse>
        @type regexp
        expression /time="(?<time>[^"]+)" level=(?<level>[^ ]+) msg="(?<msg>[^"]+)"/
        time_key time
        time_format %Y-%m-%dT%H:%M:%S.%N%z
      </parse>
    </filter>

    <filter kubelet.service>
      @type parser
      key_name MESSAGE
      reserve_data true
      <parse>
        @type regexp
        expression /[EI](?<time>\d{4} \d{2}:\d{2}:\d{2}.\d{6}) +\d* (?<class>\w*).go:\d*] (?<message>.*)/
        time_key time
        time_format %m%d %H:%M:%S.%N
        timezone +08:00
      </parse>
    </filter>

    <match *.service>
      @type elasticsearch_data_stream
      host elasticsearch-es-http.elk.svc
      port 9200
      default_elasticsearch_version 8
      user elastic
      scheme https
      password 78HOWor95Iiot076O59xq2Am
      ssl_verify false
      data_stream_name logs-${tag}-fluentd
      include_timestamp true
      <buffer>
        @type file
        path /fluentd/buf/service-logs.*
      </buffer>
    </match>

訪問驗證

查看containerd服務日志,已成功解析了MESSAGE字段內容,并新增了@timestamp、leve、msg字段

圖片圖片

查看kubelet服務日志,同樣成功解析了MESSAGE字段內容,并新增了@timestamp、class、message字段

圖片圖片

自定義日志解析

需求分析

默認情況下,fluent bit會采集所有pod日志信息,并自動添加namespace、pod、container等信息,所有日志內容存儲在log字段中。 以log-demo應為日志為例,將所有日志內容存儲到log字段下無法很好的解析日志內容,因此需要編寫fluentd解析規則,實現日志內容解析。

圖片圖片

新增自定義日志處理規則

使用rewrite_tag_filter插件,匹配到container_name字段值為log-demo的事件時,新增myapp.log標簽,接下來對myapp.log標簽的事件進一步做解析處理操作。

  • myapp-conf.yaml
apiVersion: v1
kind: ConfigMap
metadata:
  name: myapp-conf
  namespace: logging
data:
  myapp.conf : |
    <match kube.**>
      @type rewrite_tag_filter
      <rule>
        key $.kubernetes.container_name
        pattern log-demo
        tag myapp.log
      </rule>
    </match>

    <filter myapp.log>
      @type parser
      key_name log
      <parse>
        @type regexp
        expression /^(?<logtime>[^|]+) \| (?<level>[A-Z]*) *\| __main__:(?<class>\D*:\d*) - (?<content>.*)$/
        time_key logtime
        time_format %Y-%m-%d %H:%M:%S.%L
      </parse>
    </filter>

    <filter myapp.log>
      @type record_transformer
      enable_ruby
      <record>
        content ${record["content"].gsub("'", '"')}
      </record>
    </filter>

    <filter myapp.log>
      @type parser
      key_name content
      <parse>
        @type json
      </parse>
    </filter>

    <filter myapp.log>
      @type geoip
      geoip_lookup_keys remote_address
      geoip2_database /fluentd/GeoLite2-City.mmdb
      backend_library geoip2_c
      <record>
        geoip_city            ${city.names.en["remote_address"]}
        geoip_latitude        ${location.latitude["remote_address"]}
        geoip_longitude       ${location.longitude["remote_address"]}
        geoip_country         ${country.iso_code["remote_address"]}
        geoip_country_name    ${country.names.en["remote_address"]}
        geoip_postal_code     ${postal.code["remote_address"]}
        geoip_region_name     ${subdivisions.0.names.en["remote_address"]}
      </record>
    </filter>

    <match myapp.log>
      @type elasticsearch_data_stream
      host elasticsearch-es-http.elk.svc
      port 9200
      default_elasticsearch_version 8
      user elastic
      scheme https
      password 78HOWor95Iiot076O59xq2Am
      ssl_verify false
      data_stream_name logs-myapp-default
      include_timestamp true
      <buffer>
        @type file
        flush_interval 5s
        path /fluentd/buf/myapp-logs.*
      </buffer>
    </match>

訪問驗證

查看kibana索引信息,已成功創建名為logs-myapp-default的數據流。

圖片圖片

查看logs-myapp-default字段信息,已成功解析了日志內容。

圖片圖片

完整資源清單

本實驗案例所有yaml文件已上傳至git倉庫。訪問地址如下:

Github

https://github.com/cuiliang0302/blog-demo

Gitee

https://gitee.com/cuiliang0302/blog_demo

參考文檔

fluent bit轉發事件至fluentd:

https://docs.fluentbit.io/manual/pipeline/outputs/forward

構建自定義fluentd鏡像:

https://github.com/fluent/fluentd-docker-image#31-for-current-images

fluentd重寫事件tag:

https://docs.fluentd.org/output/rewrite_tag_filter

博客鏈接:https://www.cuiliangblog.cn/

責任編輯:武曉燕 來源: 崔亮的博客
相關推薦

2023-10-20 15:08:28

pod日志采集

2023-09-05 07:40:37

PythonSDKAPI

2017-01-10 16:04:02

容器MySQL實踐

2022-06-03 09:21:47

Svelte前端攜程

2021-03-12 07:47:44

KubernetesRedis-clustRedis

2023-07-12 16:07:50

鏈路數據湖技術

2020-12-31 10:48:17

ELKEFKLinux

2021-07-20 08:32:16

Kubernetes日志平臺

2021-07-19 09:18:07

KubernetesELK Stackk8s

2023-12-08 07:59:04

2023-10-09 14:36:28

工具PLGEFK

2023-10-16 16:00:27

Redis限流

2022-07-08 09:26:45

Flink快手計算

2022-03-08 08:21:21

Spring日志分析系統日志數據

2022-09-19 08:35:28

Kafka節點故障

2022-04-29 09:04:35

日志平臺開發

2022-11-23 21:51:42

大數據

2024-12-09 08:27:02

2018-10-17 10:49:49

Kubernetes存儲處理
點贊
收藏

51CTO技術棧公眾號

精品动漫3d一区二区三区免费版| jizz久久久久久| 91香蕉视频在线| 国产精品免费久久久| 翔田千里88av中文字幕| 狠狠一区二区三区| 国产精品欧美久久久久无广告 | 激情欧美日韩一区二区| 久久久免费在线观看| 久久久久亚洲av无码a片| 欧洲一区在线| 欧美性猛片xxxx免费看久爱| 日本黄网站色大片免费观看| 久久久久久久久久一级| 中文视频一区| 亚洲午夜av电影| 黄色a级三级三级三级| 五月婷婷在线视频| 9色porny自拍视频一区二区| 国产精品一区二区久久精品| 成年人在线免费看片| 欧美日韩美女| 亚洲一区二区在线视频| 图片区小说区区亚洲五月| 日本黄色不卡视频| 国内精品视频666| 久久国产精品久久久久| 亚洲一级片在线播放| 国产精品亚洲成在人线| 中文字幕中文字幕一区二区| 精品中文字幕人| 伦av综合一区| 水蜜桃精品av一区二区| 亚洲人成电影网站色…| 国产中文字幕一区二区| 一区二区三区四区精品视频| 亚洲第一福利视频在线| 欧美日韩中文字幕在线播放| 在线免费黄色| 中文字幕不卡一区| 91九色偷拍| 亚欧视频在线观看| 国产精品九九| 夜夜嗨av色一区二区不卡| 国产熟女高潮一区二区三区| 都市激情久久| 精品少妇一区二区三区| 国产日韩一区二区在线观看| segui88久久综合9999| 亚洲一区二区三区四区在线观看 | 伊人免费在线| 国产精品一区二区在线播放| 久久久久久成人精品| 国产精品揄拍100视频| 成人爽a毛片免费啪啪红桃视频| 欧美午夜精品久久久久久久| 亚洲视频精品一区| 二区三区在线视频| 麻豆一区二区99久久久久| 国产精品久久一区| 国产又粗又猛又爽又黄视频| 国产日韩欧美三区| 欧美成人免费播放| 九九热视频精品| 亚洲国产二区| 欧美在线视频一区二区| 无码人妻精品一区二区三区夜夜嗨| 91蜜臀精品国产自偷在线 | 激情小说综合网| 在线观看一二三区| 精品无码三级在线观看视频| 欧美有码在线观看| 亚洲欧美一区二区三区在线观看| 日韩综合小视频| 国产精品一区二区三区久久久| 91久久国产视频| 国产一区二区三区四区三区四| 欧美极品美女视频网站在线观看免费| 国产精品成人av久久| 国产精品婷婷| 国产精品一区=区| 亚洲国产一区在线| www.av网站| 成人午夜伦理影院| 日本免费高清一区二区| 亚洲国产精品视频在线| 播五月开心婷婷综合| 国产精品盗摄久久久| 可以在线观看av的网站| 欧美午夜免费影院| 日本视频久久久| 91亚洲精品国偷拍自产在线观看| 久久精品30| 91精品久久久久久久久青青| 色呦呦中文字幕| 国产欧美日韩激情| 日韩电影在线播放| a级影片在线观看| 亚洲视频一区在线观看| 日韩av三级在线| 色综合视频一区二区三区日韩| 精品久久久久av影院| 精人妻一区二区三区| 亚洲国产一区二区三区网站| 91麻豆精品91久久久久久清纯| 日韩一区二区av| 国产91在线播放| 中文字幕在线观看1| 国产精品一区久久久久| 国内精品久久久久影院一蜜桃| 老司机精品视频导航| 国产成人ay| 亚洲国产wwwccc36天堂| 国产熟人av一二三区| 亚洲综合伊人| 激情婷婷综合| 在线观看小视频| 国产性猛交xx乱| 不卡视频在线播放| 黑人巨大精品欧美黑白配亚洲| 国产精品一区二区三区在线观| 99视频免费看| 国产在线精品视频| 国产一区免费观看| www.国产com| 日本成人中文| 欧美极品少妇xxxxⅹ裸体艺术| 中文字幕在线播放不卡| 久久亚洲精华国产精华液 | 国产日韩中文在线| 中文亚洲av片在线观看| 99re这里只有精品视频首页| 国产精品白丝jk白祙| 人人妻人人澡人人爽久久av| 久久先锋影音av鲁色资源网| 大伊香蕉精品视频在线| 免费看一区二区三区| 欧美精品一区二区高清在线观看| 久久精品日韩无码| 国产综合久久| 成人免费看片网站| 黄色大片在线看| 精品美女久久久久久免费| 无码少妇一区二区三区芒果| 欧美绝顶高潮抽搐喷水合集| 国产一区二区三区在线视频| 国产一二三四区| 国产精品日韩| 亚洲一区二区三区视频| 天天干天天爽天天操| 亚洲一区二区三区美女| 国产chinesehd精品露脸| 正在播放日韩欧美一页| 欧洲亚洲在线视频| 天天影院图片亚洲| 1000精品久久久久久久久| av高清在线免费观看| 韩国精品福利一区二区三区| 久久久久久成人精品| 色欲久久久天天天综合网| 国产精品人人做人人爽人人添| www.com操| 亚洲女同另类| 国产精品久久国产三级国电话系列| 大黄网站在线观看| 欧美日本乱大交xxxxx| 波多野结衣久久久久| 激情深爱一区二区| 欧美黄色免费网址| 欧美成人基地| 欧美激情喷水视频| 五月天婷婷在线观看| 日韩欧美在线观看| 99精品一区二区三区无码吞精| aa亚洲婷婷| 日韩中文一区二区三区| 四虎影视精品永久在线观看| 亚洲人成亚洲人成在线观看| 中文字幕一区二区三区手机版| 91原创在线视频| 尤蜜粉嫩av国产一区二区三区| 青青草这里只有精品| 国产成人综合精品| а√天堂8资源在线官网| 精品久久久久久久久久久久久久久| 免费看一级黄色| 国产91在线看| 嫩草影院国产精品| 欧美日韩中文字幕一区二区三区 | 丁香社区五月天| 国产精品国产三级国产普通话蜜臀| 污污视频在线免费| 久久久9色精品国产一区二区三区| 国产精品美女www| 日本天码aⅴ片在线电影网站| 亚洲免费精彩视频| 国产剧情在线视频| 亚洲精品日韩一| 精品无码一区二区三区 | 久久免费精品国产| 日韩成人一级大片| 亚洲 欧美 综合 另类 中字| 亚洲一区二区三区四区电影| 欧美在线视频a| 50度灰在线| 日韩欧美精品在线视频| avove在线播放| 中文字幕第一区综合| 在线黄色免费网站| 国产综合久久久久久久久久久久| 亚洲综合第一| 高清国产一区二区三区四区五区| 成年无码av片在线| 亚洲第一页综合| 亚洲1区2区3区视频| 波多野结衣先锋影音| 国产原创一区二区| 青青草精品视频在线观看| 97精品中文字幕| 91pron在线| 日韩美女在线| 欧美俄罗斯性视频| 午夜小视频在线播放| 日韩一区二区三区视频在线观看| 国产一级视频在线观看| 久久亚洲一区二区三区四区| 在线观看免费黄网站| 香蕉视频国产精品| 国产无套精品一区二区| 欧美视频二区欧美影视| 国产日韩换脸av一区在线观看| 色www永久免费视频首页在线 | 99在线视频影院| 日韩福利视频在线观看| 正在播放木下凛凛xv99| 亚洲欧美成人一区二区三区| a资源在线观看| 久久精品视频在线看| 少妇毛片一区二区三区| 裸体在线国模精品偷拍| 丁香婷婷激情网| 欧美特黄一区| 国内少妇毛片视频| 色婷婷色综合| 亚洲视频在线观看日本a| 久久精品亚洲成在人线av网址| 国产福利成人在线| 第四色男人最爱上成人网| 欧美成人免费大片| 2024最新电影在线免费观看| 久久久极品av| 国产中文在线观看| 欧美成人福利视频| 丰满肥臀噗嗤啊x99av| 亚洲成人久久久久| 国产又大又粗又硬| 色综合色综合色综合| 亚洲s码欧洲m码国产av| 色猫猫国产区一区二在线视频| 国产成人精品777777| 欧美三级韩国三级日本一级| 国产成人在线播放视频| 精品久久久久久中文字幕| 亚洲天堂黄色片| 亚洲午夜三级在线| 特级西西444www大精品视频免费看| 亚洲色图欧美在线| 国产免费看av| 中文字幕精品三区| 男女做爰猛烈刺激| 日本一区二区三区在线不卡| 国产免费嫩草影院| 2020国产精品| 五月激情四射婷婷| 一区二区三区波多野结衣在线观看| 国产大片中文字幕| 色噜噜狠狠成人中文综合| 一级片免费网址| 在线观看精品一区| 国产一级片免费在线观看| 教室别恋欧美无删减版| 日韩中文字幕久久| 桃花色综合影院| 这里只有精品视频| 在线中文字幕电影| 国产成人精品一区二区在线 | 亚洲最黄网站| www.涩涩涩| 亚洲国产美女 | 亚洲女同二女同志奶水| 伊人开心综合网| 精品99久久久久成人网站免费| 精品久久久久久久久久久久| 日韩欧美视频在线免费观看| 亚洲成人免费视频| 亚洲熟女乱色一区二区三区久久久| 一本久久a久久精品亚洲| 制服.丝袜.亚洲.中文.综合懂色| 亚洲成av人片观看| 做爰视频毛片视频| 亚洲成人网在线观看| 艳母动漫在线看| 亚洲精品一区中文| 91麻豆免费在线视频| 国产精品成人aaaaa网站| 国产精品qvod| 国产精品jizz在线观看老狼| 婷婷亚洲图片| 男女激烈动态图| 日本成人中文字幕| 免费的av网站| 亚洲精品伦理在线| 一级片在线免费观看视频| 欧美日韩和欧美的一区二区| 香蕉视频国产在线| 欧美黑人性生活视频| 欧美一级做a| 亚洲不卡1区| 亚洲经典自拍| 四虎国产精品永久免费观看视频| 国产成人免费在线观看不卡| 大胸美女被爆操| 91福利在线导航| 一区二区三区黄| 一区二区av在线| 电影一区二区三区| 国产青春久久久国产毛片| 奇米色欧美一区二区三区| 青青草成人免费在线视频| 国产成人啪免费观看软件| 91在线播放观看| 91精品一区国产高清在线gif| 51精品国产黑色丝袜高跟鞋| 日韩国产在线不卡视频| 狠狠干一区二区| 欧美视频免费| 欧美激情精品久久久久久小说| 久久国产精品99久久人人澡| 一区二区三区伦理片| 色乱码一区二区三区88| 久蕉依人在线视频| 伦理中文字幕亚洲| 警花av一区二区三区| 久久久一本精品99久久精品| 久久精品高清| 欧美成年人视频在线观看| 国产精品嫩草99a| 日韩免费不卡视频| 日韩成人在线播放| 国产在线看片| 日本高清视频精品| 深夜福利一区| 亚洲黄色一区二区三区| 亚洲激情在线| www.久久国产| 亚洲夂夂婷婷色拍ww47| 北条麻妃一二三区| 97视频在线免费观看| 亚洲理论电影| 欧美一区二区视频在线播放| 免费视频久久| 国产123在线| 欧美日韩国内自拍| 国产高清在线观看视频| 亚洲日韩欧美视频| 成人看片毛片免费播放器| 中文字幕中文字幕在线中一区高清| 欧美一级播放| 麻豆短视频在线观看| 午夜视频在线观看一区| 精品国产免费无码久久久| 久久久久久国产精品三级玉女聊斋 | 2025中文字幕| 中文字幕视频一区| 特级西西444www大胆免费看| 精品国产欧美成人夜夜嗨| 亚洲专区**| 国产v亚洲v天堂无码久久久| 国产精品久久久久久久岛一牛影视| 国产av无码专区亚洲av| 少妇高潮久久77777| 91成人精品在线| av网址在线观看免费| 亚洲欧美日韩一区| 天堂av电影在线观看| 7777精品久久久久久| 一区二区三区自拍视频| 警花观音坐莲激情销魂小说| 成人动漫中文字幕| 国产在线一二区| 亚洲欧美国产精品va在线观看| 成人四虎影院| 青青草国产精品视频| 成人动漫一区二区三区| 久久精品波多野结衣| 日韩精品中午字幕| 日本三级韩国三级欧美三级| 欧美在线视频二区| 国产91丝袜在线18| 中文字幕有码无码人妻av蜜桃|