Memcache密钥生成策略

2024-04-08

给定函数f1它接收 n 个字符串参数,就运行时性能而言,什么被认为更好,memcache 的随机密钥生成策略?

我们的 Memcache 客户端对其获取的密钥进行内部 md5sum 哈希处理:

   public class MemcacheClient {  
       public Object get(String key) {
            String md5 = Md5sum.md5(key)
            // Talk to memcached to get the Serialization... 
            return memcached(md5);
       }
   }

我的使用场景是:

第一个选项

    public static String f1(String s1, String s2, String s3, String s4) {
         String key = s1 +  s2 + s3 + s4;
         return get(key);
    }

第二个选择

    /**
     * Calculate hash from Strings
     *
     * @param objects vararg list of String's
     *
     * @return calculated md5sum hash
     */
    public static String stringHash(Object... strings) {
        if(strings == null) 
            throw new NullPointerException("D'oh! Can't calculate hash for null");

        MD5 md5sum = new MD5();

//      if(prevHash != null)
//          md5sum.Update(prevHash);

        for(int i = 0; i < strings.length; i++) {
            if(strings[i] != null) {
                md5sum.Update("_"); 
                md5sum.Update(strings[i].toString()); // Convert to String...
                md5sum.Update("_");

            } else {
                // If object is null, allow minimum entropy  by hashing it's position
                md5sum.Update("_");
                md5sum.Update(i);
                md5sum.Update("_");
            }
        }

        return md5sum.asHex();
    }


    public static String f1(String s1, String s2, String s3, String s4) {
         String key = stringHash(s1, s2, s3, s4);
         return get(key);
    }

请注意,第二个选项可能存在的问题是,我们正在对已经经过 md5sum 处理的摘要结果执行第二个 md5sum(在 memcache 客户端中)。

谢谢阅读, 格言。

- 编辑 用过的MD5实用程序源 http://www.twmacinta.com/myjava/fast_md5_javadocs/com/twmacinta/util/package-summary.html


“更好”在什么意义上?为什么您认为第二个选项“更好”?它执行更多的字符串连接、更多的 MD5 哈希,但通常看起来比第一个效率低得多......

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Memcache密钥生成策略 的相关文章

