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

巧用 Redis,實現微博 Feed 流功能!

數據庫 Redis
最近接到一個需求,用一句話來說就是:展示關注人發布的動態,這個涉及到 feed 流系統的設計。本文主要介紹一個一般企業可用的 Feed 流解決方案。

一、背景

最近接到一個需求,用一句話來說就是:展示關注人發布的動態,這個涉及到 feed 流系統的設計。本文主要介紹一個一般企業可用的 Feed 流解決方案。

二、相關概念

下面先介紹一下關于 Feed 流的簡單概念。

1.什么是 feed 流

  • Feed:Feed 流中的每一條狀態或者消息都是 Feed,比如微博中的一條微博就是一個 Feed。
  • Feed流:持續更新并呈現給用戶內容的信息流。每個人的朋友圈,微博關注頁等等都是一個 Feed 流。

2.feed 流分類

Feed 流常見的分類有兩種:

  • Timeline:按發布的時間順序排序,產品如果選擇 Timeline 類型,那么就是認為 Feed 流中的 Feed 不多,但是每個 Feed 都很重要,都需要用戶看到。類似于微信朋友圈,微博等。
  • Rank:按某個非時間的因子排序,一般是按照用戶的喜好度排序,一般用于新聞推薦類、商品推薦等。

三、設計

設計一個 Feed 流系統,兩個關鍵步驟,一個是 Feed 流的 初始化,一個是 推送。關于 Feed 流的存儲其實也是一個核心的點,但是筆主持久化使用的還是 MySQL,后續可以考慮優化。

1.Feed 流初始化

Feed 流【關注頁 Feed 流】的初始化指的是,當用戶的 Feed 流還不存在的時候,為該用戶創建一個屬于他自己的關注頁 Feed 流,具體怎么做呢?其實很簡單,遍歷一遍關注列表,取出所有關注用戶的 feed,將 feedId 存放到 redis 的 sortSet 中即可。這里面有幾個關鍵點:

  • 初始化數據:初始化的數據需要從數據庫中加載出來。
  • key 值:sortSet 的 key 值需要使用當前用戶的 id 做標識。
  • score 值:如果是 Timeline 類型,直接取 feed 創建的時間戳即可。如果是 rank 類型,則把你的業務對應的權重值設進去。

2.推送

經過上面的初始化,已經把 feed 流放在了 redis 緩存中了。接下來就是需要更新 feed 流了,在下面四種情況需要進行更新:

  • 關注的用戶發布新的 feed:
  • 關注的用戶刪除 feed。
  • 用戶新增關注。
  • 用戶取消關注。

3.發布/刪除 Feed 流程

上面四步具體怎么操作,會在下面的實現步驟中詳細描述,在這里先我們重點討論一下第一、二種情況。因為在處理 大V 【千萬級別粉絲】的時候,我們是需要對 大V 的所有粉絲的 feed 流進行處理的,這時候涉及到的量就會非常巨大,需要多加斟酌。關于推送,一般有兩種 推/拉。

  • 推:A用戶發布新的動態時,要往 A用戶所有的粉絲 feed 流中推。
  • 拉:A用戶發布新的動態時,先不進行推送,而是等 粉絲進來的時候,才主動到 A用戶的個人頁TimeLine 拉取最新的 feed,然后進行一個 merge。如果關注了多個大V,可以并發的向多個大V 個人頁TimeLine 中拉取。

4.推拉結合模式

當用戶發布一條新的 Feed 時,處理流程如下:

  • 先從關注列表中讀取到自己的粉絲列表,以及判斷自己是否是大V。
  • 將自己的Feed消息寫入個人頁Timeline。如果是大V,寫入流程到此就結束了。
  • 如果是普通用戶,還需要將自己的Feed消息寫給自己的粉絲,如果有100個粉絲,那么就要寫給100個用戶。

當刷新自己的Feed流的時候,處理流程如下:

  • 先去讀取自己關注的大V列表
  • 去讀取自己的 Feed 流。
  • 如果有關注的大V,則再次并發讀取每一個大V的個人頁Timeline,如果關注了10個大V,那么則需要10次訪問。
  • 合并2和3步的結果,然后按時間排序,返回給用戶。

至此,使用推拉結合方式的發布,讀取Feed流的流程都結束了。

