婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > 使用SpringBoot集成redis的方法

使用SpringBoot集成redis的方法

熱門(mén)標(biāo)簽:十堰營(yíng)銷(xiāo)電銷(xiāo)機(jī)器人哪家便宜 宿遷便宜外呼系統(tǒng)平臺(tái) 日本中國(guó)地圖標(biāo)注 魔獸2青云地圖標(biāo)注 山東外呼銷(xiāo)售系統(tǒng)招商 貴州電銷(xiāo)卡外呼系統(tǒng) 超呼電話(huà)機(jī)器人 北京400電話(huà)辦理收費(fèi)標(biāo)準(zhǔn) 鄭州人工智能電銷(xiāo)機(jī)器人系統(tǒng)

今天,日月在這里教大家如何使用springBoot集成redis,說(shuō)實(shí)話(huà)比較簡(jiǎn)單,網(wǎng)上也有大把的教程。先套用一下網(wǎng)上的簡(jiǎn)介。
定義

REmote DIctionary Server(Redis) 是一個(gè)由Salvatore Sanfilippo寫(xiě)的key-value存儲(chǔ)系統(tǒng)。
Redis是一個(gè)開(kāi)源的使用ANSI C語(yǔ)言編寫(xiě)、遵守BSD協(xié)議、支持網(wǎng)絡(luò)、可基于內(nèi)存亦可持久化的日志型、Key-Value數(shù)據(jù)庫(kù),并提供多種語(yǔ)言的API。
它通常被稱(chēng)為數(shù)據(jù)結(jié)構(gòu)服務(wù)器,因?yàn)橹担╲alue)可以是 字符串(String), 哈希(Map), 列表(list), 集合(sets) 和 有序集合(sorted sets)等類(lèi)型。
reids的優(yōu)點(diǎn)

以下是Redis的一些優(yōu)點(diǎn)。

異常快 - Redis非常快,每秒可執(zhí)行大約110000次的設(shè)置(SET)操作,每秒大約可執(zhí)行81000次的讀取/獲取(GET)操作。
支持豐富的數(shù)據(jù)類(lèi)型 - Redis支持開(kāi)發(fā)人員常用的大多數(shù)數(shù)據(jù)類(lèi)型,例如列表,集合,排序集和散列等等。這使得Redis很容易被用來(lái)解決各種問(wèn)題,因?yàn)槲覀冎滥男﹩?wèn)題可以更好使用地哪些數(shù)據(jù)類(lèi)型來(lái)處理解決。
操作具有原子性 - 所有Redis操作都是原子操作,這確保如果兩個(gè)客戶(hù)端并發(fā)訪問(wèn),Redis服務(wù)器能接收更新的值。
多實(shí)用工具 - Redis是一個(gè)多實(shí)用工具,可用于多種用例,如:緩存,消息隊(duì)列(Redis本地支持發(fā)布/訂閱),應(yīng)用程序中的任何短期數(shù)據(jù),例如,web應(yīng)用程序中的會(huì)話(huà),網(wǎng)頁(yè)命中計(jì)數(shù)等。

Redis 安裝

Window 下安裝
下載地址:https://github.com/MSOpenTech/redis/releases。
Redis 支持 32 位和 64 位。這個(gè)需要根據(jù)你系統(tǒng)平臺(tái)的實(shí)際情況選擇,這里我們下載 Redis-x64-xxx.zip壓縮包到 C 盤(pán),解壓后,將文件夾重新命名為 redis。

打開(kāi)一個(gè) cmd 窗口 使用cd命令切換目錄到 C:\redis
運(yùn)行 redis-server.exe redis.windows.conf
如果想方便的話(huà),可以把 redis 的路徑加到系統(tǒng)的環(huán)境變量里,這樣就省得再輸路徑了,后面的那個(gè) redis.windows.conf 可以省略,如果省略,會(huì)啟用默認(rèn)的。輸入之后,會(huì)顯示如下界面:

集成redis

我們還是延用上一章的項(xiàng)目:Springboot集成springcloud-config實(shí)現(xiàn)dataSource熱部署

1、添加依賴(lài)

!--集成redis-->
dependency>
 groupId>org.springframework.boot/groupId>
 artifactId>spring-boot-starter-redis/artifactId>
 version>1.4.1.RELEASE/version>
/dependency>
dependency>
 groupId>com.alibaba/groupId>
 artifactId>fastjson/artifactId>
 version>1.2.3/version>
/dependency>
dependency>
 groupId>com.fasterxml.jackson.core/groupId>
 artifactId>jackson-databind/artifactId>
/dependency>

