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

Python 自動化:eip、cen監控數據對接到grafana

開發 前端
通過本文的步驟,我們可以通過API獲取阿里云 EIP 和 CEN 的監控數據,將其存儲到 InfluxDB,并通過 Grafana 進行實時監控和可視化。這為我們提供了一種自動化的方式來監控和管理阿里云網絡資源。?

概覽

日常運維中,我們有時需要關注阿里云中 EIP 和 CEN 的監控數據,如果每次登錄到平臺查看,不太方便。

可以通過 API 獲取監控數據,并輸入到 influxDB,然后再到 Grafana 中展示,以便進行實施監控和可視化。

第一步:準備工作

在開始之前,我們需要確保已經完成以下準備工作

準備阿里云的EIP和CEN實例

這一步省略

了解如何獲取EIP和CEN數據

了解如何獲取 EIP 和 CEN 數據

我的方式是 EIP 通過 EIP 產品的 API 獲取的,調試鏈接如下

https://next.api.aliyun.com/api/Vpc/2016-04-28/DescribeEipMonitorData?params={"RegionId":"cn-hangzhou"}

輸入 RegionId 和 AllocationId 等必選信息后,復制平臺生成的代碼,進行更改,下文會介紹如何更改

圖片圖片

CEN 的監控數據未找到具體的 API,但可以通過云監控的數據獲取,也是很方便的,鏈接如下

https://api.aliyun.com/api/Cms/2019-01-01/DescribeMetricData

獲取 CEN 的具體數據時,可以通過 https://cms.console.aliyun.com/metric-meta/acs_cen/cen_tr?spm=a2c4g.11186623.0.0.252476ab1Ldq0T 得到

實際上,EIP 的數據也可以通過云監控獲取

安裝Python和所需的依賴庫

下面示例的版本是截止發文時間最新版本,實際使用時,可以登錄到上面的阿里云開放平臺查看最新的版本

pip install alibabacloud_vpc20160428==5.1.0
pip install alibabacloud_cms20190101==2.0.11

安裝InfluxDB,并進行初始化配置

1. 為方便使用,我這里是使用 Docker 運行的 Influxdb

cd /data/influxdb


# 生成初始的配置文件
docker run --rm influxdb:2.7.1 influxd print-config > config.yml


# 啟動容器
docker run --name influxdb -d -p 8086:8086 --volume `pwd`/influxdb2:/var/lib/influxdb2 --volume `pwd`/config.yml:/etc/influxdb2/config.yml influxdb:2.7.1

2. 安裝完成后,可通過 http://ip:8086 登錄到 Influxdb

3. 創建 bucket

只需要創建一個 bucket 就可以了,bucket 類似 MySQL 的 database

4. 獲取 API Token,在 Python 插入數據時會用到

安裝Grafana,并進行基本的配置

省略

第二步:獲取API訪問憑證

為了能夠通過API訪問阿里云的 EIP 和 CEN 數據,我們需要獲取訪問憑證。具體步驟如下

  1. 登錄阿里云控制臺
  2. 創建 RAM 用戶并分配相應的權限
  3. 獲取 RAM 用戶的 Access Key ID 和 Access Key Secret

第三步:編寫Python腳本

使用Python編寫腳本來獲取 EIP 和 CEN 的監控數據,并將其存儲到 InfluxDB 中

本文僅展示部分代碼,如需完整的代碼,請聯系本公眾號獲取~

調整從阿里云復制的示例代碼

1. 修改構造函數,可以傳如 access_key_id 和 access_key_secret

def __init__(self, access_key_id: str=access_key_id, access_key_secret: str=access_key_secret):
        self.access_key_id = access_key_id
        self.access_key_secret = access_key_secret

2. 修改獲取 eip 數據的函數