5.推模式

如果只是用推模式了,則會變的比較簡單:

  • 「發布Feed:」不用區分是否大V,所有用戶的流程都一樣,都是三步。
  • 「讀取Feed流:」不需要第一步,也不需要第三步,只需要第二步即可,將之前的2 + N(N是關注的大V個數) 次網絡開銷減少為 1 次網絡開銷。讀取延時大幅降級。

6.兩種模式總結

推拉結合存在一個弊端,就是刷新自己的Feed流時,大V的個人頁Timeline 的讀壓力會很大。

如何解決:

  • 不使用大V/普通用戶的優化方式,使用對活躍粉絲采用推模式,非活躍粉絲采用拉模式。
  • 完全使用推模式就可以徹底解決這個問題,但是會帶來存儲量增大,大V Feed 發送總時間增大,從發給第一個粉絲到發給最后一個粉絲可能要幾分鐘時間。

四、實現

筆主主要采用純推模式實現了一個普通企業基本可用的 Feed 流系統,下面介紹一下具體的實現代碼,主要包括3大個部分:

  • 初始化 Feed 流。
  • 關注的用戶發布/刪除 feed,該用戶的粉絲更新自己的Feed流。
  • 用戶新增/取消關注,更新自己的Feed流。

1.初始化 Feed 流

當用戶第一進來刷新Feed 流,且 Feed 流還不存在時,我們需要進行初始化,初始化的具體代碼如下:核心思想就是從數據庫中load出 feed 信息,塞到 zSet 中,然后分頁返回。

/**
 * 獲取關注的人的信息流
 */
public List<FeedDto> listFocusFeed(Long userId, Integer page, Integer size) {
    String focusFeedKey = "focusFeedKey" + userId;

    // 如果 zset 為空,先初始化
    if (!zSetRedisTemplate.exists(focusFeedKey)) {
        initFocusIdeaSet(userId);
    }

    // 如果 zset 存在,但是存在 0 值
    Double zscore = zSetRedisTemplate.zscore(focusFeedKey, "0");
    if (zscore != null && zscore > 0) {
        return null;
    }

    //分頁
    int offset = (page - 1) * size;

    long score = System.currentTimeMillis();
    // 按 score 值從大到小從 zSet 中取出 FeedId 集合
    List<String> list = zSetRedisTemplate.zrevrangeByScore(focusFeedKey, score, 0, offset, size);

    List<FeedDto> result = new ArrayList<>();
    if (QlchatUtil.isNotEmpty(list)) {
        for (String s : list) {
            // 根據 feedId 從緩存中 load 出 feed
            FeedDto feedDto = this.loadCache(Long.valueOf(s));
            if (feedDto != null) {
                result.add(feedDto);
            }
        }
    }
    return result;
}

/**
 * 初始化關注的人的信息流 zSet
 */
private void initFocusFeedSet( Long userId) {
    String focusFeedKey = "focusFeedKey" + userId;
    zSetRedisTemplate.del(focusIdeaKey);

    // 從數據庫中加載當前用戶關注的人發布過的 Feed
    List<Feed> list = this.feedMapper.listFocusFeed(userId);

    if (QlchatUtil.isEmpty(list)) {
        //保存0,避免空數據頻繁查庫
        zSetRedisTemplate.zadd(focusFeedKey, 1, "0");
        zSetRedisTemplate.expire(focusFeedKey, RedisKeyConstants.ONE_MINUTE * 5);
        return;
    }

    // 遍歷 FeedList,把 FeedId 存到 zSet 中
    for (Feed feed : list) {
        zSetRedisTemplate.zadd(focusFeedKey, feed.getCreateTime().getTime(), feed.getId().toString());
    }

    zSetRedisTemplate.expire(focusFeedKey, 60 * 60 * 60);
}

2.關注的用戶發布/刪除新的 feed

每當用戶發布/刪除新的 feed,我們需要更新該用戶所有的粉絲的 Feed流,該步驟一般比較耗時,所以建議異步處理,為了避免一次性load出太多的粉絲數據,這里采用循環分頁查詢。為了避免粉絲的 Feed流過大,我們會限制 Feed 流的長度為1000,當Feed流長度超過1000時,會移除最舊的 Feed。