2、在配置中心里添加redis配置

spring.redis.host=127.0.0.1
#Redis服務(wù)器連接端口
spring.redis.port=6379
#Redis服務(wù)器連接密碼(默認(rèn)為空)
spring.redis.password=
#連接池最大連接數(shù)(使用負(fù)值表示沒(méi)有限制)
spring.redis.pool.max-active=8
#連接池最大阻塞等待時(shí)間(使用負(fù)值表示沒(méi)有限制)
spring.redis.pool.max-wait=-1
#連接池中的最大空閑連接
spring.redis.pool.max-idle=8
#連接池中的最小空閑連接
spring.redis.pool.min-idle=0
#連接超時(shí)時(shí)間(毫秒)
spring.redis.timeout=30000

3、配置類(lèi)RedisConfig

import java.lang.reflect.Method;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cache.CacheManager;
import org.springframework.cache.annotation.CachingConfigurerSupport;
import org.springframework.cache.annotation.EnableCaching;
import org.springframework.cache.interceptor.KeyGenerator;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.cache.RedisCacheManager;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import com.fasterxml.jackson.annotation.PropertyAccessor; 
import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.databind.ObjectMapper;
@Configuration
@EnableCaching
@RefreshScope
public class RedisConfig extends CachingConfigurerSupport{
 @Value("${spring.redis.host}")
 private String host;
 @Value("${spring.redis.port}")
 private int port;
 @Value("${spring.redis.timeout}")
 private int timeout;
 @Value("${spring.redis.password}")
 private String password;
 @Value("${spring.redis.pool.max-active}")
 private int maxActive;
 @Value("${spring.redis.pool.max-wait}")
 private int maxWait;
 @Value("${spring.redis.pool.max-idle}")
 private int maxIdle;
 @Value("${spring.redis.pool.min-idle}")
 private int minIdle;
 
 @RefreshScope
 @Bean
 public KeyGenerator wiselyKeyGenerator(){
 return new KeyGenerator() {
 @Override
 public Object generate(Object target, Method method, Object... params) {
 StringBuilder sb = new StringBuilder();
 sb.append(target.getClass().getName());
 sb.append(method.getName());
 for (Object obj : params) {
  sb.append(obj.toString());
 }
 return sb.toString();
 }
 };
 }
 
 @RefreshScope
 @Bean
 public JedisConnectionFactory redisConnectionFactory() {
 JedisConnectionFactory factory = new JedisConnectionFactory();
 factory.setHostName(host);
 factory.setPort(port);
 factory.setTimeout(timeout); //設(shè)置連接超時(shí)時(shí)間
 factory.setPassword(password);
 factory.getPoolConfig().setMaxIdle(maxIdle);
 factory.getPoolConfig().setMinIdle(minIdle);
 factory.getPoolConfig().setMaxTotal(maxActive);
 factory.getPoolConfig().setMaxWaitMillis(maxWait);
 return factory;
 }
 
 @RefreshScope
 @Bean
 public CacheManager cacheManager(RedisTemplate redisTemplate) {
 RedisCacheManager cacheManager = new RedisCacheManager(redisTemplate);
 // Number of seconds before expiration. Defaults to unlimited (0)
 cacheManager.setDefaultExpiration(10); //設(shè)置key-value超時(shí)時(shí)間
 return cacheManager;
 }
 
 @RefreshScope
 @Bean
 public RedisTemplateString, String> redisTemplate(RedisConnectionFactory factory) {
 StringRedisTemplate template = new StringRedisTemplate(factory);
 setSerializer(template); //設(shè)置序列化工具,這樣ReportBean不需要實(shí)現(xiàn)Serializable接口
 template.afterPropertiesSet();
 return template;
 }
 
 @RefreshScope
 private void setSerializer(StringRedisTemplate template) {
 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);
 template.setValueSerializer(jackson2JsonRedisSerializer);
 }
}

4、RedisUtils類(lèi)

import java.io.Serializable;
import java.util.List;
import java.util.Set;
import java.util.concurrent.TimeUnit;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.HashOperations;
import org.springframework.data.redis.core.ListOperations;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.SetOperations;
import org.springframework.data.redis.core.ValueOperations;
import org.springframework.data.redis.core.ZSetOperations;
import org.springframework.stereotype.Service;
@Service
public class RedisUtils {
 @Autowired
 private RedisTemplate redisTemplate;
 /**
 * 寫(xiě)入緩存
 * @param key
 * @param value
 * @return
 */
 public boolean set(final String key, Object value) {
 boolean result = false;
 try {
 ValueOperationsSerializable, Object> operations = redisTemplate.opsForValue();
 operations.set(key, value);
 result = true;
 } catch (Exception e) {
 e.printStackTrace();
 }
 return result;
 }
 /**
 * 寫(xiě)入緩存設(shè)置時(shí)效時(shí)間
 * @param key
 * @param value
 * @return
 */
 public boolean set(final String key, Object value, Long expireTime ,TimeUnit timeUnit) {
 boolean result = false;
 try {
 ValueOperationsSerializable, Object> operations = redisTemplate.opsForValue();
 operations.set(key, value);
 redisTemplate.expire(key, expireTime, timeUnit);
 result = true;
 } catch (Exception e) {
 e.printStackTrace();
 }
 return result;
 }
 /**
 * 批量刪除對(duì)應(yīng)的value
 * @param keys
 */
 public void remove(final String... keys) {
 for (String key : keys) {
 remove(key);
 }
 }
 /**
 * 批量刪除key
 * @param pattern
 */
 public void removePattern(final String pattern) {
 SetSerializable> keys = redisTemplate.keys(pattern);
 if (keys.size() > 0){
 redisTemplate.delete(keys);
 }
 }
 /**
 * 刪除對(duì)應(yīng)的value
 * @param key
 */
 public void remove(final String key) {
 if (exists(key)) {
 redisTemplate.delete(key);
 }
 }
 /**
 * 判斷緩存中是否有對(duì)應(yīng)的value
 * @param key
 * @return
 */
 public boolean exists(final String key) {
 return redisTemplate.hasKey(key);
 }
 /**
 * 讀取緩存
 * @param key
 * @return
 */
 public Object get(final String key) {
 Object result = null;
 ValueOperationsSerializable, Object> operations = redisTemplate.opsForValue();
 result = operations.get(key);
 return result;
 }
 /**
 * 哈希 添加
 * @param key
 * @param hashKey
 * @param value
 */
 public void hmSet(String key, Object hashKey, Object value){
 HashOperationsString, Object, Object> hash = redisTemplate.opsForHash();
 hash.put(key,hashKey,value);
 }
 /**
 * 哈希獲取數(shù)據(jù)
 * @param key
 * @param hashKey
 * @return
 */
 public Object hmGet(String key, Object hashKey){
 HashOperationsString, Object, Object> hash = redisTemplate.opsForHash();
 return hash.get(key,hashKey);
 }
 /**
 * 列表添加
 * @param k
 * @param v
 */
 public void lPush(String k,Object v){
 ListOperationsString, Object> list = redisTemplate.opsForList();
 list.rightPush(k,v);
 }
 /**
 * 列表獲取
 * @param k
 * @param l
 * @param l1
 * @return
 */
 public ListObject> lRange(String k, long l, long l1){
 ListOperationsString, Object> list = redisTemplate.opsForList();
 return list.range(k,l,l1);
 }
 /**
 * 集合添加
 * @param key
 * @param value
 */
 public void add(String key,Object value){
 SetOperationsString, Object> set = redisTemplate.opsForSet();
 set.add(key,value);
 }
 /**
 * 集合獲取
 * @param key
 * @return
 */
 public SetObject> setMembers(String key){
 SetOperationsString, Object> set = redisTemplate.opsForSet();
 return set.members(key);
 }
 /**
 * 有序集合添加
 * @param key
 * @param value
 * @param scoure
 */
 public void zAdd(String key,Object value,double scoure){
 ZSetOperationsString, Object> zset = redisTemplate.opsForZSet();
 zset.add(key,value,scoure);
 }
 /**
 * 有序集合獲取
 * @param key
 * @param scoure
 * @param scoure1
 * @return
 */
 public SetObject> rangeByScore(String key,double scoure,double scoure1){
 ZSetOperationsString, Object> zset = redisTemplate.opsForZSet();
 return zset.rangeByScore(key, scoure, scoure1);
 }

5、測(cè)試,修改controller

import java.util.concurrent.TimeUnit;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.chenqi.springboot.redis.RedisUtils;
import com.chenqi.springboot.service.TestService;
@RestController
public class SpringBootController {
 
 public static final Logger log = LoggerFactory.getLogger(SpringBootController.class);
 
 @Autowired
 TestService testService;
 
