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

基于Agent的金融問答系統(tǒng):RAG的檢索增強(qiáng)之ElasticSearch 原創(chuàng)

發(fā)布于 2024-11-26 08:43
瀏覽
0收藏

前言

本章內(nèi)容,我們將在已經(jīng)構(gòu)建的agent框架基礎(chǔ)上,優(yōu)化檢索器,為檢索器搭建ElasticSearch服務(wù),實現(xiàn)問答系統(tǒng)的檢索增強(qiáng)。

檢索問題

通過測試天池大賽數(shù)據(jù)集的前100個問題,我們發(fā)現(xiàn)有很多問題RAG檢索不到,例如:

? {"id": 34, "question": "根據(jù)武漢興圖新科電子股份有限公司招股意向書,電子信息行業(yè)的上游涉及哪些企業(yè)?"}

通過查看日志,檢索器沒有檢索到相關(guān)信息:

基于Agent的金融問答系統(tǒng):RAG的檢索增強(qiáng)之ElasticSearch-AI.x社區(qū)

優(yōu)化方案

分析上述case原因,檢索器太過簡單所致。

class SimpleRetrieverWrapper():
"""自定義檢索器實現(xiàn)"""

def__init__(self, store, llm, **kwargs):
        self.store = store
        self.llm = llm
        logger.info(f'檢索器所使用的Chat模型:{self.llm}')

defcreate_retriever(self):
        logger.info(f'初始化自定義的Retriever')

        chromadb_retriever = self.store.as_retriever()
return chromadb_retriever

基于以上問題,我們計劃使用集成檢索器,方案如下:

基于Agent的金融問答系統(tǒng):RAG的檢索增強(qiáng)之ElasticSearch-AI.x社區(qū)

說明:

? 將檢索器改為使用??EnsembleRetriever??

? 集成檢索器其中之一使用??ElasticSearch??? 檢索器,這個檢索器通過連接??ElasticSearch?? 服務(wù),通過關(guān)鍵字查詢相關(guān)信息。

? 集成檢索器另外一個使用??MultiQueryRetriever?? 檢索器,這個檢索器通過連接Chroma向量庫查詢信息。

關(guān)于MultiQueryRetriever和ElasticSearch,之前有文章做過基本內(nèi)容的總結(jié),詳情請查看課程總結(jié)】day29:大模型之深入了解Retrievers解析器。

優(yōu)化步驟

1、搭建ES服務(wù)

第一步:安裝Docker,該內(nèi)容不再贅述,具體請見10分鐘學(xué)會Docker的安裝和使用

第二步:創(chuàng)建網(wǎng)絡(luò)

docker network create es-net

基于Agent的金融問答系統(tǒng):RAG的檢索增強(qiáng)之ElasticSearch-AI.x社區(qū)

第三步:拉取鏡像

docker pull elasticsearch:8.6.0

基于Agent的金融問答系統(tǒng):RAG的檢索增強(qiáng)之ElasticSearch-AI.x社區(qū)

第四步:創(chuàng)建掛載點目錄

smart-finance-bot \
    |- app \                
    |- docker \
        |- elasticsearch \       # 創(chuàng)建elasticsearch掛載目錄
            |- data \            # 創(chuàng)建數(shù)據(jù)目錄
            |- config \          # 創(chuàng)建配置目錄
            |- plugins  \        # 創(chuàng)建插件目錄

第五步:命令行中輸入命令啟動Docker容器

docker run -d \
--restart=always \
--name es \
--network es-net \
-p 9200:9200 \
-p 9300:9300 \
--privileged \
-v /Users/deadwalk/Code/smart-finance-bot/docker/elasticsearch/data:/usr/share/elasticsearch/data \
-v /Users/deadwalk/Code/smart-finance-bot/docker/elasticsearch/plugins:/usr/share/elasticsearch/plugins \
-e "discovery.type=single-node" \
-e "ES_JAVA_OPTS=-Xms512m -Xmx512m" \
elasticsearch:8.6.0

注意:

? 上述的??/Users/deadwalk/Code/smart-finance-bot?? 請根據(jù)本地路徑修改;

? 運(yùn)行完畢后請使用??docker ps??確認(rèn)容器已經(jīng)啟動。

第六步:進(jìn)入es容器

docker exec -it es /bin/bash

第七步:命令行輸入重置密碼命令(此處我們重置密碼為123abc)

bin/elasticsearch-reset-password -i -u elastic

基于Agent的金融問答系統(tǒng):RAG的檢索增強(qiáng)之ElasticSearch-AI.x社區(qū)

第八步:使用瀏覽器訪問http://localhost:9200/,驗證服務(wù)可以使用

基于Agent的金融問答系統(tǒng):RAG的檢索增強(qiáng)之ElasticSearch-AI.x社區(qū)

2、添加數(shù)據(jù)到ES服務(wù)

2.1、測試ES的連接

編寫ES連接測試代碼,驗證ES服務(wù)連接。

def test_es_connect():
from elasticsearch importElasticsearch

    ELASTIC_PASSWORD ="123abc"
    host ="localhost"
    port =9200
    schema ="https"
    url =f"{schema}://elastic:{ELASTIC_PASSWORD}@{host}:{port}"

    client =Elasticsearch(
        url,
        verify_certs=False,
)

print(client.info())

運(yùn)行結(jié)果:

基于Agent的金融問答系統(tǒng):RAG的檢索增強(qiáng)之ElasticSearch-AI.x社區(qū)

2.2、實現(xiàn)ElasticSearch連接代碼

代碼文件:??app/rag/elasticsearch_db.py??

# 引入
from langchain_core.retrievers importBaseRetriever
from langchain_core.documents importDocument
# ES需要導(dǎo)入的庫
from typing importList
import re
import jieba
import nltk
from nltk.corpus import stopwords
import time
from elasticsearch importElasticsearch
from elasticsearch.exceptions importConnectionError,AuthenticationException
from elasticsearch import helpers
import settings
from utils.logger_config importLoggerManager
from utils.util_nltk importUtilNltk
import os
import warnings


warnings.simplefilter("ignore")# 屏蔽 ES 的一些Warnings
utilnltk =UtilNltk()



logger =LoggerManager().logger


classTraditionDB:
defadd_documents(self, docs):
"""
        將文檔添加到數(shù)據(jù)庫
        """
raiseNotImplementedError("Subclasses should implement this method!")

defget_store(self):
"""
        獲得向量數(shù)據(jù)庫的對象實例
        """
raiseNotImplementedError("Subclasses should implement this method!")


classElasticsearchDB(TraditionDB):
def__init__(self,
                 schema=settings.ELASTIC_SCHEMA,
                 host=settings.ELASTIC_HOST,
                 port=settings.ELASTIC_PORT,
                 index_name=settings.ELASTIC_INDEX_NAME,
                 k=3
                 #  docs=docs
                 ):
# 定義索引名稱
        self.index_name = index_name
        self.k = k

try:
            url =f"{schema}://elastic:{settings.ELASTIC_PASSWORD}@{host}:{port}"
            logger.info(f'初始化ES服務(wù)連接:{url}')

            self.es =Elasticsearch(
                url,
                verify_certs=False,
# ca_certs="./docker/elasticsearch/certs/ca/ca.crt",
# basic_auth=("elastic", settings.ELASTIC_PASSWORD)
)

            response = self.es.info()# 嘗試獲取信息
            logger.info(f'ES服務(wù)響應(yīng): {response}')
except(ConnectionError,AuthenticationException)as e:
            logger.error(f'連接 Elasticsearch 失敗: {e}')
raise
exceptExceptionas e:
            logger.error(f'發(fā)生其他錯誤: {e}')
            logger.error(f'異常類型: {type(e).__name__}')# 記錄異常類型
raise

defto_keywords(self, input_string):
"""將句子轉(zhuǎn)成檢索關(guān)鍵詞序列"""
# 按搜索引擎模式分詞
        word_tokens = jieba.cut_for_search(input_string)
# 加載停用詞表
        stop_words =set(stopwords.words('chinese'))
# 去除停用詞
        filtered_sentence =[w for w in word_tokens ifnot w in stop_words]
return' '.join(filtered_sentence)

defsent_tokenize(self, input_string):
"""按標(biāo)點斷句,沒有用到"""
# 按標(biāo)點切分
        sentences = re.split(r'(?<=[。!?;?!])', input_string)
# 去掉空字符串
return[sentence for sentence in sentences if sentence.strip()]