/**
 * 新增/刪除 feed時,處理粉絲 feed 流
 *
 * @param userId 新增/刪除 feed的用戶id
 * @param feedId 新增/刪除 的feedId
 * @param type   feed_add = 新增feed feed_sub = 刪除feed
 */
public void handleFeed(Long userId, Long feedId, String type) {

    Integer currentPage = 1;
    Integer size = 1000;
    List<FansDto> fansDtos;

    while (true) {
        Page page = new Page();
        page.setSize(size);
        page.setPage(currentPage);
        fansDtos = this.fansService.listFans(userId, page);

        for (FansDto fansDto : fansDtos) {
            String focusFeedKey = "focusFeedKey" + userId;

            // 如果粉絲 zSet 不存在,退出
            if (!this.zSetRedisTemplate.exists(focusFeedKey)) {
                continue;
            }

            // 新增Feed
            if ("feed_add".equals(type)) {
                this.removeOldestZset(focusFeedKey);
                zSetRedisTemplate.zadd(focusFeedKey, System.currentTimeMillis(), feedId);
            }
            // 刪除Feed
            else if ("feed_sub".equals(type)) {
                zSetRedisTemplate.zrem(focusFeedKey, feedId);
            }

        }

        if (fansDtos.size() < size) {
            break;
        }
        currentPage++;
    }

}

/**
 * 刪除 zSet 中最舊的數據
 */
private void removeOldestZset(String focusFeedKey){
    // 如果當前 zSet 大于1000,刪除最舊的數據
    if (this.zSetRedisTemplate.zcard(focusFeedKey) >= 1000) {
        // 獲取當前 zSet 中 score 值最小的
        List<String> zrevrange = this.zSetRedisTemplate.zrevrange(focusFeedKey, -1, -1, String.class);
        if (QlchatUtil.isNotEmpty(zrevrange)) {
            this.zSetRedisTemplate.zrem(focusFeedKey, zrevrange.get(0));
        }
    }
}

3.用戶新增關注/取消關注

這里比較簡單,新增/取消關注,把新關注的 Feed 往自己的 Feed流中增加/刪除 即可,但是同樣需要異步處理。

/**
 * 關注/取關 時,處理followerId的zSet
 *
 * @param followId   被關注的人
 * @param followerId 當前用戶
 * @param type       focus = 關注 unfocus = 取關
 */
public void handleFocus( Long followId, Long followerId, String type) {

    String focusFeedKey = "focusFeedKey" + userId;

    // 如果粉絲 zSet 不存在,退出
    if (!this.zSetRedisTemplate.exists(focusFeedKey)) {
        return;
    }
    List<FeedDto> FeedDtos = this.listFeedByFollowId(source, followId);
    for (FeedDto feedDto : FeedDtos) {

        // 關注
        if ("focus".equals(type)) {
            this.removeOldestZset(focusFeedKey);
            this.zSetRedisTemplate.zadd(focusFeedKey, feedDto.getCreateTime().getTime(), feedDto.getId());
        }
        // 取關
        else if ("unfocus".equals(type)) {
            this.zSetRedisTemplate.zrem(focusFeedKey, feedDto.getId());
        }


    }
}

上面展示的是核心代碼,僅僅是為大家提供一個實現思路,并不是直接可運行的代碼,畢竟真正實現還會涉及到很多其他的無關要緊的類。

責任編輯:趙寧寧 來源: 技術老男孩
相關推薦

2012-05-09 14:02:46

HTML5

2015-07-06 13:36:14

Redis微博關注關系

2023-11-12 21:37:56

Feed流

2021-11-03 17:10:37

CSS sticky前端代碼

2025-07-08 08:02:52

2015-04-16 10:35:08

微博微博如何實現

2024-09-09 15:24:26

Redis開發

2025-09-03 04:00:00

小紅書Feed流系統

2018-05-16 14:04:05

人工智能新浪微博實時流計算

2017-11-14 16:59:47

新浪微博深度學習

2009-11-10 13:27:30