随机推荐

  • Angular DatePipe - 将秒转换为零时区的时间(12 而不是 00)

    我想使用 DatePipe 转换数字 代表秒 得到这样的结果 00 00 05 我尝试用 DatePipe 这样做
  • 读写锁。了解从readLock升级到writeLock

    考虑一下这个JDK标准接口 public interface ReadWriteLock public Lock readLock public Lock writeLock B Goetz 在 Java Concurrency inpra
  • 使用 PDO 选择多个数据库

    我有一个functions php有一个文件PDO我用来访问数据库的连接以及所有这些好东西就是这个 host localhost db maindatabase adminuser admin adminpw 123456 global c
  • 可以列出 zip / rar 文件内容的 PHP 库 [关闭]

    就目前情况而言 这个问题不太适合我们的问答形式 我们希望答案得到事实 参考资料或专业知识的支持 但这个问题可能会引发辩论 争论 民意调查或扩展讨论 如果您觉得这个问题可以改进并可能重新开放 访问帮助中心 help reopen questi
  • CMake - 找不到 Boost(缺少:序列化)(找到版本“1.73.0”

    我已经在我的项目中使用 Boost 一段时间了 但到目前为止 我只使用了仅包含头文件的库 我现在想使用序列化 但是当我尝试将序列化添加为必需组件时 我收到标题中写入的错误 这是我的 CMAKE 文件 cmake minimum requir
  • 将 pandas 数据帧保存到 csv 时如何保留 numpy 数组

    我有一个pandas DataFrame其中一列作为图像 该列的每一行都是一个二维图像numpy array 我保存了DataFrame to a csv文件与pandas DataFrame to csv 然而 当我打开csv文件中 该列
  • 每 2 秒进行一次 AJAX 后调用是不是一个坏主意?

    如果我对 php 文件进行 AJAX post 调用 使用 jQuery 来更新某个参数 数字 这是否被认为是不好的做法 危险或类似的做法 post file php var var function data something json
  • 仅获取联系人手机号码

    关于使用联系人 API 获取联系人号码有几个问题 但我想知道是否有一种方法可以识别检索到的号码是手机号码 以下代码通常显示为获取联系人电话号码的一种方式 因为它获取一个或多个电话号码的列表 String projection Contact
  • 如何将 Dto 修补到实体?

    我有一个接受 dto 对象的控制器 我需要更改 dto 对象中存在的字段 PatchMapping value update uuid public ResponseEntity
  • 更改一个对象中的值会更改另一个对象中的值

    我正在努力生成游戏树 我输入的问题是 当我将一个对象复制到新对象 然后在新对象中进行更改时 旧对象也会更改其值 所以这似乎是一个参考问题 但如何使新对象成为一个独立的实例 创建从父对象复制的子对象后 然后更改子对象中的值 父对象也会更改 并
  • 如何确保Tomcat6在Windows上读取CATALINA_OPTS?

    我有一个在 Windows2003 机器上运行的 Tomcat6 我在此服务器上部署了 2 个 Grails 应用程序 很快我就注意到部署后的某个时间一切都崩溃了 并出现了典型的 PermGen 错误 java lang OutOfMemo
  • JPA - COUNT 的最大值或从 SELECT 中选择

    我为 MySQL 编写了以下查询 SELECT subquery t1 column1 subquery t2 id MAX subquery val FROM SELECT t1 column1 as t1 column1 t1 id t
  • 如何在 C# 中使用循环迭代所有 ComboBoxes 控件?

    我在 C 的 winform 上有一些组合框 例如 10 名为 comboBox1 coboBox2 和comboBoxN 我如何在 for 循环中访问所有这些内容 如下所示 for int i 0 i lt 10 i comboBox i
  • 根据值列表重复每个元素

    是否有一个Python内置函数可以根据另一个列表中的相应值重复列表中的每个元素 例如A在列表中x由于值的原因 位置 0 重复了 2 次2位于列表中的位置 0y gt gt gt x A B C gt gt gt y 2 1 3 gt gt
  • 具有不等式条件的合并连接算法

    我读到 Oracle 支持带有不等式连接谓词的合并连接 是否有在线参考用于实现此类连接的算法 如果有人知道该怎么做 你能回答吗 This http docs oracle com cd E16655 01 server 121 e15858
  • 编写和完善 CSV 解析器

    作为最近项目的一部分 我必须从 CSV 文件中读取和写入 然后将其放入 C 中的网格视图中 最后决定使用现成的解析器来为我完成这项工作 因为我喜欢做这类事情 所以我想知道如何自己写 到目前为止 我所能做的就是 Read the header
  • 如何检测属于 gsm/3g-modem 的 tty 是数据端口还是控制端口?

    我目前正在为 Linux 路由器编写一个小工具 当我将适当的调制解调器插入其 USB 端口时 该工具会建立 wwan gsm 3g 连接 当设备插入时 会注册多个 tty 我当前维护一个制造商和设备的列表 以及它们注册的 tty 中的哪个是
  • WinForms 中如何处理不可见控件的绘制?

    我正在尝试覆盖OnPaintwindows窗体中的事件 NET 紧凑框架 到目前为止 我已经能够使用渐变 圆角矩形等来绘制控件 而这通常是常规控件无法实现的 但是 当我想让控件不可见时 我遇到了问题 现在 我所做的就是重新绘制除那些不可见控
  • 为什么在签出 git 远程分支窗口时出现“无法创建目录”?

    我在 Windows 10 64 位上使用 git 版本 2 10 2 windows 1 在 MACOS 上 我们将两个分支合并到一个现有分支中 合并后分支包含一个folder with a 末尾有空白 Jadise 我根据 Bitbuc
  • Memcache密钥生成策略

    给定函数f1它接收 n 个字符串参数 就运行时性能而言 什么被认为更好 memcache 的随机密钥生成策略 我们的 Memcache 客户端对其获取的密钥进行内部 md5sum 哈希处理 public class MemcacheClie