def get_eip_monitor_data(self, region_id, allocation_id, start_time: str, end_time: str):
        '''
        參考文檔:
        https://api.aliyun.com/api/Vpc/2016-04-28/DescribeEipMonitorData?params={%22RegionId%22:%22cn-hangzhou%22}


        Args:
            region_id (_type_): _description_
            allocation_id (_type_): _description_
            start_time (str): utc時間
            end_time (_type_): utc時間


        Yields:
            _type_: _description_
            eip_tx: 流出的流量。單位: Byte
            eip_rx: 流入的流量。單位: Byte
        '''
        # 請確保代碼運行環境設置了環境變量 ALIBABA_CLOUD_ACCESS_KEY_ID 和 ALIBABA_CLOUD_ACCESS_KEY_SECRET。
        # 工程代碼泄露可能會導致 AccessKey 泄露,并威脅賬號下所有資源的安全性。以下代碼示例使用環境變量獲取 AccessKey 的方式進行調用,僅供參考,建議使用更安全的 STS 方式,更多鑒權訪問方式請參見:https://help.aliyun.com/document_detail/378659.html
        client = self.create_client(endpoint=f'vpc.{region_id}.aliyuncs.com', access_key_id=self.access_key_id, access_key_secret=self.access_key_secret)
        describe_eip_monitor_data_request = vpc_20160428_models.DescribeEipMonitorDataRequest(
            region_id=region_id,
            allocation_id=allocation_id,
            start_time=start_time,
            end_time=end_time
        )
        log.debug(msg=describe_eip_monitor_data_request)
        runtime = util_models.RuntimeOptions()
        log.debug(msg=runtime)
        try:
            # 復制代碼運行請自行打印 API 的返回值
            results = client.describe_eip_monitor_data_with_options(describe_eip_monitor_data_request, runtime).body.eip_monitor_datas.eip_monitor_data
            for result in results:
                yield result


        except Exception as error:
            log.error(msg=error)
            return UtilClient.assert_as_string(error.message)

3. 修改獲取 cen 數據的函數

def get_cen_monitor_data(self, namespace, metric_name, start_time: str, end_time: str):
        # 請確保代碼運行環境設置了環境變量 ALIBABA_CLOUD_ACCESS_KEY_ID 和 ALIBABA_CLOUD_ACCESS_KEY_SECRET。
        # 工程代碼泄露可能會導致 AccessKey 泄露,并威脅賬號下所有資源的安全性。以下代碼示例使用環境變量獲取 AccessKey 的方式進行調用,僅供參考,建議使用更安全的 STS 方式,更多鑒權訪問方式請參見:https://help.aliyun.com/document_detail/378659.html
        client = self.create_client(access_key_id=self.access_key_id, access_key_secret=self.access_key_secret)
        describe_metric_list_request = cms_20190101_models.DescribeMetricListRequest(
            namespace=namespace,
            metric_name=metric_name,
            start_time=start_time,
            end_time=end_time,
        )
        runtime = util_models.RuntimeOptions()
        try:
            # 復制代碼運行請自行打印 API 的返回值
            return client.describe_metric_list_with_options(describe_metric_list_request, runtime).body.datapoints


        except Exception as error:
            # 如有需要,請打印 error
            UtilClient.assert_as_string(error.message)

編寫InfluxDB相關的代碼

將 InfluxDB 的寫入代碼獨立出來可以方便后續其他業務的調用

下面的代碼在獲取 token 時,使用了 1password,可視情況進行修改,例如通過環境變量的方式獲取 Token

#!/usr/bin/env python3




import influxdb_client, time
import datetime
from influxdb_client import InfluxDBClient, Point, WritePrecision
from influxdb_client.client.write_api import SYNCHRONOUS
from modules.onepassword import OnePassword


my1p = OnePassword()




class InfluxClient:
    token = my1p.get_item_by_title(title='my_influxdb')['api']
    def __init__(self, url: str='http://10.1.1.1:8086', org: str='tyun', token: str=token):
        self.url = url
        self.org = org
        self.token = token
    
    def create_client(self):
        return influxdb_client.InfluxDBClient(url=self.url, token=self.token, org=self.org)


    def write_aliyun_eip(self, bucket: str='example', table_name: str='test1', location: str=None, eip_tx: int=None, eip_rx: int=None, time_stamp: str=None):
        write_api = self.create_client().write_api(write_optinotallow=SYNCHRONOUS)


        point = (
            Point(table_name)
            .tag("location", location)
            .field("eip_tx", eip_tx)
            .field("eip_rx", eip_rx)
            .time(time_stamp)
        )
        write_api.write(bucket=bucket, org=self.org, record=point)


    def write_cen(self, bucket: str='example', table_name: str='test1', location: str=None, tr_instance_id: str=None, value: int=None, time_stamp: str=None):
        write_api = self.create_client().write_api(write_optinotallow=SYNCHRONOUS)
        point = (
            Point(table_name)
            .tag("location", location)
            .tag("tr_instance_id", tr_instance_id)
            .field("value", value)
            .time(time_stamp)
        )
        write_api.write(bucket=bucket, org=self.org, record=point)








