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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

HBase实现谷粒微博案例

發布時間:2023/12/29 编程问答 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 HBase实现谷粒微博案例 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

HBase實現谷粒微博案例

  • 前言
  • 一、啟動集群
  • 二、功能實現
    • 1.創建工程
    • 2.constants包
    • 3.utils包
      • 3.1 createNameSpace 創建命名空間
      • 3.2 isTableExist 判斷表是否存在
      • 3.3 createTable 創建表
    • 4.dao包
      • 4.1 發微博功能
      • 4.2 關注功能
      • 4.3 取消關注
      • 4.4 獲得用戶初始頁
      • 4.5 獲得用戶全部微博內容
    • 5 test包 測試
  • 總結
  • 參考


前言

最近剛剛在b站上看完了尚硅谷hbase相關課程,在這里記錄一下,完成這個項目遇到的坑,以及案例結果(而且不要吐槽的英語注釋,我是個英語渣,大家盡量意會一下…)。如果博客有什么不對的地方,歡迎大佬指正。


一、啟動集群

由于HBase是基于hadoop的一個非結構化數據庫,所以需要啟動hadoop集群,并且還需要啟動我們的“潤滑器” zookeeper。
我使用的版本是
CentOS 6
Hadoop 3
HBase 3
Zookeeper 3 (每一個虛擬機都要啟動zookeeper)
虛擬機一共三臺,分別是hadoop102,hadoop103,hadoop104
編譯器使用的是IDEA。

二、功能實現

1.創建工程

這里我只是給出代碼以及一些相關解釋,具體的需求分析以及更加詳細的解釋,可以看后面的參考鏈接,我將會給出b站尚硅谷視頻的鏈接,有興趣的可以去看看。
打開IDEA,創建一個新的maven工程,然后進行pom.xml格式如下。這里是需要導入相關的依賴包,以及各種依賴的版本,build一下就會開始進行下載。

<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><parent><artifactId>HBase</artifactId><groupId>org.example</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>guli-weibo</artifactId><dependencies><dependency><groupId>org.apache.hbase</groupId><artifactId>hbase-server</artifactId><version>1.3.1</version></dependency><dependency><groupId>org.apache.hbase</groupId><artifactId>hbase-client</artifactId><version>1.3.1</version></dependency></dependencies><properties><maven.compiler.source>8</maven.compiler.source><maven.compiler.target>8</maven.compiler.target></properties></project>

然后在工程中創建5個文件夾(其中一個是空的,也可以不創建),后續需要添加代碼。如圖:

ok,現在我們就可以快樂的編寫代碼了。

2.constants包

在這里我們定義的是一些常量,例如是命名空間、表明、列名等,以便后面我們需要使用的時候反復重寫,防止寫錯,也可以進行一個解耦合。