defcreate_index(self):
"""如果索引不存在,則創(chuàng)建索引"""
ifnot self.es.indices.exists(index=self.index_name):
# 創(chuàng)建索引
            self.es.indices.create(index=self.index_name, ignore=400)

defbluk_data(self, paragraphs):
"""批量進(jìn)行數(shù)據(jù)灌庫"""
# 灌庫指令
        actions =[
{
"_index": self.index_name,
"_source":{
"keywords": self.to_keywords(para.page_content),
"text": para.page_content
}
}
for para in paragraphs
]
# 文本灌庫
        helpers.bulk(self.es, actions)
# # 灌庫是異步的
# time.sleep(2)

defflush(self):
# 刷新數(shù)據(jù),數(shù)據(jù)入庫完成以后刷新數(shù)據(jù)
        self.es.indices.flush()

defsearch(self, query_string):
"""關(guān)鍵詞檢索"""
# ES 的查詢語言
        search_query ={
"match":{
"keywords": self.to_keywords(query_string)
}
}
        res = self.es.search(index=self.index_name, query=search_query, size=self.k)
return[hit["_source"]["text"]for hit in res["hits"]["hits"]]

defdelete(self):
"""如果索引存在,則刪除索引"""
if self.es.indices.exists(index=self.index_name):
# 創(chuàng)建索引
            self.es.indices.delete(index=self.index_name, ignore=400)

defadd_documents(self, docs):
        self.bluk_data(docs)
        self.flush()

說明:

? elasticsearch后續(xù)的插入操作中,使用到了nltk分詞,其代碼已經(jīng)封裝在UtilNltk類中,具體代碼請查看Github倉庫代碼,本文不再贅述。

???LoggerManager??是代碼重構(gòu)時,封裝的一個日志管理類,具體代碼請查看Github倉庫代碼,本文不再贅述。

2.3、修改PDF文件導(dǎo)入代碼

在settings.py中添加elasticsearch配置信息:

"""
ES數(shù)據(jù)庫相關(guān)的配置
"""
# ES服務(wù)開關(guān):True表示開啟ES服務(wù),F(xiàn)alse表示關(guān)閉ES服務(wù)
ELASTIC_ENABLE_ES = True
ELASTIC_PASSWORD = os.getenv("ELASTIC_PASSWORD", "123abc")
ELASTIC_HOST = os.getenv("ELASTIC_HOST", "localhost")
ELASTIC_PORT = os.getenv("ELASTIC_PORT", 9200)
ELASTIC_SCHEMA = "https"
ELASTIC_INDEX_NAME = "smart_test_index"

確認(rèn)PDFProcessor.py中已經(jīng)添加了對于Elasticsearch的插入操作支持,具體代碼在【項目實戰(zhàn)】基于Agent的金融問答系統(tǒng):代碼重構(gòu)已做介紹,所以本文不再贅述。

2.4、測試PDF文件導(dǎo)入代碼

在test_framework.py中添加如下代碼

def test_import_elasticsearch():
# from rag.elasticsearch_db import TraditionDB
from rag.elasticsearch_db importElasticsearchDB
from rag.pdf_processor importPDFProcessor

    llm, chat, embed = settings.LLM, settings.CHAT, settings.EMBED

# 導(dǎo)入文件的文件目錄
    directory ="./dataset/pdf"

# 創(chuàng)建 Elasticsearch 數(shù)據(jù)庫實例
    es_db =ElasticsearchDB()

# 創(chuàng)建 PDFProcessor 實例
    pdf_processor =PDFProcessor(directory=directory,
                                 db_type="es",
                                 es_client=es_db,
                                 embed=embed)

# 處理 PDF 文件
    pdf_processor.process_pdfs()

運(yùn)行結(jié)果:

基于Agent的金融問答系統(tǒng):RAG的檢索增強(qiáng)之ElasticSearch-AI.x社區(qū)

3、修改檢索器增加Elasticsearch檢索

代碼文件:??app/rag/retrievers.py??

from langchain_core.callbacks importCallbackManagerForRetrieverRun
from utils.logger_config importLoggerManager
from langchain_core.retrievers importBaseRetriever
from langchain_core.documents importDocument
from langchain.retrievers importEnsembleRetriever
from langchain.retrievers.multi_query importMultiQueryRetriever
from rag.elasticsearch_db importElasticsearchDB
# ES需要導(dǎo)入的庫
from typing importList
import logging
import settings


