在centos7中安装redis,并通过node.js操作redis

1,610 阅读2分钟

1、cent OS7 下使用redis

  • 关闭防火墙
	systemctl stop firewalld.service #停止firewall
	systemctl disable firewalld.service #禁止firewall开机启动
    firewall-cmd --state #查看默认防火墙状态(关闭后显示notrunning,开启后显示running)
  • 配置编译环境:
    sudo yum install gcc-c++
  • 下载源码:
    wget http://download.redis.io/releases/redis-4.0.11.tar.gz
  • 解压源码:
tar -zxvf redis-4.0.11.tar.gz
  • 进入到解压目录:
cd redis-4.0.11
  • 进入到解压目录: 执行make编译Redis:
make MALLOC=libc

注意:

make命令执行完成编译后,会在src目录下生成6个可执行文件,分别是

  1. redis-server、
  2. redis-cli、
  3. redis-benchmark、
  4. redis-check-aof、
  5. redis-check-rdb、
  6. redis-sentinel
  • 安装Redis:
make install 
  • 配置Redis能随系统启动:
./utils/install_server.sh

显示结果信息如下:

Welcome to the redis service installer
This script will help you easily set up a running redis server

redis 配置

  • 关闭保护模式
    config set protected-mode no
  • 设置密码
    // 获取密码
    config get requirepass
    
    // 设置密码 
    config set requirepass yourpassword

2、nodejs中操作redis

安装redis

npm install redis --save
//引入redis
var redis = require('redis')
// 连接redis服务器
// 连接redis数据库,createClient(port,host,options);
// 如果REDIS在本机,端口又是默认,直接写createClient()即可
client = redis.createClient(6379, '192.168.73.128', {
    password: 'lentoo'
});

//错误监听?
client.on("error", function (err) {
    console.log(err);
});

2.1常用API

  • redis.print

通过redis回显

  • set 像redis中存入一个键值对

client.set('key','value')
// 设置过期时间 10s后过期
client.set('key','value','EX',10)
  • get 获取在redis中存入的值

client.get('key') // value
  • hset 通过hash key 存值

client.hset('hash key','key','value', redis.print)
  • hget 通过hash key 获取值

client.hget('hash key','key', redis.print)
  • hkeys 所有的"hash key"

// 遍历哈希表"hash key"
client.hkeys("hash key", function (err, replies) {
    console.log(replies.length + " replies:");
    replies.forEach(function (reply, i) {
        console.log("    " + i + ": " + reply);
    });
    client.quit();
});
  • hmset

client.hmset('hash 1', 'key', 'value111', 'key2', 'value222', 'key3', 'value3', redis.print)
  • hmget

client.hmget('hash 1', 'key', 'key2', 'key3', redis.print)
  • publish/subscribe 发布/订阅

const sub = redis.createClient() // 订阅者
const pub = redis.createClient() // 发布者
var msg_count = 0;

sub.on("subscribe", function (channel, count) {
    client.publish("a nice channel", "I am sending a message.");
    client.publish("a nice channel", "I am sending a second message.");
    client.publish("a nice channel", "I am sending my last message.");
});

sub.on("message", function (channel, message) {
    console.log("sub channel " + channel + ": " + message);
    msg_count += 1;
    if (msg_count === 3) {
        sub.unsubscribe();
        sub.quit();
        client.quit();
    }
});

  • ready

redis客户端连接准备好后触发,在此前所有发送给redis服务器的命令会以队列的形式进行排队,会在ready事件触发后发送给redis服务器

client.on('ready',function(){
    console.log('ready');
})
  • connct 客户端在连接到服务器后触发

client.on('connect',function(){
    console.log('connect');
})
  • reconnecting 客户端在连接断开后重新连接服务器时触发

client.on('reconnecting ', function (resc) {
    console.log('reconnecting',resc);
})
  • error 错误监听

client.on("error", function (err) { console.log(err); });

  • end 连接断开时触发

client.on('end',function(){ console.log('end')
})

  • createClient

redis.createClient([options])
redis.createClient(unix_socket[, options])
redis.createClient(redis_url[, options])
redis.createClient(port[, host][, options])
options object properties
属性 默认值 描述
host  127.0.0.1 redis服务器地址
port 6379 端口号
connect_timeout 3600000 连接超时时间 以ms为单位
password null 密码

公众号

欢迎关注我的公众号“码上开发”,每天分享最新技术资讯。关注获取最新资源