VB.NET RND(

2019-09-25 17:12:44

2012-03-30 14:45:58

2017-10-13 10:17:13

新浪

2014-04-22 10:34:57

新浪微博Redis

2018-09-26 09:24:15

微博WAIC架構

2013-01-17 14:41:33

Feed Dashbo

2011-12-08 16:31:43

新浪微博開放平臺

2011-12-21 16:19:06

網秦手機安全微博保鏢

2013-10-10 09:05:26

新浪微博Redishadoop
點贊
收藏

51CTO技術棧公眾號

亚洲精品免费电影| 欧美激情aⅴ一区二区三区| 欧美日韩在线第一页| 国外成人在线视频网站| 天天干天天操天天爱| 不卡中文字幕| 欧美精品一区二区三区高清aⅴ| 北条麻妃在线视频观看| 在线看av的网址| 国产一区二区三区在线观看免费视频 | 国产女人爽到高潮a毛片| 欧美一区二区| 国产亚洲欧美日韩美女| 97免费公开视频| 欧美1级2级| 亚洲综合网站在线观看| 亚洲高清乱码| 无码国精品一区二区免费蜜桃| 免费不卡在线视频| 97精品在线视频| 欧美aaa级片| 日韩精品福利一区二区三区| 欧美一区国产二区| 999在线免费视频| 国产精品国精产品一二| 国产精品久久久久久久蜜臀| 国产日本一区二区三区| 99热这里精品| 蜜臀久久99精品久久久久久9| 国模吧一区二区三区| www.99re6| 精品一区二区三| 日韩大陆毛片av| av漫画在线观看| 国产精品亚洲欧美日韩一区在线| 欧美又粗又大又爽| 日av中文字幕| 热色播在线视频| 亚洲午夜影视影院在线观看| 欧美做受777cos| 2019中文字幕在线视频| 国产欧美精品国产国产专区 | 亚洲成人777| 影音先锋成人资源网站| 麻豆传媒在线完整视频| 国产精品乱码一区二三区小蝌蚪| 日韩精品久久一区| 十九岁完整版在线观看好看云免费| 韩国理伦片一区二区三区在线播放 | 日韩成人中文字幕在线观看| 漂亮人妻被黑人久久精品| 亚洲一二三区视频| 日韩欧美一级二级三级| 亚洲精品一二三四| 成人av影音| 亚洲国产小视频在线观看| 亚洲一区二区三区黄色| 成人福利免费在线观看| 欧美精品一区二| 国产精品一区二区人妻喷水| 成人香蕉社区| 亚洲精品成人久久久| 第四色在线视频| 日本韩国欧美超级黄在线观看| 亚洲第一二三四五区| 亚洲国产第一区| 综合亚洲自拍| 尤物九九久久国产精品的分类 | 怡红院av一区二区三区| 成人黄色片免费| tube8在线hd| 精品国产精品三级精品av网址| 精品人妻一区二区三区四区在线| 超级碰碰久久| 欧美日韩一级片在线观看| 色呦色呦色精品| 中文字幕日韩在线| 日韩激情av在线播放| 成人无码av片在线观看| 欧美丰满日韩| 久久久亚洲精选| jizz国产在线观看| 精品一区二区免费在线观看| 99免费在线观看视频| 污污网站免费在线观看| 国产精品全国免费观看高清| 肉大捧一出免费观看网站在线播放| 懂色av一区| 一本色道久久综合亚洲91| 在线观看免费污视频| 999久久精品| 亚洲精品小视频在线观看| 国产精品www爽爽爽| 欧美成人首页| 国产91免费看片| av手机免费看| 久久久国产精华| 超薄肉色丝袜足j调教99| 日韩在线伦理| 91精品国产综合久久久久久| 久久人妻一区二区| 99久久精品网站| 欧美一级免费视频| 99在线精品视频免费观看20| 久久色在线视频| 福利在线小视频| 欧美xnxx| 亚洲精品国产精品乱码不99按摩| 国产又色又爽又高潮免费| 伊人精品在线| 国产精品中文久久久久久久| 蜜臀久久久久久999| 中文字幕精品—区二区四季| 国产美女主播在线播放| 99久久这里有精品| 亚洲人午夜精品| 国产一级免费av| 激情五月播播久久久精品| 美乳视频一区二区| 伦理在线一区| 91麻豆精品国产自产在线| 免费看污片的网站| 国产亚洲毛片| 国产伦精品一区二区三区照片91| 国产精品毛片一区二区三区四区| 午夜视黄欧洲亚洲| 一个人看的视频www| 欧美成人milf| 国产精品久久久久久久久影视| 姝姝窝人体www聚色窝| 一区二区三区在线观看国产| 日本黄大片一区二区三区| 九九久久电影| 清纯唯美亚洲激情| 性感美女福利视频| 亚洲国产欧美另类丝袜| 国产又粗又猛又爽又黄| 999国产精品永久免费视频app| 国产成人一区三区| 免费在线看v| 黑人欧美xxxx| 91传媒理伦片在线观看| 欧美三级特黄| 国产传媒一区二区三区| 亚洲无线看天堂av| 日韩欧美成人一区| 九九热视频精品| 国产不卡视频一区| 一本久道高清无码视频| 国产一区二区三区不卡av| 欧美精品成人在线| 蜜桃av中文字幕| 亚洲电影第三页| 污片免费在线观看| 亚洲永久在线| 日本一区二区三区四区高清视频| 美脚恋feet久草欧美| 日韩精品免费看| 色婷婷av国产精品| 久久亚洲捆绑美女| 毛片毛片毛片毛片毛片毛片毛片毛片毛片| 国产区精品区| 国产在线观看精品| 国产传媒在线播放| 欧美α欧美αv大片| 国产无精乱码一区二区三区| 成人av免费观看| aa在线免费观看| 精品日韩免费| 亚洲va电影大全| 678在线观看视频| 亚洲欧美日韩精品久久| 美女黄页在线观看| 亚洲精品你懂的| 丰满少妇中文字幕| 国产日韩欧美一区| 亚洲精品高清国产一线久久| www欧美在线观看| 性欧美xxxx交| 国产二区视频在线观看| 91精品国产乱码久久蜜臀| 欧美一级高潮片| 久久久.com| 国产5g成人5g天天爽| 亚洲国产高清视频| 日韩欧美在线观看强乱免费| 电影一区中文字幕| 51精品在线观看| 日本成人网址| 日韩成人在线视频观看| 91片黄在线观看喷潮| 亚洲国产综合视频在线观看| 日韩人妻无码精品综合区| 国产精品原创巨作av| 黄www在线观看| 91tv官网精品成人亚洲| 国产在线精品一区二区三区| 成人四虎影院| 97免费在线视频| 求av网址在线观看| 精品亚洲国产视频| 国产欧美一级片| 一本一道久久a久久精品综合蜜臀| 国产3级在线观看| 成人avav影音| 日韩av卡一卡二| 国产亚洲精品久久久久婷婷瑜伽| 亚洲欧洲中文| 偷拍亚洲精品| 不卡视频一区二区三区| 91精品美女| 欧美中文字幕第一页| 欧美xxxx少妇| 北条麻妃久久精品| 国产午夜在线观看| 日韩av资源在线播放| va视频在线观看| 欧美日韩电影在线播放| 免费黄色av片| 欧美日韩午夜激情| 国产一级久久久| 一区二区在线观看免费视频播放| 亚洲色图 激情小说| 久久久国际精品| 久久精品国产亚洲AV熟女| 风间由美性色一区二区三区| 97人人爽人人| 蜜臀av性久久久久av蜜臀妖精| 日韩精品一区二区三区久久| 影音先锋国产精品| av动漫在线免费观看| 亚洲精品91| 在线视频91| 欧美电影免费| 中文精品一区二区三区| 欧美日韩一区二区三区视频播放| 蜜桃av久久久亚洲精品| 狼人精品一区二区三区在线| 国产精品免费在线| 136导航精品福利| 92看片淫黄大片欧美看国产片| 欧美天堂在线| 成人黄色午夜影院| 亚洲欧美专区| 亚洲一区免费网站| 99久久99九九99九九九| 2014亚洲精品| 一区视频网站| 国产一区二区三区奇米久涩| 久久91在线| 久久国产精品-国产精品| 欧美交a欧美精品喷水| 久久久水蜜桃| 久久成人av| 一区二区三区四区| 91成人网在线观看| 欧洲精品在线播放| 国产日本精品| 亚洲黄色av网址| 国产在线精品一区二区| 国产一级二级av| 99久久精品免费看| 亚洲人成人无码网www国产 | 亚洲韩国欧洲国产日产av| 五月婷婷久久久| 亚洲欧洲免费视频| 95在线视频| 九九精品在线视频| 黄色软件视频在线观看| 国产成人a亚洲精品| 91视频亚洲| 国产精品麻豆免费版| 三级小说欧洲区亚洲区| 亚洲高清精品中出| 欧美日韩亚洲国产精品| 鲁一鲁一鲁一鲁一色| 日韩精品一二区| 手机精品视频在线| 99精品热视频| 99在线视频免费| 亚洲国产一区二区a毛片| 伦av综合一区| 91精品国产丝袜白色高跟鞋| 国产精品国产高清国产| 深夜福利日韩在线看| av在线播放资源| 国产精品日韩在线播放| 中文字幕一区二区三区四区久久| 欧美韩国日本精品一区二区三区| 欧美国产一级| 欧美日韩在线一| 精品一区二区影视| 亚洲欧美色图视频| 亚洲免费伊人电影| www.国产一区二区| 日韩一级成人av| 高清中文字幕一区二区三区| 欧美高清第一页| 亚洲mmav| 国产亚洲一区在线播放 | 91麻豆蜜桃一区二区三区| 日韩av片在线免费观看| 午夜影视日本亚洲欧洲精品| 在线播放一级片| 日韩高清人体午夜| 99热国产在线| 国产精品三级网站| 小嫩嫩12欧美| 亚洲中文字幕无码一区二区三区| 日韩国产欧美视频| 国产激情视频网站| 亚洲精品v日韩精品| 亚洲精品一区二区二区| 国产婷婷成人久久av免费高清| 在线中文字幕电影| 91精品国产综合久久香蕉922| 日韩成人一级| 日韩极品视频在线观看| 国产综合色视频| www成人啪啪18软件| 日韩欧美在线观看| 黄色小视频免费观看| 欧美成aaa人片免费看| 成人国产一区| 色噜噜一区二区| 久久天堂成人| 黄色正能量网站| 午夜精品久久一牛影视| 亚洲欧美强伦一区二区| 不用播放器成人网| 99精品视频在线免费播放| 亚洲高清视频一区| 美女免费视频一区二区| 波多野吉衣中文字幕| 欧美日韩裸体免费视频| 色一情一乱一乱一区91av| 欧美激情精品久久久久久黑人 | 草美女在线观看| 成人在线观看av| 韩日精品在线| 日本50路肥熟bbw| 亚洲成人久久影院| 欧美性猛交 xxxx| 午夜剧场成人观在线视频免费观看| www.爱久久| 国产黄页在线观看| 久久中文娱乐网| 无码人妻一区二区三区线| 亚洲精品一区中文| 欧美成a人片在线观看久| 日韩啊v在线| 麻豆精品一二三| 欧美色视频一区二区三区在线观看| 欧美剧情片在线观看| 国产精品va在线观看视色| 亚洲中国色老太| 国产真实久久| 真人bbbbbbbbb毛片| 欧美日韩亚洲一区二区| 噜噜噜在线观看播放视频| 国产成人一区二区三区电影| 日韩在线观看一区 | 91视频www| 亚洲欧美一区二区三区在线观看| 亚洲视频在线免费观看| 国产极品嫩模在线观看91精品| 宅男一区二区三区| 国产成人综合在线观看| 久久免费视频6| 精品调教chinesegay| 你懂得影院夜精品a| 在线观看欧美激情| 成熟亚洲日本毛茸茸凸凹| 国产99久久久| 日韩一区二区在线视频| 综合激情网...| 国产成人精品无码播放| 国产精品久久久久久久裸模| 丰满熟女一区二区三区| 欧美一级高清免费播放| 911久久香蕉国产线看观看| 日韩精品一区二区三区高清免费| 欧美亚洲禁片免费| 欧美日韩经典丝袜| 奇米影视首页 狠狠色丁香婷婷久久综合| 热久久久久久久| 青草草在线视频| 亚洲三级av在线| 日韩欧美中文在线观看| aaaaaa亚洲| 亚洲综合无码一区二区| jzzjzzjzz亚洲成熟少妇| wwwxx欧美| 日本中文字幕一区二区视频| 九九在线观看视频| 一区二区欧美久久| 国产调教精品| 中文字幕55页| 欧美丝袜第三区| 亚洲一二三四|