logger =LoggerManager().logger


classSimpleRetrieverWrapper():
"""自定義檢索器實現(xiàn)"""

def__init__(self, store, llm, **kwargs):
        self.store = store
        self.llm = llm
        logger.info(f'檢索器所使用的Chat模型:{self.llm}')

defcreate_retriever(self):
        logger.info(f'初始化自定義的Retriever')

# 初始化一個空的檢索器列表
        retrievers =[]
        weights =[]

# Step1:創(chuàng)建一個 多路召回檢索器 MultiQueryRetriever
        chromadb_retriever = self.store.as_retriever()
        mq_retriever =MultiQueryRetriever.from_llm(retriever=chromadb_retriever, llm=self.llm)

        retrievers.append(mq_retriever)
        weights.append(0.5)
        logger.info(f'已啟用 MultiQueryRetriever')

# Step2:創(chuàng)建一個 ES 檢索器
if settings.ELASTIC_ENABLE_ES isTrue:
            es_retriever =ElasticsearchRetriever()
            retrievers.append(es_retriever)
            weights.append(0.5)
            logger.info(f'已啟用 ElasticsearchRetriever')

# 使用集成檢索器,將所有啟用的檢索器集合在一起
        ensemble_retriever =EnsembleRetriever(retrievers=retrievers, weights=weights)
return ensemble_retriever

classElasticsearchRetriever(BaseRetriever):
def_get_relevant_documents(self, query: str, )->List[Document]:
"""Return the first k documents from the list of documents"""
        es_connector =ElasticsearchDB()
        query_result = es_connector.search(query)

        logger.info(f"ElasticSearch檢索到資料文件個數(shù):{len(query_result)}")

if query_result:
return[Document(page_content=doc)for doc in query_result]
return[]

asyncdef_aget_relevant_documents(self, query: str)->List[Document]:
"""(Optional) async native implementation."""
        es_connector =ElasticsearchDB()
        query_result = es_connector.search(query)
if query_result:
return[Document(page_content=doc)for doc in query_result]
return []

4、測試驗證

在test_framework.py中運(yùn)行test_financebot_ex()函數(shù),測試檢索功能。

def test_financebot_ex():
    from finance_bot_ex import FinanceBotEx
    # 使用Chroma 的向量庫
    financebot = FinanceBotEx()

    example_query = "根據(jù)武漢興圖新科電子股份有限公司招股意向書,電子信息行業(yè)的上游涉及哪些企業(yè)?"

    financebot.handle_query(example_query)

運(yùn)行結(jié)果: 連接ES后檢索到3個資料文件

基于Agent的金融問答系統(tǒng):RAG的檢索增強(qiáng)之ElasticSearch-AI.x社區(qū)

使用多路召回,生成3個檢索問題

基于Agent的金融問答系統(tǒng):RAG的檢索增強(qiáng)之ElasticSearch-AI.x社區(qū)

最終通過集成檢索器檢索到答案

基于Agent的金融問答系統(tǒng):RAG的檢索增強(qiáng)之ElasticSearch-AI.x社區(qū)

優(yōu)化效果

通過對天池大賽前100個問題的對比測試,我們最終得到如下對比驗證結(jié)果:

基于Agent的金融問答系統(tǒng):RAG的檢索增強(qiáng)之ElasticSearch-AI.x社區(qū)

內(nèi)容小結(jié)

  • 集成檢索器:

     可以有效提高檢索的效率,同時可以增加檢索的準(zhǔn)確度。

     可以添加多個檢索器并配置不同的權(quán)重,以實現(xiàn)靈活的組合。

  • Elasticsearch

     作為傳統(tǒng)搜索引擎,可以通過keyword_search檢索到相關(guān)內(nèi)容。

     使用時需要使用Docker搭建ES服務(wù)。

     數(shù)據(jù)文件需要添加到ES服務(wù)中,方便檢索。

  • MultiQueryRetriever

     多路召回,將問題拆分成多個問題,然后進(jìn)行檢索,最終合并結(jié)果。


本文轉(zhuǎn)載自公眾號一起AI技術(shù) 作者:Dongming