package constants;import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.hbase.*;public class Constants {public static Configuration CONFIGURATION = null;// HBase setting 這里不知道為什么要這要寫才可以,視頻里面沒有寫這個也可以運行,// 但是我就會報錯,說無法連接,希望有大佬可以解釋一下。// 那個set里面第二個放的是你們集群的名稱,可能會不一樣,看你們自己的命名了。static {CONFIGURATION = HBaseConfiguration.create();CONFIGURATION.set("hbase.zookeeper.quorum", "hadoop102,hadoop103,hadoop104");}// HBase namespace 這個是命名空間public static final String NAMESPACE = "weibo";// weibo content table 這個是內容表public static final String CONTENT_TABLE = "weibo:content";public static String CONTENT_TABLE_CF = "info";public static int CONTENT_TABLE_VERSIONS = 1;// user relationship table 這個是關系表public static final String RELATION_TABLE = "weibo:relation";public static final String RELATION_TABLE_CF1 = "attends";public static final String RELATION_TABLE_CF2 = "fans";public static final int RELATION_TABLE_VERSIONS = 1;// receipt email box 這個是收件表public static final String INBOX_TABLE = "weibo:inbox";public static final String INBOX_TABLE_CF = "info";public static final int INBOX_TABLE_VERSIONS = 2;}

3.utils包

這里主要是進行DDL的操作,例如創建命名空間,以及對表之類的操作。
代碼總覽,下面再分段解釋:

package utils;import constants.Constants; import org.apache.hadoop.hbase.HColumnDescriptor; import org.apache.hadoop.hbase.HTableDescriptor; import org.apache.hadoop.hbase.NamespaceDescriptor; import org.apache.hadoop.hbase.TableName; import org.apache.hadoop.hbase.client.Admin; import org.apache.hadoop.hbase.client.Connection; import org.apache.hadoop.hbase.client.ConnectionFactory; import org.apache.hadoop.hbase.client.Table;import java.io.IOException;/*** 1 create namespace* 2 judge table exist or not* 3 create three tables* 4*/public class HBaseUtil {// 1 create namespacepublic static void createNameSpace(String namespace) throws IOException {// 1 get the connection objectConnection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// 2 get the admin objectAdmin admin = connection.getAdmin();// 1 create namespace descriptionNamespaceDescriptor build = NamespaceDescriptor.create(namespace).build();// 2 create namespaceadmin.createNamespace(build);// 3 close resourceadmin.close();connection.close();}// 2 judge the table exist or notprivate static boolean isTableExist(String tableName) throws IOException {// 1 get the connection objectConnection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// 2 get the admin objectAdmin admin = connection.getAdmin();// 3 judge the table exist or notboolean result = admin.tableExists(TableName.valueOf(tableName));// 4 close resourceadmin.close();connection.close();// return valuereturn result;}// 3 create tablepublic static void createTable(String tableName, int versions, String... cfs) throws IOException {// 1 judge the command valueif (cfs.length <= 0) {System.out.println("column information is not available.");return ;}// 2 judge the table exist or notif (isTableExist(tableName)) {System.out.println(tableName + "table is exist.");return;}// 3 get the connection objectConnection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// 4 get the admin objectAdmin admin = connection.getAdmin();// 5 create table descriptionHTableDescriptor hTableDescriptor = new HTableDescriptor(TableName.valueOf(tableName));// 6 cycle add column informationfor (String cf : cfs) {HColumnDescriptor hColumnDescriptor = new HColumnDescriptor(cf);// 7 set the versionhColumnDescriptor.setMaxVersions(versions);hTableDescriptor.addFamily(hColumnDescriptor);}// 8 create tableadmin.createTable(hTableDescriptor);// close resourceadmin.close();connection.close();} }

3.1 createNameSpace 創建命名空間

// 1 create namespacepublic static void createNameSpace(String namespace) throws IOException {// 1 get the connection object 創建一個連接的對象Connection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// 2 get the admin object 創建一個admin的對象,// 對hbase操作基本上通admin來操作Admin admin = connection.getAdmin();// 1 create namespace description 創建一個命名空間的解釋器NamespaceDescriptor build = NamespaceDescriptor.create(namespace).build();// 2 create namespace 創建命名空間admin.createNamespace(build);// 3 close resource 關閉資源admin.close();connection.close();}

3.2 isTableExist 判斷表是否存在

// 2 judge the table exist or notprivate static boolean isTableExist(String tableName) throws IOException {// 1 get the connection objectConnection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// 2 get the admin objectAdmin admin = connection.getAdmin();// 3 judge the table exist or not. // tableExists這個函數是需要傳入TableName參數的,所以需要轉換。boolean result = admin.tableExists(TableName.valueOf(tableName));// 4 close resourceadmin.close();connection.close();// return valuereturn result;}

3.3 createTable 創建表

這一塊蠻重要的,但是也是固定的套路。

// 3 create tablepublic static void createTable(String tableName, int versions, String... cfs) throws IOException {// 1 judge the command value 判斷一下傳入的參數是否小于等于0if (cfs.length <= 0) {System.out.println("column information is not available.");return ;}// 2 judge the table exist or not 判斷表是否存在if (isTableExist(tableName)) {System.out.println(tableName + "table is exist.");return;}// 3 get the connection objectConnection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// 4 get the admin objectAdmin admin = connection.getAdmin();// 5 create table description // 創建表描述器,對表的操作都是通過描述器來操作。HTableDescriptor hTableDescriptor = new HTableDescriptor(TableName.valueOf(tableName));// 6 cycle add column informationfor (String cf : cfs) {// 這里是創建一個列描述器HColumnDescriptor hColumnDescriptor = new HColumnDescriptor(cf);// 7 set the versionhColumnDescriptor.setMaxVersions(versions);// 將列描述器加入到表描述器當中,也就是把列族加進去。hTableDescriptor.addFamily(hColumnDescriptor);}// 8 create tableadmin.createTable(hTableDescriptor);// close resourceadmin.close();connection.close();}

4.dao包

這里是一些DML的操作,例如一些在表中插入數據,或者是刪除數據的操作。
老規矩,先來一個代碼總覽(比較長…):

package dao;import constants.Constants; import org.apache.hadoop.hbase.Cell; import org.apache.hadoop.hbase.CellUtil; import org.apache.hadoop.hbase.TableName; import org.apache.hadoop.hbase.client.*; import org.apache.hadoop.hbase.filter.CompareFilter; import org.apache.hadoop.hbase.filter.RowFilter; import org.apache.hadoop.hbase.filter.SubstringComparator; import org.apache.hadoop.hbase.util.Bytes;import java.io.IOException; import java.util.ArrayList;/*** 1 send the weibo* 2 delete the weibo* 3 focus the user* 4 check off user* 5 get the user's weibo detail* 6 get the user's initialize page*/ public class HBaseDao {// 1 send the weibopublic static void publishWeiBo(String uid, String content) throws IOException {// 1 get the connection objectConnection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// 2 get the admin objectAdmin admin = connection.getAdmin();// 1 operate weibo content table// 1.1 get the weibo content table objectTable conTable = connection.getTable(TableName.valueOf(Constants.CONTENT_TABLE));// 1.2 get the current timelong ts = System.currentTimeMillis();// 1.3 get the RowkeyString rowKey = uid + "_" + ts;// 1.4 create put objectPut conPut = new Put(Bytes.toBytes(rowKey));// 1.5 Assignment the put objectconPut.addColumn(Bytes.toBytes(Constants.CONTENT_TABLE_CF), Bytes.toBytes("content"), Bytes.toBytes(content));// 1.6 execute insert data operationconTable.put(conPut);// 2 operate weibo email box// 2.1 get user relation table objectTable relaTable = connection.getTable(TableName.valueOf(Constants.RELATION_TABLE));// 2.2 get the fans's information of the person who publish weibo in currentGet get = new Get(Bytes.toBytes(uid));get.addFamily(Bytes.toBytes(Constants.RELATION_TABLE_CF2));Result result = relaTable.get(get);// 2.3 create a map, in order to store the put object of weibo content tableArrayList<Put> inboxPuts = new ArrayList<>();// 2.4 traverse the fans listfor (Cell cell : result.rawCells()) {// 2.5 create the put object of weibo infobox tablePut inboxPut = new Put(CellUtil.cloneQualifier(cell));// 2.6 assignment the information to the inbox tableinboxPut.addColumn(Bytes.toBytes(Constants.INBOX_TABLE_CF), Bytes.toBytes(uid), Bytes.toBytes(rowKey));// 2.7 store the put object into the inbox tableinboxPuts.add(inboxPut);}// 2.8 judge fans exist or notif (inboxPuts.size() > 0) {// get the inbox objectTable inboxTable = connection.getTable(TableName.valueOf(Constants.INBOX_TABLE));// execute the insert operationinboxTable.put(inboxPuts);// close the inbox tableinboxTable.close();}// close the resourcerelaTable.close();conTable.close();connection.close();}// 2 focus the userpublic static void addAttends(String uid, String... attends) throws IOException {// judge if or not exist attendsif (attends.length <= 0) {System.out.println("please choose attention person");return ;}// get the connection objectConnection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// first, operate user relationship table// 1 get the user relationship table objectTable relaTable = connection.getTable(TableName.valueOf(Constants.RELATION_TABLE));// 2 create a map, in order to store a put object of user relationship tableArrayList<Put> relaPuts = new ArrayList<>();// 3 create an operator put objectPut uidPut = new Put(Bytes.toBytes(uid));// 4 cycle create a put object of attended personfor (String attend : attends) {// 5 assignment value to operator's put objectuidPut.addColumn(Bytes.toBytes(Constants.RELATION_TABLE_CF1), Bytes.toBytes(attend), Bytes.toBytes(attend));// 6 create a put object of attended personPut attendPut = new Put(Bytes.toBytes(attend));// 7 assignment value to attended person's put objectattendPut.addColumn(Bytes.toBytes(Constants.RELATION_TABLE_CF2), Bytes.toBytes(uid), Bytes.toBytes(uid));// 8 put the attended person's put object into maprelaPuts.add(attendPut);}// 9 add operator's put object into maprelaPuts.add(uidPut);// 10 execute user relationship table the insertion operationrelaTable.put(relaPuts);// second operate inbox table// 1 get the weibo content table objectTable contTable = connection.getTable(TableName.valueOf(Constants.CONTENT_TABLE));// 2 create put object of inbox tablePut inboxPut = new Put(Bytes.toBytes(uid));// 3 cycle attends, get the every attended person current published weibofor (String attend : attends) {// 4 get the attended person's current published weibo -> map resultScannerScan scan = new Scan(Bytes.toBytes(attend + "_"), Bytes.toBytes(attend + "|"));ResultScanner resultScanner = contTable.getScanner(scan);// define a time stamplong ts = System.currentTimeMillis();// 5 traverse the valuefor (Result result : resultScanner) {// 6 assignment the value into the inbox tableinboxPut.addColumn(Bytes.toBytes(Constants.INBOX_TABLE_CF), Bytes.toBytes(attend), ts++, result.getRow());}}// judge the put object exist or notif (!inboxPut.isEmpty()) {// get the inbox table objectTable inboxTable = connection.getTable(TableName.valueOf(Constants.INBOX_TABLE));// insert datainboxTable.put(inboxPut);// close inboxTable connectioninboxTable.close();}// close resourcerelaTable.close();contTable.close();connection.close();}// 3 delete attentionpublic static void deleteAttends(String uid, String... dels) throws IOException {if (dels.length <= 0) {System.out.println("please choose deletion person");return;}// get the connection objectConnection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// first operate user relationship table// 1 get the user relationship table objectTable relatTable = connection.getTable(TableName.valueOf(Constants.RELATION_TABLE));// 2 create a map, in order to store the delete object of user relationship tableArrayList<Delete> relatDelete = new ArrayList<>();// 3 create the delete object of operatorDelete uidDelete = new Delete(Bytes.toBytes(uid));// 4 cycle create the delete object of delete attentionfor (String del : dels) {// 5 assignment value to operator's delete objectuidDelete.addColumns(Bytes.toBytes(Constants.RELATION_TABLE_CF1), Bytes.toBytes(del));// 6 create the conceal person's(取關者...) deletion objectDelete delDelte = new Delete(Bytes.toBytes(del));// 7 assignment value to the conceal person's deletion objectdelDelte.addColumns(Bytes.toBytes(Constants.RELATION_TABLE_CF2), Bytes.toBytes(uid));// 8 add the conceal person's deletion object into the maprelatDelete.add(delDelte);}// 9 add the operator's deletion object into the maprelatDelete.add(uidDelete);// 10 delete the data in user relationship tablerelatTable.delete(relatDelete);// second operate inbox table// 1 get the inbox table objectTable inboxTable = connection.getTable(TableName.valueOf(Constants.INBOX_TABLE));// 2 create the deletion object of operatorDelete inboxDelete = new Delete(Bytes.toBytes(uid));// 3 assignment value to operator's deletion objectfor (String del : dels) {inboxDelete.addColumns(Bytes.toBytes(Constants.INBOX_TABLE_CF), Bytes.toBytes(del));}// 4 delete data in inbox tableinboxTable.delete(inboxDelete);// close resourcerelatTable.close();inboxTable.close();connection.close();}// 4 get the initial page datapublic static void getInit(String uid) throws IOException {// 1 get the connection objectConnection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// 2 get inbox table objectTable inboxTable = connection.getTable(TableName.valueOf(Constants.INBOX_TABLE));// 3 get the content table objectTable conTable = connection.getTable(TableName.valueOf(Constants.CONTENT_TABLE));// 4 create inbox get object, and get the data max versionGet inboxGet = new Get(Bytes.toBytes(uid));inboxGet.setMaxVersions();Result result = inboxTable.get(inboxGet);// 5 traverse the datafor (Cell cell : result.rawCells()) {// 6 construct the content table get objectGet conGet = new Get(CellUtil.cloneValue(cell));// 7 get the object dataResult conResult = conTable.get(conGet);// 8 print datafor (Cell conCell : conResult.rawCells()) {System.out.println("RK:" + Bytes.toString(CellUtil.cloneRow(conCell)) +", CF:" + Bytes.toString(CellUtil.cloneFamily(conCell)) +", CN:" + Bytes.toString(CellUtil.cloneQualifier(conCell)) +", Value:" + Bytes.toString(CellUtil.cloneValue(conCell)));}}// 9 close resourceinboxTable.close();conTable.close();connection.close();}// 5 get the all the content of somebody weibopublic static void getWeibo(String uid) throws IOException {// 1 get the connectionConnection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// 2 get the weibo content tableTable conTable = connection.getTable(TableName.valueOf(Constants.CONTENT_TABLE));// construct scan objectScan scan = new Scan();// construct filterRowFilter rowFilter = new RowFilter(CompareFilter.CompareOp.EQUAL, new SubstringComparator(uid + "_"));scan.setFilter(rowFilter);// 4 get the dataResultScanner resultScanner = conTable.getScanner(scan);// 5 printf datafor (Result result : resultScanner) {for (Cell cell : result.rawCells()) {System.out.println("RK:" + Bytes.toString(CellUtil.cloneRow(cell)) +", CF:" + Bytes.toString(CellUtil.cloneFamily(cell)) +", CN:" + Bytes.toString(CellUtil.cloneQualifier(cell)) +", Value:" + Bytes.toString(CellUtil.cloneValue(cell)));}}// 6 close resourceconTable.close();connection.close();} }

4.1 發微博功能

這一個功能比較難,因為不僅對于當前發布微博的人的內容表需要進行更新,并且需要對當前這個人的粉絲的收件表也需要更新,因為粉絲需要看到關注的人的最新動態。所以這里需要對兩張表,多個人進行操作。

// 1 publish the weibopublic static void publishWeiBo(String uid, String content) throws IOException {// 1 get the connection objectConnection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// 2 get the admin objectAdmin admin = connection.getAdmin();// 1 operate weibo content table 對微博內容表進行操作// 1.1 get the weibo content table objectTable conTable = connection.getTable(TableName.valueOf(Constants.CONTENT_TABLE));// 1.2 get the current timelong ts = System.currentTimeMillis();// 1.3 get the RowkeyString rowKey = uid + "_" + ts;// 1.4 create put object 將需要put的內容對象先創建好Put conPut = new Put(Bytes.toBytes(rowKey));// 1.5 Assignment the put object 給put對象賦值conPut.addColumn(Bytes.toBytes(Constants.CONTENT_TABLE_CF), Bytes.toBytes("content"), Bytes.toBytes(content));// 1.6 execute insert data operation// 執行put操作,即對表進行插入數據conTable.put(conPut);// 2 operate weibo email box 操作微博收件表// 2.1 get user relation table objectTable relaTable = connection.getTable(TableName.valueOf(Constants.RELATION_TABLE));// 2.2 get the fans's information of the person who publish weibo in current// 得到最近發布微博的被關注者的粉絲的信息Get get = new Get(Bytes.toBytes(uid));get.addFamily(Bytes.toBytes(Constants.RELATION_TABLE_CF2));Result result = relaTable.get(get);// 2.3 create a map, in order to store the put object of weibo content table// 創建一個集合為了存儲微博的內容ArrayList<Put> inboxPuts = new ArrayList<>();// 2.4 traverse the fans list// 遍歷uid的粉絲for (Cell cell : result.rawCells()) {// 2.5 create the put object of weibo infobox table// 創建粉絲的單元格Put inboxPut = new Put(CellUtil.cloneQualifier(cell));// 2.6 assignment the information to the inbox table// 對粉絲的收件表進行賦值,更新關注的人的最新微博inboxPut.addColumn(Bytes.toBytes(Constants.INBOX_TABLE_CF), Bytes.toBytes(uid), Bytes.toBytes(rowKey));// 2.7 store the put object into the inbox tableinboxPuts.add(inboxPut);}// 2.8 judge fans exist or not// 判斷當前發布微博的人是否有粉絲if (inboxPuts.size() > 0) {// get the inbox objectTable inboxTable = connection.getTable(TableName.valueOf(Constants.INBOX_TABLE));// execute the insert operationinboxTable.put(inboxPuts);// close the inbox tableinboxTable.close();}// close the resourcerelaTable.close();conTable.close();connection.close();}

4.2 關注功能

關注某個人之后,需要獲得這個人的最近發布的微博,以及在微博關系表當中需要添加新的關系。代碼也比較長…

// 2 focus the userpublic static void addAttends(String uid, String... attends) throws IOException {// judge if or not exist attendsif (attends.length <= 0) {System.out.println("please choose attention person");return ;}// get the connection objectConnection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// first, operate user relationship table// 操作微博關系表// 1 get the user relationship table objectTable relaTable = connection.getTable(TableName.valueOf(Constants.RELATION_TABLE));// 2 create a map, in order to store a put object of user relationship table// 創建關注的集合,因為有可能一次性關注多個人。ArrayList<Put> relaPuts = new ArrayList<>();// 3 create an operator put objectPut uidPut = new Put(Bytes.toBytes(uid));// 4 cycle create a put object of attended personfor (String attend : attends) {// 5 assignment value to operator's put objectuidPut.addColumn(Bytes.toBytes(Constants.RELATION_TABLE_CF1), Bytes.toBytes(attend), Bytes.toBytes(attend));// 6 create a put object of attended person// 這是被關注者對象Put attendPut = new Put(Bytes.toBytes(attend));// 7 assignment value to attended person's put objectattendPut.addColumn(Bytes.toBytes(Constants.RELATION_TABLE_CF2), Bytes.toBytes(uid), Bytes.toBytes(uid));// 8 put the attended person's put object into maprelaPuts.add(attendPut);}// 9 add operator's put object into maprelaPuts.add(uidPut);// 10 add data into user relationship tablerelaTable.put(relaPuts);// second operate inbox table// 1 get the weibo content table objectTable contTable = connection.getTable(TableName.valueOf(Constants.CONTENT_TABLE));// 2 create put object of inbox tablePut inboxPut = new Put(Bytes.toBytes(uid));// 3 cycle attends, get the every attended person current published weibofor (String attend : attends) {// 4 get the attended person's current published weibo -> map resultScanner// 獲得被關注者最近發布的微博Scan scan = new Scan(Bytes.toBytes(attend + "_"), Bytes.toBytes(attend + "|"));ResultScanner resultScanner = contTable.getScanner(scan);// define a time stamplong ts = System.currentTimeMillis();// 5 traverse the valuefor (Result result : resultScanner) {// 6 assignment the value into the inbox table// 循環放入粉絲的收件表中inboxPut.addColumn(Bytes.toBytes(Constants.INBOX_TABLE_CF), Bytes.toBytes(attend), ts++, result.getRow());}}// judge the put object exist or notif (!inboxPut.isEmpty()) {// get the inbox table objectTable inboxTable = connection.getTable(TableName.valueOf(Constants.INBOX_TABLE));// insert datainboxTable.put(inboxPut);// close inboxTable connectioninboxTable.close();}// close resourcerelaTable.close();contTable.close();connection.close();}

4.3 取消關注

// 3 delete attentionpublic static void deleteAttends(String uid, String... dels) throws IOException {if (dels.length <= 0) {System.out.println("please choose deletion person");return;}// get the connection objectConnection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// first operate user relationship table// 1 get the user relationship table objectTable relatTable = connection.getTable(TableName.valueOf(Constants.RELATION_TABLE));// 2 create a map, in order to store the delete object of user relationship tableArrayList<Delete> relatDelete = new ArrayList<>();// 3 create the delete object of operatorDelete uidDelete = new Delete(Bytes.toBytes(uid));// 4 cycle create the delete object of delete attentionfor (String del : dels) {// 5 assignment value to operator's delete objectuidDelete.addColumns(Bytes.toBytes(Constants.RELATION_TABLE_CF1), Bytes.toBytes(del));// 6 create the conceal person's(取關者...) deletion objectDelete delDelte = new Delete(Bytes.toBytes(del));// 7 assignment value to the conceal person's deletion objectdelDelte.addColumns(Bytes.toBytes(Constants.RELATION_TABLE_CF2), Bytes.toBytes(uid));// 8 add the conceal person's deletion object into the maprelatDelete.add(delDelte);}// 9 add the operator's deletion object into the maprelatDelete.add(uidDelete);// 10 delete the data in user relationship tablerelatTable.delete(relatDelete);// second operate inbox table// 1 get the inbox table objectTable inboxTable = connection.getTable(TableName.valueOf(Constants.INBOX_TABLE));// 2 create the deletion object of operatorDelete inboxDelete = new Delete(Bytes.toBytes(uid));// 3 assignment value to operator's deletion objectfor (String del : dels) {inboxDelete.addColumns(Bytes.toBytes(Constants.INBOX_TABLE_CF), Bytes.toBytes(del));}// 4 delete data in inbox tableinboxTable.delete(inboxDelete);// close resourcerelatTable.close();inboxTable.close();connection.close();}

4.4 獲得用戶初始頁

// 4 get the initial page datapublic static void getInit(String uid) throws IOException {// 1 get the connection objectConnection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// 2 get inbox table objectTable inboxTable = connection.getTable(TableName.valueOf(Constants.INBOX_TABLE));// 3 get the content table objectTable conTable = connection.getTable(TableName.valueOf(Constants.CONTENT_TABLE));// 4 create inbox get object, and get the data max versionGet inboxGet = new Get(Bytes.toBytes(uid));inboxGet.setMaxVersions();Result result = inboxTable.get(inboxGet);// 5 traverse the datafor (Cell cell : result.rawCells()) {// 6 construct the content table get objectGet conGet = new Get(CellUtil.cloneValue(cell));// 7 get the object dataResult conResult = conTable.get(conGet);// 8 print datafor (Cell conCell : conResult.rawCells()) {System.out.println("RK:" + Bytes.toString(CellUtil.cloneRow(conCell)) +", CF:" + Bytes.toString(CellUtil.cloneFamily(conCell)) +", CN:" + Bytes.toString(CellUtil.cloneQualifier(conCell)) +", Value:" + Bytes.toString(CellUtil.cloneValue(conCell)));}}// 9 close resourceinboxTable.close();conTable.close();connection.close();}

4.5 獲得用戶全部微博內容

// 5 get the all the content of somebody weibopublic static void getWeibo(String uid) throws IOException {// 1 get the connectionConnection connection = ConnectionFactory.createConnection(Constants.CONFIGURATION);// 2 get the weibo content tableTable conTable = connection.getTable(TableName.valueOf(Constants.CONTENT_TABLE));// construct scan objectScan scan = new Scan();// construct filterRowFilter rowFilter = new RowFilter(CompareFilter.CompareOp.EQUAL, new SubstringComparator(uid + "_"));scan.setFilter(rowFilter);// 4 get the dataResultScanner resultScanner = conTable.getScanner(scan);// 5 printf datafor (Result result : resultScanner) {for (Cell cell : result.rawCells()) {System.out.println("RK:" + Bytes.toString(CellUtil.cloneRow(cell)) +", CF:" + Bytes.toString(CellUtil.cloneFamily(cell)) +", CN:" + Bytes.toString(CellUtil.cloneQualifier(cell)) +", Value:" + Bytes.toString(CellUtil.cloneValue(cell)));}}// 6 close resourceconTable.close();connection.close();}

5 test包 測試

在test包當中,編寫測試代碼,相對簡單。

package test;import constants.Constants; import dao.HBaseDao; import utils.HBaseUtil;import java.io.IOException;public class TestWeiBo {public static void init() {try {// create namespaceHBaseUtil.createNameSpace(Constants.NAMESPACE);// create weibo content tableHBaseUtil.createTable(Constants.CONTENT_TABLE, Constants.CONTENT_TABLE_VERSIONS, Constants.CONTENT_TABLE_CF);// create user relationship tableHBaseUtil.createTable(Constants.RELATION_TABLE, Constants.RELATION_TABLE_VERSIONS,Constants.RELATION_TABLE_CF1, Constants.RELATION_TABLE_CF2);// create inbox tableHBaseUtil.createTable(Constants.INBOX_TABLE, Constants.INBOX_TABLE_VERSIONS, Constants.INBOX_TABLE_CF);} catch (IOException e) {e.printStackTrace();}}public static void main(String[] args) throws IOException, InterruptedException {// initializeinit();System.out.println("init done");// 1001 publish weiboHBaseDao.publishWeiBo("1001","這是1001的微博,Hello World");System.out.println("publish done");// 1002 attend 1001, 1003HBaseDao.addAttends("1002", "1001", "1003");System.out.println("attend done");// get the 1002 initial pageHBaseDao.getInit("1002");System.out.println("*********************111**********************");// 1003 publish 3 weibo, at the same time 1002 publish 2 weiboHBaseDao.publishWeiBo("1003", "快結束了HBase了!!");Thread.sleep(10);HBaseDao.publishWeiBo("1001", "那你還是個弟弟啊!!");Thread.sleep(10);HBaseDao.publishWeiBo("1003", "哦,不我要當哥哥!!");Thread.sleep(10);HBaseDao.publishWeiBo("1001", "弟弟!!");Thread.sleep(10);HBaseDao.publishWeiBo("1003", "叫哥哥!!");// get 1002 initial pageHBaseDao.getInit("1002");System.out.println("*********************222***********************");// 1002 conceal 1003HBaseDao.deleteAttends("1002", "1003");// get the 1002 initial pageHBaseDao.getInit("1002");System.out.println("*********************333***********************");// 1002 attend 1003 againHBaseDao.addAttends("1002", "1003");// get the 1002 initial pageHBaseDao.getInit("1002");System.out.println("*********************444***********************");// get 1001 detail initial pageHBaseDao.getWeibo("1001");System.out.println("*********************555***********************");} }

總結

不知道為什么在configuration配置的時候總是存在問題,最后參考以前寫的測試API的代碼,加上了configuration.set(),才可以跑通。否則一直顯示的是連接超時,不存在zookeeper的master。具體問題還不清楚,感覺像是代碼找不到連接zookeeper的端口了。
最后我這個弱雞終于成功跑通了代碼,感覺還是蠻不錯的,記錄一下遇到的坑。
1、編寫代碼的時候,需要記住addColumns()函數里面是需要對列進行操作,好幾次寫成了table,忘了加CF了,然后報錯。并且還需要轉換成字節的形式。
2、需要弄清楚業務的邏輯,因為里面只是設計了三張表所以邏輯相對簡單。但是盡可能的還是多考慮考慮一些解耦合的操作或者是需求分析的時候對創建表考慮清楚。

最后,加油吧,諸君。

參考

b站尚硅谷的hbase視頻

總結

以上是生活随笔為你收集整理的HBase实现谷粒微博案例的全部內容,希望文章能夠幫你解決所遇到的問題。

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

欧美日韩亚洲在线 | 国产a免费 | 成人毛片在线视频 | 亚洲在线免费视频 | 国产精品2区 | 亚洲欧美日韩精品久久久 | 日本高清免费中文字幕 | 国内精品小视频 | 久久久久成人精品 | 国产馆在线播放 | 日韩h在线观看 | 久草国产精品 | 中文字幕久久久精品 | 天天干天天操av | 亚洲影音先锋 | 日韩一级片网址 | 国产视频在线观看一区 | 久久成人高清 | 久久午夜国产精品 | 视频在线观看入口黄最新永久免费国产 | 激情五月伊人 | 热热热热热色 | 成人av电影网址 | 亚洲婷婷丁香 | 亚洲国产色一区 | 激情大尺度视频 | 97色在线观看免费视频 | 香蕉视频啪啪 | 在线视频 区 | 国产91精品一区二区麻豆亚洲 | 国产一区二区网址 | 中文字幕丝袜一区二区 | 国产精久久久 | 国产午夜不卡 | 久久国产美女视频 | 黄色大全免费网站 | 夜夜操天天 | 欧美日韩一区三区 | 福利一区在线 | 色大片免费看 | 麻花传媒mv免费观看 | 国产精品久久久久久久久免费看 | 欧美黑人巨大xxxxx | 久草视频99 | 人人精久 | 亚洲国产视频网站 | 一区二区视频欧美 | 中国一级片在线 | 久久五月婷婷综合 | 日韩国产欧美在线视频 | 精品久久网站 | 一区二区三区三区在线 | 在线成人高清电影 | 激情在线网站 | 国产视频在线观看一区 | 97精品国产97久久久久久春色 | 日本精品久久久一区二区三区 | 国产精品免费在线视频 | 国产美女视频一区 | 国产一级在线看 | 国产人成精品一区二区三 | 亚洲天天做 | 日日干激情五月 | 国产一区二区在线免费观看 | 国产视频午夜 | 91最新地址永久入口 | 97精品超碰一区二区三区 | 四虎影院在线观看av | 日韩色av色资源 | 久久国产精品免费看 | 精品福利网站 | 精品国产一区二区三区免费 | 91精品视频观看 | 国产一区高清在线 | 国产成人一区三区 | 国产精品一区二区三区久久久 | 综合伊人久久 | 丁香婷婷激情网 | 日韩欧美国产免费播放 | 美女视频a美女大全免费下载蜜臀 | 成人小视频在线播放 | 国内外激情视频 | 最近能播放的中文字幕 | 久久97精品 | 99久免费精品视频在线观看 | 欧美在线观看禁18 | 91九色性视频 | 亚洲天堂在线观看完整版 | 成人午夜精品福利免费 | av高清一区 | ,午夜性刺激免费看视频 | 久操中文字幕在线观看 | 久久97视频 | 日韩av成人免费看 | 五月开心激情网 | 婷婷成人亚洲综合国产xv88 | 伊人射 | 青青河边草免费直播 | 久久手机精品视频 | 夜夜天天干 | 免费高清在线观看成人 | 狠狠的干 | 又湿又紧又大又爽a视频国产 | 黄色一级网| 久久九九影视 | 国产一级精品视频 | 99热.com| 久久免费视频这里只有精品 | 91免费在线视频 | 国产精品久久片 | 久久久久免费精品国产小说色大师 | 在线播放av网址 | 91在线91拍拍在线91 | 日韩av在线一区二区 | 91丨九色丨91啦蝌蚪老版 | 亚洲 欧美 另类人妖 | 久久综合毛片 | 人人草在线视频 | 丁香午夜婷婷 | 国产拍揄自揄精品视频麻豆 | 久久这里只有精品久久 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 草莓视频在线观看免费观看 | 99热高清| 婷婷色影院 | 精品视频国产 | 99国产在线观看 | 激情五月婷婷综合网 | 日韩精品无 | 99精品在线免费观看 | 91视频在线 | 婷婷在线五月 | 美女又爽又黄 | 国产一区网址 | 97看片吧| 午夜在线免费观看 | 久久视频在线免费观看 | 成人黄色小说视频 | 九九久久影院 | 激情开心网站 | 欧美日韩一区二区久久 | 天堂va在线观看 | 一区二区三区三区在线 | 黄色av网站在线免费观看 | 国产精品毛片一区二区 | 国产精品成人a免费观看 | 人人爽人人爽人人片av免 | 99热这里只有精品免费 | 国内丰满少妇猛烈精品播 | 中文字幕久久网 | 天天爱天天操天天爽 | 久久精品视频在线观看免费 | 国产不卡在线观看视频 | 久久久久国产一区二区三区 | 久草在线免费电影 | 久久人人爽人人片av | 日本在线视频一区二区三区 | 精品美女久久久久久免费 | 亚洲天天干| 午夜精品久久久久久久99婷婷 | 狠狠狠色丁香综合久久天下网 | 日韩美女av在线 | 久久艹精品 | 免费观看v片在线观看 | 丰满少妇对白在线偷拍 | 久久久久久久福利 | 亚洲精品乱码久久久久久蜜桃欧美 | 一本之道乱码区 | 国产精品一区二区在线播放 | 欧美亚洲免费在线一区 | 亚洲欧洲一区二区在线观看 | 一区二区三区电影在线播 | 婷婷综合| 亚洲精选视频免费看 | 在线观看不卡视频 | 国产精品久久精品 | 色精品视频 | 日韩在线第一区 | 国产一区二区三区免费在线观看 | 香蕉网站在线观看 | 午夜久草 | 999电影免费在线观看 | 亚洲人成网站精品片在线观看 | 婷婷在线免费视频 | 少妇精品久久久一区二区免费 | 久久这里只有精品久久 | 亚洲电影免费 | 欧美二区视频 | 四虎在线视频免费观看 | 国产午夜精品一区二区三区欧美 | 在线免费观看涩涩 | 免费看黄色小说的网站 | 国产高清在线免费 | 国产免费嫩草影院 | 欧美国产视频在线 | 在线亚洲免费视频 | 久久你懂得| 亚洲精品综合久久 | 国产亚洲精品女人久久久久久 | 精品国产一区二区三区蜜臀 | 精品999| 久久久精品免费看 | 亚洲国产免费看 | 欧美日本日韩aⅴ在线视频 插插插色综合 | 欧美激情精品久久久久 | 久久99精品久久只有精品 | 激情欧美在线观看 | 91精品国产99久久久久久久 | 日本久久精品视频 | 天天草天天草 | 日日夜夜添 | 国产美腿白丝袜足在线av | 亚洲精品视频网站在线观看 | 日韩免| 在线观看91精品视频 | 日韩手机在线 | 中文字幕在线有码 | 亚洲一区 影院 | 岛国一区在线 | 婷婷久草 | 日日爱999| 欧美精品亚洲二区 | 欧美激情综合五月 | 色婷婷av在线 | 9热精品| 人人看看人人 | 欧美国产精品久久久久久免费 | 91经典在线 | 97在线免费视频观看 | 免费国产在线精品 | 日韩一区二区在线免费观看 | 手机看片国产 | 免费观看国产视频 | 四虎国产视频 | 天天摸天天弄 | 午夜10000| 国产精品一区二区三区四 | 久久久亚洲影院 | 黄网站a | 国际精品久久久 | 天天干天天看 | 精品国内 | 欧美日韩二区在线 | 日日爱影视 | 成人免费视频观看 | 天天天操天天天干 | 午夜在线观看一区 | 色婷婷五 | 久久久精品 一区二区三区 国产99视频在线观看 | 日韩网站在线观看 | av九九| 婷婷社区五月天 | 欧美a视频在线观看 | 免费在线观看av不卡 | 国产区欧美| 在线亚洲精品 | 在线观看视频免费大全 | 亚洲天天草 | 99视频精品免费视频 | 国产成人一区二区三区免费看 | 国产精品成人一区二区三区吃奶 | 午夜精品久久久久久中宇69 | 亚洲精品午夜国产va久久成人 | 欧美精品一二 | 国产精品 中文字幕 亚洲 欧美 | 日韩在线观看视频免费 | 亚洲黄色大片 | 精品影院一区二区久久久 | 制服丝袜天堂 | 一级黄色片网站 | 亚洲国产成人高清精品 | 91免费视频网站在线观看 | 99精品一级欧美片免费播放 | 特级西西人体444是什么意思 | 超碰99在线 | 一区二区三区在线观看免费 | 日韩免费视频线观看 | 97精品在线观看 | 永久av免费在线观看 | 黄色毛片在线 | 日韩激情av在线 | 黄色91免费观看 | 在线观看日韩一区 | 999久久久 | 看国产黄色大片 | 午夜精品麻豆 | 国产999视频 | 久久这里精品视频 | 成年人免费在线观看网站 | 婷婷激情站 | 久久97久久97精品免视看 | 成片免费 | 国产精品久久久久久久久久99 | 亚洲最新合集 | 久久久国产高清 | av电影在线免费观看 | 日本在线观看视频一区 | 婷婷色综合网 | 91亚洲精品视频 | 欧美另类高清 videos | 国产 日韩 中文字幕 | 久久伊人免费视频 | 四季av综合网站 | 99综合电影在线视频 | 免费观看成人网 | 五月婷婷中文字幕 | 日韩欧美视频在线播放 | 国产高清小视频 | 久草精品视频在线看网站免费 | 色爱区综合激月婷婷 | 久草久草久草久草 | 操久在线| 91爱爱免费观看 | 久久毛片高清国产 | 色播五月激情五月 | 国产精品久久久久久久久久尿 | 亚洲九九九在线观看 | 天天拍天天操 | 亚洲精品videossex少妇 | 亚洲日韩欧美视频 | 99产精品成人啪免费网站 | 国产精品久久久久久久99 | 91精品国产成人观看 | 国产在线播放一区二区三区 | 亚洲精品视频中文字幕 | 久久天天躁狠狠躁亚洲综合公司 | 最近中文字幕免费av | 国内精品久久久久久久影视简单 | 亚洲 欧美 日韩 综合 | 中文字幕在线观看的网站 | 狠狠操91| 日韩精品高清不卡 | 日韩免费在线看 | 亚洲免费av在线播放 | 中文字幕第一页在线播放 | 日本精品xxxx| 亚洲精品国产精品国自产在线 | 国产一区二区免费看 | 久久久久久久久久久久久9999 | 91精品福利在线 | 色五月激情五月 | 国产精品久久久久久久久久久久久久 | 精品成人网| 亚洲 综合 精品 | 午夜精品久久久久久久99热影院 | 在线日本看片免费人成视久网 | 精品影院一区二区久久久 | 亚洲国产理论片 | 国产精品久久视频 | 国产美女精彩久久 | 亚洲精品国内 | 91精品亚洲影视在线观看 | 久久久久久久久久久免费视频 | 国产精品免费观看视频 | 三级黄色网址 | 日韩av在线网站 | 91字幕 | 日韩视频在线观看免费 | 在线中文字幕一区二区 | 久久精品亚洲 | 视频在线一区二区三区 | 亚洲精品在线网站 | 免费看黄视频 | 国产精品扒开做爽爽的视频 | 性色av一区二区三区在线观看 | 亚洲成人蜜桃 | 99国产精品免费网站 | 亚洲精品91天天久久人人 | 国产涩涩网站 | 日韩 精品 一区 国产 麻豆 | 狠狠操天天射 | 夜色成人av | 国产精品日韩欧美 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 久久激情综合网 | 丁香六月五月婷婷 | 国产精品久久久久四虎 | 国产精品一区二区在线 | sm免费xx网站 | 91大神免费视频 | 欧洲精品久久久久毛片完整版 | 久久99网 | 中文字幕大全 | 日韩欧美在线视频一区二区 | 久久天堂影院 | 久久999精品| 久久91久久久久麻豆精品 | 91精品国产亚洲 | 狠狠狠狠狠色综合 | 成人在线观看免费 | 狠狠干干| 国产无遮挡又黄又爽在线观看 | 五月精品| 国产麻豆视频免费观看 | 色综合夜色一区 | 久久精品a | 久操免费视频 | 首页中文字幕 | 婷色| 久久丁香| 精品久久久久久国产91 | 国产精品成人免费精品自在线观看 | 久久毛片网站 | 亚洲综合视频在线 | 右手影院亚洲欧美 | 国产欧美日韩一区 | 成人在线一区二区三区 | 91久久人澡人人添人人爽欧美 | 中文一区二区三区在线观看 | 夜夜干夜夜 | 日韩欧美91 | 国产精品久久久久久久午夜片 | 国产一区在线看 | 免费网站在线观看成人 | 国产精品1区2区在线观看 | 天天舔夜夜操 | 亚洲精品久久久久中文字幕m男 | 亚洲综合色视频 | 国产在线一区二区 | 黄色一集片 | 九九热在线精品视频 | 黄色免费网站下载 | 国产精品久久久免费看 | 三级av中文字幕 | 片黄色毛片黄色毛片 | 在线观看免费日韩 | 日日干日日| 在线播放 日韩专区 | 国产精品免费人成网站 | 亚洲欧洲一区二区在线观看 | 久青草电影 | 亚洲小视频在线 | 午夜123| 亚洲激情在线视频 | 国产一区二区三区午夜 | 欧美色图亚洲图片 | 亚洲精品久久久蜜桃直播 | 精品久久久久久久久久 | 成人毛片在线观看视频 | 免费观看国产视频 | av成人免费 | 国产精品久久久久久一区二区三区 | 国产精品乱码久久久久久1区2区 | 超碰免费久久 | 91精品视频在线免费观看 | 亚洲精品资源在线观看 | 精品主播网红福利资源观看 | 日韩欧美极品 | 日本精品视频一区二区 | 日韩欧美一区二区三区视频 | 九九99靖品 | 九九热精品视频在线观看 | 黄色在线免费观看网址 | 国产日韩在线观看一区 | 美女精品网站 | 激情动态 | 国产精品网址在线观看 | 黄色成人在线观看 | 九九热免费在线视频 | 在线视频18在线视频4k | 97色视频在线| 欧美精品资源 | 视频福利在线观看 | 日本精品在线 | 深爱婷婷网 | 欧美日韩一级久久久久久免费看 | 免费在线观看不卡av | 亚洲码国产日韩欧美高潮在线播放 | 97人人澡人人添人人爽超碰 | 国产精品久久久久av免费 | 日韩在线观看视频免费 | 久久综合久久久 | 国产v在线播放 | 波多野结衣一区二区三区中文字幕 | 国产精品白丝jk白祙 | 91刺激视频 | 亚洲精品国偷自产在线99热 | 国产中文字幕91 | 天天草网站 | 欧美视频在线二区 | 中文在线免费视频 | 亚洲男男gaygayxxxgv | 黄色软件在线看 | 亚洲视屏一区 | 国产在线v | 91网站观看 | 国产精品久久久久久久av大片 | 成人app在线播放 | 成av在线 | 婷婷五月情| 51久久成人国产精品麻豆 | 在线成人一区 | 欧美日韩免费观看一区=区三区 | 国产啊v在线 | 亚洲国产免费 | 九九爱免费视频 | 日韩午夜视频在线观看 | 96av在线视频 | 日韩a欧美 | 国内精品亚洲 | 日韩免费电影网站 | 色噜噜日韩精品一区二区三区视频 | 麻豆av一区二区三区在线观看 | 国产精品久久久久久吹潮天美传媒 | 国产在线精品区 | 国产免费观看视频 | 能在线看的av | 丁香五月缴情综合网 | 成年人免费av| 中文字幕电影网 | 狠狠狠狠狠操 | 国产传媒中文字幕 | 免费黄a| 日韩三级久久 | 日韩一级黄色片 | 国产精品一区二区免费 | 日韩91av| 亚洲精品乱码久久久久久蜜桃不爽 | 国产片网站 | 亚洲视频免费在线观看 | 成片免费 | 国产精品video爽爽爽爽 | 91九色国产蝌蚪 | 日韩理论电影在线 | 成人午夜在线电影 | 欧美一级裸体视频 | 午夜久久久久久久久久影院 | 狠狠操综合网 | 激情电影影院 | 欧美日韩另类视频 | 成人精品影视 | 国产一级电影在线 | 免费在线色 | 黄色成人av | 美女亚洲精品 | 久久久影院一区二区三区 | 日韩免费二区 | 视频一区亚洲 | 99热这里只有精品1 av中文字幕日韩 | 日韩在线播放av | 色狠狠狠 | 日韩av手机在线看 | 亚洲欧美成人在线 | 日韩免费在线观看视频 | 日韩三级不卡 | 久久国产网站 | 亚洲精品免费在线播放 | 黄色小网站免费看 | 欧美日韩国产区 | 中文字幕日韩伦理 | 91插插插免费视频 | www.大网伊人 | 色婷婷午夜 | 97视频人人澡人人爽 | 最近免费中文字幕 | 插婷婷 | 天天操天天爱天天爽 | 国产女教师精品久久av | 午夜av在线 | 国产一级免费电影 | 亚洲国产合集 | 日韩av线观看 | 国产xxxx做受性欧美88 | 毛片永久新网址首页 | 超碰在线94 | 日韩视频一区二区 | 国产在线欧美日韩 | 精品一二三区视频 | 国产又粗又长又硬免费视频 | 中文字幕国产一区二区 | 狠狠地日 | 狂野欧美激情性xxxx欧美 | 国产一区在线视频观看 | 视频一区在线免费观看 | www在线免费观看 | 精品久久久久久综合 | 97超碰在线久草超碰在线观看 | 久久久国产99久久国产一 | 五月宗合网 | 天天干天天做 | 精品久久91| 国产91九色视频 | 日本黄色免费大片 | av在线播放中文字幕 | 欧美在线观看视频 | 国产看片网站 | 国产黄色免费在线观看 | 日韩午夜三级 | 国产区在线 | 午夜a区| 天天操人人干 | 欧美日韩不卡一区 | 国产精品123 | 永久免费毛片在线观看 | 精品国产1区二区 | 久青草视频在线观看 | 亚洲欧美少妇 | 特级西西444www大精品视频免费看 | 96av麻豆蜜桃一区二区 | 国产精品久久久久久久久软件 | 久久精品一区二区三区四区 | 亚洲一区二区精品 | 人人干干人人 | 亚洲少妇影院 | 久爱精品在线 | 亚洲精品综合欧美二区变态 | 中文字幕中文字幕 | 九九综合久久 | 国产色啪| 人人干网站 | 亚洲国产精品99久久久久久久久 | 狠狠的日 | 五月天六月丁香 | 久久网站av | 久草视频网| 日本中文在线 | 久草免费在线 | www.com久久久 | 免费在线中文字幕 | 福利视频网址 | 91精品国产一区二区在线观看 | 一级淫片在线观看 | 亚洲一区日韩精品 | 欧美有色| 免费激情在线电影 | 欧美日韩一区二区三区免费视频 | 久久99深爱久久99精品 | 亚洲区另类春色综合小说 | 成在人线av | 国产日韩在线看 | 成人黄色小说网 | 日韩精品视频在线观看免费 | 中文字幕av最新更新 | 日日夜夜天天干 | 天天操天天干天天综合网 | 欧美做受高潮电影o | 亚洲视频高清 | 福利视频一区二区 | 伊人成人久久 | 久久国产亚洲视频 | 免费日韩 精品中文字幕视频在线 | 国产在线国产 | 成人午夜av电影 | 色综合久久久久久中文网 | 日韩在线网 | 亚洲精品乱码久久久久久按摩 | 色诱亚洲精品久久久久久 | 狠狠色丁香婷婷综合久小说久 | 欧美福利网址 | 四虎国产精品免费 | 久久草精品 | 国产精品岛国久久久久久久久红粉 | 亚洲高清视频在线 | 国产精品99久久久久久久久久久久 | 三级黄色片子 | 国产精品福利在线 | 久草资源在线观看 | 永久免费的av电影 | 人人添人人 | 99久久久国产精品 | 99久久99热这里只有精品 | 亚洲精选视频免费看 | 午夜视频免费在线观看 | 免费视频在线观看网站 | 国产高清专区 | 一区二区三区高清不卡 | 深爱开心激情 | 国产精品理论片在线播放 | 99精品免费 | av丝袜美腿 | 国产小视频你懂的 | 在线久热 | 91在线免费播放视频 | 国产精品porn | 国产精品一区二区三区99 | 国产精品一区二区av麻豆 | 五月天婷婷视频 | 亚洲视频在线看 | 中文字幕在线播放av | 婷婷在线免费 | 免费观看www小视频的软件 | 精品国产乱码久久久久久天美 | 欧美日韩一区二区三区视频 | 久久伊人色综合 | 国产成人一区二 | 三级黄色网址 | 久久精品国产亚洲精品2020 | 免费看国产黄色 | 最近免费观看的电影完整版 | 美女视频一区二区 | 黄网站色欧美视频 | 人人爽人人av | av中文电影| 看黄色91 | 黄色片免费在线 | 亚洲精品在线国产 | 国产一级电影免费观看 | 免费看一级 | 国产一区在线免费观看视频 | 亚洲天堂网视频 | 国产精品麻豆视频 | 欧美精品首页 | 久久精品99国产精品酒店日本 | 在线国产欧美 | 国产一线二线三线在线观看 | 人人爱人人添 | 青青久草在线视频 | 中文字幕在线播放日韩 | 成人av免费网站 | 狠狠狠色丁香综合久久天下网 | 91av视频在线免费观看 | 国产精品九九久久久久久久 | 亚洲成年人在线播放 | 日韩视频三区 | 免费a网址 | 亚洲成人精品在线观看 | 69精品视频在线观看 | 精品视频在线观看 | 亚洲国产999 | 亚洲无在线 | 国产韩国日本高清视频 | 久久免费视频在线观看6 | 精品免费国产一区二区三区四区 | 国产精品久久久久一区二区国产 | 人人爱人人爽 | 在线观看视频三级 | 日本丶国产丶欧美色综合 | 亚洲精品国产自产拍在线观看 | 国产一级一级国产 | 456免费视频 | 亚洲成a人片在线观看网站口工 | 国产三级精品三级在线观看 | 最新超碰 | 久久久久综合 | 欧美一级片免费播放 | 九九九在线观看 | 日韩av影视在线观看 | 狠狠干夜夜操 | 日日干精品 | 欧洲亚洲精品 | 91色蜜桃 | 青青啪 | 美女国内精品自产拍在线播放 | 九精品| 亚洲黄色在线观看 | 成人免费观看a | www黄色大片 | 亚洲精品视频一 | 久久综合亚洲鲁鲁五月久久 | 国产91九色视频 | 91精品国产欧美一区二区成人 | 亚洲一区二区三区毛片 | 久久综合影院 | 狠狠色噜噜狠狠狠狠2021天天 | 天天色天天综合网 | v片在线播放 | 美女视频久久 | 一区二区三区三区在线 | 亚洲一区免费在线 | 久久免费看a级毛毛片 | 97精品在线观看 | 在线观看中文字幕一区 | 激情丁香5月 | 国产精品久久久久9999吃药 | 亚洲乱亚洲乱亚洲 | 日韩女同一区二区三区在线观看 | 免费看黄在线网站 | 国产成人精品一区在线 | 国产精品免费观看网站 | 999久久国精品免费观看网站 | 国产精品一区二区三区四区在线观看 | 日韩在线观看视频在线 | 欧美色久 | 国产成人在线一区 | 欧美 亚洲 另类 激情 另类 | 日韩在线视频网址 | 色美女在线 | 日日爽夜夜爽 | 欧美性色黄大片在线观看 | 97超碰在线免费 | 日本精品一区二区三区在线观看 | 成人免费在线网 | 黄色中文字幕在线 | 日本黄色一级电影 | 91精品国产自产在线观看永久 | 亚洲精品国产精品国自产 | 在线观看播放av | 国产成人精品午夜在线播放 | 91福利社在线观看 | 亚洲午夜在线视频 | 97国产超碰在线 | 在线视频福利 | 伊人超碰在线 | 91av免费在线观看 | 麻花豆传媒一二三产区 | 中文字幕在线观看1 | 亚洲jizzjizz日本少妇 | 九草在线观看 | 免费在线观看91 | 国产喷水在线 | 久草视频观看 | 国产小视频免费在线观看 | 丁香国产视频 | aⅴ视频在线 | 色香蕉在线视频 | 日韩高清免费无专码区 | 五月婷婷综合久久 | 久草视频首页 | 中文在线8资源库 | 91成人蝌蚪 | 视频在线91 | 亚洲欧洲精品一区二区精品久久久 | 91高清在线 | 国产精品亚洲精品 | 日韩在线第一 | 国产 视频 久久 | 午夜精品久久久久久中宇69 | 超碰在线97观看 | 人人干干人人 | 天天干天天色2020 | 91亚洲网| 久久久福利视频 | 久久tv | 九九免费在线看完整版 | 国产黄av | 91黄色在线观看 | 国产做aⅴ在线视频播放 | 91完整版观看 | 婷香五月 | 成人啪啪18免费游戏链接 | 一二三区在线 | 麻豆免费视频观看 | 亚洲综合爱 | 日本二区三区在线 | 一本色道久久综合亚洲二区三区 | 久久免费视频网 | 午夜婷婷在线播放 | 超碰在线成人 | 97视频网址 | 精品黄色在线观看 | 六月婷操 | 日日干天天射 | 夜夜骑天天操 | 午夜久久福利影院 | 国产毛片aaa | 久草免费电影 | 婷婷丁香花五月天 | 成人高清av在线 | 在线观看国产区 | 日韩av一区二区三区在线观看 | 婷婷丁香激情网 | 日日日爽爽爽 | 国产精品日韩 | 91亚洲国产 | 日韩v在线 | 国产精品一区二区三区免费看 | 久久久久成人精品免费播放动漫 | 久草资源在线 | 欧美成年人在线视频 | 毛片一区二区 | 99精品国产高清在线观看 | 日本黄色大片免费看 | 国产五月色婷婷六月丁香视频 | 黄色毛片视频 | 国产剧情在线一区 | 国产一区二区久久精品 | 91爱爱免费观看 | 亚洲国产中文字幕在线观看 | 99在线视频免费观看 | 成人在线观看免费 | 亚洲v精品 | 久久午夜鲁丝片 | 在线观看国产中文字幕 | 国产视频欧美视频 | 色视频网站在线 | 国产破处在线视频 | 久久久夜色 | 午夜影院一级 | 久久综合九色欧美综合狠狠 | 成人免费亚洲 | 美女视频国产 | 玖玖在线播放 | 国产亚洲精品久久 | 九九视频网 | 日一日操一操 | 日韩三级中文字幕 | 九九免费精品 | 免费毛片一区二区三区久久久 | 久草视频免费观 | 久久免费视频在线观看 | 亚洲精品国偷拍自产在线观看 | 96久久欧美麻豆网站 | 精品国产一区二区三区久久影院 | 国产高清视频在线观看 | 中文字幕国产一区二区 | 国产福利在线免费 | 久久综合亚洲鲁鲁五月久久 | 国产日韩欧美在线观看视频 | 国产一区二区手机在线观看 | 久久国内精品99久久6app | av片子在线观看 | 一级一级一片免费 | 久久久国产精华液 | 99色精品视频 | 成人动漫一区二区三区 | 97国产精品视频 | 日韩在线 一区二区 | 中文字幕成人网 | 在线看片91 | 一区二区伦理 | 色婷婷亚洲综合 | 国产高清成人 | 亚洲性视频 | 国产精品免费麻豆入口 | 国产精品一区二区久久精品爱微奶 | 日韩一区二区三区高清免费看看 | 黄色国产在线观看 | 99精品一级欧美片免费播放 | 日本精品xxxx| 欧美性生活免费 | 丁香六月婷婷综合 | 亚洲资源网 | 精品96久久久久久中文字幕无 | 91高清一区| 岛国大片免费视频 | 久久久精品一区二区三区 | 在线综合 亚洲 欧美在线视频 | 国产精品视频在线观看 | www.久久久com| 久久av网址 | www激情网 | 国产a精品| 99精品免费在线观看 | 91av官网 | 中文字幕九九 | 久章草在线观看 | 成人免费亚洲 | 亚洲最新视频在线播放 | av综合在线观看 | 91毛片在线观看 | 亚洲最大免费成人网 | 日韩特级毛片 | 日韩av成人在线观看 | 亚洲精品在线观看的 | 国产精品一区二区av影院萌芽 | 激情欧美xxxx | 91视频在线免费观看 | 国产精品99久久久久久人免费 | 波多野结衣一区 | 91中文字幕在线观看 | 久久黄色美女 | 亚洲欧洲一区二区在线观看 | 欧美做受高潮 | 亚洲欧美日本一区二区三区 | 中文字幕在线电影 | 日韩av女优视频 | 国产麻豆精品久久一二三 | 日日躁你夜夜躁你av蜜 | 精品自拍sae8—视频 | 久久精品99久久久久久 | 日韩av在线资源 | 最近日本中文字幕a | 91桃色在线观看视频 | ,午夜性刺激免费看视频 | 男女激情免费网站 | 国产成人久久精品 | 免费在线观看视频a | 国产美女搞久久 | 亚洲女同ⅹxx女同tv | 天天色图 | 国产高清在线观看av | 欧美日韩在线视频一区 | 国产福利电影网址 | 天天操人人干 | 夜夜干夜夜 | 91九色精品国产 | av在线收看| 成人免费亚洲 | 最近中文字幕mv | 亚洲国产手机在线 | 五月婷婷六月综合 | 99精品视频99| avwww在线观看 | 中文字幕一区在线观看视频 | av色一区| 欧美黄网站 | 人人草天天草 | 麻豆av电影 | 亚洲一区网站 | 亚洲综合狠狠干 | 91亚洲精品久久久蜜桃借种 | av成人免费网站 | 中午字幕在线 | 日韩欧美视频在线观看免费 | 久久久国内精品 | 欧美成人亚洲成人 | 97国产小视频| 亚洲va欧美va人人爽春色影视 |