Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >mybatis-plus团队新作:mybatis-mate 轻松搞定数据权限

mybatis-plus团队新作:mybatis-mate 轻松搞定数据权限

作者头像
良月柒
发布于 2021-12-01 08:16:52
发布于 2021-12-01 08:16:52
82700
代码可运行
举报
运行总次数:0
代码可运行

0、简介

mybatis-mate 为 mp 企业级模块,支持分库分表,数据审计、数据敏感词过滤(AC算法),字段加密,字典回写(数据绑定),数据权限,表结构自动生成 SQL 维护等,旨在更敏捷优雅处理数据。

1、主要功能

  • 字典绑定
  • 字段加密
  • 数据脱敏
  • 表结构动态维护
  • 数据审计记录
  • 数据范围(数据权限)
  • 数据库分库分表、动态据源、读写分离、数据库健康检查自动切换。

2、使用

2.1 依赖导入

Spring Boot 引入自动依赖注解包

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<dependency>
  <groupId>com.baomidou</groupId>
  <artifactId>mybatis-mate-starter</artifactId>
  <version>1.0.8</version>
</dependency>

注解(实体分包使用)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<dependency>
  <groupId>com.baomidou</groupId>
  <artifactId>mybatis-mate-annotation</artifactId>
  <version>1.0.8</version>
</dependency>
2.2 字段数据绑定(字典回写)

例如 user_sex 类型 sex 字典结果映射到 sexText 属性

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@FieldDict(type = "user_sex", target = "sexText")
private Integer sex;

private String sexText;

实现 IDataDict 接口提供字典数据源,注入到 Spring 容器即可。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Component
public class DataDict implements IDataDict {

    /**
     * 从数据库或缓存中获取
     */
    private Map<String, String> SEX_MAP = new ConcurrentHashMap<String, String>() {{
        put("0", "女");
        put("1", "男");
    }};

    @Override
    public String getNameByCode(FieldDict fieldDict, String code) {
        System.err.println("字段类型:" + fieldDict.type() + ",编码:" + code);
        return SEX_MAP.get(code);
    }
}
2.3 字段加密

属性 @FieldEncrypt 注解即可加密存储,会自动解密查询结果,支持全局配置加密密钥算法,及注解密钥算法,可以实现 IEncryptor 注入自定义算法。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@FieldEncrypt(algorithm = Algorithm.PBEWithMD5AndDES)
private String password;
2.4 字段脱敏

属性 @FieldSensitive 注解即可自动按照预设策略对源数据进行脱敏处理,默认 SensitiveType 内置 9 种常用脱敏策略。

例如:中文名、银行卡账号、手机号码等 脱敏策略。

也可以自定义策略如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@FieldSensitive(type = "testStrategy")
private String username;

@FieldSensitive(type = SensitiveType.mobile)
private String mobile;

自定义脱敏策略 testStrategy 添加到默认策略中注入 Spring 容器即可。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Configuration
public class SensitiveStrategyConfig {

    /**
     * 注入脱敏策略
     */
    @Bean
    public ISensitiveStrategy sensitiveStrategy() {
        // 自定义 testStrategy 类型脱敏处理
        return new SensitiveStrategy().addStrategy("testStrategy", t -> t + "***test***");
    }
}

例如文章敏感词过滤

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/**
 * 演示文章敏感词过滤
 */
@RestController
public class ArticleController {
    @Autowired
    private SensitiveWordsMapper sensitiveWordsMapper;