def main():
    influx_client = InfluxClient() 
    for i in range(5):
        influx_client.write_data(bucket='example', table_name='test1', locatinotallow='hangzhou', EipBandwidth=i, EipFlow=i)
        time.sleep(1)




if __name__ == '__main__':
    main()

編寫主程序

1. 獲取 eip 并插入到 influxdb

#!/usr/bin/env python3


from collections import namedtuple
from modules.aliyun.eip import Eip
from modules.database.influxdb.write import InfluxClient
from modules.tools.my_time import MyDatetime as my_time


eip = Eip()
influx_client = InfluxClient()


def insert_data(region_id, location, table_name, allocation_id, start_time, end_time):
    '''
    _summary_


    Args:
        region_id (_type_): _description_
        location (_type_): _description_
        table_name (_type_): _description_
        allocation_id (_type_): _description_
        start_time (_type_): _description_
        interval (int, optional): 取值的范圍, 默認是5.
    '''


    eip_datas = eip.get_eip_monitor_data(region_id=region_id, allocation_id=allocation_id, start_time=start_time, end_time=end_time)
    for eip_data in eip_datas:
        # print(eip_data)
        influx_client.write_aliyun_eip(bucket='example',
                                       table_name=table_name,
                                       locatinotallow=location,
                                       eip_rx=eip_data.eip_rx,
                                       eip_tx=eip_data.eip_tx,
                                       time_stamp=eip_data.time_stamp)


Instance = namedtuple('Instance', ['region_id', 'allocation_id', 'bandwidth', 'env'])


hangzhou = Instance(region_id='hangzhou', allocation_id='eip-xxxxxxxxx', bandwidth='100m', env='prod')




eip_site_list = [hangzhou]


for eip_site in eip_site_list:
    insert_data(region_id=f'cn-{eip_site.region_id}', 
                locatinotallow=f'cn-{eip_site.region_id}',
                table_name='eip',
                allocation_id=eip_site.allocation_id,
                start_time=my_time.get_utc_now_str_offset(offset=-60*10),
                end_time=my_time.get_utc_now_str()
                )

2. 獲取 cen 數據并插入到 influxdb

#!/usr/bin/env python3


import ast
from modules.aliyun.metrics import Metrics
from modules.database.influxdb.write import InfluxClient
from modules.tools.my_time import MyDatetime as my_time
from modules.logger.client import LogClient




metrics = Metrics()
influx_client = InfluxClient()
log = LogClient(app='example_traffic')




def tr_instance_id_to_location(tr_instance_id):
    if tr_instance_id == 'tr-xxxxxxxxxxxxx':
        location = 'hangzhou'
        bandwidth = '20m'
    else:
        location = 'none'
    return location, bandwidth




metric_names = ['AttachmentOutRate', 'AttachmentInRate']




for metric_name in metric_names:
    results = metrics.get_cen_monitor_data(namespace='acs_cen', 
                                           metric_name=metric_name, 
                                           start_time=my_time.get_utc_now_str_offset(offset=-60*10),
                                           end_time=my_time.get_utc_now_str())
    log.debug(msg=results)


    for result in ast.literal_eval(results):
        result['metric_name'] = metric_name
        trInstanceId = result['trInstanceId']
        result['location'] = tr_instance_id_to_location(tr_instance_id=trInstanceId)[0]
        result['bandwidth'] = tr_instance_id_to_location(tr_instance_id=trInstanceId)[1]
        
        log.info(msg=metric_name + ' ' + my_time.timestamp_to_str(timestamp=result['timestamp']) + ' ' + ' ' + result['location'] + ' ' + str(result['Value']))


        influx_client.write_cen(bucket='example', 
                                table_name=metric_name, 
                                locatinotallow=result['location'],
                                tr_instance_id=result['trInstanceId'], 
                                value=result['Value'], 
                                time_stamp=my_time.timestamp_to_str(timestamp=result['timestamp']))

