npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

node-shared-shm-cache

v0.0.1

Published

Node.js shared memory cache

Downloads

7

Readme

Nodejs Shared Memory Map

a shared memory cache for nodejs, support grow/shrink, read/write lock

  1. with this, every process QPS 4W+ and pipe 400MB/s data
  2. i try use ipc(process.send message) to share cache ,but QPS 4k and pipe 50MB/s
  3. i try use mmap or other lib, but no read/write lock so is hard to sync even crash or stuck
  4. comfort for nodejs server with fork() process, local cache

Installation

xxx todo 

Usage

const addon = require('../build/Release/hello.node');
const cluster = require('node:cluster');


class ShmObject {
    cache = null;
    constructor() {
        if (cluster.isMaster || cluster.isPrimary) {
            // careful only master set true to reset memory 
            this.cache = new addon.NodeShareCache("Highscorev3", 1024 * 100, true);
        } else {
            // child process set false 
            this.cache = new addon.NodeShareCache("Highscorev3", 1024 * 100, false);
        }
        // cache expire time
        this.cache.setMaxAge(40000);
        // enable lock
        this.cache.setLock(true);

    }
    get(key) {
        return this.cache.get(key);
    }
    set(key, value) {
        return this.cache.set(key, value);
    }
}

module.exports = ShmObject;

API

  1. get/set with key , base data operation
  2. setMaxAge , set max age for data expire,default 2000ms
  3. setMaxSize , set max memory allocation size, default 800MB
  4. setLock(bool), enable/disable lock

    can be disable when read only to improve performance
    !!!!can nooooot disable when write, cause crash or stuck

  5. setLogLevel(1,2,3) , show detail logs

memory allocation

grow

  1. <4MB auto grow x2
  2. 4MB-400MB auto grow 400KB
  3. 400MB-4GB auto grow 4MB
  4. and custome grow

shrink

when clean up, and free memory more than 40MB shrink to fit the size of data

read/write lock

  1. read with shared lock
  2. write with exclusive lock
  3. no timeout lock support (toto later add)
  4. memory grow/shrink with exclusive lock

benchmark

5 child process , read only, macbook pro

read_only

5 child process , read+write, macbook pro

write_only

5 child process , read first, macbook pro

write_only

5 child process , write first, win64 i5-12490 img.png