首頁 >web前端 >js教程 >redis在nodejs中應用實戰項目分享

redis在nodejs中應用實戰項目分享

php中世界最好的语言
php中世界最好的语言原創
2018-06-01 11:52:071518瀏覽

這次帶給大家redis在nodejs中應用實戰項目分享,redis在nodejs中應用的注意事項有哪些,下面就是實戰案例,一起來看一下。

redis是一個效能非常好的記憶體資料庫,部署在應用程式和mysql資料中間做快取資料函式庫,可以極大的提升應用程式的效能,這裡簡單介紹nodejs客戶端操作redis的demo程式

redis裡面總共可以儲存5種資料型別,分別是字串,列表、集合、三列、有序集合;這裡將對這5種資料型別的增刪查改一一處理;

1、redis在mac上的安裝:

https://redis. io/download,目前我使用的版本穩定版本是4.0.9,解壓縮之後,進入redis-4.0.9目錄,執行make && sudo make install,稍等幾分鐘就可以安裝好;

2 、redis啟動:

命令列執行redis-server即可啟動,預設連接埠是6379;

3、安裝nodejs客戶端:

建立redis-node目錄,在該目錄下yarn init -y之後,執行指令:yarn add redis 即可安裝nodejs的redis客戶端,參考文件:https://github.com/NodeRedis/node_redis

#4、在redis- node目錄下,終端機上執行node,即可在終端機上響應式的執行nodejs程式碼,用做測試,下面開始demo程式

首先要建立客戶端,並連接redis伺服器,在執行以下連接在客戶端程式碼之前,請確保已經執行了redis伺服器:終端商執行redis-server即可,預設連接埠6379;

const redis = require('redis');
const client = redis.createClient(); //默认连接localhost:6379,具体配置参数可以参考文档https://github.com/NodeRedis/node_redis

如果一切順利,我們就已經建立好了連接redis伺服器的客戶端,後續操作都是在client物件上進行。

一、字串類型

雖然說是字串類型,但可以儲存的資料包括字串、整數以及浮點數。

var res = client.set('name', 'abczhijia', (err, data) => {
 console.log('err: ', err, ' data: ', data);
}); // err: null data: OK,res的值是true
client.get('name', (err, data) => {
 console.log('err: ', err, ' data: ', data);
}); // err: null data: abczhijia

為了簡單起見,我們定義一個回呼函數,用於輸出資料:

const cb = (err, data) => {
 console.log('err: ', err, ' data: ', data, ' data type: ', typeof data);
}

下面再針對整數做一個測試:

client.set('age', 20, cb); //err: null data: OK data type: string
client.get('age', cb); //err: null data: 20 data type: string

可以看出,雖然設定的是整數,輸出來的時候,其實還是字串,所以如果要進行計算,需要自己在回呼函數裡面做轉換

二、列表資料型別

//从右侧推入
client.rpush('friends', 'mike', 'jhon', cb); //err: null data: 2 data type: number
client.lrange('friends', 0, -1, cb); //err: null data: [ 'mike', 'jhon' ] data type: object
//从左侧推入
client.lpush('friends', 'sam', 'bob', cb); //err: null data: 4 data type: number
client.lrange('friends', 0, -1, cb); // err: null data: [ 'bob', 'sam', 'mike', 'jhon' ] data type: object
//从右侧弹出
client.rpop('friends', cb); //err: null data: jhon data type: string
//从左侧弹出
client.lpop('friends', cb); //err: null data: bob data type: string
//打印看看发生了啥
client.lrange('friends', 0, -1, cb); // err: null data: [ 'sam', 'mike' ] data type: object
//查看索引位置的值
client.lindex('friends', 0, cb); // err: null data: sam data type: string
//对列表进行裁剪
client.rpush('friends', 'tom', 'bryant', cb)// err: null data: 4 data type: number
client.ltrim('friends', 1, 2, cb); //err: null data: OK data type: string
client.lrange('friends', 0, -1, cb); //err: null data: [ 'mike', 'tom' ] data type: object

這裡注意,列表的操作可以從右邊rpush推入一個或多個數據,也可以從左邊lpush推入一個或多個數據;另外,取值的時候,需要指明需要起止位置,如果要取得整個,可以把結束位置寫成-1。

三、集合資料型別

//往集合ids中加几个元素
client.sadd('ids', 1, 2, cb); //err: null data: 2 data type: number
//查看集合元素
client.smembers('ids', cb); //err: null data: [ '1', '2' ] data type: object
//从集合中删除元素
client.srem('ids', 2, cb); // err: null data: 1 data type: number
//看看发生了啥
client.smembers('ids', cb); //err: null data: [ '1' ] data type: object
//看看集合有多少个元素
client.scard('ids', cb); //err: null data: 1 data type: number
//再加几个元素进去
client.sadd('ids', 3, 5, 8, 9); //
//判断元素是否在集合内
client.sismember('ids', 8, cb); // err: null data: 1 data type: number
client.sismember('ids', 80, cb); //err: null data: 0 data type: number

四、雜湊資料型別

//往散列上添加多组键值对
client.hmset('phone', 'price', 5888, 'name', 'iphonex', cb); //err: null data: OK data type: string
//查看多个键的值
client.hmget('phone', 'price', 'name', cb); //err: null data: [ '5888', 'iphonex' ] data type: object
//查看键值对的数量
client.hlen('phone', cb); //err: null data: 2 data type: number
//删掉其中一个键值对
client.hdel('phone', 'price', cb); //err: null data: 1 data type: number
//看看price是否还在?
client.hmget('phone', 'price', cb); //err: null data: [ null ] data type: object,原来只留下了null
//再加几个属性
client.hmset('phone', 'vendor', 'apple', 'madein', 'china', cb);
//取出所有的键值对
client.hgetall('phone', cb); //err: null data: { name: 'iphonex', vendor: 'apple', madein: 'china' } data type: object
//取出所有的键
client.hkeys('phone', cb); //err: null data: [ 'name', 'vendor', 'madein' ] data type: object
//取出所有的值
client.hvals('phone', cb); //err: null data: [ 'iphonex', 'apple', 'china' ] data type: object
//判断键是否存在
client.hexists('phone', 'name', cb); //err: null data: 1 data type: number
client.hexists('phone', 'price', cb); //err: null data: 0 data type: number

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

如何使用Vue SSR 元件載入

Vue.js內部偵聽器使用案例解析

以上是redis在nodejs中應用實戰項目分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn