成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > redis 主從備份及其主備切換的操作

redis 主從備份及其主備切換的操作

熱門標(biāo)簽:超呼電話機器人 鄭州人工智能電銷機器人系統(tǒng) 北京400電話辦理收費標(biāo)準 貴州電銷卡外呼系統(tǒng) 日本中國地圖標(biāo)注 十堰營銷電銷機器人哪家便宜 宿遷便宜外呼系統(tǒng)平臺 山東外呼銷售系統(tǒng)招商 魔獸2青云地圖標(biāo)注

首先原文是用了3 個服務(wù)器,我是用了一個服務(wù)器;

然后再原文的基礎(chǔ)上,稍加了自己的整理。

前提:

redis中,主從切換場景中,沒有絕對的主和從,只有初始化的主和從,然后當(dāng)主down后,從就變成主了,而主即使連接上,也是從,不會變?yōu)橹?/p>

1.redis-server的主備關(guān)系:

master : redis-1

slave1 : redis-2

slave3 : redis-3

2. 首先進行主從備份:

修改從服務(wù) redis-1 redis-2 的redis.conf

在從服務(wù)上 修改redis.conf 加入 slaveof 127.0.0.1 6379

主從備份: 這里設(shè)置成功之后,會進行主服務(wù)進行set之后,可在從服務(wù)進行g(shù)et key ,可是一旦主服務(wù)宕機,從服務(wù)無法再進行set key

3.設(shè)置主從切換

三個服務(wù)器都修改 sentinel-test.conf

加入

sentinel monitor MyMaster 127.0.0.1 6381 1
sentinel down-after-milliseconds MyMaster 5000
sentinel failover-timeout MyMaster 900000
sentinel parallel-syncs MyMaster 2

第一行配置指示 Sentinel 去監(jiān)視一個名為 mymaster 的主服務(wù)器, 這個主服務(wù)器的 IP 地址為 127.0.0.1 , 端口號為 6379 , 而將這個主服務(wù)器判斷為失效至少需要 2 個 Sentinel 同意 (只要同意 Sentinel 的數(shù)量不達標(biāo),自動故障遷移就不會執(zhí)行)。

第二行down-after-milliseconds 選項指定了 Sentinel 認為服務(wù)器已經(jīng)斷線所需的毫秒數(shù)。

如果服務(wù)器在給定的毫秒數(shù)之內(nèi), 沒有返回 Sentinel 發(fā)送的 PING 命令的回復(fù), 或者返回一個錯誤, 那么 Sentinel 將這個服務(wù)器標(biāo)記為主觀下線(subjectively down,簡稱 SDOWN )。

不過只有一個 Sentinel 將服務(wù)器標(biāo)記為主觀下線并不一定會引起服務(wù)器的自動故障遷移: 只有在足夠數(shù)量的 Sentinel 都將一個服務(wù)器標(biāo)記為主觀下線之后, 服務(wù)器才會被標(biāo)記為客觀下線(objectively down, 簡稱 ODOWN ), 這時自動故障遷移才會執(zhí)行。

將服務(wù)器標(biāo)記為客觀下線所需的 Sentinel 數(shù)量由對主服務(wù)器的配置決定。

第三行暫時不知道是什么意思;

第四行 parallel-syncs 選項指定了在執(zhí)行故障轉(zhuǎn)移時, 最多可以有多少個從服務(wù)器同時對新的主服務(wù)器進行同步, 這個數(shù)字越小, 完成故障轉(zhuǎn)移所需的時間就越長。

如果從服務(wù)器被設(shè)置為允許使用過期數(shù)據(jù)集(參見對 redis.conf 文件中對 slave-serve-stale-data 選項的說明), 那么你可能不希望所有從服務(wù)器都在同一時間向新的主服務(wù)器發(fā)送同步請求, 因為盡管復(fù)制過程的絕大部分步驟都不會阻塞從服務(wù)器, 但從服務(wù)器在載入主服務(wù)器發(fā)來的 RDB 文件時, 仍然會造成從服務(wù)器在一段時間內(nèi)不能處理命令請求: 如果全部從服務(wù)器一起對新的主服務(wù)器進行同步, 那么就可能會造成所有從服務(wù)器在短時間內(nèi)全部不可用的情況出現(xiàn)。

你可以通過將這個值設(shè)為 1 來保證每次只有一個從服務(wù)器處于不能處理命令請求的狀態(tài)。

4.啟動

  啟動redis-server
    # ./src/redis-server redis.conf 
    啟動redis-sentinel
    # ./src/redis-sentinelsentinel-test.conf 

注意: 三臺服務(wù)器都是這么啟動的哦!~

補充:Redis CLuster主備切換、故障轉(zhuǎn)移測試

redis版本5.0.5

測試redis Cluster主備切換、故障轉(zhuǎn)移

1.下線一個從節(jié)點,此時它的主節(jié)點打印的日志

集群狀態(tài)

2.下線一臺主節(jié)點,此時它的從節(jié)點打印的日志

集群狀態(tài)

測試主備切換時客戶端狀態(tài)

第一步:查看當(dāng)前集群狀態(tài)

可以看到六個節(jié)點都是可用狀態(tài),其中83.46的6379是81.64上的6380的從節(jié)點,計劃Kill掉81.64上的6380主節(jié)點,然后觀察83.46的6379節(jié)點日志

第二步:kill掉81.64上的6380

10:11:25:kill掉81.64上的6380,可以看到其從節(jié)點很快提示連接主節(jié)點失敗,并且開始一秒鐘一次的重連操作

此時查看集群的節(jié)點狀態(tài)如下,可以看到槽 5461-10922在這個主節(jié)點上,此時整個reidis集群處于不可用狀態(tài)

10:12:24:應(yīng)用程序報錯,redis操作超時

10:11:43 :在重連17次失敗次數(shù)之后,從節(jié)點將主節(jié)點標(biāo)記為失敗,并且整個集群的狀態(tài)切換為不可用,之后不甘心,又去嘗試連接主節(jié)點

10:12:03:在重連20次失敗后,從節(jié)點打印日志,等待投票選舉,但是沒有達到多數(shù)贊成,于是繼續(xù)重連之前的主節(jié)點

10:12:14:提示選舉失敗,選舉過期,又繼續(xù)重連

10:12:45:選舉成功勝出,成為了新的主節(jié)點,整個集群的狀態(tài)變?yōu)榭捎?/p>

10:13:39:大概一分鐘之后,redis客戶端自動刷新了集群配置,成功連接上redis集群,此時主備切換和故障轉(zhuǎn)移完成

此前項目中存在的問題

redis master宕機之后,會出現(xiàn)應(yīng)用程序連接不上redis cluster的問題,需要重啟服務(wù)才能解決

排查原因之后發(fā)現(xiàn)是spring boot 2.x版本默認使用了lettuce作為redis客戶端,而lettuce默認是不開啟自動刷新集群拓撲的,當(dāng)redis master宕機并且集群完成故障轉(zhuǎn)移/主從切換之后,客戶端使用的還是之前錯誤的集群信息,就會導(dǎo)致應(yīng)用程序一直連接不上redis集群。解決方案就是修改redis客戶端配置,開啟開啟自適應(yīng)刷新拓撲

配置文件如下

spring.redis.cluster.nodes=${redis.nodes}
spring.redis.password=${redis.pass}
spring.redis.timeout=60000
# 最大重定向次數(shù)
spring.redis.cluster.max-redirects=3
spring.redis.lettuce.pool.max-active=64
spring.redis.lettuce.pool.max-idle=16
spring.redis.lettuce.pool.min-idle=0
spring.redis.lettuce.pool.max-wait=60000ms
spring.redis.lettuce.shutdown-timeout=100ms

完整的配置類如下