    // 测试访问下面地址观察请求地址、界面返回数据及控制台( 普通参数 )
    // 无敏感词 http://localhost:8080/info?content=tom&see=1&age=18
    // 英文敏感词 http://localhost:8080/info?content=my%20content%20is%20tomcat&see=1&age=18
    // 汉字敏感词 http://localhost:8080/info?content=%E7%8E%8B%E5%AE%89%E7%9F%B3%E5%94%90%E5%AE%8B%E5%85%AB%E5%A4%A7%E5%AE%B6&see=1
    // 多个敏感词 http://localhost:8080/info?content=%E7%8E%8B%E5%AE%89%E7%9F%B3%E6%9C%89%E4%B8%80%E5%8F%AA%E7%8C%ABtomcat%E6%B1%A4%E5%A7%86%E5%87%AF%E7%89%B9&see=1&size=6
    // 插入一个字变成非敏感词 http://localhost:8080/info?content=%E7%8E%8B%E7%8C%AB%E5%AE%89%E7%9F%B3%E6%9C%89%E4%B8%80%E5%8F%AA%E7%8C%ABtomcat%E6%B1%A4%E5%A7%86%E5%87%AF%E7%89%B9&see=1&size=6
    @GetMapping("/info")
    public String info(Article article) throws Exception {
        return ParamsConfig.toJson(article);
    }


    // 添加一个敏感词然后再去观察是否生效 http://localhost:8080/add
    // 观察【猫】这个词被过滤了 http://localhost:8080/info?content=%E7%8E%8B%E5%AE%89%E7%9F%B3%E6%9C%89%E4%B8%80%E5%8F%AA%E7%8C%ABtomcat%E6%B1%A4%E5%A7%86%E5%87%AF%E7%89%B9&see=1&size=6
    // 嵌套敏感词处理 http://localhost:8080/info?content=%E7%8E%8B%E7%8C%AB%E5%AE%89%E7%9F%B3%E6%9C%89%E4%B8%80%E5%8F%AA%E7%8C%ABtomcat%E6%B1%A4%E5%A7%86%E5%87%AF%E7%89%B9&see=1&size=6
    // 多层嵌套敏感词 http://localhost:8080/info?content=%E7%8E%8B%E7%8E%8B%E7%8C%AB%E5%AE%89%E7%9F%B3%E5%AE%89%E7%9F%B3%E6%9C%89%E4%B8%80%E5%8F%AA%E7%8C%ABtomcat%E6%B1%A4%E5%A7%86%E5%87%AF%E7%89%B9&see=1&size=6
    @GetMapping("/add")
    public String add() throws Exception {
        Long id = 3L;
        if (null == sensitiveWordsMapper.selectById(id)) {
            System.err.println("插入一个敏感词:" + sensitiveWordsMapper.insert(new SensitiveWords(id, "猫")));
            // 插入一个敏感词,刷新算法引擎敏感词
            SensitiveWordsProcessor.reloadSensitiveWords();
        }
        return "ok";
    }

    // 测试访问下面地址观察控制台( 请求json参数 )
    // idea 执行 resources 目录 TestJson.http 文件测试
    @PostMapping("/json")
    public String json(@RequestBody Article article) throws Exception {
        return ParamsConfig.toJson(article);
    }
}
2.5 DDL 数据结构自动维护

解决升级表结构初始化,版本发布更新 SQL 维护问题,目前支持 MySql、PostgreSQL

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Component
public class PostgresDdl implements IDdl {

    /**
     * 执行 SQL 脚本方式
     */
    @Override
    public List<String> getSqlFiles() {
        return Arrays.asList(
                // 内置包方式
                "db/tag-schema.sql",
                // 文件绝对路径方式
                "D:\\db\\tag-data.sql"
        );
    }
}

不仅仅可以固定执行,也可以动态执行!!

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ddlScript.run(new StringReader("DELETE FROM user;\n" +
                "INSERT INTO user (id, username, password, sex, email) VALUES\n" +
                "(20, 'Duo', '123456', 0, 'Duo@baomidou.com');"));

它还支持多数据源执行!!!

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Component
public class MysqlDdl implements IDdl {

    @Override
    public void sharding(Consumer<IDdl> consumer) {
        // 多数据源指定,主库初始化从库自动同步
        String group = "mysql";
        ShardingGroupProperty sgp = ShardingKey.getDbGroupProperty(group);
        if (null != sgp) {
            // 主库
            sgp.getMasterKeys().forEach(key -> {
                ShardingKey.change(group + key);
                consumer.accept(this);
            });
            // 从库
            sgp.getSlaveKeys().forEach(key -> {
                ShardingKey.change(group + key);
                consumer.accept(this);
            });
        }
    }