 @Autowired
 private RedisUtils redisUtils;
 @RequestMapping(value = "/hello/{id}")
 public String hello(@PathVariable(value = "id") String id){
 //查詢(xún)緩存中是否存在
 boolean hasKey = redisUtils.exists(id);
 String str = "";
 if(hasKey){
 //獲取緩存
 Object object = redisUtils.get(id);
 log.info("從緩存獲取的數(shù)據(jù)"+ object);
 str = object.toString();
 }else{
 //從數(shù)據(jù)庫(kù)中獲取信息
 log.info("從數(shù)據(jù)庫(kù)中獲取數(shù)據(jù)");
 str = testService.test();
 //數(shù)據(jù)插入緩存(set中的參數(shù)含義:key值,user對(duì)象,緩存存在時(shí)間10(long類(lèi)型),時(shí)間單位)
 redisUtils.set(id,str,10L,TimeUnit.MINUTES);
 log.info("數(shù)據(jù)插入緩存" + str);
 }
 return str;
 }
}

啟動(dòng)項(xiàng)目,第一次訪問(wèn):http://localhost:8002/hello/111


通過(guò)控制臺(tái)輸出,我們可以看到是從數(shù)據(jù)庫(kù)中獲取的數(shù)據(jù),并且存入了redis緩存中。

我們?cè)俅嗡⑿聻g覽器

可以看到,第二次是從緩存中讀取的,我們?cè)囋嚥粩嗨⑿聻g覽器

可以看到,之后都是從緩存中獲取的。

到此我們的redis就配置好了。

SpringBoot集成Redis-demo下載

急需demo的兄弟就自行下載吧,不急可以留言郵箱,一般48小時(shí)內(nèi)會(huì)發(fā)。

