ホームページ > ウェブフロントエンド > jsチュートリアル > Nodejsにおけるredisの適用事例を詳しく解説

Nodejsにおけるredisの適用事例を詳しく解説

php中世界最好的语言
リリース: 2018-05-14 14:14:13
オリジナル
1876 人が閲覧しました

今回はnodejsでredisを利用する場合の注意点について詳しく解説していきます。実際の事例を見てみましょう。

redis は非常に優れたパフォーマンスを備えたインメモリ データベースであり、アプリケーションと mysql データの間の キャッシュ データ ライブラリとしてデプロイされ、アプリケーションのパフォーマンスを大幅に向上させることができます。 ここでは、そのデモ プログラムを簡単に紹介します。 Nodejs クライアントで Redis を操作する

合計 5 つの

データ型 を Redis に保存できます。これは、文字列、リスト、セット、3 つの列、および順序付きセットであり、追加、削除、チェック、および変更です。これら 5 つのデータ型は 1 つずつ処理されます。

1 . Mac への redis のインストール:

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 の後にコマンドを実行して、nodejs の redis クライアントをインストールします: https://github. com/NodeRedis/node_redis

4. redis-node ディレクトリ内 次に、ターミナル上でノードを実行します。テストのためにターミナル上で Nodejs コードを応答的に実行できます。まず、クライアントを作成して、次の接続クライアント コードを実行する前に、redis サーバーが実行されていることを確認してください。ターミナル プロバイダーは redis-server を実行できます。デフォルトのポートは 6379 です。すべてがうまくいけば、クライアントが Redis サーバーに接続し、その後の操作がクライアント オブジェクトに対して実行されます。

1.文字列型

文字列型ですが、格納できるデータは文字列、整数、浮動小数点数が含まれます。

const redis = require('redis');
const client = redis.createClient(); //默认连接localhost:6379,具体配置参数可以参考文档https://github.com/NodeRedis/node_redis
ログイン後にコピー
簡単にするために、データを出力するためのコールバック関数を定義します:

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);
}
ログイン後にコピー
設定は整数ですが、出力されると、実際にはまだ文字列なので、計算を実行したい場合は、コールバック関数で自分で変換を行う必要があります

2. リスト データ型

client.set('age', 20, cb); //err: null data: OK data type: string
client.get('age', cb); //err: null data: 20 data type: string
ログイン後にコピー
ここで、リスト操作は 1 つ以上をプッシュできることに注意してください。右側の lpush からデータをプッシュすることも、左側の lpush から 1 つ以上のデータをプッシュすることもできます。値を取得するときに、開始位置と終了位置を指定する必要があります。全体を取得したい場合は、終了位置を記述することができます。 -1 として位置します。

3. コレクション データ型

//从右侧推入
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
ログイン後にコピー

4. ハッシュ データ型

//往集合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
ログイン後にコピー
この記事の事例を読んだ後は、この方法を習得したと思います。さらに興味深い情報については、他の関連記事に注目してください。 PHP中国語ウェブサイトです!

推奨読書:

ES6で全画面スクロールプラグインを実装する手順の詳細な説明

nodejsログモジュールwinstonの使用方法の概要

以上がNodejsにおけるredisの適用事例を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート