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

cachecow

v1.0.1

Published

An on-disk cache for files with various garbage collection options.

Downloads

3

Readme

Cache Cow

All the caching modules I found on npm were for caching things in memory, or in an external service like Redis. I couldn't find any cache modules on npm that fit my need, so I wrote this one.

Motivation

  1. Do you have extra hard drive space?
  2. Store some of your files in the cloud or whatever?
  3. Want to save bandwidth or time by making fewer fetches to that cloud?

That is the use case this module is designed for. I wanted to use the hard drive to cache files that are in remote storage like Amazon S3.

Features

  • When cache reaches 90% of the defined maxsize it deletes files until the cache is 70% of maxsize.
  • Returns streams, not buffers, for faster requests.
  • How it chooses which files to delete can be customized

Free support

Email me or create an issue if you need help! I'm throwing this up without a lot of documentation, and am very welcome to feedback and suggestions.

Example

# Hypothetical example using CacheCow with an HTTP proxy server
express = require('express')
request = require('request')
CacheCow = require('cachecow')

app = express()

cache = new CacheCow({
  maxsize: 1024*1024*1024*10 # 10GB
  # Define a function to deal with cache misses
  getter: (filename, callback) ->
    console.log "Not found in cache"
    stream = request("http://httpstat.us/#{filename}")
    callback(null, stream)
})

# Retrieve something from cache
app.get "/:filepath", (req, res) ->
  cache.get req.params.filepath, (err, stream) ->
    return res.status(404).send(err.message) if err?
    stream.pipe res

# This scans the cache directory to gather file size information for any files
# already present in the cache directory.
cache.init (err) ->
  console.log err if err?
  app.listen 8080, (err) ->
    console.log err if err?
    console.log "started"

Options

# Default values
cache = new CacheCow
  maxsize: 1024*1024*1 # 1MB
  dir: upath.join(os.tmpdir(), 'cachecow')
  getter: ->
    console.log 'You must define a getter function for cache misses!'
  # Weights used in garbage collection equation
  DeleteByFileSize: 0      # Delete big files first, keep as many files as possible
  DeleteByTotalReads: 0    # Delete rarely used files, keep file that are frequently fetched
  DeleteByLastAccess: 1    # Delete old files, keep files that have been recently fetched