到此這篇關(guān)于使用SpringBoot集成redis的方法的文章就介紹到這了,更多相關(guān)SpringBoot集成redis內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 關(guān)于Springboot2.x集成lettuce連接redis集群報(bào)超時(shí)異常Command timed out after 6 second(s)
  • SpringBoot集成Redis實(shí)現(xiàn)消息隊(duì)列的方法
  • springboot集成redis實(shí)現(xiàn)簡(jiǎn)單秒殺系統(tǒng)
  • SpringBoot集成Redisson實(shí)現(xiàn)分布式鎖的方法示例
  • springBoot集成redis的key,value序列化的相關(guān)問(wèn)題
  • SpringBoot集成Redis的實(shí)現(xiàn)示例
  • springboot集成測(cè)試?yán)锏膔edis
  • SpringBoot集成Redis的思路詳解

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用SpringBoot集成redis的方法》,本文關(guān)鍵詞  使用,SpringBoot,集成,redis,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用SpringBoot集成redis的方法》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于使用SpringBoot集成redis的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日韩精品一区二区三区在线观看| 精品精品国产高清a毛片牛牛| 日韩avvvv在线播放| 一区二区三区中文字幕| 国产精品久久久久永久免费观看 | 国产亚洲va综合人人澡精品 | 日韩欧美亚洲国产另类| 日韩欧美国产成人一区二区| 欧美成人乱码一区二区三区| 精品免费一区二区三区| 2020国产成人综合网| 国产日韩欧美一区二区三区乱码 | 极品美女销魂一区二区三区| 狠狠网亚洲精品| 丰满亚洲少妇av| eeuss鲁片一区二区三区在线观看| 色综合色综合色综合| 欧美日韩国产中文| 欧美精品一区二区蜜臀亚洲| 日韩精品一区二| 国产日产欧美一区| 亚洲三级理论片| 日韩不卡一区二区三区 | 99re成人精品视频| 欧美色区777第一页| 日韩一区二区三区电影在线观看| 欧美日韩三级在线| 337p日本欧洲亚洲大胆精品| 中文在线一区二区| 亚洲成a人片在线不卡一二三区| 另类中文字幕网| 91在线观看污| 欧美精品在线一区二区三区| 精品久久人人做人人爰| 亚洲摸摸操操av| 精品一区二区在线免费观看| 91年精品国产| 久久综合av免费| 亚洲成人激情av| 成人免费高清视频在线观看| 欧美一级xxx| 中文字幕欧美日本乱码一线二线| 亚洲mv大片欧洲mv大片精品| 丁香另类激情小说| 日韩欧美中文字幕精品| 亚洲激情一二三区| 国产乱码精品1区2区3区| 欧美影院一区二区| 欧美一区二区视频在线观看2022| 国产精品久久久久久久久免费樱桃| 午夜精品成人在线视频| 色先锋aa成人| 国产精品国产三级国产普通话三级| 午夜精品久久久久| 另类小说视频一区二区| 欧美在线免费观看视频| 久久久国产综合精品女国产盗摄| 亚洲h精品动漫在线观看| 99国产一区二区三精品乱码| 欧美成人福利视频| 2017欧美狠狠色| 久久久99精品免费观看不卡| 精品一区二区综合| 2021国产精品久久精品| 国产成人av资源| 最新久久zyz资源站| 色综合久久99| 丝袜美腿一区二区三区| 欧美一区二区三区婷婷月色| 国产麻豆一精品一av一免费| 国产精品免费看片| 欧美亚洲动漫制服丝袜| 免费日韩伦理电影| 国产日韩av一区| 日本福利一区二区| 美腿丝袜亚洲一区| 中文字幕av一区二区三区| 91论坛在线播放| 麻豆国产精品视频| 18成人在线观看| 欧美一二三四在线| 91亚洲永久精品| 久久se精品一区精品二区| 成人欧美一区二区三区视频网页| 欧美日韩一区二区欧美激情| 国产一区二区调教| 亚洲图片欧美综合| 中文字幕精品三区| 欧美乱妇20p| 成人av电影在线| 不卡视频免费播放| 国产精品美日韩| 欧美日韩1234| 北条麻妃国产九九精品视频| 日韩中文欧美在线| 国产精品美女久久久久久| 欧美一区二区私人影院日本| heyzo一本久久综合| 美女脱光内衣内裤视频久久网站 | 国产一区二区三区免费观看 | 欧美在线视频你懂得| 国产精品一区二区在线看| 亚洲一区中文日韩| 国产精品天美传媒沈樵| 日韩一区二区三区电影在线观看 | 亚洲一区国产视频| 欧美激情中文不卡| 日韩欧美亚洲一区二区| 99久久99久久精品免费看蜜桃| 久久国产成人午夜av影院| 亚洲伊人伊色伊影伊综合网| 亚洲国产经典视频| 精品国产一区二区三区不卡| 欧美日韩不卡一区二区| 91免费国产在线| av爱爱亚洲一区| 国产成人a级片| 久久国产免费看| 亚洲电影你懂得| 亚洲综合自拍偷拍| 一区二区三区四区在线免费观看 | 亚洲欧美中日韩| 久久嫩草精品久久久精品一| 欧美一区二区三区免费在线看| 91黄色免费版| av在线不卡电影| jiyouzz国产精品久久| 国产大陆亚洲精品国产| 国产精品一二三四五| 久久成人精品无人区| 另类小说一区二区三区| 激情综合一区二区三区| 狠狠色丁香久久婷婷综合_中| 免费av成人在线| 久久超碰97人人做人人爱| 精品影院一区二区久久久| 精品一区二区三区蜜桃| 国产在线看一区| 国产成都精品91一区二区三| 国产精品88888| 成人黄色在线视频| 91麻豆国产精品久久| 在线亚洲一区观看| 欧美久久久久久久久| 91精品国模一区二区三区| 欧美一卡二卡在线观看| 日韩一区和二区| 久久亚洲精精品中文字幕早川悠里| 久久久久久久久久久久久女国产乱 | 日日摸夜夜添夜夜添国产精品| 亚洲午夜一区二区三区| 午夜影视日本亚洲欧洲精品| 日本不卡不码高清免费观看| 另类小说图片综合网| 国产精品白丝jk白祙喷水网站| 国产99久久久国产精品潘金| 91影院在线观看| 欧美电影在哪看比较好| 欧美tk—视频vk| 国产精品进线69影院| 亚洲在线免费播放| 久久国产免费看| av一区二区久久| 欧美日本韩国一区二区三区视频| 日韩亚洲欧美一区| 色悠悠久久综合| 奇米888四色在线精品| 国产一区二区三区av电影 | 国产日韩综合av| 亚洲免费资源在线播放| 日韩成人精品在线观看| 国产精品亚洲一区二区三区在线| 色综合色综合色综合色综合色综合 | 国产日韩高清在线| 亚洲狠狠爱一区二区三区| 国内精品伊人久久久久av一坑| 色综合天天做天天爱| 欧美一级日韩不卡播放免费| 国产欧美精品日韩区二区麻豆天美| 一区二区三区欧美日| 国产在线视频一区二区三区| 91国偷自产一区二区开放时间| 精品成人一区二区三区四区| 一区二区久久久久| 粗大黑人巨茎大战欧美成人| 欧美一区二区三区日韩视频| 亚洲三级在线播放| 粉嫩欧美一区二区三区高清影视| 91精品国产手机| 亚洲猫色日本管| 国产91高潮流白浆在线麻豆| 欧美一级一区二区| 一区二区三区四区在线播放| 国产成人免费在线视频| 日韩视频123| 视频一区二区中文字幕| 色婷婷国产精品久久包臀| 国产欧美日韩不卡免费| 久久草av在线| 欧美一级二级三级蜜桃|