原文鏈接:??https://mp.weixin.qq.com/s/6O-cIzdjKOd-xG0eysx-qQ??

?著作權(quán)歸作者所有,如需轉(zhuǎn)載,請注明出處,否則將追究法律責(zé)任
標(biāo)簽
已于2024-11-26 09:35:19修改
收藏
回復(fù)
舉報
回復(fù)
相關(guān)推薦
色综久久综合桃花网| 制服丝袜中文字幕一区| 欧美三级网色| 一区二区三区亚洲视频| 欧美日本三区| 精品爽片免费看久久| 韩国日本美国免费毛片| 国产剧情在线| 久久先锋影音av| 成人免费网视频| 精品国产乱码一区二区| 欧美hentaied在线观看| 亚洲黄色免费三级| 欧美成人手机在线视频| 中文字幕在线官网| 亚洲乱码日产精品bd| 欧美亚洲免费高清在线观看| 国产视频一区二区三| 欧美亚洲一区| 久久国产精品久久久久久久久久| 亚洲熟妇无码av| 91精品导航| 欧美三级日韩在线| aⅴ在线免费观看| 欧美xxxx少妇| 中文字幕亚洲不卡| 日韩在线三级| 涩涩视频在线观看免费| 国产精品白丝jk白祙喷水网站 | 国产福利久久精品| 中文字幕一区二区三区波野结| 日韩视频一区| 色综合久久久888| 多男操一女视频| 欧美日韩色图| 亚洲视频综合网| 右手影院亚洲欧美 | 久久国产精品一区二区三区四区| 国产女同91疯狂高潮互磨| 日本不卡高清视频| 91精品国产沙发| 国产成人精品av久久| 欧美午夜免费影院| 欧美国产日韩免费| 欧美人妻精品一区二区三区| 99热精品久久| 日韩一区二区三区xxxx| 99在线视频免费| 精品国产乱码久久久| 亚洲欧美日韩精品久久奇米色影视| 国产精品亚洲一区二区无码| 成人在线视频中文字幕| 精品国产精品网麻豆系列| 日本美女视频网站| 18国产精品| 欧美精品一区二| 中国极品少妇videossexhd| 999久久精品| 欧美精品一区二区三区在线播放 | 天堂va欧美ⅴa亚洲va一国产| 91麻豆精品国产91久久久久久 | 日韩一区中文| 欧美二区乱c少妇| 999热精品视频| 77成人影视| 国产视频亚洲精品| 国产中年熟女高潮大集合| 国产精品欧美三级在线观看| 夜夜嗨av色一区二区不卡| 激情五月深爱五月| 亚洲五月综合| 国外成人性视频| 精品人妻无码一区二区性色| 日韩成人一级片| 91精品久久久久久久久久入口| 国产乱码精品一区二区三区精东| 国产福利精品一区| 91麻豆蜜桃| 头脑特工队2在线播放| 2024国产精品| 亚洲人成人77777线观看| h片在线免费| 亚洲成人精品在线观看| 欧美韩国日本在线| 992tv国产精品成人影院| 欧美一级在线视频| 男男一级淫片免费播放| 国产精品片aa在线观看| 久久久精品美女| 久久久国产高清| 精品亚洲aⅴ乱码一区二区三区| 亚洲综合精品伊人久久| 日本大片在线观看| 中文字幕亚洲区| www插插插无码视频网站| 朝桐光一区二区| 日韩午夜电影av| 全黄一级裸体片| 欧美在线高清| 国产精彩精品视频| www.狠狠干| 日本一区免费视频| 成人在线国产视频| 国产精品videossex撒尿| 日韩视频在线你懂得| 国产在线观看h| 欧美久久影院| 国产噜噜噜噜久久久久久久久| 韩国av永久免费| 国产精品美女久久久久久久| 亚洲人成无码网站久久99热国产 | 亚洲精品电影在线一区| 蜜桃传媒在线观看免费进入| 欧美日韩免费高清一区色橹橹 | 日韩欧美天堂| 欧美另类69精品久久久久9999| 亚洲天堂一区在线| 国产激情视频一区二区在线观看 | 来吧亚洲综合网| 午夜在线一区| 国产在线精品日韩| 1stkiss在线漫画| 欧美在线free| 亚洲一区二区三区蜜桃| 欧美精品国产| 成人激情视频在线| 成人在线免费电影| 色婷婷亚洲综合| 中文字幕免费高清视频| 欧美88av| 亚洲最大的成人网| 视频三区在线| 欧美视频一区二区三区在线观看 | 国产精品密蕾丝视频下载 | 在线观看免费黄色片| 欧美大片免费观看网址| 日韩精品视频观看| 日韩欧美三级在线观看| 国产精品123| 97在线免费视频观看| 国产亚洲精aa在线看| 日韩中文字幕国产| 一本到在线视频| 国产精品高潮呻吟久久| 欧美黄色性生活| 成人aaaa| 国产综合久久久久| 美女黄视频在线观看| 欧美猛男男办公室激情| 亚洲欧美另类日本| 国产精品一区久久久久| 在线观看av的网址| 91精品入口| 欧美精品videos另类日本| 精品人妻一区二区三区含羞草| 亚洲精品视频一区| 中文字幕一区二区三区人妻在线视频 | 欧美刺激脚交jootjob| 欧美日韩激情在线观看| 大白屁股一区二区视频| 久久久久久人妻一区二区三区| 久久电影在线| 秋霞午夜一区二区| av在线日韩国产精品| 欧美男男青年gay1069videost| 国产午夜手机精彩视频| 国产成人免费高清| 无码精品a∨在线观看中文| 亚洲人成网站77777在线观看 | 免费观看性欧美大片无片| 欧美成人午夜激情视频| 人妻一区二区三区免费| 欧美午夜精品久久久久久人妖| 91成人在线免费视频| 久久91精品久久久久久秒播| 欧美精品久久96人妻无码| 国产精品欧美大片| 国产91在线播放| 欧美日韩在线看片| 精品奇米国产一区二区三区| 国产嫩bbwbbw高潮| 国产精品久久久久精k8| 三大队在线观看| 久久aⅴ乱码一区二区三区| 少妇精品久久久久久久久久| 日本免费一区二区三区视频| 日本91av在线播放| 黄色动漫在线观看| 日韩黄色在线免费观看| 一级特黄色大片| 亚洲高清久久久| 免费看的黄色录像| 成人黄页在线观看| 一区二区三区视频网| 欧美性久久久| 一区二区精品免费视频| 极品国产人妖chinesets亚洲人妖| 国产精品xxx视频| 视频在线这里都是精品| 影音先锋欧美精品| 国产91绿帽单男绿奴| 欧美日韩免费不卡视频一区二区三区| 国产亚洲自拍av| 国产精品久久久久影院亚瑟| 波多野结衣一二三区| 久久99久久久欧美国产| 免费无码国产v片在线观看| 亚洲精品网址| 日韩电影免费观看在| 欧美人妖视频| 亚洲一区二区三区毛片 | 欧美性淫爽ww久久久久无| 国产无码精品在线播放| 中文字幕一区二区在线观看 | 亚洲欧洲一区二区在线播放| 国产麻豆天美果冻无码视频| 国产伦精品一区二区三区免费 | 99久久精品国产导航| 加勒比av中文字幕| 丝袜诱惑亚洲看片| 国产素人在线观看| 欧美三级在线| 法国空姐在线观看免费| 久久久影院免费| 日本一区免费看| 日韩精品免费一区二区夜夜嗨| 91手机在线视频| 亚洲人成777| 国产精品久久久久一区二区| 欧美粗大gay| 欧美一级在线亚洲天堂| 678在线观看视频| 欧美激情xxxx| 丁香花视频在线观看| 欧美精品在线播放| 国产视频中文字幕在线观看| 视频在线观看99| av播放在线观看| 中文字幕精品在线| 第一福利在线| 中文字幕国产亚洲2019| 91社区在线| 久久激情五月丁香伊人| 黄色网页在线免费看| www.日韩视频| 黄网址在线观看| 久久精品夜夜夜夜夜久久| 在线视频1区2区| 中文字幕久精品免费视频| av在线免费播放网站| 日日骚久久av| 国产三区在线观看| 精品自拍视频在线观看| 免费在线国产视频| 97超级碰碰碰久久久| 成人性生活av| 国产精品免费在线免费 | 粉嫩av四季av绯色av第一区| eeuss国产一区二区三区四区| 国产富婆一区二区三区| 女同一区二区三区| 裸模一区二区三区免费| 欧美精品一二| 黄瓜视频免费观看在线观看www| 久久精品久久久| 成年人视频大全| 亚洲国产免费看| 亚洲熟妇av一区二区三区| 日韩国产高清在线| 国产性生活一级片| 成人激情免费网站| 黄色片网站免费| 亚洲美女少妇撒尿| 日本在线视频中文字幕| 91国产丝袜在线播放| 一二三四区在线| 精品久久一二三区| 国产日本在线视频| 久久中文久久字幕| 九色porny丨首页入口在线| 国产精品69精品一区二区三区| av日韩一区| 精品国产一二| 99精品美女| 97超碰在线人人| 日韩成人精品在线| 日本少妇一区二区三区| 久久亚洲春色中文字幕久久久| 久久久久久久久久97| 精品久久久中文| 97人妻精品一区二区三区| 日韩av一区二区在线| 色综合久久影院| 欧美亚洲成人精品| 国产精品3区| 欧美亚洲国产免费| 欧美视频久久| 在线免费观看av的网站| www.亚洲激情.com| 成人涩涩小片视频日本| 欧美性高潮在线| www久久久com| 中文字幕无线精品亚洲乱码一区| av日韩国产| 91色p视频在线| 国产aⅴ精品一区二区三区久久| 国产在线视频在线| 男男视频亚洲欧美| 久久久亚洲av波多野结衣| 亚洲最新在线观看| 一级黄色a毛片| 亚洲午夜av电影| 精精国产xxxx视频在线野外 | 久久久久久香蕉| 成人毛片老司机大片| 黄色片子在线观看| 欧美午夜电影网| 青草久久伊人| 国内揄拍国内精品| 亚洲国产一区二区三区网站| 曰韩不卡视频| 蜜臀久久久99精品久久久久久| 精品夜夜澡人妻无码av| 亚洲一区中文日韩| 国产suv精品一区二区69| 精品国产美女在线| jizzjizz少妇亚洲水多| 欧美精品免费观看二区| 亚洲理论在线| 四季av综合网站| 亚洲资源在线观看| 亚洲精品一区二区三区区别| 久久国产精品久久久| а天堂中文最新一区二区三区| 日韩欧美一区二区三区久久婷婷| 国产一级久久| 久久精品一区二区免费播放| 欧美性猛交xxxx久久久| 天堂中文资源在线| 2019精品视频| 神马日本精品| 黑鬼大战白妞高潮喷白浆| 91麻豆免费观看| 日韩美一区二区| 国产午夜精品一区二区三区 | 精品国内片67194| 欧美hdxxx| 国产精品久久久久久久免费大片 | 国自产精品手机在线观看视频| caoporn成人| 国产午夜福利在线播放| 久久免费美女视频| www.久久视频| 中文国产亚洲喷潮| 成人激情久久| 日本黄大片在线观看| 波多野结衣中文一区| 日产精品久久久| 国产亚洲福利一区| 国产精品原创视频| 福利在线小视频| 成人免费毛片app| 国产精品第5页| 中文字幕少妇一区二区三区| 国产精品久久久久久久久久久久久久久| 日本丰满少妇黄大片在线观看| 国产白丝精品91爽爽久久 | 亚洲在线视频| 久久久久亚洲AV成人无在| 正在播放亚洲一区| 国产又色又爽又黄刺激在线视频| 国产一区精品在线| 日韩电影免费在线| 麻豆chinese极品少妇| 日韩精品中文字幕视频在线| 成人国产一区| 欧美国产视频一区| 久久久久国产免费免费| 在线观看免费高清视频| 久久久久久91| 欧洲福利电影| 成年人看片网站| 色婷婷国产精品综合在线观看| 久久精品视频免费看| 精品视频第一区| 狠狠色狠狠色合久久伊人| 欧美亚韩一区二区三区| 中文字幕日韩有码| 久久黄色影视| 亚洲一区二区三区观看| 午夜av一区二区| 免费av网站在线观看| 久久久久久久久久久一区 | 在线视频你懂得一区二区三区| 久久久久久国产精品免费无遮挡 | 艳女tv在线观看国产一区| 右手影院亚洲欧美 | 国产在线观看精品一区| 91手机在线播放| 久久精品国产精品亚洲红杏|