    /**
     * 执行 SQL 脚本方式
     */
    @Override
    public List<String> getSqlFiles() {
        return Arrays.asList("db/user-mysql.sql");
    }
}
2.6 动态多数据源主从自由切换

@Sharding 注解使数据源不限制随意使用切换,你可以在 mapper 层添加注解,按需求指哪打哪!!

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Mapper
@Sharding("mysql")
public interface UserMapper extends BaseMapper<User> {

    @Sharding("postgres")
    Long selectByUsername(String username);
}

你也可以自定义策略统一调兵遣将

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Component
public class MyShardingStrategy extends RandomShardingStrategy {

    /**
     * 决定切换数据源 key {@link ShardingDatasource}
     *
     * @param group          动态数据库组
     * @param invocation     {@link Invocation}
     * @param sqlCommandType {@link SqlCommandType}
     */
    @Override
    public void determineDatasourceKey(String group, Invocation invocation, SqlCommandType sqlCommandType) {
        // 数据源组 group 自定义选择即可, keys 为数据源组内主从多节点,可随机选择或者自己控制
        this.changeDatabaseKey(group, sqlCommandType, keys -> chooseKey(keys, invocation));
    }
}

可以开启主从策略,当然也是可以开启健康检查!!!

具体配置:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mybatis-mate:
  sharding:
    health: true # 健康检测
    primary: mysql # 默认选择数据源
    datasource:
      mysql: # 数据库组
        - key: node1
          ...
        - key: node2
          cluster: slave # 从库读写分离时候负责 sql 查询操作,主库 master 默认可以不写
          ...
      postgres:
        - key: node1 # 数据节点
          ...
2.7 分布式事务日志打印

部分配置如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/**
 * <p>
 * 性能分析拦截器,用于输出每条 SQL 语句及其执行时间
 * </p>
 */
@Slf4j
@Component
@Intercepts({@Signature(type = StatementHandler.class, method = "query", args = {Statement.class, ResultHandler.class}),
        @Signature(type = StatementHandler.class, method = "update", args = {Statement.class}),
        @Signature(type = StatementHandler.class, method = "batch", args = {Statement.class})})
public class PerformanceInterceptor implements Interceptor {
    /**
     * SQL 执行最大时长,超过自动停止运行,有助于发现问题。
     */
    private long maxTime = 0;
    /**
     * SQL 是否格式化
     */
    private boolean format = false;
    /**
     * 是否写入日志文件<br>
     * true 写入日志文件,不阻断程序执行!<br>
     * 超过设定的最大执行时长异常提示!
     */
    private boolean writeInLog = false;

    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        Statement statement;
        Object firstArg = invocation.getArgs()[0];
        if (Proxy.isProxyClass(firstArg.getClass())) {
            statement = (Statement) SystemMetaObject.forObject(firstArg).getValue("h.statement");
        } else {
            statement = (Statement) firstArg;
        }
        MetaObject stmtMetaObj = SystemMetaObject.forObject(statement);
        try {
            statement = (Statement) stmtMetaObj.getValue("stmt.statement");
        } catch (Exception e) {
            // do nothing
        }
        if (stmtMetaObj.hasGetter("delegate")) {//Hikari
            try {
                statement = (Statement) stmtMetaObj.getValue("delegate");
            } catch (Exception e) {

            }
        }

        String originalSql = null;
        if (originalSql == null) {
            originalSql = statement.toString();
        }
        originalSql = originalSql.replaceAll("[\\s]+", " ");
        int index = indexOfSqlStart(originalSql);
        if (index > 0) {
            originalSql = originalSql.substring(index);
        }

        // 计算执行 SQL 耗时
        long start = SystemClock.now();
        Object result = invocation.proceed();
        long timing = SystemClock.now() - start;

