Memcached下载和安装
data:image/s3,"s3://crabby-images/b9b31/b9b31d8c20c2185088278f4768a2dfe4b23e9378" alt=""
是一个国内使用量还是比较大的技术
data:image/s3,"s3://crabby-images/9a655/9a655ab07c4af83ddc5ef6ef25d64d947b1b7978" alt=""
打开文件夹
data:image/s3,"s3://crabby-images/5ee0a/5ee0ada7c57935c3e3c3ea1bba707929bed6bfde" alt=""
我们需要在命令行窗口启动
注意要以管理员方式运行
data:image/s3,"s3://crabby-images/a3568/a3568a6c9533d96e13a7cb14a7e41534169d658c" alt=""
先尝试进入指定文件
data:image/s3,"s3://crabby-images/d6f67/d6f6701bef4a3d73e99f2ee292d2474e1d0f75d1" alt=""
然后又再次运行
data:image/s3,"s3://crabby-images/d198b/d198b63c20dc4a7a3088c4595a4e8354e174d16d" alt=""
下载
memcached.exe -d install
启动
memcached.exe -d start
停止
memcached.exe -d stop
memcached.exe -d install
memcached.exe -d start
memcached.exe -d stop
我们打开任务管理器 发现成功运行
data:image/s3,"s3://crabby-images/ec4a1/ec4a18870fe5e0a901b6f13617fd3e82049b0684" alt=""
Memcached缓存技术
问题是springboot提供整合技术
还没有纳入到整合中
需要使用硬编码的方式实现给客户端初始化管理
data:image/s3,"s3://crabby-images/a435e/a435e856ce474c4ea7b0ba00faf4366c1499221c" alt=""
我们打开idea
首先得导入坐标
data:image/s3,"s3://crabby-images/4093e/4093ed0a73966a4afb8e7d66cc5f6d70207fc7a9" alt=""
<!-- memcached的依赖-->
<dependency>
<groupId>com.google.code.maven-play-plugin.spy</groupId>
<artifactId>memcached</artifactId>
<version>2.4.2</version>
</dependency>
data:image/s3,"s3://crabby-images/23e9a/23e9ade62e4f97245afe2e068561ea85ddd63d51" alt=""
因为springboot没有整合
根本没有配置
所以我们直接采取硬编码的形式
找到业务层的实现类
准备书写代码
data:image/s3,"s3://crabby-images/8b63d/8b63d40ac7659e8dccf9dd453ad1b3b90a48422f" alt=""
我们做一个配置类
目的是为了让Mencached被spring容器加载
data:image/s3,"s3://crabby-images/a750d/a750d000ed3ddfc9b671de6f2f9edc783dc655ae" alt=""
配置一个客户端对象
然后加载为spring容器的bean
package com.example.demo.config;
import net.rubyeye.xmemcached.MemcachedClient;
import net.rubyeye.xmemcached.MemcachedClientBuilder;
import net.rubyeye.xmemcached.XMemcachedClientBuilder;
import net.spy.memcached.MemcachedClient;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import java.io.IOException;
@Configuration
public class XMemcachedConfig {
@Bean
public MemcachedClient getmemcachedClient() throws IOException {
//配置服务器端口
MemcachedClientBuilder memcachedClientBuilder = new XMemcachedClientBuilder("localhost:11211");
//构建启动
MemcachedClient memcachedClient=memcachedClientBuilder.build();
return memcachedClient;
}
}
我们直接进行依赖注入
data:image/s3,"s3://crabby-images/e5719/e57195a3dcd1526971fd1a6473e18a96436ed5b2" alt=""
我们接下来补全业务层的代码
书写完毕
data:image/s3,"s3://crabby-images/3d85f/3d85f63afafbfc616605dbfc8fed403dc890a208" alt=""
package com.example.demo.service.impl;
import com.example.demo.domain.SMSCode;
import com.example.demo.service.SMSCodeService;
import com.example.demo.utils.CodeUtils;
import net.rubyeye.xmemcached.MemcachedClient;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cache.annotation.CachePut;
import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Service;
@Service
public class SMSCodeServiceImpl implements SMSCodeService {
@Autowired
private CodeUtils codeUtils;
@Autowired
private MemcachedClient memcachedClient;
//以下是Springboot中使用xmemcached
@Override
public String sendCodeToSMS(String tele) {
String code=codeUtils.generator(tele);
try{
memcachedClient.set(tele,0,code);
}catch (Exception e){
e.printStackTrace();
}
return code;
}
@Override
public boolean checkCode(SMSCode smsCode) {
String code=null;
try{
code=memcachedClient.get(smsCode.getTele().toString());
}catch (Exception e){
e.printStackTrace();
}
return smsCode.getCode().equals(code);
}
}
我们要去改一下缓存的注释
我们把之前采用的缓存方案全部注释掉
data:image/s3,"s3://crabby-images/f7d9f/f7d9fc1f9f6c0ff5baf5faa5f7a64c08b3dd9da2" alt=""
# 专门用来配置的对象datasource
spring:
datasource:
druid:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/mybatis?serverTimezone=UTC
username: root
password: 123456
devtools:
restart:
# 设置不参与热部署的文件或文件夹
exclude: static/**,public/**,config/application.yml
启动成功
data:image/s3,"s3://crabby-images/0281b/0281b51e8d76ce8cfb774a73a9ca26e00892db51" alt=""
去postman发起请求测试
data:image/s3,"s3://crabby-images/f5fad/f5fad73249722745648d1385bba0bf09932d0fed" alt=""
我们通过修改客户端的数值
能改变一些设置
如设置缓存失效时间
data:image/s3,"s3://crabby-images/b545b/b545b0204d60f2f3ae29d22afc3a48ca50fedca0" alt=""
硬编码
就是手搓客户端对象
然后交给spring容器管理后
在业务层的实现类注入
使用缓存的时候使用set
获取缓存数据的时候使用get
data:image/s3,"s3://crabby-images/e8c5c/e8c5c2cb0290474233c4b231c89b3926954f69c6" alt=""
但是我们这边还有个问题
就是在书写客户端的时候
这个数据应该从配置文件里去处理
data:image/s3,"s3://crabby-images/3cfe1/3cfe1b367edf0303d94f66897bdbf6721b0615c6" alt=""
先写一个类
这个类有成员属性 代表的是各种配置信息
data:image/s3,"s3://crabby-images/b74ed/b74ed8a8b9a6567d27f63d31eca287a8196fbc67" alt=""
我们需要做的是自定义配置
data:image/s3,"s3://crabby-images/a1288/a12881357b4f563338c43ec134b87a7546486f73" alt=""
memcached:
servers: localhost:11211
poolSize: 10
opTimeout: 3000
然后在类里面去读取
data:image/s3,"s3://crabby-images/1ce5f/1ce5f1e668eab833a17579a00699db3d00453793" alt=""
package com.example.demo.config;
import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
@Component
@ConfigurationProperties(prefix = "memcached")
@Data
public class XMemcachedProperties {
private String servers;
private int poolSize;
private long opTimeout;
}
这样我们的类就能成功加载
@Component注解又能让这个类被spring容器管理
我们在这边直接注入就行
data:image/s3,"s3://crabby-images/50234/50234726870f44d1a45e8dd1bb2ca6fc7f152456" alt=""
只不过是数值换了一个地方加载
package com.example.demo.config;
import net.rubyeye.xmemcached.MemcachedClient;
import net.rubyeye.xmemcached.MemcachedClientBuilder;
import net.rubyeye.xmemcached.XMemcachedClientBuilder;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import java.io.IOException;
@Configuration
public class XMemcachedConfig {
@Autowired
private XMemcachedProperties memcachedProperties;
@Bean
public MemcachedClient getmemcachedClient() throws IOException {
//配置服务器端口
MemcachedClientBuilder memcachedClientBuilder = new XMemcachedClientBuilder(memcachedProperties.getServers());
//配置数据库连接池最大连接量
memcachedClientBuilder.setConnectionPoolSize(memcachedProperties.getPoolSize());
//配置缓存时间
memcachedClientBuilder.setConnectTimeout(memcachedProperties.getOpTimeout());
//构建启动
MemcachedClient memcachedClient=memcachedClientBuilder.build();
return memcachedClient;
}
}
发起请求
成功
data:image/s3,"s3://crabby-images/ebb39/ebb3905a9a8f2cb83e3f3df5e58019b921b7e225" alt=""
个人号推广
博客主页
Web后端开发
https://blog.csdn.net/qq_30500575/category_12624592.html?spm=1001.2014.3001.5482
Web前端开发
https://blog.csdn.net/qq_30500575/category_12642989.html?spm=1001.2014.3001.5482
数据库开发
https://blog.csdn.net/qq_30500575/category_12651993.html?spm=1001.2014.3001.5482
项目实战
https://blog.csdn.net/qq_30500575/category_12699801.html?spm=1001.2014.3001.5482
算法与数据结构
https://blog.csdn.net/qq_30500575/category_12630954.html?spm=1001.2014.3001.5482
计算机基础
https://blog.csdn.net/qq_30500575/category_12701605.html?spm=1001.2014.3001.5482
回忆录
https://blog.csdn.net/qq_30500575/category_12620276.html?spm=1001.2014.3001.5482