开启运维之路之第 7 篇——RedisDesktopManager使用、Keys通用操作、Java代码操作基本的Redis

本文主要是介绍开启运维之路之第 7 篇——RedisDesktopManager使用、Keys通用操作、Java代码操作基本的Redis,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

RedisDesktopManager下载地址:Redis桌面管理工具官方下载地址  今天(2019年11月5日)才良心发现,居然收费了!

提供一个 po 解版网盘下载地址:https://pan.baidu.com/s/1pLEMKpAHJMv8xPMbrn_iFA  提取码: aqkv

 

2021年6月11日:这里推荐一款良心的 Redis 客户端工具(用过的都说好):https://pan.baidu.com/s/1ruIATzKKWv8ypdkzzfrh5w  提取码:tijx

 

安装好,直接双击打开。

说明:我本机的 IP 由于使用公司的 IP ,经常会变动,但不影响连接 Linux 虚拟机。

现在发现个问题,无法连接到 Redis 。

解决过程:

①Redis 在默认情况下,配置文件里并没有设置登录密码,可以查看:前提是先进入 Redis 客户端,命令查看上一篇博客。

127.0.0.1:6379> config get requirepass
1) "requirepass"
2) ""

默认情况下 requirepass 参数是空的,这就意味着你无需通过密码验证就可以连接到 redis 服务。可问题是不用密码也连接不上,这不是坑爹?

不,不多踩一些坑,是不会有进步的,特别是在技术领域。一帆风顺反而引起你的恐慌。

那就设置一下登录 Redis 的密码:config set requirepass XXXXX

127.0.0.1:6379> config set requirepass 123456
OK
127.0.0.1:6379> auth 123456
OK

说明:如果遇到下面的错误:(error) ERR Client sent AUTH, but no password is set

请先进入客户端,设置如下命令:config set requirepass XXXXX,再进行授权密码XXXXX

再验证下:

还是不行。

想一下,应该是防火墙的问题。防火墙。防火墙。防火墙。

查看防火墙状态:

127.0.0.1:6379> exit
[root@localhost redis]# firewall-cmd --state
not running

结果防火墙也没开启,因为我已经设置防火墙开机不启动了。(防火墙没开启,说明 Linux 的端口都可以访问。以前听说那些网站被病毒攻击,就是因为病毒使用了某些开放的端口,让病毒有机可乘。一般是不去访问病毒网站或者关闭病毒入侵的端口号。)

OK,那就应该是配置文件的问题了。去看下。(说明:本系列博客,在玩 Redis 的时候,已经把配置文件复制出来,放在与 Redis 解压文件的同一级目录了。原生的 redis.conf 文件并没有改动。这样一来,哪怕你玩坏了复制的那份配置文件,也不会有问题,还可以使用原生的配置文件。)

[root@localhost redis]# ls
bin  dump.rdb  redis.conf

下面是查看原生 redis.conf 配置文件的命令:

[root@localhost ~]# cd /root/redis-4.0.10
[root@localhost redis-4.0.10]# ls
00-RELEASENOTES  deps       README.md        runtest-sentinel  utils
BUGS             INSTALL    redis.conf       sentinel.conf
CONTRIBUTING     Makefile   runtest          src
COPYING          MANIFESTO  runtest-cluster  tests

OK,修改一下我们默认启动时使用的配置文件:我们之前复制了一份配置文件放在 redis 的目录下。

[root@localhost redis]# ls
bin  dump.rdb  redis.conf

现在修改这份配置文件:[root@localhost redis]# vi redis.conf 

找到 bind 127.0.0.1,添加 # 注释掉。不注释掉就只有使用 Linux 机器才能登录。然后保存退出。

这时候再连接,还是会报错!因为没有重启。然后就重启 Redis 。

可以使用 shell 脚本,也可以敲打命令:

[root@localhost ~]# cd /usr/local/redis/
[root@localhost redis]# ./bin/redis-server ./redis.conf 

OK,windows客户端管理连接成功!

这时候,我们再进入 Linux 下 Redis 的客户端,ping 一下:

[root@localhost redis]# ./bin/redis-cli
127.0.0.1:6379> ping
(error) NOAUTH Authentication required.

无法 ping 通,必须使用密码。那就设置密码。

127.0.0.1:6379> auth 123456
OK
127.0.0.1:6379> ping
PONG

说明:这样设置授权密码的方式,在重启 Redis 之后,密码失效,又得重新设置。因此,我们设置到 Redis 的配置文件,下次启动就不需要重新设置密码了。

修改配置文件:通过输入 /requirepass 搜索密码设置,n 查找下一个,N查找上一个匹配的字符串。

[root@localhost redis]# vi redis.conf

然后修改密码:把注释去掉,修改 foobared 成你的密码。

保存,退出。这样,下次就不需要再重新授权密码了。不过,进入 Redis 客户端,都要通过密码登陆。

[root@localhost redis]# ./bin/redis-cli
127.0.0.1:6379> ping
(error) NOAUTH Authentication required.
127.0.0.1:6379> auth 123456
OK
127.0.0.1:6379> ping
PONG

还有一种方式,就是去掉 Redis 的自我保护,但这种方式安全性差,不推荐,只有在特殊的情况下使用,了解即可。

 

OK,回到windows的Redis管理工具

说明:Redis 默认使用 db0 这个库。里面存放着所有的数据,就是我们之前测试的。右边主要是数据的一些操作。TTL (Time To Live)的值是 -1 说明数据不会过期。我们试着在这里增加一些数据,然后去 Linux 客户端下查看:

注意,我们设置的是 hash 类型,需要根据 hash 的特性进行获取值:

OK,完美搞定!

 

Keys通用操作

①显示所有 keys ,包括 5 种数据类型:keys *

127.0.0.1:6379> keys *1) "s1"2) "myList3"3) "sr1"4) "n1"5) "h1"6) "c"7) "m"

②正则表达式: * 代表所有,? 代表一个字符

127.0.0.1:6379> keys s*
1) "s1"
2) "sr1"
3) "s2"
4) "sr2"
5) "sr3"
127.0.0.1:6379> keys s?
1) "s1"
2) "s2"

③删除 key:del key1 key2  ...

127.0.0.1:6379> del n1 c
(integer) 2

④判断 key 是否存在:1-存在,0-不存在:exists key

127.0.0.1:6379> exists n1
(integer) 0
127.0.0.1:6379> exists s1
(integer) 1

⑤对 key 重命名:rename oldName newName

127.0.0.1:6379> rename m m2
OK

⑥设置 key 的有效期:expire key time  单位:秒

127.0.0.1:6379> expire m2 120
(integer) 1

我们打开 Redis 桌面管理工具,查看 m2 的有效期

⑦查看 key 有效期:ttl key

127.0.0.1:6379> ttl m2
(integer) 4
127.0.0.1:6379> ttl m2
(integer) 1
127.0.0.1:6379> ttl m2
(integer) -2

说明:单位是秒,-1 是永久有效,-2 是已经不存在。

对不存在的 key 设置过期时间,返回 0 :

127.0.0.1:6379> expire m2 123
(integer) 0

⑧查看 key 类型:type key

127.0.0.1:6379> type s1
set
127.0.0.1:6379> type n
string

 

Java代码操作基本的Redis

①在 pom.xml 配置文件里添加下面的配置

<dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>2.9.0</version></dependency>

或者去下载一个操作 Redis 的 jar 包,地址:操作 Redis 的 jar 包下载地址

OK,编写测试Java类:

package com.test.test;import redis.clients.jedis.Jedis;public class JedisTest {public static void main(String[] args){Jedis jedis=new Jedis();}}

到这步,我们进入 Jedis 类,看下里面的构造器、实现的方法。按住 Ctrl + 鼠标左键,进入 Jedis 类。

看下常用方法:(只列举一点做引导,很多方法都是根据 Redis 客户端的方法来定义方法名的。这样可以避免方法名的转换,顾名思义,即拿即用。)

/*** Set the string value as value of the key. The string can't be longer than 1073741824 bytes (1* GB).* <p>* Time complexity: O(1)* @param key* @param value* @return Status code reply*/public String set(final String key, String value) {checkIsInMultiOrPipeline();client.set(key, value);return client.getStatusCodeReply();}/*** Get the value of the specified key. If the key does not exist null is returned. If the value* stored at key is not a string an error is returned because GET can only handle string values.* <p>* Time complexity: O(1)* @param key* @return Bulk reply*/public String get(final String key) {checkIsInMultiOrPipeline();client.sendCommand(Protocol.Command.GET, key);return client.getBulkReply();}/*** Test if the specified key exists. The command returns "1" if the key exists, otherwise "0" is* returned. Note that even keys set with an empty string as value will return "1". Time* complexity: O(1)* @param key* @return Boolean reply, true if the key exists, otherwise false*/public Boolean exists(final String key) {checkIsInMultiOrPipeline();client.exists(key);return client.getIntegerReply() == 1;}public Long del(String key) {client.del(key);return client.getIntegerReply();}public Long expire(final String key, final int seconds) {checkIsInMultiOrPipeline();client.expire(key, seconds);return client.getIntegerReply();}public Long ttl(final String key) {checkIsInMultiOrPipeline();client.ttl(key);return client.getIntegerReply();}public Long hset(final String key, final String field, final String value) {checkIsInMultiOrPipeline();client.hset(key, field, value);return client.getIntegerReply();}public String hget(final String key, final String field) {checkIsInMultiOrPipeline();client.hget(key, field);return client.getBulkReply();}

OK,我们来玩一下:

public static void main(String[] args){Jedis jedis=new Jedis("192.168.126.130",6379);jedis.set("name","Hi,girl,would you love me? 好哒");String name=jedis.get("name");System.out.println("name="+name);jedis.close();}

点击运行 main 函数:

说明了啥?需要授权密码。OK,我们设置密码:

perfect!强势搞定!不信去 Redis 桌面管理工具看看!

 

package com.test.test;import redis.clients.jedis.Jedis;import java.util.List;
import java.util.Set;public class JedisTest {public static void main(String[] args){Jedis jedis=new Jedis("192.168.126.130",6379);jedis.auth("123456");/*************** 测试 string *******************/jedis.set("name","Hi,girl,would you love me? 好哒");String name=jedis.get("name");System.out.println("name="+name);/*************** 测试 list *******************/jedis.rpush("jList","What's your "," telephone ?");List<String> list= jedis.lrange("jList",0,-1);for(String str : list){System.out.println(str);}/*************** 测试 hash *******************/jedis.hset("jHash","hometown","My hometown is 流放深圳!");String hash=jedis.hget("jHash","hometown");System.out.println(hash);/*************** 测试 set *******************/jedis.sadd("jSet","北京");jedis.sadd("jSet","上海");jedis.sadd("jSet","深圳");Set<String> set = jedis.smembers("jSet");for(String str : set) {System.out.println(str);}/*************** 测试 zset *******************/jedis.zadd("jzSet",18,"小薇");jedis.zadd("jzSet",20,"小胖");jedis.zadd("jzSet",15,"小傻");Set<String> zset=jedis.zrange("jzSet",0,-1);for(String str : zset){System.out.println(str);}jedis.close();}}

 

这篇关于开启运维之路之第 7 篇——RedisDesktopManager使用、Keys通用操作、Java代码操作基本的Redis的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/262214

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。