第四步:配置Grafana

在Grafana中配置 InfluxDB 數據源,并創建相應的儀表盤來展示 EIP 和 CEN 的監控數據。具體步驟如下:

  1. 添加 InfluxDB 數據源,并配置連接信息我用的是 Flux 的查詢語言,配置數據源時,需要注意以下事項:

數據源名字推薦使用:InfluxDB-Flux,注明是 Flux 類型的數據源

InfluxDB Details 填寫 Organization、Token、Default Bucket 即可

不用填寫 HTTP 認證

  1. 創建儀表盤,配置 eip 和 cen 的查詢語句· EIP 接收方向的流量
from(bucket: "example")
  |> range(start: v.timeRangeStart, stop: v.timeRangeStop)
  |> filter(fn: (r) => r["_measurement"] == "eip")
  |> filter(fn: (r) => r["_field"] == "eip_rx")
  |> filter(fn: (r) => r["location"] == "cn-hangzhou")
  |> aggregateWindow(every: v.windowPeriod, fn: last, createEmpty: false)
  |> map(fn: (r) => ({ r with _value: r._value / 8 }))
  |> yield(name: "last")
  •  EIP 發送方向的流量
from(bucket: "example")
  |> range(start: v.timeRangeStart, stop: v.timeRangeStop)
  |> filter(fn: (r) => r["_measurement"] == "eip")
  |> filter(fn: (r) => r["_field"] == "eip_tx")
  |> filter(fn: (r) => r["location"] == "cn-hangzhou")
  |> aggregateWindow(every: v.windowPeriod, fn: last, createEmpty: false)
  |> map(fn: (r) => ({ r with _value: r._value / 8 }))
  |> yield(name: "last")
  •  CEN 發送方向的流量
from(bucket: "example")
  |> range(start: v.timeRangeStart, stop: v.timeRangeStop)
  |> filter(fn: (r) => r["_measurement"] == "AttachmentOutRate")
  |> filter(fn: (r) => r["_field"] == "value")
  |> filter(fn: (r) => r["location"] == "hangzhou")
  |> aggregateWindow(every: v.windowPeriod, fn: last, createEmpty: false)
  |> yield(name: "last")
  • CEN 接收方向流量
from(bucket: "example")
  |> range(start: v.timeRangeStart, stop: v.timeRangeStop)
  |> filter(fn: (r) => r["_measurement"] == "AttachmentInRate")
  |> filter(fn: (r) => r["_field"] == "value")
  |> filter(fn: (r) => r["location"] == "hangzhou")
  |> aggregateWindow(every: v.windowPeriod, fn: last, createEmpty: false)
  |> yield(name: "last")
  1. eip 和 cen 的數據單位都是 bit/sec(SI)
  2. 建議配置 Grafana 面板的 Thresholds
    100M為 100000000,配置后會顯示一條紅線,可以更直觀的看到流量的占用情況

總結

通過本文的步驟,我們可以通過API獲取阿里云 EIP 和 CEN 的監控數據,將其存儲到 InfluxDB,并通過 Grafana 進行實時監控和可視化。這為我們提供了一種自動化的方式來監控和管理阿里云網絡資源。

責任編輯:武曉燕 來源: 新鈦云服
相關推薦

2018-07-13 06:46:35

數據中心自動化微服務

2016-10-18 14:28:08

網絡監控自動化網絡監控

2017-12-17 21:58:18

2017-01-18 10:57:24

MySQLZabbix監控

2024-01-05 11:40:02

2024-06-11 10:41:14

2012-09-27 10:50:39

自動化監控

2024-06-17 10:34:12

2018-05-11 08:29:10

Python自動化測試數據驅動

2016-09-07 13:15:24

Zabbix監控Action

2018-05-11 13:39:05

PythonCSV接口測試

2009-05-19 15:48:43

2022-07-05 08:26:10

Python報表自動化郵箱

2024-11-21 15:24:49

2010-03-03 16:36:02

Python PAMI

2023-10-18 13:57:17

2013-11-27 11:34:43

自動化部署Python

2020-12-31 11:55:56

