rails-brotli-cache 0.3.2 → 0.3.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/README.md +7 -7
- data/lib/rails-brotli-cache/store.rb +8 -0
- data/lib/rails-brotli-cache/version.rb +1 -1
- data/spec/rails-brotli-cache/store_spec.rb +11 -0
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 412dc55dcd3f00210f9c090472b3dfcf10bedba7c2882015a74349797bfe4197
|
4
|
+
data.tar.gz: 7f8085d5fc354f899db174cf6080ea5f03a06f97a714afbb56b9f05aee801a2e
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 539de77bdcf9cd35b99023859a8e9c8d4cb25c99161ea32699a11818ec45f38165bf29bc7a738fb57e6ee39c8774460b9e2b8a626e77cbf1ed597b3178e6e0c4
|
7
|
+
data.tar.gz: 18326136e7fe619a5af79e6bb3ea803a0656a06aacdf624c7c5f8fd2ef7d175a1a9b24583675b96155e5dd3fc8e838b2dee4bdb3100366c6a799e7462c216c9d
|
data/README.md
CHANGED
@@ -1,10 +1,10 @@
|
|
1
1
|
# Rails Brotli Cache [](https://badge.fury.io/rb/rails-brotli-cache) [](https://circleci.com/gh/pawurb/rails-brotli-cache)
|
2
2
|
|
3
|
-
This gem enables support for compressing Ruby on Rails cache entries using the [Brotli compression algorithm](https://github.com/google/brotli). `RailsBrotliCache::Store` offers better compression and
|
3
|
+
This gem enables support for compressing Ruby on Rails cache entries using the [Brotli compression algorithm](https://github.com/google/brotli). `RailsBrotliCache::Store` offers better compression and performance compared to the default `Rails.cache` Gzip, regardless of the underlying data store. The gem also allows specifying any custom compression algorithm instead of Brotli.
|
4
4
|
|
5
5
|
## Benchmarks
|
6
6
|
|
7
|
-
Brotli cache works as a proxy layer wrapping the
|
7
|
+
Brotli cache works as a proxy layer wrapping the standard cache data store. It applies Brotli compression instead of the default Gzip before storing cache entries.
|
8
8
|
|
9
9
|
```ruby
|
10
10
|
redis_cache = ActiveSupport::Cache::RedisCacheStore.new(
|
@@ -23,8 +23,8 @@ brotli_redis_cache.write("json", json)
|
|
23
23
|
|
24
24
|
## Check the size of cache entries stored in Redis
|
25
25
|
redis = Redis.new(url: "redis://localhost:6379")
|
26
|
-
redis.get("json").size # => 31698
|
27
|
-
redis.get("br-json").size # => 24058
|
26
|
+
redis.get("json").size # => 31698 ~31kb
|
27
|
+
redis.get("br-json").size # => 24058 ~24kb
|
28
28
|
```
|
29
29
|
|
30
30
|
**~20%** better compression of a sample ActiveRecord objects array:
|
@@ -34,8 +34,8 @@ users = User.limit(100).to_a # 100 ActiveRecord objects
|
|
34
34
|
redis_cache.write("users", users)
|
35
35
|
brotli_redis_cache.write("users", users)
|
36
36
|
|
37
|
-
redis.get("users").size # => 12331
|
38
|
-
redis.get("br-users").size # => 10299
|
37
|
+
redis.get("users").size # => 12331 ~12kb
|
38
|
+
redis.get("br-users").size # => 10299 ~10kb
|
39
39
|
```
|
40
40
|
|
41
41
|
**~25%** faster performance for reading/writing a larger JSON file:
|
@@ -103,7 +103,7 @@ config.cache_store = RailsBrotliCache::Store.new(
|
|
103
103
|
)
|
104
104
|
```
|
105
105
|
|
106
|
-
You should avoid using it with `ActiveSupport::Cache::MemoryStore`. This type of cache store does not serialize or compress objects but keeps them directly in the RAM
|
106
|
+
You should avoid using it with `ActiveSupport::Cache::MemoryStore`. This type of cache store does not serialize or compress objects but keeps them directly in the RAM. In this case, adding this gem would reduce RAM usage but add huge performance overhead.
|
107
107
|
|
108
108
|
Gem appends `br-` to the cache key names to prevent conflicts with previously saved entries. You can disable this behavior by passing `{ prefix: nil }` during initialization:
|
109
109
|
|
@@ -82,6 +82,10 @@ module RailsBrotliCache
|
|
82
82
|
Marshal.load(serialized)
|
83
83
|
end
|
84
84
|
|
85
|
+
def exist?(name, options = nil)
|
86
|
+
@core_store.exist?(cache_key(name), options)
|
87
|
+
end
|
88
|
+
|
85
89
|
def delete(name, options = nil)
|
86
90
|
@core_store.delete(cache_key(name), options)
|
87
91
|
end
|
@@ -90,6 +94,10 @@ module RailsBrotliCache
|
|
90
94
|
@core_store.clear
|
91
95
|
end
|
92
96
|
|
97
|
+
def self.supports_cache_versioning?
|
98
|
+
true
|
99
|
+
end
|
100
|
+
|
93
101
|
private
|
94
102
|
|
95
103
|
def compressor_class(options, default:)
|
@@ -40,6 +40,17 @@ describe RailsBrotliCache do
|
|
40
40
|
end
|
41
41
|
end
|
42
42
|
|
43
|
+
describe "exist?" do
|
44
|
+
it "returns true if cache entry exists" do
|
45
|
+
cache_store.write("test-key", 1234)
|
46
|
+
expect(cache_store.exist?("test-key")).to eq true
|
47
|
+
end
|
48
|
+
|
49
|
+
it "returns false if cache entry does not exist" do
|
50
|
+
expect(cache_store.exist?("test-key")).to eq false
|
51
|
+
end
|
52
|
+
end
|
53
|
+
|
43
54
|
describe "#core_store" do
|
44
55
|
it "exposes the underlying data store" do
|
45
56
|
expect(cache_store.core_store.class).to eq ActiveSupport::Cache::MemoryStore
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: rails-brotli-cache
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.3.
|
4
|
+
version: 0.3.4
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- pawurb
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-05-
|
11
|
+
date: 2023-05-25 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|