V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
JimmyChan1506
V2EX  ›  Redis

怎么使用命令批量删除匹配的 key 值?

  •  
  •   JimmyChan1506 · 288 天前 · 1433 次点击
    这是一个创建于 288 天前的主题,其中的信息可能已经有所发展或是发生改变。

    使用下面的命令可以查到一堆 key

    redis-cli -a myPassword -h redis-host -p 6379 --scan --pattern '*myKey*' 
    

    但使用下面的命令,却无法删除成功

    redis-cli -a myPassword -h redis-host -p 6379 --scan --pattern '*myKey*' | xargs redis-cli -a myPassword -h redis-host -p 6379 unlink 
    (integer) 0
    

    当然了, 把 unlink 改成 del 也是一样的效果, 不知道大家有没有解决过一样的问题?

    20 条回复    2023-07-17 08:39:39 +08:00
    Azone
        1
    Azone  
       288 天前
    xargs 是不是少个 -n 1 的参数
    JimmyChan1506
        2
    JimmyChan1506  
    OP
       288 天前
    @Azone 加了试了一下还是没有能成功删除
    Red998
        3
    Red998  
       288 天前
    用 lua 脚本删除呗 、数据不多 就直接 del
    Red998
        4
    Red998  
       288 天前
    unlink 可不一样 虽然是卸载了查询不到 但是 redis 还没有真正释放内存、有定时任务会清理。del 就是直接释放内存空间。但是如果大 key 删除就会阻塞其他命令
    aaronkk
        5
    aaronkk  
       287 天前
    据量大的话要避免阻塞,用 unlink 异步删除比 del 更安全
    8355
        6
    8355  
       287 天前
    用 lua 脚本
    local keys = redis.call('KEYS', 'aaa*')
    for i, key in ipairs(keys) do
    redis.call('UNLINK', key)
    end
    8355
        7
    8355  
       287 天前
    @Red998 #4 说的对,类似大 hash 和 list 的话这种还是建议 unlink 删
    JimmyChan1506
        8
    JimmyChan1506  
    OP
       287 天前
    @Red998 主要是想知道这种命令应该怎么写, 删 key 倒不是目的了
    aaronkk
        9
    aaronkk  
       287 天前
    集群,带上-c 参数试试
    JimmyChan1506
        10
    JimmyChan1506  
    OP
       287 天前
    @aaronkk 加了, 没用
    JimmyChan1506
        11
    JimmyChan1506  
    OP
       287 天前
    @Azone 加了-t 和-n 1 参数后, 发现是把 key 按空格键对一个 key 进行多行分割了, 不明白为何加了 -n 1 之后还是会出现这种情况 .....
    JimmyChan1506
        12
    JimmyChan1506  
    OP
       287 天前
    key 是类似于 "aaa::bb{cc='a', id=null } theReqeust[id=null;no=aa;]" 这样的形式
    rrfeng
        13
    rrfeng  
       287 天前 via Android
    先看看 scan 。的输出啊,不一定是只有 key
    xargs 直接干也是够大胆…
    yangxx
        14
    yangxx  
       287 天前
    用这样的命令试下,redis-cli -h localhost --scan --pattern '*test*' |xargs -n 1 echo unlink |redis-cli -h localhost
    pubby
        15
    pubby  
       287 天前 via iPhone
    按行读取试试

    SCAN | while read k; do DEL $k; done
    dorothyREN
        16
    dorothyREN  
       287 天前
    redis-cli -a myPassword -h redis-host -p 6379 keys '*myKey*' | | xargs redis-cli -a myPassword -h redis-host -p 6379 DEL
    worldOnlyYou
        17
    worldOnlyYou  
       287 天前
    redis-cli scan 返回的 key 前面还有序号的,你这样直接删肯定不行
    JimmyChan1506
        18
    JimmyChan1506  
    OP
       286 天前
    @worldOnlyYou 那应该怎么搞呢?
    JimmyChan1506
        19
    JimmyChan1506  
    OP
       285 天前
    @worldOnlyYou 我把 xargs 前面的部分执行, 取其中一个 key 来 del, 是没有问题的
    JimmyChan1506
        20
    JimmyChan1506  
    OP
       285 天前
    @rrfeng 测试环境, 为开发方便
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   2906 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 09:00 · PVG 17:00 · LAX 02:00 · JFK 05:00
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.