PythonPlaywright微軟

2020-03-18 09:23:24

Python數據SQL

2017-07-21 09:14:21

點贊
收藏

51CTO技術棧公眾號

国产成人精品一区二区免费看京 | 日韩成人高清在线| 毛片在线播放视频| av影片免费在线观看| 国产九色精品成人porny| 欧美精品生活片| 大黑人交xxx极品hd| 久久天堂影院| 午夜精品久久久久久久久久久| 欧美成ee人免费视频| 888奇米影视| 一本色道88久久加勒比精品| 中文字幕日韩精品在线| 91视频在线免费| 另类一区二区三区| 岛国av一区二区三区| 日本三级福利片| 可以在线观看的av| 播五月开心婷婷综合| 成人网页在线免费观看| 欧美h在线观看| 欧美黄污视频| 色一情一乱一区二区| 在线观看国产三级| 精品视频一区二区三区在线观看| 日韩欧美亚洲综合| 欧美黑人在线观看| 人人干在线视频| 国产欧美一区二区精品秋霞影院| 肥熟一91porny丨九色丨| 亚洲一区中文字幕在线| 久久高清国产| 午夜精品理论片| 在线免费日韩av| 欧美国产偷国产精品三区| 亚洲毛片一区二区| 在线天堂www在线国语对白| 国产成人视屏| 欧美日韩久久不卡| 亚洲这里只有精品| 久久久人成影片一区二区三区在哪下载 | 粉嫩高清一区二区三区精品视频| 一区精品在线观看| 日韩高清不卡一区二区| 欧美做爰性生交视频| 久久久久久国产精品免费播放| 国产精品传媒精东影业在线| 国产香蕉精品视频一区二区三区 | 亚洲美女15p| 亚洲精品美女久久久久| 制服丝袜av在线| 精品国产导航| 亚洲国产小视频在线观看| 国产乱国产乱老熟300部视频| 北岛玲精品视频在线观看| 欧美另类高清zo欧美| 久热精品在线观看视频| 激情久久99| 欧美高清视频一二三区 | 国产欧美综合色| 日本在线成人一区二区| 国产黄在线看| 国产精品久久久久影院色老大| 日韩一区国产在线观看| av福利精品| 国产精品传媒入口麻豆| 黄色一级片av| 福利写真视频网站在线| 天天操天天干天天综合网| 久激情内射婷内射蜜桃| 国产精品伦理| 欧美日韩一二区| 韩国一区二区在线播放| 日韩视频在线直播| 亚洲第一精品福利| 国产肥白大熟妇bbbb视频| 欧美精品一二| 久久视频在线直播| 国产奶水涨喷在线播放| 亚洲一区日本| 国产一区二区香蕉| 黄色av一区二区三区| 91亚洲永久精品| 天天久久人人| 色呦呦在线免费观看| 欧美日韩日本国产| 午夜免费福利在线| 视频成人永久免费视频| 国产视频欧美视频| www.黄色com| 亚洲国产裸拍裸体视频在线观看乱了中文| 57pao成人国产永久免费| 中文字幕+乱码+中文乱码www| 国产一区二区精品在线观看| 国产一区二区三区高清| 98在线视频| 亚洲成a人片在线观看中文| 国产成人av影视| 视频免费一区二区| 亚洲最新视频在线| 国产精品第二十页| 蜜桃视频在线一区| 久久精品日产第一区二区三区 | av网站免费播放| 国产亚洲欧美日韩俺去了| 国产成年人在线观看| 小早川怜子影音先锋在线观看| 欧美日韩亚洲国产综合| 三级男人添奶爽爽爽视频| 欧美www视频在线观看| 97在线看免费观看视频在线观看| 中文字幕在线播放不卡| 99久久久精品| 91视频 - 88av| 免费视频观看成人| 亚洲人成人99网站| 香蕉免费毛片视频| 国产成人精品一区二区三区网站观看 | 欧美在线国产精品| 精品人妻无码一区二区| 国产精品色哟哟| 久久人妻精品白浆国产| 欧美久久香蕉| 久久777国产线看观看精品| 国产九色91回来了| 久久久久久久久97黄色工厂| 国产免费裸体视频| 欧美欧美在线| 久久国产视频网站| 国产视频在线观看免费| 国产精品嫩草影院av蜜臀| 久久精品午夜福利| 香蕉视频一区二区三区| 91爱视频在线| 色婷婷激情五月| 亚洲国产成人高清精品| 9191在线视频| 欧美视频导航| 91情侣偷在线精品国产| 毛片在线播放a| 欧美久久一二三四区| 免费看一级黄色| 青青草成人在线观看| 日本免费高清一区二区| 亚洲最大网站| 亚洲欧美一区二区三区久久| 国产a∨精品一区二区三区仙踪林| 国产精品自产自拍| 女人床在线观看| 中文字幕一区二区三区日韩精品| 插插插亚洲综合网| 超碰免费在线97| 亚洲女子a中天字幕| 少妇性l交大片7724com| 欧美在线首页| 国产91精品入口17c| sis001亚洲原创区| 精品亚洲国产成av人片传媒| 国产情侣自拍av| 久久久久亚洲蜜桃| 国产高潮免费视频| 亚洲国产精品久久久天堂| 91美女片黄在线观| 欧美xxxx性xxxxx高清| 欧美精品一区二区三区视频| www..com国产| 国产午夜精品一区二区三区嫩草| 一本色道久久亚洲综合精品蜜桃| 99久久精品网站| 国产激情美女久久久久久吹潮| 国产高清视频色在线www| 亚洲美女av在线播放| 国产亚洲久一区二区| 日韩理论在线观看| 国产性猛交96| 日韩在线一区二区| 亚洲一区尤物| 国产精品极品在线观看| 奇米成人av国产一区二区三区| jyzzz在线观看视频| 91精品国产一区二区人妖| 日本少妇激情视频| 亚洲国产电影在线观看| 两女双腿交缠激烈磨豆腐| 亚洲久久一区| 亚洲精品一区二区毛豆| 57pao国产一区二区| 欧美亚洲在线播放| 麻豆av在线免费看| 亚洲精品aⅴ中文字幕乱码| 中文字幕av无码一区二区三区| 亚洲综合免费观看高清完整版在线| 中文字幕乱码在线| 激情综合亚洲精品| 欧美国产激情视频| 我不卡影院28| 日本一区二区三区四区高清视频| 91精品视频一区二区| 欧美亚洲国产视频| 1stkiss在线漫画| 亚洲四色影视在线观看| 精品人妻少妇AV无码专区 | 性色av一区二区三区| 性开放的欧美大片| 日韩av在线精品| 精品国自产拍在线观看| 在线视频欧美区| 日韩av在线播| 亚洲男人天堂一区| 国产在线免费av| 91在线观看高清| 91精产国品一二三| 精品在线亚洲视频| 黄色片视频在线播放| 欧美久久成人| 日本一区二区三区四区高清视频 | 在线观看91精品国产麻豆| 91美女免费看| 成人免费在线观看入口| 国产中年熟女高潮大集合| 成人激情小说乱人伦| 国内自拍第二页| 久久精品1区| 人体内射精一区二区三区| 91tv官网精品成人亚洲| 色女人综合av| 精品在线观看入口| 精品日韩电影| 黄色美女久久久| 亚洲va码欧洲m码| 欧洲午夜精品| 国产玖玖精品视频| 电影久久久久久| 欧美亚洲在线播放| 天堂在线中文网官网| 69国产精品成人在线播放| 青青在线视频| 欧美久久久精品| 国产激情视频在线| 美女久久久久久久久久久| 黄色片网站在线| 久久久久北条麻妃免费看| 在线日本中文字幕| 色999日韩欧美国产| av在线天堂播放| 中文字幕日韩有码| √天堂资源地址在线官网| 亚洲一品av免费观看| 黄色小视频在线免费观看| 亚洲免费高清视频| 麻豆国产在线播放| 亚洲天堂av高清| 成年人视频免费在线观看| 亚洲小视频在线观看| 成人影院免费观看| 日韩三级成人av网| 成人video亚洲精品| 欧美成人剧情片在线观看| 色网在线观看| 国语自产在线不卡| 性欧美18xxxhd| 国产精品69av| a成人v在线| 成人欧美一区二区三区黑人孕妇| 国产精选久久| 国产精品日韩一区二区三区| 老牛国内精品亚洲成av人片| 国产精品一区二区三区观看| 欧美日韩一本| 日本不卡一区| 99国产精品免费视频观看| 女同性恋一区二区| 亚洲精选91| 精品久久久噜噜噜噜久久图片| 久久午夜激情| 亚洲一级免费在线观看| 国产iv一区二区三区| 给我免费观看片在线电影的| 国产亚洲精品资源在线26u| 91精品少妇一区二区三区蜜桃臀| 亚洲精品成a人| 免费的毛片视频| 欧美日韩国产综合视频在线观看 | 亚洲韩国欧洲国产日产av | 久久久999国产精品| 欧美bbbxxxxx| 国产脚交av在线一区二区| 国产成人久久精品一区二区三区| 久久99精品久久久久子伦| 日韩成人精品一区| 国产精品无码免费专区午夜| 欧美综合国产| 中文字幕在线观看日| 成人av在线电影| 亚洲女同二女同志奶水| 亚洲v中文字幕| 一级特黄特色的免费大片视频| 亚洲成人网久久久| 91精彩在线视频| 午夜精品久久久久久久久久久久久| 亚洲成人av观看| 成人免费看片网址| 青青草91久久久久久久久| 97干在线视频| 久草热8精品视频在线观看| 一二三不卡视频| 亚洲精品国产无套在线观| 91porny九色| 亚洲成人久久久久| 成人日批视频| 国产精品9999| 日韩精品免费一区二区夜夜嗨 | 99re视频在线播放| 日韩久久精品网| 国产xxxxx在线观看| 国产成人一区二区精品非洲| 制服 丝袜 综合 日韩 欧美| 一区二区三区中文在线| 亚洲天堂久久久久| 亚洲欧洲在线视频| 日本孕妇大胆孕交无码| 成人黄色生活片| 精品久久久久久久| 欧美日韩在线视频一区二区三区| 国产精品自拍一区| 久久成人小视频| 欧美午夜寂寞影院| 猫咪在线永久网站| 欧美最近摘花xxxx摘花| 成人高潮视频| 欧美日韩激情四射| 国产一区二区三区高清播放| 男人天堂资源网| 欧美性一区二区| 国产色a在线| 国产精品爱久久久久久久| 美女视频亚洲色图| 欧美综合在线播放| 成人av在线观| 日韩精品一卡二卡| 精品国产伦一区二区三区免费| 在线视频观看国产| 3d蒂法精品啪啪一区二区免费| 天堂美国久久| 色男人天堂av| 亚洲激情五月婷婷| 亚洲黄色在线观看视频| 欧美大荫蒂xxx| 荡女精品导航| www精品久久| 99精品视频在线观看免费| 日韩免费不卡视频| 亚洲国产黄色片| 国产亚洲成av人片在线观看| 久草热久草热线频97精品| 国产精品社区| 久久亚洲无码视频| 欧美私模裸体表演在线观看| 在线观看美女网站大全免费| 国产一区私人高清影院| 一区二区中文字| 大尺度在线观看| 一本一道综合狠狠老| 国产一级片在线| 成人黄色网免费| 国产综合婷婷| 99久久国产精| 欧美网站大全在线观看| 成人在线免费看黄| 国产无套精品一区二区| 国产日韩免费| 一级在线观看视频| 制服丝袜亚洲色图| 福利小视频在线| 日韩欧美精品一区二区| 激情综合五月天| www.国产成人| 中文字幕日韩欧美在线视频| 蜜桃在线一区| 久久久免费视频网站| 自拍视频在线观看一区二区| 理论片中文字幕| 国产精品福利在线| 欧美freesex交免费视频| 搡老熟女老女人一区二区| 欧美撒尿777hd撒尿| 女人天堂av在线播放| 欧美18视频| 国产一区二区三区免费在线观看| 日本在线免费观看| 在线观看国产精品日韩av| 日韩精品一区二区三区中文| wwwxxx黄色片| 亚洲综合清纯丝袜自拍| 国产小视频在线| 成人资源视频网站免费| 日韩av一区二区在线影视| 久久久精品一区二区涩爱| 国产午夜精品一区二区三区| 91精品啪在线观看国产爱臀|