        // 格式化 SQL 打印执行结果
        Object target = PluginUtils.realTarget(invocation.getTarget());
        MetaObject metaObject = SystemMetaObject.forObject(target);
        MappedStatement ms = (MappedStatement) metaObject.getValue("delegate.mappedStatement");
        StringBuilder formatSql = new StringBuilder();
        formatSql.append(" Time:").append(timing);
        formatSql.append(" ms - ID:").append(ms.getId());
        formatSql.append("\n Execute SQL:").append(sqlFormat(originalSql, format)).append("\n");
        if (this.isWriteInLog()) {
            if (this.getMaxTime() >= 1 && timing > this.getMaxTime()) {
                log.error(formatSql.toString());
            } else {
                log.debug(formatSql.toString());
            }
        } else {
            System.err.println(formatSql);
            if (this.getMaxTime() >= 1 && timing > this.getMaxTime()) {
                throw new RuntimeException(" The SQL execution time is too large, please optimize ! ");
            }
        }
        return result;
    }

    @Override
    public Object plugin(Object target) {
        if (target instanceof StatementHandler) {
            return Plugin.wrap(target, this);
        }
        return target;
    }

    @Override
    public void setProperties(Properties prop) {
        String maxTime = prop.getProperty("maxTime");
        String format = prop.getProperty("format");
        if (StringUtils.isNotEmpty(maxTime)) {
            this.maxTime = Long.parseLong(maxTime);
        }
        if (StringUtils.isNotEmpty(format)) {
            this.format = Boolean.valueOf(format);
        }
    }

    public long getMaxTime() {
        return maxTime;
    }

    public PerformanceInterceptor setMaxTime(long maxTime) {
        this.maxTime = maxTime;
        return this;
    }

    public boolean isFormat() {
        return format;
    }

    public PerformanceInterceptor setFormat(boolean format) {
        this.format = format;
        return this;
    }

    public boolean isWriteInLog() {
        return writeInLog;
    }

    public PerformanceInterceptor setWriteInLog(boolean writeInLog) {
        this.writeInLog = writeInLog;
        return this;
    }

    public Method getMethodRegular(Class<?> clazz, String methodName) {
        if (Object.class.equals(clazz)) {
            return null;
        }
        for (Method method : clazz.getDeclaredMethods()) {
            if (method.getName().equals(methodName)) {
                return method;
            }
        }
        return getMethodRegular(clazz.getSuperclass(), methodName);
    }

    /**
     * 获取sql语句开头部分
     *
     * @param sql
     * @return
     */
    private int indexOfSqlStart(String sql) {
        String upperCaseSql = sql.toUpperCase();
        Set<Integer> set = new HashSet<>();
        set.add(upperCaseSql.indexOf("SELECT "));
        set.add(upperCaseSql.indexOf("UPDATE "));
        set.add(upperCaseSql.indexOf("INSERT "));
        set.add(upperCaseSql.indexOf("DELETE "));
        set.remove(-1);
        if (CollectionUtils.isEmpty(set)) {
            return -1;
        }
        List<Integer> list = new ArrayList<>(set);
        Collections.sort(list, Integer::compareTo);
        return list.get(0);
    }

    private final static SqlFormatter sqlFormatter = new SqlFormatter();

    /**
     * 格式sql
     *
     * @param boundSql
     * @param format
     * @return
     */
    public static String sqlFormat(String boundSql, boolean format) {
        if (format) {
            try {
                return sqlFormatter.format(boundSql);
            } catch (Exception ignored) {
            }
        }
        return boundSql;
    }
}

使用:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@RestController
@AllArgsConstructor
public class TestController {
    private BuyService buyService;

    // 数据库 test 表 t_order 在事务一致情况无法插入数据,能够插入说明多数据源事务无效
    // 测试访问 http://localhost:8080/test
    // 制造事务回滚 http://localhost:8080/test?error=true 也可通过修改表结构制造错误
    // 注释 ShardingConfig 注入 dataSourceProvider 可测试事务无效情况
    @GetMapping("/test")
    public String test(Boolean error) {
        return buyService.buy(null != error && error);
    }
}
2.8 数据权限

mapper 层添加注解:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 测试 test 类型数据权限范围,混合分页模式
@DataScope(type = "test", value = {
        // 关联表 user 别名 u 指定部门字段权限
        @DataColumn(alias = "u", name = "department_id"),
        // 关联表 user 别名 u 指定手机号字段(自己判断处理)
        @DataColumn(alias = "u", name = "mobile")
})
@Select("select u.* from user u")
List<User> selectTestList(IPage<User> page, Long id, @Param("name") String username);