import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import io.lettuce.core.cluster.ClusterClientOptions;
import io.lettuce.core.cluster.ClusterTopologyRefreshOptions;
import org.apache.commons.pool2.impl.GenericObjectPoolConfig;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.data.redis.RedisProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisClusterConfiguration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.connection.RedisNode;
import org.springframework.data.redis.connection.RedisPassword;
import org.springframework.data.redis.connection.lettuce.LettuceClientConfiguration;
import org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory;
import org.springframework.data.redis.connection.lettuce.LettucePoolingClientConfiguration;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;
import java.time.Duration;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
@Configuration
public class RedisConfig {
    @Autowired
    private RedisProperties redisProperties;
    @Bean
    @SuppressWarnings("all")
    public RedisTemplateString, Object> redisTemplate(RedisConnectionFactory factory) {
        RedisTemplateString, Object> template = new RedisTemplateString, Object>();
        template.setConnectionFactory(factory);
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
        ObjectMapper om = new ObjectMapper();
        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(om);
        StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
        // key采用String的序列化方式
        template.setKeySerializer(stringRedisSerializer);
        // hash的key也采用String的序列化方式
        template.setHashKeySerializer(stringRedisSerializer);
        // value序列化方式采用jackson
        template.setValueSerializer(jackson2JsonRedisSerializer);
        // hash的value序列化方式采用jackson
        template.setHashValueSerializer(jackson2JsonRedisSerializer);
        template.afterPropertiesSet();
        return template;
    }
    /**
     * 為RedisTemplate配置Redis連接工廠實現(xiàn)
     * LettuceConnectionFactory實現(xiàn)了RedisConnectionFactory接口
     * 這里要注意的是,在構(gòu)建LettuceConnectionFactory 時,如果不使用內(nèi)置的destroyMethod,可能會導(dǎo)致Redis連接早于其它Bean被銷毀
     *
     * @return 返回LettuceConnectionFactory
     */
    @Bean(destroyMethod = "destroy")
    public LettuceConnectionFactory lettuceConnectionFactory() {
        ListString> clusterNodes = redisProperties.getCluster().getNodes();
        SetRedisNode> nodes = new HashSet>();
        clusterNodes.forEach(address -> nodes.add(new RedisNode(address.split(":")[0].trim(), Integer.parseInt(address.split(":")[1]))));
        RedisClusterConfiguration clusterConfiguration = new RedisClusterConfiguration();
        clusterConfiguration.setClusterNodes(nodes);
        clusterConfiguration.setPassword(RedisPassword.of(redisProperties.getPassword()));
        clusterConfiguration.setMaxRedirects(redisProperties.getCluster().getMaxRedirects());
        GenericObjectPoolConfig poolConfig = new GenericObjectPoolConfig();
        poolConfig.setMaxIdle(redisProperties.getLettuce().getPool().getMaxIdle());
        poolConfig.setMinIdle(redisProperties.getLettuce().getPool().getMinIdle());
        poolConfig.setMaxTotal(redisProperties.getLettuce().getPool().getMaxActive());
        return new LettuceConnectionFactory(clusterConfiguration, getLettuceClientConfiguration(poolConfig));
    }
    /**
     * 配置LettuceClientConfiguration 開啟自適應(yīng)刷新拓撲 包括線程池配置和安全項配置
     *
     * @param genericObjectPoolConfig common-pool2線程池
     * @return lettuceClientConfiguration
     */
    private LettuceClientConfiguration getLettuceClientConfiguration(GenericObjectPoolConfig genericObjectPoolConfig) {
        /*
        ClusterTopologyRefreshOptions配置用于開啟自適應(yīng)刷新和定時刷新。如自適應(yīng)刷新不開啟,Redis集群變更時將會導(dǎo)致連接異常!
         */
        ClusterTopologyRefreshOptions topologyRefreshOptions = ClusterTopologyRefreshOptions.builder()
                //開啟自適應(yīng)刷新
                //.enableAdaptiveRefreshTrigger(ClusterTopologyRefreshOptions.RefreshTrigger.MOVED_REDIRECT, ClusterTopologyRefreshOptions.RefreshTrigger.PERSISTENT_RECONNECTS)
                //開啟所有自適應(yīng)刷新,MOVED,ASK,PERSISTENT都會觸發(fā)
                .enableAllAdaptiveRefreshTriggers()
                // 自適應(yīng)刷新超時時間(默認30秒)
                .adaptiveRefreshTriggersTimeout(Duration.ofSeconds(25)) //默認關(guān)閉開啟后時間為30秒
                // 開周期刷新
                .enablePeriodicRefresh(Duration.ofSeconds(20))  // 默認關(guān)閉開啟后時間為60秒 ClusterTopologyRefreshOptions.DEFAULT_REFRESH_PERIOD 60  .enablePeriodicRefresh(Duration.ofSeconds(2)) = .enablePeriodicRefresh().refreshPeriod(Duration.ofSeconds(2))
                .build();
        return LettucePoolingClientConfiguration.builder()
                .poolConfig(genericObjectPoolConfig)
                .clientOptions(ClusterClientOptions.builder().topologyRefreshOptions(topologyRefreshOptions).build())
                .build();
    }
}

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • Redis Sentinel的使用方法
  • Redis Sentinel的基本搭建
  • Redis服務(wù)之高可用組件sentinel詳解
  • 詳解SpringBoot Redis自適應(yīng)配置(Cluster Standalone Sentinel)
  • 基于docker搭建redis-sentinel集群的方法示例
  • Linux redis-Sentinel配置詳解
  • Redis Sentinel實現(xiàn)哨兵模式搭建小結(jié)
  • 玩轉(zhuǎn)Redis搭建集群之Sentinel詳解
  • 解決redis sentinel 頻繁主備切換的問題

