Skip to content

A module to force mongoose to use more durable commits.

License

Notifications You must be signed in to change notification settings

hubba/mongoose-vicks

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Mongoose Vicks Vapo Rub

This Module will load a plugin will allow Mongoose models to have durable commits. MongoDB has the ability to enforce safe commits so that actions will be propagated to the other servers.

The name is an allusion to giving mongooses vics vapo rub help them get (along)[https://gizmodo.com/zoo-keepers-use-vicks-vap-o-rub-to-help-mongooses-get-1599938029].

Profiles

You can set up many profiles and have a switch that will activate the profile based on the node environment var.

Please see the tests for usage.

When the plugin is loaded it will only affect schemas initialized with a durable property.

Initialization

There are a variety of options for the number of slaves that the transaction must commit on before acknowledging it as a successful action.

    const Vicks = require('mongoose-vicks');
    const mongoVicks = Vicks();
    // This will set the timeout to be 1 second, the number of slaves
    // to be 0 and data to be written to the journal.
    mongoVicks.addDurabilityProfile('test',0, 1000, true);
    
    // Set the profile to be test
    mongoVicks.setDurabilityProfile('test');
    mongoVicks.loadPlugin(mongoose);

After loading the plugin then you can just set a property on a mongoose schema and the options will automatically apply.

    const DurableSchema = new Schema({
        name: {
            type: String,
            unique: true
        },

        age: {
            type: Number
        },

        address: {
            type: String,
            unique: true
        }
    });

    // The property needs to be set as true
    DurableSchema.durable = true;

This module will change the writeConcern in mongoose collections, please read: https://docs.mongodb.com/manual/reference/write-concern/.

Write Concerns Values

  • 'majority' - If a data bearing node goes down for any reason, you'll lose the ability to perform writes for any operations using that write concern. (mlab)
  • 1 - Requests acknowledgement that the write operation has propagated to the standalone mongod or the primary in a replica set. w: 1 is the default write concern for MongoDB.
  • 0 - Please see https://docs.mongodb.com/manual/reference/write-concern/

Journal

  • true - The requests acknowledgement that the mongod instances, as specified.

    • From Notes: Changed in version (MongoDB) 3.2: With j: true, MongoDB returns only after the requested number of members, including the primary, have written to the journal. Previously j: true write concern in a replica set only requires the primary to write to the journal, regardless of the w: write concern.

Testing

To run the tests run npm test.

About

A module to force mongoose to use more durable commits.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published