一、MongoDB
MongoDB是一個基於分散式文件存儲概念的開源資料庫系統,由C++語言編寫,旨在為Web應用提供可擴展的高性能數據存儲解決方案。MongoDB的數據模型是面向文檔的,可以存儲比較複雜的結構數據(例如json格式),支持動態查詢,索引能夠包含子文檔(數組或內嵌文檔),且查詢效率高。MongoDB適用於需要大量寫入的場景,但是缺乏事務(4.0版本開始支持事務),對於一些金融領域中需要強一致性的應用並不適合。
1、示例代碼
//連接資料庫
const mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/test');
//定義Schema
const Schema = mongoose.Schema;
const userSchema = new Schema({
name: String,
age: Number
});
//編譯Schema生成Model
const UserModel = mongoose.model('User', userSchema);
//數據的增、刪、改、查操作
UserModel.create({ name: '張三', age: 20 }, function (err, user) {
//新增
});
UserModel.updateOne({ name: '張三' }, { $set: { age: 21 } }, function (err, result) {
//修改
});
UserModel.deleteOne({ name: '張三' }, function (err) {
//刪除
});
UserModel.find({ age: { $gte: 20 } }, function (err, users) {
//查詢
});
二、Redis
Redis是一個內存中的數據結構存儲系統,支持字元串、哈希表、列表、集合、有序集合等數據類型。Redis的好處是能快速地讀寫存儲的數據,對於緩存和短期數據存儲非常適合。另外Redis支持發布訂閱模式、支持事務等特性。但是,因為Redis是內存資料庫,所以無法存儲海量數據,且不支持持久化存儲,只能將內存中的數據定期寫入磁碟,如果機器宕機,會造成一定的數據丟失。
1、示例代碼
//連接Redis
const redis = require('redis');
const client = redis.createClient();
//增、刪、改、查操作
client.set('name', '張三', redis.print); //新增
client.get('name', function (err, result) { //查詢
console.log(result);
});
client.del('name', redis.print); //刪除
三、Apache Kafka
Apache Kafka是一個分散式的流處理平台,主要用於解決高並發場景下的數據處理問題,像日誌收集、實時流處理、數據分析等。與傳統消息隊列不同,Kafka可以支持海量消息數據的存儲,同時也可以實現消息的快速傳輸和高度可靠的消息處理。此外,Kafka還適合於數據流的處理,可以將大量數據通過分區方式分散到多個隊列中,以實現數據的並行處理和高效傳輸。
1、示例代碼
//構建producer
const kafka = require('kafka-node');
const Producer = kafka.Producer;
const KeyedMessage = kafka.KeyedMessage;
const client = new kafka.Client('localhost:2181');
const producer = new Producer(client);
//構建consumer
const Consumer = kafka.Consumer;
const consumer = new Consumer(
client,
[
{ topic: 'test', partition: 0 },
],
{
autoCommit: true,
fromBeginning: true
}
);
//發送消息
producer.on('ready', function () {
const message = new KeyedMessage('key', 'hello kafka');
producer.send([{ topic: 'test', messages: [message] }]);
});
//接收消息
consumer.on('message', function (message) {
console.log(message);
});
原創文章,作者:XEKIX,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/370908.html