模拟业务处理逻辑:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Bean
public IDataScopeProvider dataScopeProvider() {
    return new AbstractDataScopeProvider() {
        @Override
        protected void setWhere(PlainSelect plainSelect, Object[] args, DataScopeProperty dataScopeProperty) {
            // args 中包含 mapper 方法的请求参数,需要使用可以自行获取
            /*
                // 测试数据权限,最终执行 SQL 语句
                SELECT u.* FROM user u WHERE (u.department_id IN ('1', '2', '3', '5'))
                AND u.mobile LIKE '%1533%'
             */
            if ("test".equals(dataScopeProperty.getType())) {
                // 业务 test 类型
                List<DataColumnProperty> dataColumns = dataScopeProperty.getColumns();
                for (DataColumnProperty dataColumn : dataColumns) {
                    if ("department_id".equals(dataColumn.getName())) {
                        // 追加部门字段 IN 条件,也可以是 SQL 语句
                        Set<String> deptIds = new HashSet<>();
                        deptIds.add("1");
                        deptIds.add("2");
                        deptIds.add("3");
                        deptIds.add("5");
                        ItemsList itemsList = new ExpressionList(deptIds.stream().map(StringValue::new).collect(Collectors.toList()));
                        InExpression inExpression = new InExpression(new Column(dataColumn.getAliasDotName()), itemsList);
                        if (null == plainSelect.getWhere()) {
                            // 不存在 where 条件
                            plainSelect.setWhere(new Parenthesis(inExpression));
                        } else {
                            // 存在 where 条件 and 处理
                            plainSelect.setWhere(new AndExpression(plainSelect.getWhere(), inExpression));
                        }
                    } else if ("mobile".equals(dataColumn.getName())) {
                        // 支持一个自定义条件
                        LikeExpression likeExpression = new LikeExpression();
                        likeExpression.setLeftExpression(new Column(dataColumn.getAliasDotName()));
                        likeExpression.setRightExpression(new StringValue("%1533%"));
                        plainSelect.setWhere(new AndExpression(plainSelect.getWhere(), likeExpression));
                    }
                }
            }
        }
    };
}

最终执行 SQL 输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SELECT u.* FROM user u 
  WHERE (u.department_id IN ('1', '2', '3', '5')) 
  AND u.mobile LIKE '%1533%' LIMIT 1, 10

目前仅有付费版本,了解更多 mybatis-mate 使用示例详见:

