spring boot整合cache使用memcached 优化将配置信息放入 application中管理

上文 spring boot整合cache使用memcached

我们简单做了个 spring boot 整合cache 使用 memcached 缓存的案例

但 我们是将地址这类信息 放在了config 目录下的一个 配置类中了

这样 可维护性肯定是很低的

其实 memcached 是有一系列配置的

我们还是正确将 配置信息 写进 application 中

首先 我们在 config 目录下再创建一个类 名字随意 开心就好 我这里取名叫 XMemcachedProperties

参考代码如下

java 复制代码
package com.example.webdom.config;

import org.springframework.stereotype.Component;

@Component

public class XMemcachedProperties {
    //服务地址
    private String servers;
    //连接池数量
    private int poolsize;
    //超时时间
    private long opTimeout;

    public String getServers() {
        return servers;
    }

    public int getPoolsize() {
        return poolsize;
    }

    public long getOpTimeout() {
        return opTimeout;
    }

    public void setServers(String servers) {
        this.servers = servers;
    }

    public void setPoolsize(int poolsize) {
        this.poolsize = poolsize;
    }

    public void setOpTimeout(long opTimeout) {
        this.opTimeout = opTimeout;
    }
}

这里 我们定义了三个属性 然后分别定义了 get set函数 然后 Component 将它写为一个bean

因为只有bean外面才能拿到 然后 get set 方便外面处理它的属性

这三个值 对应 我们 memcached 的 服务器地址 连接池数量 超时时间

然后在application中配置这三个属性

javascript 复制代码
memcached:
  servers: localhost:11211
  poolsize: 10
  opTimeout: 3000

这相当于我们自己自定义的属性 我们后面要去类里读 这个是之前讲过的东西了

这里 我们给 XMemcachedProperties 类加上 ConfigurationProperties prefix值指向 我们 application的memcached属性

然后 我们封装这些属性 是为了给我们之前的 XMemcachedconfig 用的

先将它条件装配进来

getServers 肯定是放到 XMemcachedClientBuilder 中

然后 其他几个属性 我们 memcachedclientBuilder 有非常多的set属性

我们这里要的是 setConnectionPoolSize 连接池数量 setOpTimeout 超时时间

参考代码如下

java 复制代码
package com.example.webdom.config;

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 net.rubyeye.xmemcached.MemcachedClient;

import java.io.IOException;

@Configuration
public class XMemcachedconfig {

    @Autowired
    private XMemcachedProperties XMemcachedProperties;

    @Bean
    public MemcachedClient getMemcachedclient() throws IOException {
        XMemcachedClientBuilder memcachedclientBuilder = new XMemcachedClientBuilder(XMemcachedProperties.getServers());
        memcachedclientBuilder.setConnectionPoolSize(XMemcachedProperties.getPoolsize());
        memcachedclientBuilder.setOpTimeout(XMemcachedProperties.getOpTimeout());
        MemcachedClient memcachedclient = memcachedclientBuilder.build();
        return memcachedclient;
    }
}

memcachedclientBuilder里面有哪些set 你都可以自己去看 里面可以配的东西多了去了

然后 我们运行项目

对我们运行是没有任何影响的

相关推荐
stark张宇13 分钟前
避坑指南:Windows 用户安装 OpenClaw 的正确姿势,拒绝失败率 100%
人工智能·后端·llm
程序员爱钓鱼1 小时前
Go错误处理全解析:errors包实战与最佳实践
前端·后端·go
巫山老妖9 小时前
从零开发一个掘金自动发布 Skill,并上架 Clawhub
后端
颜酱10 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
雨中飘荡的记忆10 小时前
零拷贝技术深度解析
后端
uzong11 小时前
十年老员工的项目管理实战心得:有道有术
后端
Victor35612 小时前
MongoDB(31)索引对查询性能有何影响?
后端
Victor35612 小时前
MongoDB(30)如何删除索引?
后端
lizhongxuan13 小时前
多 Agent 协同机制对比
后端
IT_陈寒13 小时前
SpringBoot项目启动慢?5个技巧让你的应用秒级响应!
前端·人工智能·后端