標(biāo)簽:楊凌 臺州 江蘇 果洛 大慶 朝陽 北京 吉安

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《redis 主從備份及其主備切換的操作》,本文關(guān)鍵詞  redis,主從,備份,及其,主備,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《redis 主從備份及其主備切換的操作》相關(guān)的同類信息!
  • 本頁收集關(guān)于redis 主從備份及其主備切換的操作的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    韩国三级电影一区二区| 中文无字幕一区二区三区| 黄色污网站在线观看| 日韩一区二区三区在线看| 最新版天堂资源中文官网| 91综合在线| 亚洲一区二区三区高清不卡| 91精品人妻一区二区三区四区| 九一国产精品| 亚洲老板91色精品久久| 久久精品一区八戒影视| 久久精品国产亚洲av麻豆蜜芽| 蜜桃特黄a∨片免费观看| 麻豆成人在线看| 欧美日韩亚洲一区二区| 94色蜜桃网一区二区三区| 国产91|九色| 91大神福利视频| 99国产麻豆精品| 亚洲最新无码中文字幕久久| 性欧美性free| 成人做爰69片免网站| yw视频在线观看| 精品伊人久久97| 亚洲高清国产拍精品26u| www.爱色av.com| 91偷拍一区二区三区精品| 亚洲精品粉嫩美女一区| 最近2019年手机中文字幕| 小泽玛利亚一区| 日韩乱码人妻无码中文字幕久久| 亚洲性在线观看| 欧美一进一出视频| 中文字幕在线导航| 国产91ⅴ在线精品免费观看| 亚洲一区二区三区在线视频| 亚洲欧美福利视频| 色欧美乱欧美15图片| 日韩情涩欧美日韩视频| 久久免费福利| 黑人巨大精品欧美一区| 2018天天操夜夜操| 久久久久久久国产精品视频| 亚洲色图狂野欧美| 亚洲精品电影在线观看| 超碰在线免费| 欧美在线观看视频在线| www.com在线观看| 国产亚洲精品久| 国产精品无码电影在线观看| 一区二区三区欧美激情| 欧美午夜影院| 99久久免费国产精精品| 国内毛片毛片毛片毛片毛片| 日韩a∨精品日韩在线观看| 中文字幕永久在线视频| 444亚洲人体| www日本在线| 欧美日韩岛国| 国产精品伦一区二区三区视频| 97久久综合精品久久久综合| 日韩视频亚洲视频| 偷拍自拍在线| 欧美日韩免费观看视频| wwwxx在线观看| 伊人春色在线观看| 成人性免费视频| 欧美日本国产| 国产成人自拍偷拍| 一区二区三区四区视频| 欧美影院一区| 日本a人精品| 国产丶欧美丶日本不卡视频| 波多野结衣在线观看一区二区| 噜噜噜在线观看免费视频日韩| 日韩在线不卡一区| 不卡影院免费观看| 国产乱在线观看完整版视频| 日韩成人高清视频| 国产视频一二三| 1区2区3区国产精品| 成人黄色在线| 国产自产自拍视频在线观看| 国产精品亚洲不卡a| 国产精品免费视频二三区| 一二三四中文在线| 欧亚成年男女午夜| 日韩中文字幕av电影| 国产精品高清一区二区| 这里都是精品| 成人免费精品视频| 欧美日韩大陆一区二区| 国产v综合v| 日韩一区二区三区高清免费看看| 亚洲人永久免费| 国产福利电影在线| 国产精品成人3p一区二区三区| 亚洲黄色免费视频| 亚洲国产精品悠悠久久琪琪| 亚洲午夜天堂| 黄色在线免费观看网站| 初体验·韩国| 永久免费无码av网站在线观看| 福利一区二区在线观看| 亚洲精品国产精品国产自| 99精彩视频在线观看免费| 国产十六处破外女视频| 一区视频网站| 国产精品传媒视频| 成人免费淫片免费观看| 国产欧美日韩精品在线观看| 四虎影视国产在线视频| 成人精品在线看| 蜜芽一区二区三区| 欧美在线视频一二三| 国产又粗又长免费视频| 成人网18免费网站在线| 亚洲美女91| 久久国产香蕉视频| 蜜桃一级网站.| 欧美精品在线免费播放| 亚洲欧美一区二区三区情侣bbw| 黄色av网站免费在线观看| 国产精品999| 国产精品一区二区a| 日韩有码第一页| 同性gay免费| 久久久久久九九九九| 国产亚洲第一伦理第一区| 亚洲熟妇av乱码在线观看| wwww在线观看免费视频| 国产又黄又大又粗视频| 91论坛在线播放| 午夜精品一区二区三区免费视频| 亚洲免费一级电影| 中文字幕久久熟女蜜桃| 亚洲精品卡一卡二| 久久精品成人| 久久人人爽人人爽人人片| 韩国精品久久久999| 精品国产一区二区三区性色av| 欧美国产一区二区三区激情无套| 一本色道久久综合亚洲精品酒店| 一区二区中文字幕| 日韩av免费看网站| 四虎亚洲精品| 天天躁日日躁狠狠躁av麻豆男男| 亚洲一区二区偷拍精品| 国产欧美一区二区三区在线看| 欧美大片免费久久精品三p| 最全影音av资源中文字幕在线| 国产精品资源站在线| 日日噜噜夜夜狠狠视频欧美人| 亚洲免费色视频| 欧美网站大全在线观看| 国产精品羞羞答答在线| 国产日韩精品入口| 波多野结衣中文一区| 亚洲乱码国产乱码精品精可以看| 久久一区二区三区四区五区| 国产伦精品一区二区三区视频小说| 成人免费乱码大片a毛片软件| 这里只有久久精品视频| 日韩欧美黄色| 绿色成人影院| 69av在线播放| 中文字幕免费在线不卡| 蜜桃专区在线| 4hu四虎永久网址| 久草视频免费在线观看| 久久久91精品国产一区不卡| 91av一区| 国产精品igao视频| 欧美精品人人做人人爱视频| 在线观看国产精品91| 成人在线视频网站| 亚洲成人av中文字幕| 国产精品sss| 国产男女裸体做爰爽爽| 国产露脸国语对白在线| 麻豆高清免费国产一区| 欧美另类极品videosbest最新版本| 亚洲精品在线观看91| 综合色天天鬼久久鬼色| 亚洲精品国产精品国自| 欧美二区观看| 日韩视频在线观看免费| 色偷偷免费视频| 午夜精品一区二区三区视频| 91xxx在线观看| 国内激情视频在线观看| 6080亚洲精品一区二区| 波多野结衣福利| 要久久爱电视剧全集完整观看| 婷婷亚洲婷婷综合色香五月| 大片免费在线看视频| av在线看网址| 日韩午夜av一区| 伊人伊人av电影| caoporen国产精品视频| 一区二区三区四区在线看| 亚洲综合清纯丝袜自拍| 天堂网在线观看视频| 免费观看成年在线视频网站| 欧美另类videosbestsex日本| 国产露出视频在线观看| 欧美在线视频导航| 久久国产精品高清一区二区三区| 乱妇乱女熟妇熟女网站| 一区二区国产日产| 亚洲va欧美va天堂v国产综合| 国产suv精品一区二区883| 亚洲欧美日韩在线高清直播| 国语精品中文字幕| 国产精品-区区久久久狼| 久久国产免费观看| √…a在线天堂一区| 国产成人aa精品一区在线播放| 国产欧美日韩中文久久| 色av手机在线| av在线播放一区二区三区| 午夜免费激情视频| 成人综合网网址| 国产一区亚洲二区| 久久这里只有精品一区二区| 日本不卡三区| 欧美熟妇另类久久久久久多毛| 日韩电影精品| 成品网站w灬+源码1688网页| jizz免费看| 欧美色窝79yyyycom| 公交车强行挺进岳身体| 麻豆一区二区麻豆免费观看| 免费看黄在线看| 熟女少妇在线视频播放| 最近中文字幕在线中文高清版| 国产日本在线播放| 日本一区视频| 亚洲宅男天堂在线观看无病毒| 色窝窝无码一区二区三区| 啪一啪鲁一鲁2019在线视频| 嫩草影院懂你的影院| 欧美大电影免费观看| 91白丝在线| 97人妻精品一区二区三区视频| 日本一二三不卡视频| 呦视频在线一区二区三区| 成人一区二区三区视频| 国产在线精品免费av| 欧美精品久久久| 日韩大片在线永久免费观看网站| 亚洲天堂2020| 午夜福利理论片在线观看| 亚洲一区在线播放| 久久亚洲精品中文字幕| 高清欧美日韩| 日韩中文字幕在线播放| 亚洲美女视频网站| 欧美熟妇另类久久久久久多毛| 国产亚洲精品久久久久久青梅| 久久久久久久久久国产精品| 免费在线看a| 亚洲一卡2卡三卡4卡2021四卡| 在线一区免费| 日本一区二区视频| 精品国产av色一区二区深夜久久| 在线a人片免费观看视频| 成熟丰满熟妇高潮xxxxx视频| mm1313亚洲国产精品美女| 亚洲伊人成综合成人网| 美女扒开大腿让男人桶| 国产成人精品三级高清久久91| 超级碰碰不卡在线视频| 国产精品www网站| 4438国产精品一区二区| 蜜桃国内精品久久久久软件9| 一区二区精品免费视频| 高清在线一区二区| 久久精品久久久| 国产日韩在线观看一区| 可以免费看毛片的网站| 一区二区视频观看| 5566日本婷婷色中文字幕97| 亚洲在线免费看| 国产美女视频一区| eeuss影院在线| 激情综合网最新| 亚洲免费视频一区二区| 福利视频导航大全| www.蜜臀av| 久久精品国产久精国产| 石原莉奈在线亚洲二区| 宅男噜噜噜66国产免费观看| 欧美午夜片在线看| 欧美日韩综合网| 黄色美女网站在线观看| 26uuu久久噜噜噜噜| 中文字幕精品av| 少妇精品在线| 久久精品综合一区| 99久久免费国产精品| 成人欧美日韩| 成人亚洲成人影院| 国产成人精品一区二区| 精品一区二区三区三区| 91亚洲一区精品| 69精品丰满人妻无码视频a片| 免费观看在线综合| 精品国产一区二区三区久久影院| 免费看一级大黄情大片| 亚洲激情成人| www.久久热| 国产制服91一区二区三区制服| www.超碰在线观看| 亚洲一区二区三区四区精品| 姝姝窝人体www聚色窝| 精品国产一区二区三| 欧美中文字幕在线播放| 成人福利电影精品一区二区在线观看| www国产精品视频| 成人亚洲精品7777| 亚洲第一免费看片| 久久精品亚洲a| 娇小发育未年成性色xxx8| 天天综合网在线| 精品一卡二卡三卡四卡日本乱码| 亚洲福利视频专区| 欧美久久婷婷综合色|