5e0faf4959
tracking_collisions.c: sha1 + crc64 implemented.
2019-08-02 20:24:27 +02:00
a368209b1d
tracking_collisions.c: initial skeleton.
...
... of a program to just test the hashing functions collisions on a 24
bit output with strings that are very likely Redis key names, and names
of a kind that are particularly prone to collisions.
2019-08-02 20:13:21 +02:00
d3f7eb0c87
networking: flushSlavesOutputBuffers bugfix
2019-08-02 17:17:19 +08:00
583933e2d6
Fix regression causing EXEC to appear in the slow log.
...
This was recently introduced with PR #6266 .
2019-07-31 19:05:20 +02:00
2a8a63af44
Make EMBSTR case of #6261 more obvious.
2019-07-31 12:03:10 +02:00
f899c31fbc
Merge pull request #6261 from chendq8/robj
...
make memory usage consistent of robj with OBJ_ENCODING_INT
2019-07-31 11:54:11 +02:00
fc5c2052b5
Merge pull request #6266 from madolson/dev-unstable-hide-auth-and-hello
...
Hide HELLO and AUTH from slowlog and monitor
2019-07-31 11:12:46 +02:00
e1b13b4d39
Merge branch 'unstable' of github.com:/antirez/redis into unstable
2019-07-31 10:37:17 +02:00
b2079cb508
HyperLogLog: fix the fix of a corruption bug.
2019-07-31 10:36:23 +02:00
f0c10d4360
Merge pull request #6277 from devnexen/fbsd_get_rss
...
Updating resident memory request impl on FreeBSD.
2019-07-30 18:24:38 +02:00
40c4183196
Log message when modules prevent diskless-load
2019-07-30 16:32:58 +03:00
07b1abab95
Add test for module diskless short reads
2019-07-30 15:20:03 +03:00
e5187ad2ae
Merge remote-tracking branch 'oss/unstable' into module_rdb_load_errors
2019-07-30 15:14:08 +03:00
4339706e07
Avoid diskelss-load if modules did not declare they handle read errors
2019-07-30 15:11:57 +03:00
f42846e8c7
Merge pull request #6264 from oranagra/modules_api_aux_rdb
...
Implement module api for aux data in rdb
2019-07-30 11:50:44 +02:00
ce72cac0f8
Merge pull request #6269 from wubostc/patch-1
...
Reduce the calling stack
2019-07-30 11:41:48 +02:00
e4b3c8bbc3
emptyDbGeneric(): call signalFlushDb() before deleting the keys.
...
This was broken since a refactoring performed recently by myself.
2019-07-30 11:20:54 +02:00
cc8125a779
Merge pull request #6282 from JohnSully/hll_corruption
...
Fix HLL corruption bug
2019-07-30 10:24:28 +02:00
d659654f53
Fix HLL corruption bug
2019-07-29 18:11:52 -04:00
f1c6c658ac
Updating resident memory request impl on FreeBSD.
2019-07-28 14:33:57 +01:00
505a855000
Merge branch 'unstable' of github.com:/antirez/redis into unstable
2019-07-25 19:18:26 +02:00
0714581e0c
Mark diskless loads as experimental in redis.conf.
2019-07-25 19:17:58 +02:00
5591a14c0a
Merge pull request #6248 from oranagra/module-log
...
RM_Log - add support for logging without a context or context without module
2019-07-25 18:48:46 +02:00
e91d9a6fff
Extend modules API to allow modules report to redis INFO
...
this implements #6012
2019-07-24 12:58:15 +03:00
fde5e737dc
Merge branch 'unstable' of github.com:/antirez/redis into unstable
2019-07-24 11:45:19 +02:00
e53a26b5d8
Client side caching: document tracking-table-max-fill in redis.conf.
2019-07-24 11:45:10 +02:00
0b780a5477
Example redis.conf: stay under 80 cols.
2019-07-24 11:38:11 +02:00
32efd9adf8
Client side caching: config option for table fill rate.
2019-07-24 11:35:01 +02:00
a67d0411e7
Remove experimental warning from diskless replication.
2019-07-24 11:33:53 +02:00
48f4cfb601
Reduce the calling stack
2019-07-24 16:22:26 +08:00
dbee7ca007
Merge pull request #6265 from madolson/dev-unstable-remove-create-object
...
Removed unnecessary creation of Redis objects
2019-07-23 17:05:10 +02:00
c98e7717bb
Client side caching: show tracking slots usage in INFO.
2019-07-23 11:02:14 +02:00
9268493e8d
Client side caching: implement full slot limit function.
2019-07-23 10:57:22 +02:00
47ce1cebeb
Merge pull request #6267 from soloestoy/opt-claim-trackingtable
...
Client side caching: do not reclaim tracking table if it's empty
2019-07-23 09:43:41 +02:00
9012e587ca
Client side caching: do not reclaim tracking table if it's empty
2019-07-23 15:25:00 +08:00
7d21754710
Hide HELLO and AUTH from slowlog and monitor
2019-07-22 22:53:15 -07:00
8fe173452a
Removed unecessary creation of Redis objects
2019-07-22 22:52:16 -07:00
3b6aeea44c
Implement module api for aux data in rdb
...
Other changes:
* fix memory leak in error handling of rdb loading of type OBJ_MODULE
2019-07-22 21:15:33 +03:00
c41f94d2a3
Client side caching: split invalidation into key / slot.
2019-07-22 18:59:53 +02:00
09c06698e9
Client side caching: redis-cli ability to enable tracking.
...
This is extremely useful in order to simulate an high load of requests
about different keys, and force Redis to track a lot of informations
about several clients, to simulate real world workloads.
2019-07-22 18:45:47 +02:00
436d02dd7b
Move signalFlushedDb() into a better place.
...
Now that the call also invalidates client side caching slots, it is
important that after an internal flush operation we both send the
notifications to the clients and, at the same time, are able to reclaim
the memory of the tracking table. This may even fix a few edge cases
related to MULTI/EXEC + WATCH during resync, not sure, but in general
looks more correct.
2019-07-22 12:37:47 +02:00
7d3992a80a
Client side caching: reclaim the tracking table on FLUSHALL.
2019-07-22 12:33:49 +02:00
842b44dc46
Client side caching: call the invalidation functions always.
...
Otherwise what happens is that the tracking table will never get garbage
collected if there are no longer clients with tracking enabled.
Now the invalidation function immediately checks if there is any table
allocated, otherwise it returns ASAP, so the overhead when the feature
is not used should be near zero.
2019-07-22 12:29:54 +02:00
f850201c64
Client side caching: don't hash the key if not needed.
2019-07-22 12:10:51 +02:00
e00442eb13
Clinet side caching: take count of used caching slots.
2019-07-22 11:47:44 +02:00
004c26ec28
make memory usage consistent of robj with OBJ_ENCODING_INT
2019-07-22 17:45:30 +08:00
d7d028a7a7
Allow modules to handle RDB loading errors.
...
This is especially needed in diskless loading, were a short read could have
caused redis to exit. now the module can handle the error and return to the
caller gracefully.
this fixes #5326
2019-07-21 18:19:32 +03:00
ff682d7902
Modules must have execute permissions to load
2019-07-19 15:28:31 -04:00
bc5cb168f5
RDB: fix MODULE_AUX loading by continuing to next opcode.
...
Thanks to @JohnSully for noticing this problem.
2019-07-19 11:12:46 +02:00
70534846d1
Modules must have execute permissions to load
2019-07-19 01:37:34 -04:00