日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

爬虫 spider10——搭建elk平台,开发服务提供者

發布時間:2024/2/28 编程问答 54 豆豆
生活随笔 收集整理的這篇文章主要介紹了 爬虫 spider10——搭建elk平台,开发服务提供者 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

第一步:爬取指定數據,去重復,并存儲到mysql。

Springboot+ssm+定時(定時器)爬取+redis去重+mybatis保存。

詳情請看爬蟲 spider09——爬取指定數據,去重復,并存儲到mysql

https://blog.csdn.net/qq_41946557/article/details/102573282


?

第二步:搭建elk平臺,把mysql中數據導入es中

第三步:開發服務提供者(8001),讀取es中數據,提供關鍵字查詢功能。

?

先說第二步:搭建elk平臺,把mysql中數據導入es中

通過第一步我們已經把數據爬取到數據庫mysql中

此時我們要做的是去整合elasticsearch(把mysql中數據導入es中)

? ? ?0.下載logstash

https://artifacts.elastic.co/downloads/logstash/logstash-7.3.2.zip

  • 解壓的指定目錄
  • 在bin的同級目錄中創建存放mysql驅動jar的文件夾mysql
  • 拷貝mysql驅動jar包到3中的mysql文件夾中
  • 在config或bin下創建配置文件logstash.conf【話雖這樣說,不過我在config下并不成功】
  • logstash.conf內容,詳見配置文件
  • input {

    ??# 多張表的同步只需要設置多個jdbc的模塊就行了

    ??jdbc {

    ??????# mysql 數據庫鏈接,shop為數據庫名

    ??????jdbc_connection_string => "jdbc:mysql://localhost:3306/spider?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC"

    ??????# 用戶名和密碼

    ??????jdbc_user => "root"

    ??????jdbc_password => "123456"

    ?

    ??????# 驅動

    ??????jdbc_driver_library => "D:/es/logstash-7.3.2/mysql/mysql-connector-java-5.1.6-bin.jar"

    ?

    ??????# 驅動類名

    ??????jdbc_driver_class => "com.mysql.jdbc.Driver"

    ??????jdbc_validate_connection => "true"

    ?

    ??????#是否分頁

    ??????jdbc_paging_enabled => "true"

    ??????jdbc_page_size => "1000"

    ??????#時區

    ??????jdbc_default_timezone => "Asia/Shanghai"

    ?

    ??????#直接執行sql語句

    ??????statement => "select * from news where id >=:sql_last_value order by id asc"

    ??????# 執行的sql 文件路徑+名稱

    ??????# statement_filepath => "/hw/elasticsearch/logstash-6.2.4/bin/test.sql"

    ?

    ??????#設置監聽間隔 ?各字段含義(由左至右)分、時、天、月、年,全部為*默認含義為每分鐘都更新

    ??????schedule => "* * * * *"

    ??????#每隔10分鐘執行一次

    ??????#schedule => "*/10 * * * *"

    ??????#是否記錄上次執行結果, 如果為真,將會把上次執行到的 tracking_column 字段的值記錄下來,保存到last_run_metadata_path

    ??????record_last_run => true

    ??????#記錄最新的同步的offset信息

    ??????last_run_metadata_path => "D:/es/logstash-7.3.2/logs/last_id.txt"

    ?

    ??????use_column_value => true

    ??????#遞增字段的類型,numeric 表示數值類型, timestamp 表示時間戳類型

    ??????tracking_column_type => "numeric"

    ??????tracking_column => "id"

    ??????

    ??????clean_run => false

    ?

    ??????# 索引類型

    ??????#type => "jdbc"

    ????}

    ?

    }

    ?

    ?

    output {

    ??elasticsearch {

    ????????#es的ip和端口

    ????????hosts => ["http://localhost:9200"]

    ????????#ES索引名稱(自己定義的)

    ????????index => "spider"

    ????????#文檔類型

    ????????document_type => "_doc"

    ????????#設置數據的id為數據庫中的字段

    ????????document_id => "%{id}"

    ????}

    ????stdout {

    ????????codec => json_lines

    ????}

    }

    ?

    ? ? ?6.啟動logstash,進入bin文件夾下,執行:logstash -f logstash.conf

    ?

    【注】爬取前需啟動es

    ?

    啟動kibana檢驗:

    ?

    ?


    ?

    第三步:開發服務提供者(8001),讀取es中數據,提供關鍵字查詢功能。?

    1、修改pom.xml

    <dependency><groupId>org.elasticsearch</groupId><artifactId>elasticsearch</artifactId><version>7.3.2</version></dependency><dependency><groupId>org.elasticsearch.client</groupId><artifactId>elasticsearch-rest-client</artifactId><version>7.3.2</version></dependency><dependency><groupId>org.elasticsearch.client</groupId><artifactId>elasticsearch-rest-high-level-client</artifactId><version>7.3.2</version><exclusions><exclusion><groupId>org.elasticsearch</groupId><artifactId>elasticsearch</artifactId></exclusion><exclusion><groupId>org.elasticsearch.client</groupId><artifactId>elasticsearch-rest-client</artifactId></exclusion></exclusions></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency>

    ?

    2、修改yml

    #elasticSearch配置 elasticSearch:hostlist: 127.0.0.1:9200client:connectNum: 10connectPerRoute: 50

    3、導入es訪問相關工具類

    從上到下代碼演示:?

    ?EsEntity

    package com.henu.es.bean;public final class EsEntity<T> {//文檔idprivate String id;//一條文檔private T data;public EsEntity() {}public EsEntity(String id, T data) {this.data = data;this.id = id;}public String getId() {return id;}public void setId(String id) {this.id = id;}public T getData() {return data;}public void setData(T data) {this.data = data;} }

    ?EsPage

    package com.henu.es.bean;import lombok.Getter; import lombok.NoArgsConstructor; import lombok.Setter; import lombok.ToString; import java.util.List; import java.util.Map;@Getter @Setter @NoArgsConstructor @ToString public class EsPage {/*** 當前頁*/private int currentPage;/*** 每頁顯示多少條*/private int pageSize;/*** 總記錄數*/private int recordCount;/*** 本頁的數據列表*/private List<Map<String, Object>> recordList;/*** 總頁數*/private int pageCount;/*** 頁碼列表的開始索引(包含)*/private int beginPageIndex;/*** 頁碼列表的結束索引(包含)*/private int endPageIndex;/*** 只接受前4個必要的屬性,會自動的計算出其他3個屬性的值* @param currentPage* @param pageSize* @param recordCount* @param recordList*/public EsPage(int currentPage, int pageSize, int recordCount, List<Map<String, Object>> recordList) {this.currentPage = currentPage;this.pageSize = pageSize;this.recordCount = recordCount;this.recordList = recordList;// 計算總頁碼pageCount = (recordCount + pageSize - 1) / pageSize;// 計算 beginPageIndex 和 endPageIndex// 總頁數不多于10頁,則全部顯示if (pageCount <= 10) {beginPageIndex = 1;endPageIndex = pageCount;}// 總頁數多于10頁,則顯示當前頁附近的共10個頁碼else {// 當前頁附近的共10個頁碼(前4個 + 當前頁 + 后5個)beginPageIndex = currentPage - 4;endPageIndex = currentPage + 5;// 當前面的頁碼不足4個時,則顯示前10個頁碼if (beginPageIndex < 1) {beginPageIndex = 1;endPageIndex = 10;}// 當后面的頁碼不足5個時,則顯示后10個頁碼if (endPageIndex > pageCount) {endPageIndex = pageCount;beginPageIndex = pageCount - 10 + 1;}}} }

    ?User

    package com.henu.es.bean;import lombok.Data; /*** userRepository操作的bean*/ @Data public class User {private Integer id;private String name;private String address;private Integer sex; }

    ElasticsearchRestClient

    package com.henu.es.client;import com.henu.es.factory.ESClientSpringFactory; import lombok.Getter; import lombok.Setter; import org.apache.http.HttpHost; import org.elasticsearch.client.RestClient; import org.elasticsearch.client.RestHighLevelClient; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Scope;@Configuration @Getter @Setter @ComponentScan(basePackageClasses= ESClientSpringFactory.class) public class ElasticsearchRestClient {private final Logger LOGGER = LoggerFactory.getLogger(ElasticsearchRestClient.class);@Value("${elasticSearch.client.connectNum}")private Integer connectNum;@Value("${elasticSearch.client.connectPerRoute}")private Integer connectPerRoute;@Value("${elasticSearch.hostlist}")private String hostlist;@Beanpublic HttpHost[] httpHost(){//解析hostlist配置信息String[] split = hostlist.split(",");//創建HttpHost數組,其中存放es主機和端口的配置信息HttpHost[] httpHostArray = new HttpHost[split.length];for(int i=0;i<split.length;i++){String item = split[i];httpHostArray[i] = new HttpHost(item.split(":")[0], Integer.parseInt(item.split(":")[1]), "http");}LOGGER.info("init HttpHost");return httpHostArray;}@Bean(initMethod="init",destroyMethod="close")public ESClientSpringFactory getFactory(){LOGGER.info("ESClientSpringFactory 初始化");return ESClientSpringFactory.build(httpHost(), connectNum, connectPerRoute);}@Bean@Scope("singleton")public RestClient getRestClient(){LOGGER.info("RestClient 初始化");return getFactory().getClient();}@Bean(name = "restHighLevelClient")@Scope("singleton")public RestHighLevelClient getRHLClient(){LOGGER.info("RestHighLevelClient 初始化");return getFactory().getRhlClient();} }

    SpiderController

    package com.henu.es.controller;import com.henu.es.bean.EsPage; import com.henu.es.util.ElasticsearchUtil; import org.apache.ibatis.annotations.Param; import org.elasticsearch.index.query.QueryBuilder; import org.elasticsearch.index.query.QueryBuilders; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.ResponseBody;/*** @author George* @description**/ @Controller public class SpiderController {@RequestMapping("/search")@ResponseBodypublic String search(@RequestParam(value = "keyword")String keyword, @RequestParam(value="currentPage",defaultValue = "1") int currentPage, @RequestParam(value="pageSize",defaultValue = "10") int pageSize){System.out.println("好好學習,天天向上:"+keyword);QueryBuilder queryBuilder = QueryBuilders.matchQuery("intro", keyword);EsPage esPage = ElasticsearchUtil.searchDataPage("spider", currentPage, pageSize, queryBuilder, "id,appid,title,intro,url,source,updatetime", "id", "intro");return esPage.toString();} }

    ESClientSpringFactory

    package com.henu.es.factory;import org.apache.http.HttpHost; import org.elasticsearch.client.RestClient; import org.elasticsearch.client.RestClientBuilder; import org.elasticsearch.client.RestHighLevelClient; import org.slf4j.Logger; import org.slf4j.LoggerFactory;import java.io.IOException; import java.util.Arrays;public class ESClientSpringFactory {private final Logger LOGGER = LoggerFactory.getLogger(ESClientSpringFactory.class);public static int CONNECT_TIMEOUT_MILLIS = 1000;public static int SOCKET_TIMEOUT_MILLIS = 30000;public static int CONNECTION_REQUEST_TIMEOUT_MILLIS = 500;public static int MAX_CONN_PER_ROUTE = 10;public static int MAX_CONN_TOTAL = 30;private static HttpHost[] HTTP_HOST;private RestClientBuilder builder;private RestClient restClient;private RestHighLevelClient restHighLevelClient;private static ESClientSpringFactory esClientSpringFactory = new ESClientSpringFactory();private ESClientSpringFactory(){}public static ESClientSpringFactory build(HttpHost[] httpHostArray,Integer maxConnectNum, Integer maxConnectPerRoute){HTTP_HOST = httpHostArray;MAX_CONN_TOTAL = maxConnectNum;MAX_CONN_PER_ROUTE = maxConnectPerRoute;return esClientSpringFactory;}public static ESClientSpringFactory build(HttpHost[] httpHostArray,Integer connectTimeOut, Integer socketTimeOut,Integer connectionRequestTime,Integer maxConnectNum, Integer maxConnectPerRoute){HTTP_HOST = httpHostArray;CONNECT_TIMEOUT_MILLIS = connectTimeOut;SOCKET_TIMEOUT_MILLIS = socketTimeOut;CONNECTION_REQUEST_TIMEOUT_MILLIS = connectionRequestTime;MAX_CONN_TOTAL = maxConnectNum;MAX_CONN_PER_ROUTE = maxConnectPerRoute;return esClientSpringFactory;}public void init(){builder = RestClient.builder(HTTP_HOST);setConnectTimeOutConfig();setMutiConnectConfig();restClient = builder.build();restHighLevelClient = new RestHighLevelClient(builder);LOGGER.info("init factory" + Arrays.toString(HTTP_HOST));}/*** 配置連接時間延時* */public void setConnectTimeOutConfig(){builder.setRequestConfigCallback(requestConfigBuilder -> {requestConfigBuilder.setConnectTimeout(CONNECT_TIMEOUT_MILLIS);requestConfigBuilder.setSocketTimeout(SOCKET_TIMEOUT_MILLIS);requestConfigBuilder.setConnectionRequestTimeout(CONNECTION_REQUEST_TIMEOUT_MILLIS);return requestConfigBuilder;});}/*** 使用異步httpclient時設置并發連接數* */public void setMutiConnectConfig(){builder.setHttpClientConfigCallback(httpClientBuilder -> {httpClientBuilder.setMaxConnTotal(MAX_CONN_TOTAL);httpClientBuilder.setMaxConnPerRoute(MAX_CONN_PER_ROUTE);return httpClientBuilder;});}public RestClient getClient(){return restClient;}public RestHighLevelClient getRhlClient(){return restHighLevelClient;}public void close() {if (restClient != null) {try {restClient.close();} catch (IOException e) {e.printStackTrace();}}LOGGER.info("close client");} }

    ElasticsearchUtil

    package com.henu.es.util;import com.alibaba.fastjson.JSON; import com.henu.es.bean.EsEntity; import com.henu.es.bean.EsPage; import org.elasticsearch.action.bulk.BulkRequest; import org.elasticsearch.action.delete.DeleteRequest; import org.elasticsearch.action.index.IndexRequest; import org.elasticsearch.action.index.IndexResponse; import org.elasticsearch.action.search.ClearScrollRequest; import org.elasticsearch.action.search.SearchRequest; import org.elasticsearch.action.search.SearchResponse; import org.elasticsearch.action.search.SearchScrollRequest; import org.elasticsearch.client.RequestOptions; import org.elasticsearch.client.RestHighLevelClient; import org.elasticsearch.client.indices.CreateIndexRequest; import org.elasticsearch.client.indices.CreateIndexResponse; import org.elasticsearch.client.indices.GetIndexRequest; import org.elasticsearch.common.text.Text; import org.elasticsearch.common.unit.TimeValue; import org.elasticsearch.common.xcontent.XContentBuilder; import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentType; import org.elasticsearch.index.query.QueryBuilder; import org.elasticsearch.index.query.QueryBuilders; import org.elasticsearch.index.reindex.DeleteByQueryRequest; import org.elasticsearch.search.SearchHit; import org.elasticsearch.search.SearchHits; import org.elasticsearch.search.builder.SearchSourceBuilder; import org.elasticsearch.search.fetch.subphase.highlight.HighlightBuilder; import org.elasticsearch.search.sort.FieldSortBuilder; import org.elasticsearch.search.sort.SortOrder; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import org.springframework.util.StringUtils;import javax.annotation.PostConstruct; import java.io.IOException; import java.util.ArrayList; import java.util.Collection; import java.util.List; import java.util.Map; import java.util.concurrent.TimeUnit; import java.util.stream.Collectors;/*** /**** @author Administrator* @date 2019/10/13 0013 23:32* @description*/ @Component public class ElasticsearchUtil<T> {private static final Logger LOGGER = LoggerFactory.getLogger(ElasticsearchUtil.class);@Autowiredprivate RestHighLevelClient rhlClient;private static RestHighLevelClient client;/*** spring容器初始化的時候執行該方法*/@PostConstructpublic void init() {client = this.rhlClient;}/*** 判斷索引是否存在 *** @param index 索引,類似數據庫* @return boolean* @auther: LHL*/public static boolean isIndexExist(String index) {boolean exists = false;try {exists = client.indices().exists(new GetIndexRequest(index), RequestOptions.DEFAULT);} catch (IOException e) {e.printStackTrace();}if (exists) {LOGGER.info("Index [" + index + "] is exist!");} else {LOGGER.info("Index [" + index + "] is not exist!");}return exists;}/*** 創建索引以及映射mapping,并給索引某些字段指定iK分詞,以后向該索引中查詢時,就會用ik分詞。** @param: indexName 索引,類似數據庫* @return: boolean* @auther: LHL*/public static boolean createIndex(String indexName) {if (!isIndexExist(indexName)) {LOGGER.info("Index is not exits!");}CreateIndexResponse createIndexResponse = null;try {//創建映射XContentBuilder mapping = null;try {mapping = XContentFactory.jsonBuilder().startObject().startObject("properties")//.startObject("m_id").field("type","keyword").endObject() //m_id:字段名,type:文本類型,analyzer 分詞器類型//該字段添加的內容,查詢時將會使用ik_max_word 分詞 //ik_smart ik_max_word standard.startObject("id").field("type", "text").endObject().startObject("title").field("type", "text").field("analyzer", "ik_smart").endObject().startObject("content").field("type", "text").field("analyzer", "ik_smart").endObject().startObject("state").field("type", "text").endObject().endObject().startObject("settings")//分片數.field("number_of_shards", 3)//副本數.field("number_of_replicas", 1).endObject().endObject();} catch (IOException e) {e.printStackTrace();}CreateIndexRequest request = new CreateIndexRequest(indexName).source(mapping);//設置創建索引超時2分鐘request.setTimeout(TimeValue.timeValueMinutes(2));createIndexResponse = client.indices().create(request, RequestOptions.DEFAULT);} catch (IOException e) {e.printStackTrace();}return createIndexResponse.isAcknowledged();}/*** 數據添加,一條文檔** @param content 要增加的數據* @param indexName 索引,類似數據庫* @param id id* @return String* @auther: LHL*/public static String addData(XContentBuilder content, String indexName, String id) {IndexResponse response = null;try {IndexRequest request = new IndexRequest(indexName).id(id).source(content);response = client.index(request, RequestOptions.DEFAULT);LOGGER.info("addData response status:{},id:{}", response.status().getStatus(), response.getId());} catch (IOException e) {e.printStackTrace();}return response.getId();}/*** 批量添加數據** @param list 要批量增加的數據* @param index 索引,類似數據庫* @return* @auther: LHL*/public void insertBatch(String index, List<EsEntity> list) {BulkRequest request = new BulkRequest();list.forEach(item -> request.add(new IndexRequest(index).id(item.getId()).source(JSON.toJSONString(item.getData()), XContentType.JSON)));try {client.bulk(request, RequestOptions.DEFAULT);} catch (Exception e) {throw new RuntimeException(e);}}/*** 根據條件刪除** @param builder 要刪除的數據 new TermQueryBuilder("userId", userId)* @param indexName 索引,類似數據庫* @return* @auther: LHL*/public void deleteByQuery(String indexName, QueryBuilder builder) {DeleteByQueryRequest request = new DeleteByQueryRequest(indexName);request.setQuery(builder);//設置批量操作數量,最大為10000request.setBatchSize(10000);request.setConflicts("proceed");try {client.deleteByQuery(request, RequestOptions.DEFAULT);} catch (Exception e) {throw new RuntimeException(e);}}/*** 批量刪除** @param idList 要刪除的數據id* @param index 索引,類似數據庫* @return* @auther: LHL*/public static <T> void deleteBatch(String index, Collection<T> idList) {BulkRequest request = new BulkRequest();idList.forEach(item -> request.add(new DeleteRequest(index, item.toString())));try {client.bulk(request, RequestOptions.DEFAULT);} catch (Exception e) {throw new RuntimeException(e);}}/*** 使用分詞查詢 高亮 排序 ,并分頁** @param index 索引名稱* @param startPage 當前頁* @param pageSize 每頁顯示條數* @param query 查詢條件* @param fields 需要顯示的字段,逗號分隔(缺省為全部字段)"id,appid,title,intro,source,updatetime"* @param highlightField 高亮字段* @return 結果*/public static EsPage searchDataPage(String index, int startPage, int pageSize, QueryBuilder query, String fields, String sortField, String highlightField) {SearchRequest searchRequest = new SearchRequest(index);SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();//設置一個可選的超時,控制允許搜索的時間searchSourceBuilder.timeout(new TimeValue(60, TimeUnit.SECONDS));// 需要顯示的字段,逗號分隔(缺省為全部字段)if (!StringUtils.isEmpty(fields)) {System.out.println("顯示的字段:"+fields);searchSourceBuilder.fetchSource(fields.split(","), null);}//排序字段if (!StringUtils.isEmpty(sortField)) {searchSourceBuilder.sort(new FieldSortBuilder(sortField).order(SortOrder.ASC));}// 高亮(xxx=111,aaa=222)if (!StringUtils.isEmpty(highlightField)) {HighlightBuilder highlightBuilder = new HighlightBuilder();//設置前綴highlightBuilder.preTags("<span style='color:red' >");//設置后綴highlightBuilder.postTags("</span>");HighlightBuilder.Field highlightTitle = new HighlightBuilder.Field(highlightField);//熒光筆類型highlightTitle.highlighterType("unified");// 設置高亮字段highlightBuilder.field(highlightTitle);searchSourceBuilder.highlighter(highlightBuilder);}// 設置是否按查詢匹配度排序searchSourceBuilder.explain(true);if (startPage <= 0) {startPage = 0;}//如果 pageSize是10 那么startPage>9990 (10000-pagesize) 如果 20 那么 >9980 如果 50 那么>9950//深度分頁 TODOif (startPage > (10000 - pageSize)) {searchSourceBuilder.query(query);searchSourceBuilder// .setScroll(TimeValue.timeValueMinutes(1)).size(10000);//打印的內容 可以在 Elasticsearch head 和 Kibana 上執行查詢LOGGER.info("\n{}", searchSourceBuilder);// 執行搜索,返回搜索響應信息searchRequest.source(searchSourceBuilder);SearchResponse searchResponse = null;try {searchResponse = client.search(searchRequest, RequestOptions.DEFAULT);} catch (IOException e) {e.printStackTrace();}long totalHits = searchResponse.getHits().getTotalHits().value;if (searchResponse.status().getStatus() == 200) {//使用scrollId迭代查詢List<Map<String, Object>> result = disposeScrollResult(searchResponse, highlightField);List<Map<String, Object>> sourceList = result.stream().parallel().skip((startPage - 1 - (10000 / pageSize)) * pageSize).limit(pageSize).collect(Collectors.toList());return new EsPage(startPage, pageSize, (int) totalHits, sourceList);}} else {//淺度分頁searchSourceBuilder.query(QueryBuilders.matchAllQuery());searchSourceBuilder.query(query);/*MatchQueryBuilder matchQueryBuilder = new MatchQueryBuilder("username", "pretty");matchQueryBuilder.fuzziness(Fuzziness.AUTO);//在匹配查詢上啟用模糊匹配matchQueryBuilder.prefixLength(3);//在匹配查詢上設置前綴長度選項matchQueryBuilder.maxExpansions(10);//設置最大擴展選項以控制查詢的模糊過程searchSourceBuilder.query(matchQueryBuilder);*/// 分頁應用searchSourceBuilder//設置from確定結果索引的選項以開始搜索。默認為0// .from(startPage).from((startPage - 1) * pageSize)//設置size確定要返回的搜索匹配數的選項。默認為10.size(pageSize);//打印的內容 可以在 Elasticsearch head 和 Kibana 上執行查詢LOGGER.info("\n{}", searchSourceBuilder);// 執行搜索,返回搜索響應信息searchRequest.source(searchSourceBuilder);SearchResponse searchResponse = null;try {searchResponse = client.search(searchRequest, RequestOptions.DEFAULT);} catch (IOException e) {e.printStackTrace();}long totalHits = searchResponse.getHits().getTotalHits().value;long length = searchResponse.getHits().getHits().length;LOGGER.debug("共查詢到[{}]條數據,處理數據條數[{}]", totalHits, length);if (searchResponse.status().getStatus() == 200) {// 解析對象List<Map<String, Object>> sourceList = setSearchResponse(searchResponse, highlightField);return new EsPage(startPage, pageSize, (int) totalHits, sourceList);}}return null;}/*** 高亮結果集 特殊處理* @param searchResponse 搜索的結果集* @param highlightField 高亮字段*/private static List<Map<String, Object>> setSearchResponse(SearchResponse searchResponse, String highlightField) {List<Map<String, Object>> sourceList = new ArrayList<>();for (SearchHit searchHit : searchResponse.getHits().getHits()) {Map<String, Object> resultMap = getResultMap(searchHit, highlightField);sourceList.add(resultMap);}return sourceList;}/*** 獲取高亮結果集** @param: [hit, highlightField]* @return: java.util.Map<java.lang.String, java.lang.Object>* @auther: LHL*/private static Map<String, Object> getResultMap(SearchHit hit, String highlightField) {hit.getSourceAsMap().put("id", hit.getId());if (!StringUtils.isEmpty(highlightField)) {Text[] text = hit.getHighlightFields().get(highlightField).getFragments();String hightStr = null;if (text != null) {for (Text str : text) {hightStr = str.string();}//遍歷 高亮結果集,覆蓋 正常結果集hit.getSourceAsMap().put(highlightField, hightStr);}}return hit.getSourceAsMap();}public static <T> List<T> search(String index, SearchSourceBuilder builder, Class<T> c) {SearchRequest request = new SearchRequest(index);request.source(builder);try {SearchResponse response = client.search(request, RequestOptions.DEFAULT);SearchHit[] hits = response.getHits().getHits();List<T> res = new ArrayList<>(hits.length);for (SearchHit hit : hits) {res.add(JSON.parseObject(hit.getSourceAsString(), c));}return res;} catch (Exception e) {throw new RuntimeException(e);}}/*** 處理scroll結果** @param: [response, highlightField]* @return: java.util.List<java.util.Map < java.lang.String, java.lang.Object>>* @auther: LHL*/private static List<Map<String, Object>> disposeScrollResult(SearchResponse response, String highlightField) {List<Map<String, Object>> sourceList = new ArrayList<>();//使用scrollId迭代查詢while (response.getHits().getHits().length > 0) {String scrollId = response.getScrollId();try {response = client.scroll(new SearchScrollRequest(scrollId), RequestOptions.DEFAULT);} catch (IOException e) {e.printStackTrace();}SearchHits hits = response.getHits();for (SearchHit hit : hits.getHits()) {Map<String, Object> resultMap = getResultMap(hit, highlightField);sourceList.add(resultMap);}}ClearScrollRequest request = new ClearScrollRequest();request.addScrollId(response.getScrollId());try {client.clearScroll(request, RequestOptions.DEFAULT);} catch (IOException e) {e.printStackTrace();}return sourceList;} }

    SpringbootElasticsearchApplication

    package com.henu.es;import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication;/**/*** 操作elasticsearch有兩種方式:* (1)jest:默認不生效,需要導入包io.searchbox.jest* 配置application.properties,測試添加文檔和查詢文檔* (2)spring-data-es:導入spring-data-elasticsearch包* 配置application.properties:cluster-name cluster-nodes* 啟動要是報錯:可能是版本不匹配* 兩種用法:* (1)編寫接口繼承elasticsearchRepository* (2) elasticsearchTemplate* (3)spring-data-es CRUD + 分頁 + 高亮的練習**/ @SpringBootApplication public class SpringbootElasticsearchApplication {public static void main(String[] args) {// 避免netty沖突System.setProperty("es.set.netty.runtime.available.processors", "false");SpringApplication.run(SpringbootElasticsearchApplication.class, args);} }

    搜索結果:

    ?

    ?

    總結

    以上是生活随笔為你收集整理的爬虫 spider10——搭建elk平台,开发服务提供者的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    久久久久国产精品一区二区 | 9999在线视频 | 欧美综合色在线图区 | 国产精品美女久久久久久久 | 日本大尺码专区mv | 免费观看国产视频 | 国产成人久 | 精品999久久久 | 午夜性福利 | 丁香婷婷成人 | 日韩成人免费在线观看 | 欧美看片 | 免费男女羞羞的视频网站中文字幕 | 国产在线91在线电影 | 免费av大全| 日韩mv欧美mv国产精品 | 国产精品一区二区在线观看 | 91热在线| 亚洲女人av | 亚洲精品午夜久久久久久久久久久 | 免费h在线观看 | 国产亚洲免费的视频看 | 亚洲日本va午夜在线影院 | 91成人免费在线 | 成人毛片在线视频 | 狠狠狠色丁香综合久久天下网 | 国产日韩欧美综合在线 | 成人黄色电影在线观看 | www免费黄色 | 久久久久久毛片精品免费不卡 | www.天堂av| 国产视频91在线 | 亚洲精品美女久久久久网站 | 久久国产二区 | 在线观看日本高清mv视频 | 免费在线观看av网址 | 草免费视频 | 日本黄色大片免费 | av大全免费在线观看 | 欧美在线视频一区二区三区 | 精品久久久久亚洲 | 亚洲无吗天堂 | 91免费网 | 亚洲欧美成aⅴ人在线观看 四虎在线观看 | 午夜色大片在线观看 | 亚洲最大在线视频 | 久久国产精品99久久久久久老狼 | 开心色婷婷 | 国产一级电影 | 精品亚洲二区 | 亚洲免费专区 | 久久久久久久久久久久电影 | 久久精品永久免费 | 精品视频| 在线视频专区 | 毛片网站免费在线观看 | 91久久久久久久 | 日日草天天干 | 缴情综合网五月天 | 97影视 | 国产福利网站 | 亚洲区另类春色综合小说 | 狠狠久久婷婷 | 91pony九色丨交换 | 精品国产乱码久久久久久浪潮 | 丁香电影小说免费视频观看 | 成人久久18免费网站麻豆 | 日韩中文字幕a | 亚洲精品视频在线看 | 日日摸日日碰 | 午夜电影av| 精品久久久99 | 日韩精品五月天 | 精品国产欧美一区二区三区不卡 | 美女搞黄国产视频网站 | 天天爽天天碰狠狠添 | 伊香蕉大综综综合久久啪 | av手机在线播放 | 欧美a在线看 | 色综合久久综合网 | 日韩视频在线观看免费 | 日韩欧美xxx| 91探花系列在线播放 | 在线国产片| 国产成人av综合色 | 免费看精品久久片 | 四虎影视国产精品免费久久 | 色婷婷色 | 国产69精品久久99的直播节目 | 人人爱爱 | 深夜精品福利 | 国产一区二区久久久 | 国产一区二区久久精品 | 久久国产网站 | 国产精品免费大片视频 | 日韩欧美xxx | 亚洲国产精品成人av | 国产精品二区在线 | 五月天久久精品 | 欧美日韩高清一区二区 国产亚洲免费看 | 久久99精品久久久久久秒播蜜臀 | 一本大道久久精品懂色aⅴ 五月婷社区 | 成人免费视频播放 | 久综合网 | 九九久久免费 | 日韩在线高清 | av成人免费在线观看 | 日日干网 | 亚洲欧美国产精品久久久久 | av 一区 二区 久久 | 国产精品破处视频 | 久草视频观看 | 亚洲乱亚洲乱亚洲 | 我要看黄色一级片 | 国产成人精品久久亚洲高清不卡 | 丁香五婷| 激情小说久久 | 伊人久久在线观看 | 国产精品99久久久久久小说 | 粉嫩高清一区二区三区 | 天天色综合天天 | 日韩在线观看一区 | 国产1区在线观看 | 久久99这里只有精品 | 精品91 | 国产精品免费一区二区 | 国产午夜一区二区 | 国产一区在线播放 | 久久久久高清毛片一级 | 日韩久久精品一区二区 | 欧美看片 | 在线看片中文字幕 | 国产成人精品在线播放 | 91亚洲影院 | 玖玖爱国产在线 | 黄色在线观看www | 日韩午夜电影网 | 日韩av电影网站在线观看 | 国产原创中文在线 | 欧美久久久久久久久中文字幕 | 婷婷丁香五 | 毛片a级片 | 日本久久电影网 | 午夜av一区二区三区 | 国产v在线播放 | 国精产品999国精产 久久久久 | 国产精品久久网 | 欧美日韩在线视频一区 | 久久久麻豆精品一区二区 | 日本精品一区二区三区在线播放视频 | 日韩videos| 亚洲伊人天堂 | 天天射天天干天天 | 九九九热精品 | 91丨九色丨蝌蚪丰满 | 日日碰狠狠躁久久躁综合网 | 349k.cc看片app | 国产网站av| www免费| 夜夜视频 | 99久久er热在这里只有精品66 | 国产精品二区三区 | 亚洲成人二区 | 国产一级久久 | 精品国产一区二区三区四区vr | 久久久久久中文字幕 | 国产无遮挡又黄又爽在线观看 | www.日日操.com | 久久经典国产视频 | 国产成人在线免费观看 | h文在线观看免费 | 成人va在线观看 | 国产精品视频资源 | 日韩在线免费看 | 国产精品美女久久久久久免费 | 亚洲妇女av| 在线三级播放 | 久草久草在线 | 日本h视频在线观看 | 国产黄色大片 | 亚洲免费资源 | 精品视频专区 | 国产二区视频在线观看 | 日本在线观看一区二区三区 | 在线免费日韩 | 天天干天天摸天天操 | 亚洲精品在线国产 | 久久久夜色 | 欧美日韩不卡一区二区三区 | 欧美日韩亚洲第一页 | 在线精品观看 | 五月婷av| 正在播放国产精品 | 精品国产乱码久久 | 99高清视频有精品视频 | 中文字幕在线成人 | 在线视频国产区 | 日b黄色片 | 久久人91精品久久久久久不卡 | 久久久五月天 | 日韩极品视频在线观看 | 在线观看中文字幕一区 | 国产99久久精品一区二区永久免费 | 欧美韩日视频 | 成人久久久久久久久久 | 色婷婷免费 | 亚洲欧美激情插 | 美女网站免费福利视频 | 天天操夜操 | 在线观看精品国产 | 草久在线观看视频 | 99精品国产99久久久久久97 | 韩国在线一区二区 | 亚洲影院天堂 | 成人午夜免费福利 | 在线观看中文字幕2021 | 99久久精品国产一区二区成人 | 91av在线电影| 色欧美日韩| 国产男女爽爽爽免费视频 | www.久久精品视频 | 国产精品免费观看网站 | 亚洲精品乱码白浆高清久久久久久 | 日韩av在线一区二区 | 成人亚洲免费 | 久草网在线观看 | 香蕉成人在线视频 | 最近在线中文字幕 | 亚洲欧美激情精品一区二区 | 国产午夜在线观看 | 国产视频精品久久 | 久久久久久久久久久免费视频 | 欧美日韩在线免费观看视频 | 三上悠亚一区二区在线观看 | 成人国产精品免费观看 | 国产精品美女视频 | 中文字幕在线观看国产 | 91精品国产一区 | 五月婷婷欧美 | 久久久久久久久久久久av | 色姑娘综合天天 | 18久久久 | 99久久超碰中文字幕伊人 | 美女视频网| 日本精品久久久久 | 亚洲欧美国产日韩在线观看 | 国产精品久免费的黄网站 | 欧美午夜精品久久久久久浪潮 | 欧美地下肉体性派对 | 国产亚洲精品久久网站 | 日韩久久久久久 | 亚洲综合五月天 | 久久久久久久久毛片精品 | 91成人精品一区在线播放 | 99热这里只有精品在线观看 | 日韩免费视频线观看 | 手机看片| 婷婷国产在线观看 | 一区二区三区高清在线观看 | 久久精品看片 | 麻花豆传媒一二三产区 | 久久影院午夜论 | 五月婷香 | 久久久久高清毛片一级 | 久久精品视频在线看 | 欧美日韩中文字幕在线视频 | 又紧又大又爽精品一区二区 | 狠狠色丁香婷婷综合久小说久 | 国产91精品一区二区麻豆亚洲 | 亚洲成年人在线播放 | 亚洲一区美女视频在线观看免费 | 粉嫩一区二区三区粉嫩91 | 国产午夜三级一二三区 | 97精品在线观看 | 婷婷色站 | 国产精品成人品 | 国产欧美精品在线观看 | 一区二区三区免费播放 | 国产美女精品人人做人人爽 | 亚州av免费 | 六月天综合网 | 久久久久高清毛片一级 | 黄污污网站 | 国产视频日韩 | 日韩精品一区二区三区不卡 | 免费看的黄色的网站 | 精品在线观看一区二区 | 亚洲国产电影在线观看 | 国产精品18久久久久久久 | 日批在线看 | 国产一区二区电影在线观看 | 92中文资源在线 | 天天摸日日摸人人看 | 成人小视频免费在线观看 | 国产h片在线观看 | 91精品久久久久久综合乱菊 | 啪啪午夜免费 | 五月婷婷网站 | 国产精品麻豆91 | 亚洲精品综合一二三区在线观看 | 久久久久久久久网站 | 97碰在线视频 | japanesexxxxfreehd乱熟 | 免费久久99精品国产 | 亚洲国产视频直播 | 久久激情久久 | 久久久久久久久影视 | 麻豆网站免费观看 | 99热播精品 | 国产免费又爽又刺激在线观看 | 精品国产美女在线 | 国产亚洲精品久 | av片一区 | 免费黄色av电影 | 中文字幕在线观看完整版电影 | 欧美日韩1区 | 久久免费国产视频 | 中文字幕综合在线 | 色网站在线免费观看 | 天天插日日射 | 免费久久网 | 免费福利在线观看 | 亚洲精品乱码久久久久久蜜桃91 | 久久人人爽人人爽人人片 | 色综合久久久久久久久五月 | 国产.精品.日韩.另类.中文.在线.播放 | 日韩av电影手机在线观看 | 天天干天天弄 | 国产精品久久久久久久久久久久久 | 国产高清视频免费在线观看 | 最近免费中文字幕mv在线视频3 | 久久综合欧美精品亚洲一区 | 888av| 亚洲视屏 | 亚洲a免费 | japanese黑人亚洲人4k | 91av成人| 免费av福利| 欧美亚洲国产一卡 | 国产成人一区二区三区 | 色综合久久88色综合天天 | 免费a v观看 | 美女视频黄免费的久久 | 超碰97在线看 | 日韩一区二区三区不卡 | 超碰日韩 | 黄色三级免费看 | 色婷婷综合五月 | 日韩电影久久 | 亚洲一级电影在线观看 | 国产精品视频观看 | 国产男女无遮挡猛进猛出在线观看 | 精品91视频 | 久久久久久久久爱 | 久草免费在线观看视频 | 美国三级黄色大片 | 999视频在线播放 | 久久综合射 | 久久久久久蜜av免费网站 | 在线日韩精品视频 | 久久www免费视频 | 国产不卡一 | 超碰人人乐 | 日韩欧美黄色网址 | 91在线www | 国产91精品一区二区麻豆亚洲 | 99精品久久久 | 99在线精品观看 | 色婷婷av一区二 | 亚洲精品在线视频 | 国际精品久久久久 | 日韩中文字幕亚洲一区二区va在线 | 国产三级视频在线 | 亚洲午夜精品福利 | 在线国产91 | 国产韩国精品一区二区三区 | 国产伦精品一区二区三区高清 | 国内精品免费久久影院 | 欧美性色黄 | 久久久高清一区二区三区 | 中文字幕国内精品 | 亚洲aⅴ乱码精品成人区 | 国产亚洲一区二区在线观看 | 日韩理论在线观看 | 81精品国产乱码久久久久久 | 欧美巨大荫蒂茸毛毛人妖 | 国产精品久久久久久一区二区 | 久久精品网| 99这里有精品 | 久久99国产综合精品 | 精品在线观 | 超碰97免费在线 | 日韩在线观看三区 | 国产一区二区在线免费视频 | 国产 在线 高清 精品 | 日韩视频在线观看免费 | 玖玖玖精品 | 久久成人久久 | 99精品国产视频 | 国产黄色片一级三级 | 中文字幕视频观看 | 日本黄色一级电影 | 麻豆一区二区三区视频 | 成人a在线观看高清电影 | 日韩在线观看视频一区二区三区 | 97视频中文字幕 | av蜜桃在线 | 欧美日韩不卡一区二区 | 久久精品老司机 | 日韩欧美高清在线 | 色播五月激情综合网 | 午夜影院一级 | 成人黄大片| 一区二区视频欧美 | 91成人小视频| 天天爽天天爽天天爽 | 久久久久久国产精品久久 | 国产精品久久久久久高潮 | 欧洲一区精品 | 俺要去色综合狠狠 | 日韩欧美成人网 | 九九热在线视频免费观看 | 蜜臀aⅴ国产精品久久久国产 | 免费观看性生活大片 | 91| 午夜视频导航 | 中文字幕一区二区三区视频 | 色综合久久久网 | 五月天婷亚洲天综合网鲁鲁鲁 | 国产日韩高清在线 | 久久精品牌麻豆国产大山 | 久久亚洲综合国产精品99麻豆的功能介绍 | 色97在线| 亚洲免费精品视频 | 视频一区久久 | 精品国产视频在线 | 国产理伦在线 | 91精品国产99久久久久久红楼 | 97理论电影 | 国产美女免费看 | 国内精自线一二区永久 | 久久免费视频3 | 国精产品满18岁在线 | 日韩免费视频网站 | 国产精品免费久久久久影院仙踪林 | 国产精品 国产精品 | 久久综合精品国产一区二区三区 | 黄污网站在线 | 九九久久影院 | 在线免费高清视频 | 午夜精品久久久久久久久久久久久久 | 亚洲麻豆精品 | 97中文字幕| 日本91在线| 不卡的一区二区三区 | 香蕉久久久久 | 久久精品中文 | 色偷偷网站视频 | 欧美一区二区三区免费观看 | 成人黄色片免费看 | 黄色午夜 | 欧美福利久久 | 91污视频在线观看 | 婷婷在线视频 | 特级毛片在线 | 久久精品五月 | 日韩女同一区二区三区在线观看 | 探花视频在线版播放免费观看 | 2022国产精品视频 | 99热这里只有精品8 久久综合毛片 | 99精品视频播放 | 四虎影视精品成人 | 99精品国产一区二区三区麻豆 | 91av视频免费在线观看 | 亚洲日本黄色 | 久久久久久久久久网 | 黄色高清视频在线观看 | 国产精品久久久久久久久久久久久 | 国产综合精品一区二区三区 | 国产精品久久久久av福利动漫 | 国产成人精品区 | 久草在线观 | 亚洲免费永久精品国产 | 亚洲激情中文 | 国产精品久久久视频 | 97超碰在线资源 | 亚洲热视频 | 在线www色 | 亚洲成av人片在线观看香蕉 | 天天色图 | 美女网站免费福利视频 | 国产精品情侣视频 | 婷婷色狠狠 | 久久久九色精品国产一区二区三区 | 久久久国产精品成人免费 | 二区视频在线 | 久久精品亚洲精品国产欧美 | 亚洲国产小视频在线观看 | 久久久久久黄色 | 337p日本大胆噜噜噜噜 | 成人a视频| 蜜臀av性久久久久av蜜臀妖精 | 日本黄色黄网站 | 99麻豆久久久国产精品免费 | 久久久久久久综合色一本 | 黄色一级大片在线免费看产 | 亚洲国内在线 | 在线中文字幕观看 | 精品久久久一区二区 | 九九九热精品 | 日韩专区一区二区 | 在线观看视频国产一区 | 韩国av一区二区三区在线观看 | 色综合久久天天 | 日日操日日操 | 日韩一区二区免费在线观看 | 在线观看视频h | 久久国产成人午夜av影院潦草 | 伊人久久国产 | 久久国内精品 | 99在线视频免费观看 | 91精品久久久久久综合五月天 | 美女视频黄频大全免费 | 久久深夜福利免费观看 | 国产一区二区三区四区在线 | 日韩国产在线观看 | 97精品久久 | 日韩欧美在线国产 | 成人永久视频 | 97超级碰碰碰碰久久久久 | 在线日本看片免费人成视久网 | 国产一二区视频 | 国产精品视频免费在线观看 | 午夜精品福利在线 | 中文字幕成人网 | 久久精品一区二区三区视频 | 性色va| 日韩免费一级a毛片在线播放一级 | 91视频xxxx| 成人四虎影院 | 337p日本欧洲亚洲大胆裸体艺术 | 高潮久久久久久久久 | 成人动漫视频在线 | 中文在线| 亚洲精品乱码白浆高清久久久久久 | 一二区av | 日韩在线 一区二区 | 国产精品乱看 | 国际精品久久久久 | 亚洲91精品在线观看 | 国产xvideos免费视频播放 | 日韩欧美视频免费观看 | 久久久国产精品亚洲一区 | 亚洲黄色激情小说 | 久久99电影| 4hu视频| 色香蕉在线| 99色视频在线 | 国产精华国产精品 | 国产999视频| 日韩欧美一区二区三区视频 | 美女国产精品 | 美女黄濒 | 波多野结衣资源 | 国产福利一区二区三区在线观看 | 91看毛片 | 一区二区三区四区免费视频 | 97精品在线观看 | 免费看黄在线看 | av高清一区二区三区 | 欧美精品在线一区二区 | 97成人精品 | 国产精品久久99综合免费观看尤物 | 狠狠色噜噜狠狠狠狠2021天天 | 欧美先锋影音 | 久章草在线观看 | 久久综合九色综合久久久精品综合 | 91 在线视频播放 | 久久这里只有精品久久 | 狠狠激情中文字幕 | 国产小视频在线 | av在线短片| 久久婷婷五月综合色丁香 | 亚洲女同ⅹxx女同tv | 国产精品免费av | 国产亚洲精品久久久久5区 成人h电影在线观看 | 国产99一区 | 精品国产一区在线观看 | 日韩精品不卡 | 在线观看不卡的av | 在线观看日本高清mv视频 | 国产精品原创视频 | 粉嫩av一区二区三区四区在线观看 | 麻豆免费视频观看 | 国产视频亚洲 | 97视频人人澡人人爽 | 欧美巨大荫蒂茸毛毛人妖 | 一级黄网 | 午夜av在线| 99热只有精品在线观看 | 久久伊人精品天天 | 欧美日韩伦理一区 | 奇米7777狠狠狠琪琪视频 | 狠狠色婷婷丁香六月 | 狠狠综合| 免费毛片一区二区三区久久久 | www.com在线观看 | 在线免费观看一区二区三区 | 91一区啪爱嗯打偷拍欧美 | 国产亚洲激情视频在线 | 亚洲精品免费播放 | 182午夜在线观看 | 欧美天堂久久 | 日韩免费高清在线观看 | 久久国产精品免费观看 | 国产日产欧美在线观看 | 国产美女视频一区 | 91网址在线看 | 激情五月婷婷综合网 | 91视频这里只有精品 | 日本黄色免费网站 | 天天干天天爽 | 中文av在线免费观看 | 亚洲国产精品成人女人久久 | 亚洲在线精品视频 | a极黄色片 | 毛片永久新网址首页 | 国产视频1 | 91在线最新 | 久久久这里有精品 | 国产精品综合在线 | 亚洲专区路线二 | 手机色站 | 天天添夜夜操 | 91av久久| 91高清免费看 | 久久久精品影视 | 91精品国产网站 | 久久久久一区 | 五月婷婷综合久久 | 色婷婷狠狠五月综合天色拍 | 日韩在线视频看看 | 久久精品国产亚洲精品2020 | 色婷婷啪啪免费在线电影观看 | 国语黄色片 | 天天爽天天爽天天爽 | 日韩中文字幕在线 | 日韩电影中文字幕在线 | 日韩在线 | 久久a免费视频 | 狠狠亚洲 | 国产精品麻豆视频 | 在线观看 国产 | 91污视频在线观看 | 国产69精品久久99不卡的观看体验 | 久久免费成人网 | 99久久久久久久久久 | 麻豆视传媒官网免费观看 | 国产一级黄色片免费看 | 成人av影视| 国产亚洲精品久久久久久电影 | 精品久久久免费 | 色播五月婷婷 | 欧美成人猛片 | 91麻豆国产福利在线观看 | 国产亚洲精品av | 免费av片在线 | 久草久视频| 亚洲婷婷在线视频 | 色91在线 | 日日爱视频 | 国产精品片 | 在线观看岛国片 | 成人av免费在线观看 | 亚洲天天综合 | 综合网在线视频 | 97国产在线观看 | 成人av在线影院 | 国产精品久久久区三区天天噜 | 国产精品白虎 | 国产在线国产 | 69精品 | 91视频在线免费下载 | 久久99久久99精品免观看粉嫩 | 亚洲综合在线视频 | 欧美怡红院视频 | 成人av免费在线播放 | 精品96久久久久久中文字幕无 | 欧美日韩高清一区二区 国产亚洲免费看 | 久久精品看 | 波多野结衣视频一区 | 狠狠狠狠干 | 久久免费99精品久久久久久 | 日韩免费一区二区 | 欧美少妇xx | 国产在线不卡视频 | 久久国产美女视频 | 国产成人黄色av | 激情久久久久久久久久久久久久久久 | 免费看搞黄视频网站 | 午夜国产福利在线观看 | 色av网站 | 亚洲一区久久 | 成人资源网 | 九九热视频在线播放 | 久久亚洲人 | 西西大胆免费视频 | 久草剧场 | 男女视频久久久 | 亚洲午夜久久久久久久久 | 亚洲视频免费在线观看 | 贫乳av女优大全 | 国产成人在线网站 | 99久久精品久久久久久动态片 | 国产亚洲精品久久久久久久久久久久 | 久久综合九色综合97婷婷女人 | 日韩毛片一区 | 波多野结衣理论片 | 一本色道久久综合亚洲二区三区 | 色先锋av资源中文字幕 | 久久精品欧美一区 | 手机在线小视频 | 少妇av片 | 国产成人精品电影久久久 | 国内丰满少妇猛烈精品播放 | 婷婷色社区| 久久69精品 | 91最新在线 | 主播av在线 | 97在线精品国自产拍中文 | 日韩黄色大片在线观看 | 国产精品久久久久国产精品日日 | 国产高清在线 | 99精品视频在线免费观看 | 日本深夜福利视频 | 色婷婷视频在线观看 | 永久免费精品视频网站 | 夜夜操狠狠干 | 日韩精品一区二区在线 | 在线观看播放av | 天天干天天插 | 日韩中文字幕a | 国产麻豆精品久久一二三 | 免费a v在线 | 国产精品丝袜 | 97超碰超碰久久福利超碰 | 高清精品久久 | 婷婷丁香狠狠爱 | 亚洲夜夜综合 | 九九久久久久99精品 | 91热精品 | 亚洲国产中文字幕在线观看 | 91大神dom调教在线观看 | 久久精品91久久久久久再现 | 久免费 | 91视频免费观看 | 国产亚洲精品中文字幕 | 在线观看视频国产一区 | 日韩欧美高清在线观看 | 中文字幕视频在线播放 | 日韩视频免费看 | 亚洲在线精品视频 | 久草网在线观看 | 亚洲丁香日韩 | 欧美精品久久久久久久久久白贞 | 伊人天天色 | 欧美一性一交一乱 | 亚洲免费在线播放视频 | 中文字幕91在线 | 免费成人短视频 | 国产麻豆剧果冻传媒视频播放量 | 国产高清成人 | 欧美精品一区二区三区一线天视频 | 国产在线精品区 | 日韩精品高清不卡 | 日韩精品中文字幕在线播放 | 国产成人久久精品77777综合 | 麻豆免费在线播放 | 最新av电影网址 | 亚洲欧美日韩国产一区二区 | 精品人人人人 | 波多野结衣最新 | 久久久久免费视频 | 91亚洲精品国偷拍自产在线观看 | 国产精品videoxxxx | 综合色在线 | 五月情婷婷 | 久久久久久久国产精品 | 91网在线看 | 开心激情五月网 | 激情综合色综合久久 | 免费三级黄色片 | 久草青青在线观看 | 午夜精品一区二区三区可下载 | 中文字幕人成乱码在线观看 | 久久伊人婷婷 | 亚洲欧美综合 | 蜜臀精品久久久久久蜜臀 | 丁香婷婷激情国产高清秒播 | 久久免费99 | 中国一级特黄毛片大片久久 | 国产精品欧美久久久久久 | 96精品视频 | 韩国av永久免费 | 天天操夜夜操天天射 | 91在线视频一区 | 亚洲一级性 | 黄色免费网 | 久久一精品| 国产又黄又爽又猛视频日本 | 欧美va天堂va视频va在线 | 99c视频高清免费观看 | 51精品国自产在线 | av大片免费看 | 亚洲国产精品999 | 狠狠干在线 | 69视频国产 | 久久综合九色综合久99 | 国产美腿白丝袜足在线av | 免费观看性生交 | 中文字幕在线专区 | 亚洲最大av | 久久手机在线视频 | 伊人狠狠干 | 中文字幕丰满人伦在线 | 在线观影网站 | 欧美日韩精品电影 | 成人在线视频免费观看 | 九九热精品视频在线观看 | 国产麻豆精品久久一二三 | 日韩高清 一区 | 插婷婷 | 国产精品久久久久久久免费 | 国产人成看黄久久久久久久久 | 亚洲国产久 | 96久久 | 丁香网五月天 | 黄网站色成年免费观看 | 国产精品少妇 | 日韩电影在线观看一区二区三区 | 免费av高清 | 成人资源站 | 草在线视频| 狠狠干夜夜操天天爽 | 亚洲精品777 | 久久婷婷一区二区三区 | 亚洲最大成人免费网站 | 一二三区av | 国产超碰97| 午夜久久视频 | 看片网站黄 | 久久久国产网站 | 国产操在线| 免费在线观看日韩视频 | 亚洲区另类春色综合小说校园片 | 中文字幕在线观看你懂的 | 亚洲一区日韩在线 | 日韩在线免费 | 超碰在线人人爱 | 91高清免费| 成人免费观看网址 | 91av九色| 国产一区二区精品91 | 中文字幕丝袜制服 | 片黄色毛片黄色毛片 | 伊人开心激情 | 亚洲在线精品 | 中文字幕乱在线伦视频中文字幕乱码在线 | 国产精品美女免费视频 | 91成人欧美 | 午夜视频不卡 | 精品国产一区二区三区久久久蜜月 | 69精品人人人人 | 精品美女国产在线 | 久久久久国产一区二区 | av官网在线 | 中文在线a√在线 | 免费观看国产精品 | 国产精品久久久久久电影 | 国产亚洲精品成人av久久影院 | 国产91综合一区在线观看 | 亚洲在线日韩 | 国产免费叼嘿网站免费 | 狠狠色丁香久久婷婷综合丁香 | 国产手机视频在线观看 | 日日夜夜综合网 | 免费视频91 | 国产精品一区二区在线播放 | 午夜电影一区 | 最近能播放的中文字幕 | 五月的婷婷 | 亚洲va欧洲va国产va不卡 | 久久伊人八月婷婷综合激情 | 免费在线观看不卡av | 激情久久久久久久久久久久久久久久 | 色姑娘综合 | 欧美粗又大 | www.com久久久 | 欧美a级在线播放 | 日韩高清免费无专码区 | 日批网站免费观看 | 免费观看91视频 | 99热国产在线 | 中文字幕亚洲不卡 | 日韩字幕在线观看 | 日本成人免费在线观看 | 国产91精品高清一区二区三区 | 精品亚洲欧美一区 | 免费看片成年人 | 精品视频999| 精品久久久久一区二区国产 | 久久婷婷综合激情 | 婷婷开心久久网 | 欧美日韩国内在线 | 久久久麻豆精品一区二区 | 91成人天堂久久成人 | 不卡电影免费在线播放一区 | 91大片网站| 超碰免费久久 | 中文字幕亚洲字幕 | 久久97久久 | 天天综合入口 | av成人在线电影 | 不卡视频国产 | 亚洲精品视频在线观看视频 | 欧美韩日视频 | 国产专区视频在线观看 | 日韩aⅴ视频 | 在线 高清 中文字幕 | 久久a视频| 激情综合五月天 | 久久影院亚洲 | 豆豆色资源网xfplay | 最新av免费 | 久草在线费播放视频 | 最近免费中文字幕 | 日韩成人精品在线观看 | 欧美孕妇与黑人孕交 | 中文在线字幕免 | 国产成人99久久亚洲综合精品 | 麻豆国产精品视频 | 四虎国产永久在线精品 | 在线观看中文字幕亚洲 | 国产成人精品一区一区一区 | 天天在线视频色 | 久热色超碰 | 日韩区欠美精品av视频 | 亚洲精品无 | 国产精品久久久网站 | 国产视频久久久 | 久草电影在线观看 | 一区二区视频在线免费观看 | 在线视频中文字幕一区 | 国产在线观看h | 国产精品久久久久久久久久三级 | 国产手机视频在线 | 国产激情久久久 | 玖玖国产精品视频 | 天天躁天天狠天天透 | 久久老司机精品视频 | 亚洲韩国一区二区三区 | 99热这里精品 | 久要激情网 | 久久综合成人 | 在线 高清 中文字幕 | 黄色资源在线观看 | 久久超碰97 | 91精品久久久久久 | 国产一区二区影院 | 六月丁香六月婷婷 | 国产午夜三级一区二区三 | 国产一级一级国产 | 九九九在线观看 | 在线电影 一区 | 久久只精品99品免费久23小说 | 成人蜜桃视频 | 久久高清精品 | 国产一级在线视频 | 一区二区三区免费在线 | 中文字幕观看在线 | 天天操天天射天天操 | 97超碰资源总站 | 久久久国产精品电影 | 国内外成人在线 | 69久久夜色精品国产69 | 亚洲精品美女在线观看播放 | 在线观看免费黄视频 | 亚洲草视频 | 五月天堂色 | 激情综合五月网 | 亚洲欧洲av在线 | 亚洲欧洲精品在线 | 欧美日韩一区二区三区免费视频 | 欧美日韩一区二区视频在线观看 | 99精品免费 | 久久视频在线视频 | 伊人www22综合色 | 特级黄色视频毛片 |