https://gitee.com/baomidou/mybatis-mate-examples

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-11-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序员的成长之路 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
elasticsearch v9.0.2全新发布!深度解析最新功能、修复与性能提升,打造高效搜索新体验
引言 随着大数据和人工智能技术不断发展,企业对搜索引擎的性能和智能化需求日益增长。elasticsearch作为领先的分布式搜索和分析引擎,持续升级优化以满足用户多变的需求。2025年最新发布的elasticsearch v9.0.2版本,带来了关键的功能增强、Bug修复及安全加固,极大提升了整体系统的可靠性和搜索效率。本文将为您深入解读此版本的重点改进和实际应用价值,助力您充分发挥elasticsearch的强大潜力。
福大大架构师每日一题
2025/06/11
4360
elasticsearch v9.0.2全新发布!深度解析最新功能、修复与性能提升,打造高效搜索新体验
elasticsearch v9.0.0重磅发布!解锁最新核心特性与性能飞跃,安全升级焕新体验!
时隔 3 年,Elasticsearch 迎来重大版本更新!基于 Lucene 10.1.0 构建,9.0.0 版本在 AI 搜索、安全分析、向量计算、集群管理 等多个领域实现突破性升级
福大大架构师每日一题
2025/04/22
9850
elasticsearch v9.0.0重磅发布!解锁最新核心特性与性能飞跃,安全升级焕新体验!
Elasticsearch 8.17.4 发布:修复解析异常、资源泄漏等关键Bug!
Elasticsearch 团队近日发布了 8.17.4 版本,虽然是小版本迭代,但修复了多个关键问题,涉及查询解析、索引管理、线程池优化、机器学习模型兼容性等核心功能。如果你正在使用 8.17.x 系列,强烈建议尽快升级,避免潜在风险!
福大大架构师每日一题
2025/03/27
1730
Elasticsearch 8.17.4 发布:修复解析异常、资源泄漏等关键Bug!
milvus v2.5.9 重磅发布!JSON性能翻倍、索引能力升级,十大核心优化助力AI应用再提速!​
Milvus v2.5.9 作为 2.5 系列的又一关键补丁版本,聚焦 JSON处理性能、索引兼容性 和 系统稳定性 三大方向,带来10+项核心改进与20+项关键Bug修复,为开发者提供更高效、更可靠的向量数据库体验!
福大大架构师每日一题
2025/04/13
2070
milvus v2.5.9 重磅发布!JSON性能翻倍、索引能力升级,十大核心优化助力AI应用再提速!​
elasticsearch实战应用理论实践!2W字带你全部了解elasticsearch
Elasticsearch,这一基于Lucene构建的开源搜索引擎,以其强大的全文搜索和实时分析能力,在数据处理领域中独树一帜。作为一款分布式搜索和分析引擎,它不仅能应对大规模的数据集,还提供了灵活且可扩展的解决方案,以满足现代数据处理的各种需求。
小白的大数据之旅
2024/11/20
3810
elasticsearch实战应用理论实践!2W字带你全部了解elasticsearch
深度解读transformers v4.52.4:关键功能升级与实用修复,全方位助力模型开发与优化
作为自然语言处理领域最火热的开源框架之一,Transformers持续为开发者和研究者带来功能丰富且性能优异的模型实现。继前版本更新后,Transformers再次发布了v4.52.4补丁版本,涵盖多项细节修复与功能优化,为视觉语言模型、视频处理及模型兼容性等领域注入新活力。
福大大架构师每日一题
2025/06/09
2070
深度解读transformers v4.52.4:关键功能升级与实用修复,全方位助力模型开发与优化
基于Elasticsearch的可观测系统,这样构建更高效更稳定!
在云原生时代,传统的监控系统由于缺乏对微服务之间的串联分析能力,逐渐被可观测系统取代。
博文视点Broadview
2023/09/21
2790
基于Elasticsearch的可观测系统,这样构建更高效更稳定!
陈曦:性能与稳定并存 Elasticsearch调优实践
我今天分享的是Elassticsearch调优实践,首先自我介绍一下,我资历比较浅,我是腾讯TEG基础架构部后台开发工程师,虽然我不是项目经理,但是我们项目负责人就在下面,我还是很有压力的。
腾讯云开发者社区技术沙龙
2018/10/31
1.4K0
openai-go v1.2.1全新发布|关键接口修复与开发优化,助力Go语言AI项目全面升级!
2025年6月3日,备受期待的openai-go客户端正式发布v1.2.1版本。本次更新虽以“点滴修复”形式出现,但其背后的影响却不可小觑,尤其是针对人工智能开发者和Go语言生态的深度优化,将为开源社区和企业级用户带来显著便利。本文将为你带来openai-go v1.2.1版本的详细解读,围绕bug修复、代码质量提升和开发流程优化三个维度,深入剖析此次升级的价值,以及如何通过这些改进打造性能更优、体验更佳的智能应用。
福大大架构师每日一题
2025/06/06
940
openai-go v1.2.1全新发布|关键接口修复与开发优化,助力Go语言AI项目全面升级!
Elasticsearch 8.X 最新学习路线图——一图在手,进阶跟我走!
在大数据时代,Elasticsearch 作为一款强大的搜索和分析引擎,被广泛应用于各种场景。无论是实时日志分析、全文搜索还是复杂数据的实时处理,Elasticsearch 都能胜任。
铭毅天下
2024/05/28
1.9K0
Elasticsearch 8.X 最新学习路线图——一图在手,进阶跟我走!
weaviate v1.31.0发布,全新命名向量兼容、MUVERA编码、HNSW快照、BM25逻辑升级,助力智能搜索进入新时代
向量数据库 Weaviate 自 1.0 版本问世以来,一直以「性能极致」「模块生态」「开箱即用」著称。2025 年 5 月 30 日,官方正式放出了 v1.31.0。相比上一版,这一次没有“破坏性变更”,却带来了超过 200 个功能点、性能优化与问题修复。本文为你提炼关键亮点,并对重要特性进行深度解读,帮助开发者、架构师、数据科学家第一时间吃透升级价值。
福大大架构师每日一题
2025/06/06
2540
weaviate v1.31.0发布,全新命名向量兼容、MUVERA编码、HNSW快照、BM25逻辑升级,助力智能搜索进入新时代
weaviate v1.30.1重磅发布!BlockMax空过滤器搜索修复,性能优化+多维度升级全解析
开源向量数据库Weaviate迎来v1.30.1版本更新!本次更新聚焦BlockMax搜索稳定性修复、性能优化和安全增强,覆盖搜索、存储、权限管理等核心场景。无论是开发者还是企业用户,这些改进都将直接提升生产环境效率与可靠性。
福大大架构师每日一题
2025/04/22
1560
weaviate v1.30.1重磅发布!BlockMax空过滤器搜索修复,性能优化+多维度升级全解析
深度解析ElasticSearch:构建高效搜索与分析的基石
在数据爆炸的时代,如何快速、准确地从海量数据中检索出有价值的信息成为了企业面临的重要挑战。ElasticSearch,作为一款基于Lucene的开源分布式搜索和分析引擎,凭借其强大的实时搜索、分析和扩展能力,成为了众多企业的首选。本文将深入解析ElasticSearch的核心原理、架构设计及优化实践,帮助读者全面理解这一强大的工具。
小马哥学JAVA
2024/09/19
5340
redis 8.0.1重磅来袭!服务器性能大提升,资源优化与多项关键 BUG 修复详解
在现代互联网架构中,Redis作为高性能的开源内存数据结构存储系统,广泛应用于缓存、消息队列、实时分析等场景,已经成为众多企业技术栈的重要组成部分。随着业务规模和性能需求的日益提升,Redis不断推陈出新,持续改进性能,提升稳定性。
福大大架构师每日一题
2025/05/15
2600
redis 8.0.1重磅来袭!服务器性能大提升,资源优化与多项关键 BUG 修复详解
chroma 1.0.8全新上线!超强功能迭代与重大Bug修复,打造最稳定高效向量数据库体验!
在人工智能和大数据技术迅猛发展的时代背景下,向量数据库已经成为支撑智能搜索、推荐系统和自然语言处理等多项关键应用的核心基础设施。作为开源且灵活强大的向量数据库项目,Chroma一直备受业界关注。2025年5月5日,Chroma团队发布了最新版本——Chroma 1.0.8,这不仅是一次简单的版本更新,更是功能完善与性能优化的重要里程碑。
福大大架构师每日一题
2025/05/09
1960
chroma 1.0.8全新上线!超强功能迭代与重大Bug修复,打造最稳定高效向量数据库体验!
Elasticsearch7.14版本集群架构升级之冷热集群
具备主节点角色,拥有控制集群的权限。当节点被授予该角色时,则表明该节点有资格被选举为主节点。
空洞的盒子
2024/07/24
4131
milvus v2.5.12震撼发布!全新JSON索引支持再升级,安全与性能双重保障!
随着数据智能化应用的不断深入,向量数据库在大规模、高性能数据管理领域的重要性日益凸显。作为业界领先的开源向量数据库,Milvus始终致力于为开发者和企业提供强大、稳定且高效的向量数据管理解决方案。近日,Milvus官方重磅发布了全新版本——Milvus v2.5.12,带来丰富的新特性、关键的功能改进以及大量的稳定性和安全性修复,助力用户打造更加智慧、高效的应用系统。
福大大架构师每日一题
2025/06/06
1600
milvus v2.5.12震撼发布!全新JSON索引支持再升级,安全与性能双重保障!
滴滴 Elasticsearch 多集群架构实践
Elasticsearch 是基于 Lucene 实现的分布式搜索引擎,提供了海量数据实时检索和分析能力。Elastic 公司开源的一系列产品组成的 Elastic Stack,可以为日志服务、搜索引擎、系统监控等提供简单、易用的解决方案。
良月柒
2019/03/20
1.7K0
滴滴 Elasticsearch 多集群架构实践
重磅!Elasticsearch 8 正式发布!
点击上方蓝色字体,选择“设为星标” 回复”学习资料“获取学习宝典 文 | Travis 出品 | OSC开源社区(ID:oschina2013)Elasticsearch 是一个基于 Lucene 库的搜索引擎。它提供了一个分布式、支持多租户的全文搜索引擎,具有 HTTP Web 接口和无模式 JSON 文档。Elasticsearch 是用 Java 开发的,并在 Apache 许可证下作为开源软件发布。官方客户端在 Java、.NET(C#)、PHP、Python、Apache Groovy、Rub
猿天地
2022/03/04
1.3K0
mcp-go v0.31.0 发布!全新功能与关键修复,引领高效开发新时代!
随着云计算和微服务架构的不断普及,开发者对底层通信与服务调用工具的要求日益提升。作为现代服务治理的利器,mcp-go凭借其高性能、易用性和高度扩展性,深受开发者社区的喜爱。2025年5月30日,mcp-go迎来了v0.31.0版本的重磅更新。本次版本不仅带来了重要的新功能,还解决了多个关键的技术难题,极大地提升了框架的稳定性和灵活性。
福大大架构师每日一题
2025/06/06
830
mcp-go v0.31.0 发布!全新功能与关键修复,引领高效开发新时代!
推荐阅读
elasticsearch v9.0.2全新发布!深度解析最新功能、修复与性能提升,打造高效搜索新体验
4360
elasticsearch v9.0.0重磅发布!解锁最新核心特性与性能飞跃,安全升级焕新体验!
9850
Elasticsearch 8.17.4 发布:修复解析异常、资源泄漏等关键Bug!
1730
milvus v2.5.9 重磅发布!JSON性能翻倍、索引能力升级,十大核心优化助力AI应用再提速!​
2070
elasticsearch实战应用理论实践!2W字带你全部了解elasticsearch
3810
深度解读transformers v4.52.4:关键功能升级与实用修复,全方位助力模型开发与优化
2070
基于Elasticsearch的可观测系统,这样构建更高效更稳定!
2790
陈曦:性能与稳定并存 Elasticsearch调优实践
1.4K0
openai-go v1.2.1全新发布|关键接口修复与开发优化,助力Go语言AI项目全面升级!
940
Elasticsearch 8.X 最新学习路线图——一图在手,进阶跟我走!
1.9K0
weaviate v1.31.0发布,全新命名向量兼容、MUVERA编码、HNSW快照、BM25逻辑升级,助力智能搜索进入新时代
2540
weaviate v1.30.1重磅发布!BlockMax空过滤器搜索修复,性能优化+多维度升级全解析
1560
深度解析ElasticSearch:构建高效搜索与分析的基石
5340
redis 8.0.1重磅来袭!服务器性能大提升,资源优化与多项关键 BUG 修复详解
2600
chroma 1.0.8全新上线!超强功能迭代与重大Bug修复,打造最稳定高效向量数据库体验!
1960
Elasticsearch7.14版本集群架构升级之冷热集群
4131
milvus v2.5.12震撼发布!全新JSON索引支持再升级,安全与性能双重保障!
1600
滴滴 Elasticsearch 多集群架构实践
1.7K0
重磅!Elasticsearch 8 正式发布!
1.3K0
mcp-go v0.31.0 发布!全新功能与关键修复,引领高效开发新时代!
830
相关推荐
elasticsearch v9.0.2全新发布!深度解析最新功能、修复与性能提升,打造高效搜索新体验
更多 >
交个朋友
加入腾讯云官网粉丝站
蹲全网底价单品 享第一手活动信息
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验