Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: fix RegisterOnChange methods for journal and db_slice #3171

Merged
merged 7 commits into from
Jun 20, 2024

Conversation

BorysTheDev
Copy link
Contributor

@BorysTheDev BorysTheDev commented Jun 12, 2024

We have a bug with the journal->RegisterOnChange functions:

  1. Start 2 tasks with traversing through the whole DB
  2. The first task is already work
  3. Second task do db_slice_->RegisterOnChange(db_callback)
  4. After that second task do journal->RegisterOnChange(..) and yield to another fiber on the mutex JournalSlice::cb_mu_
  5. during the 4th step we do LPUSH for example and db_callback save the bucket
  6. we still don't have a callback for the journal so we lost data for LPUSH
  7. we finish journal->RegisterOnChange(..)

This issue was reproducible in test_cluster_fuzzymigration

Also, I have fixed the issue with db_slice_->UnregisterOnChange() if it was called during callbacks processing (if the fiber yields during callback)

@romange
Copy link
Collaborator

romange commented Jun 12, 2024

Please provide a PR description. In general, I would like to ask to provide a better context for non -trivial bug fixes. See #3103 for example how @adiholden does it.

@romange
Copy link
Collaborator

romange commented Jun 12, 2024

@BorysTheDev can you also explain the fix - i.e. why shared_ptr solves the issue?

@BorysTheDev
Copy link
Contributor Author

BorysTheDev commented Jun 12, 2024

@romange the problem was in mutex that could yield to another fiber but prevented removing a callback during a call. So to fix the issue I need to remove mutex from RegisterOnChange, in this case, the fiber doesn't yield, but I need to prevent removing a callback so I change the vector to the list

src/server/db_slice.cc Outdated Show resolved Hide resolved
@BorysTheDev
Copy link
Contributor Author

BorysTheDev commented Jun 12, 2024

to not forget, It looks we need mutex too to prevent removing some data while callback is in progress. Will think about better fix tomorrow

@BorysTheDev BorysTheDev force-pushed the fix_RegisterOnChange_journal_method branch from 76bdf28 to 33f7849 Compare June 13, 2024 09:00
@BorysTheDev BorysTheDev force-pushed the fix_RegisterOnChange_journal_method branch 2 times, most recently from 2d0a808 to 5775f95 Compare June 13, 2024 09:50
@romange
Copy link
Collaborator

romange commented Jun 13, 2024

LGTM from my side, will wait for Adi to approve

@adiholden
Copy link
Collaborator

I am not sure about the correctness of this solution.
In this change we dont have a mutex in JournalSlice::RegisterOnChange

Lets take for example the following scenario:

  1. callback "LPUSH key val" is executed
  2. we run db_slice callbacks for bucket holding the key
  3. we give new version to the bucket holding key - version x
  4. we run journal_slice callback to write journal change "lpush key val"
  5. we yield when writing the journal change
  6. another replica is starting calling db_slice register on change with version x+1
  7. journal slice is registered on change
  8. we return to fiber yield in step 5 continue iterating the journal changes list
  9. we no write the journal change "lpush key val" to the stream before we serialized the bucket

src/server/db_slice.h Outdated Show resolved Hide resolved
@BorysTheDev BorysTheDev force-pushed the fix_RegisterOnChange_journal_method branch from b4c6dac to 0d85fc7 Compare June 17, 2024 18:08
@adiholden
Copy link
Collaborator

@BorysTheDev The changes looks good. Not sure why he ci failed here.
Also please make sure to run regression tests on you branch before merging

@kostasrim
Copy link
Contributor

@BorysTheDev The changes looks good. Not sure why he ci failed here. Also please make sure to run regression tests on you branch before merging

yes and I will be merging my CI changes and we have a failure on cluster slot which I disabled manually -- keep that in mind as well

@BorysTheDev BorysTheDev force-pushed the fix_RegisterOnChange_journal_method branch from 0d85fc7 to 9301ebf Compare June 18, 2024 08:47
@BorysTheDev BorysTheDev requested a review from adiholden June 18, 2024 13:31
@BorysTheDev BorysTheDev force-pushed the fix_RegisterOnChange_journal_method branch 2 times, most recently from 11da5d3 to 9de1e0b Compare June 19, 2024 14:49
.vscode/launch.json Outdated Show resolved Hide resolved
@BorysTheDev BorysTheDev force-pushed the fix_RegisterOnChange_journal_method branch from 9de1e0b to 487fe25 Compare June 20, 2024 08:34
@BorysTheDev BorysTheDev requested a review from adiholden June 20, 2024 08:35
@BorysTheDev BorysTheDev merged commit d75c79c into main Jun 20, 2024
10 checks passed
@BorysTheDev BorysTheDev deleted the fix_RegisterOnChange_journal_method branch June 20, 2024 09:37
dranikpg pushed a commit to dranikpg/dragonfly that referenced this pull request Jun 23, 2024
…db#3171)

* fix: fix RegisterOnChange methods for journal and db_slice. Call db_slice and journal callbacks atomically. Made a hack to avoid deadlock during SAVE
szinn referenced this pull request in szinn/k8s-homelab Jul 9, 2024
…nfly ( v1.19.2 → v1.20.0 ) (#3956)

This PR contains the following updates:

| Package | Update | Change |
|---|---|---|
|
[docker.dragonflydb.io/dragonflydb/dragonfly](https://togithub.com/dragonflydb/dragonfly)
| minor | `v1.19.2` -> `v1.20.0` |

---

### Release Notes

<details>
<summary>dragonflydb/dragonfly
(docker.dragonflydb.io/dragonflydb/dragonfly)</summary>

###
[`v1.20.0`](https://togithub.com/dragonflydb/dragonfly/releases/tag/v1.20.0)

[Compare
Source](https://togithub.com/dragonflydb/dragonfly/compare/v1.19.2...v1.20.0)

##### Dragonfly v1.20.0

Some prominent changes include:

- Improvements around client side caching
([#&#8203;3136](https://togithub.com/dragonflydb/dragonfly/issues/3136)
[#&#8203;3158](https://togithub.com/dragonflydb/dragonfly/issues/3158))
Specifically, rueidis is now supported
([#&#8203;2454](https://togithub.com/dragonflydb/dragonfly/issues/2454))
- Improvements around search and vector search APIs, FT.ALTER is now
supported
([#&#8203;3144](https://togithub.com/dragonflydb/dragonfly/issues/3144),
[#&#8203;3148](https://togithub.com/dragonflydb/dragonfly/issues/3148),
[#&#8203;3178](https://togithub.com/dragonflydb/dragonfly/issues/3178),
[#&#8203;3186](https://togithub.com/dragonflydb/dragonfly/issues/3186))
- JSON.MSET is added
([#&#8203;3167](https://togithub.com/dragonflydb/dragonfly/issues/3167))
- Expiry notifications are now supported
([#&#8203;3154](https://togithub.com/dragonflydb/dragonfly/issues/3154))

##### What's Changed

- test(cluster_mgr): Add tests for cluster_mgr.py by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3129](https://togithub.com/dragonflydb/dragonfly/pull/3129)
- chore: get rid of kv_args and replace it with slices to full_args by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3101](https://togithub.com/dragonflydb/dragonfly/pull/3101)
- fix: Fix live-lock in connection test by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3135](https://togithub.com/dragonflydb/dragonfly/pull/3135)
- chore: call breaker_cb\_ on shutdown by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3128](https://togithub.com/dragonflydb/dragonfly/pull/3128)
- chore: Add option to disable aws dependency by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3077](https://togithub.com/dragonflydb/dragonfly/pull/3077)
- feat(cluster): Add important logs by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3138](https://togithub.com/dragonflydb/dragonfly/pull/3138)
- chore: a small cleanup by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3140](https://togithub.com/dragonflydb/dragonfly/pull/3140)
- test: skip test_cluster_migration_cancel, it is broken by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3146](https://togithub.com/dragonflydb/dragonfly/pull/3146)
- chore: update helio by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3150](https://togithub.com/dragonflydb/dragonfly/pull/3150)
- fix: fix bug in cluster/slot_set by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3143](https://togithub.com/dragonflydb/dragonfly/pull/3143)
- chore: recommit client tracking by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3136](https://togithub.com/dragonflydb/dragonfly/pull/3136)
- feat(search): Tag field options (separator, case sensitivity) by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3144](https://togithub.com/dragonflydb/dragonfly/pull/3144)
- feat(search): basic FT.ALTER by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3148](https://togithub.com/dragonflydb/dragonfly/pull/3148)
- chore: Introduce pipeline back-pressure by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3152](https://togithub.com/dragonflydb/dragonfly/pull/3152)
- fix: lua and client tracking by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3163](https://togithub.com/dragonflydb/dragonfly/pull/3163)
- feat: client tracking optout by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3158](https://togithub.com/dragonflydb/dragonfly/pull/3158)
- feat: add noloop subcommand in client tracking by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3164](https://togithub.com/dragonflydb/dragonfly/pull/3164)
- fix(ci): docker not using iouring by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3169](https://togithub.com/dragonflydb/dragonfly/pull/3169)
- fix(ci): add missing docker option on reg tests workflow by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3172](https://togithub.com/dragonflydb/dragonfly/pull/3172)
- fix: acl compatibility by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3147](https://togithub.com/dragonflydb/dragonfly/pull/3147)
- chore: Streamer is rewritten with async interface by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3108](https://togithub.com/dragonflydb/dragonfly/pull/3108)
- feat(json): MSET by [@&#8203;dranikpg](https://togithub.com/dranikpg)
in
[https://github.com/dragonflydb/dragonfly/pull/3167](https://togithub.com/dragonflydb/dragonfly/pull/3167)
- fix(cluster): Wait for flow creation before cancelling it by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3159](https://togithub.com/dragonflydb/dragonfly/pull/3159)
- chore: improve ft.create for vector search by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3178](https://togithub.com/dragonflydb/dragonfly/pull/3178)
- feat: add incoming migration error processing by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3175](https://togithub.com/dragonflydb/dragonfly/pull/3175)
- chore: add parsing support for the rest of VECTOR parameters by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3179](https://togithub.com/dragonflydb/dragonfly/pull/3179)
- fix(cluster): Wait before all access to slot migrations by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3180](https://togithub.com/dragonflydb/dragonfly/pull/3180)
- fix(server): fix bug in replication on cached mode by
[@&#8203;adiholden](https://togithub.com/adiholden) in
[https://github.com/dragonflydb/dragonfly/pull/3156](https://togithub.com/dragonflydb/dragonfly/pull/3156)
- chore: small acl compat changes by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3177](https://togithub.com/dragonflydb/dragonfly/pull/3177)
- chore: allow calling Context::ReportError from I/O dispatch fiber by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3182](https://togithub.com/dragonflydb/dragonfly/pull/3182)
- chore: add a lexer test covering KNN query by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3185](https://togithub.com/dragonflydb/dragonfly/pull/3185)
- chore(search): Add \__vector_score alias by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3186](https://togithub.com/dragonflydb/dragonfly/pull/3186)
- chore: Refactor string span management by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3165](https://togithub.com/dragonflydb/dragonfly/pull/3165)
- chore(ci): run replication tests on arm by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3168](https://togithub.com/dragonflydb/dragonfly/pull/3168)
- chore(search): improve parser error reporting by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3184](https://togithub.com/dragonflydb/dragonfly/pull/3184)
- fix(reply_builder): remove virtual modifier in SendError(ErrorReply)
method by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3191](https://togithub.com/dragonflydb/dragonfly/pull/3191)
- fix(cluster): Support `FLUSHALL` while slot migration is in progress
by [@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3173](https://togithub.com/dragonflydb/dragonfly/pull/3173)
- fix: fix RegisterOnChange methods for journal and db_slice by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3171](https://togithub.com/dragonflydb/dragonfly/pull/3171)
- fix(generic_family): fix RenameGeneric command for non-string data
types by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3181](https://togithub.com/dragonflydb/dragonfly/pull/3181)
- fix(server): Rename confusing flag
`replica_reconnect_on_master_restart` by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3193](https://togithub.com/dragonflydb/dragonfly/pull/3193)
- fix(unit tests): fix generic family info test by
[@&#8203;adiholden](https://togithub.com/adiholden) in
[https://github.com/dragonflydb/dragonfly/pull/3187](https://togithub.com/dragonflydb/dragonfly/pull/3187)
- test: improve cluster_fuzzy_migration test by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3197](https://togithub.com/dragonflydb/dragonfly/pull/3197)
- chore(core): Remove DfImpl inside ScoredMap by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3199](https://togithub.com/dragonflydb/dragonfly/pull/3199)
- chore(tiering): Remove IoMgr by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3198](https://togithub.com/dragonflydb/dragonfly/pull/3198)
- test(cluster): Make sure migration maintains TTL by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3188](https://togithub.com/dragonflydb/dragonfly/pull/3188)
- feat(cluster): Support `STICK` bit in slot migration by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3200](https://togithub.com/dragonflydb/dragonfly/pull/3200)
- chore: Re-enable previously flaky test by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3196](https://togithub.com/dragonflydb/dragonfly/pull/3196)
- feat(acl): add support of multiple passwords by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3189](https://togithub.com/dragonflydb/dragonfly/pull/3189)
- chore(tiering): More advanced tiering tests by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3201](https://togithub.com/dragonflydb/dragonfly/pull/3201)
- chore: add replica-priority flag by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3204](https://togithub.com/dragonflydb/dragonfly/pull/3204)
- chore: fix tiering regtest test by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3208](https://togithub.com/dragonflydb/dragonfly/pull/3208)
- feat(generic_family): Assemble RESTORE and STICK commands into one
commmand during replication of the RENAME command by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3209](https://togithub.com/dragonflydb/dragonfly/pull/3209)
- core(search): Add EF_RUNTIME parameter by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3206](https://togithub.com/dragonflydb/dragonfly/pull/3206)
- fix(sanitizers): failing json test by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3176](https://togithub.com/dragonflydb/dragonfly/pull/3176)
- feat(server): expiry notifications by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3154](https://togithub.com/dragonflydb/dragonfly/pull/3154)
- fix: replicaof_reject_on_load flake by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3203](https://togithub.com/dragonflydb/dragonfly/pull/3203)
- fix(cluster): Don't miss keys when migrating slots by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3218](https://togithub.com/dragonflydb/dragonfly/pull/3218)
- fix(tiering): Fix pending leak during immediate stash error by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3219](https://togithub.com/dragonflydb/dragonfly/pull/3219)
- chore: provide basic logging to catch possible command errors by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3213](https://togithub.com/dragonflydb/dragonfly/pull/3213)
- chore: disable tiering test by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3236](https://togithub.com/dragonflydb/dragonfly/pull/3236)
- fix(transaction): Don't transactionalize empty EVAL inside EXEC by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3231](https://togithub.com/dragonflydb/dragonfly/pull/3231)
- fix: fix deadlock in DFLYCLUSTER CONFIG command and outgoing migration
finaliztion by [@&#8203;BorysTheDev](https://togithub.com/BorysTheDev)
in
[https://github.com/dragonflydb/dragonfly/pull/3239](https://togithub.com/dragonflydb/dragonfly/pull/3239)
- chore(tiered): minor fixes + expose buffer allocation type stats by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3234](https://togithub.com/dragonflydb/dragonfly/pull/3234)
- fix(pytest): timed ticker for simpler conditions by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3242](https://togithub.com/dragonflydb/dragonfly/pull/3242)
- fix(server): Fix SCAN deadlock by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3235](https://togithub.com/dragonflydb/dragonfly/pull/3235)
- chore: introduce back-pressure to tiered storage by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3243](https://togithub.com/dragonflydb/dragonfly/pull/3243)
- chore: improve dfly_bench by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3244](https://togithub.com/dragonflydb/dragonfly/pull/3244)
- chore(tiering): External alloc free page chaining by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3237](https://togithub.com/dragonflydb/dragonfly/pull/3237)
- fix: total_stash_overflows statistic by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3248](https://togithub.com/dragonflydb/dragonfly/pull/3248)
- chore: update action versions by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3250](https://togithub.com/dragonflydb/dragonfly/pull/3250)
- chore(lua): Return which undeclared key was accessed by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3245](https://togithub.com/dragonflydb/dragonfly/pull/3245)
- chore: replace session wide fixtures with scope by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3251](https://togithub.com/dragonflydb/dragonfly/pull/3251)
- chore: pull helio and adjust mimalloc for 32MiB segments by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3174](https://togithub.com/dragonflydb/dragonfly/pull/3174)
- chore: add more logs around the duplicate value case in small_bins by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3254](https://togithub.com/dragonflydb/dragonfly/pull/3254)
- fix: fix move error during migration finalization by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3253](https://togithub.com/dragonflydb/dragonfly/pull/3253)
- chore: upload all the logs from /tmp by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3263](https://togithub.com/dragonflydb/dragonfly/pull/3263)
- fix(tiering): Throttle snapshot load by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3249](https://togithub.com/dragonflydb/dragonfly/pull/3249)
- chore: initiate grow preemptively by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3267](https://togithub.com/dragonflydb/dragonfly/pull/3267)
- chore(monitoring): add more dashboards + memcached by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3268](https://togithub.com/dragonflydb/dragonfly/pull/3268)
- fix(json_family): fix JSON.GET commmand for JSON legacy mode by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3261](https://togithub.com/dragonflydb/dragonfly/pull/3261)
- chore: dfly_bench can send traffic to memcached by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3271](https://togithub.com/dragonflydb/dragonfly/pull/3271)
- chore: print effective QPS of the server. by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3274](https://togithub.com/dragonflydb/dragonfly/pull/3274)
- chore: debugging fixes by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3275](https://togithub.com/dragonflydb/dragonfly/pull/3275)
- chore: more debug checks around tiered storage by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3277](https://togithub.com/dragonflydb/dragonfly/pull/3277)
- chore(license): Fix typo in LICENSE.md text by
[@&#8203;softmoth](https://togithub.com/softmoth) in
[https://github.com/dragonflydb/dragonfly/pull/3283](https://togithub.com/dragonflydb/dragonfly/pull/3283)
- fix(test): Verify that save has not finished by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3278](https://togithub.com/dragonflydb/dragonfly/pull/3278)
- Create scorecard.yml by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3270](https://togithub.com/dragonflydb/dragonfly/pull/3270)
- chore: Disable cluster_mgr_test by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3279](https://togithub.com/dragonflydb/dragonfly/pull/3279)
- fix: Increase key count to make test more robust by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3286](https://togithub.com/dragonflydb/dragonfly/pull/3286)
- fix: properly clean tiered state upon flash by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3281](https://togithub.com/dragonflydb/dragonfly/pull/3281)
- fix(bug): crash on takeover and info replication by
[@&#8203;adiholden](https://togithub.com/adiholden) in
[https://github.com/dragonflydb/dragonfly/pull/3282](https://togithub.com/dragonflydb/dragonfly/pull/3282)

##### New Contributors

- [@&#8203;softmoth](https://togithub.com/softmoth) made their first
contribution in
[https://github.com/dragonflydb/dragonfly/pull/3283](https://togithub.com/dragonflydb/dragonfly/pull/3283)

##### Huge thanks to all the contributors! ❤️

**Full Changelog**:
dragonflydb/dragonfly@v1.19.0...v1.20.0

</details>

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNy40MjYuMiIsInVwZGF0ZWRJblZlciI6IjM3LjQyNi4yIiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6WyJyZW5vdmF0ZS9jb250YWluZXIiLCJ0eXBlL21pbm9yIl19-->

Co-authored-by: repo-jeeves[bot] <106431701+repo-jeeves[bot]@users.noreply.github.com>
spiceratops referenced this pull request in spiceratops/k8s-gitops Jul 9, 2024
#845)

This PR contains the following updates:

| Package | Update | Change |
|---|---|---|
|
[ghcr.io/dragonflydb/dragonfly](https://togithub.com/dragonflydb/dragonfly)
| minor | `v1.19.2` -> `v1.20.0` |

---

> [!WARNING]
> Some dependencies could not be looked up. Check the Dependency
Dashboard for more information.

---

### Release Notes

<details>
<summary>dragonflydb/dragonfly (ghcr.io/dragonflydb/dragonfly)</summary>

###
[`v1.20.0`](https://togithub.com/dragonflydb/dragonfly/releases/tag/v1.20.0)

[Compare
Source](https://togithub.com/dragonflydb/dragonfly/compare/v1.19.2...v1.20.0)

##### Dragonfly v1.20.0

Some prominent changes include:

- Improvements around client side caching
([#&#8203;3136](https://togithub.com/dragonflydb/dragonfly/issues/3136)
[#&#8203;3158](https://togithub.com/dragonflydb/dragonfly/issues/3158))
Specifically, rueidis is now supported
([#&#8203;2454](https://togithub.com/dragonflydb/dragonfly/issues/2454))
- Improvements around search and vector search APIs, FT.ALTER is now
supported
([#&#8203;3144](https://togithub.com/dragonflydb/dragonfly/issues/3144),
[#&#8203;3148](https://togithub.com/dragonflydb/dragonfly/issues/3148),
[#&#8203;3178](https://togithub.com/dragonflydb/dragonfly/issues/3178),
[#&#8203;3186](https://togithub.com/dragonflydb/dragonfly/issues/3186))
- JSON.MSET is added
([#&#8203;3167](https://togithub.com/dragonflydb/dragonfly/issues/3167))
- Expiry notifications are now supported
([#&#8203;3154](https://togithub.com/dragonflydb/dragonfly/issues/3154))

##### What's Changed

- test(cluster_mgr): Add tests for cluster_mgr.py by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3129](https://togithub.com/dragonflydb/dragonfly/pull/3129)
- chore: get rid of kv_args and replace it with slices to full_args by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3101](https://togithub.com/dragonflydb/dragonfly/pull/3101)
- fix: Fix live-lock in connection test by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3135](https://togithub.com/dragonflydb/dragonfly/pull/3135)
- chore: call breaker_cb\_ on shutdown by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3128](https://togithub.com/dragonflydb/dragonfly/pull/3128)
- chore: Add option to disable aws dependency by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3077](https://togithub.com/dragonflydb/dragonfly/pull/3077)
- feat(cluster): Add important logs by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3138](https://togithub.com/dragonflydb/dragonfly/pull/3138)
- chore: a small cleanup by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3140](https://togithub.com/dragonflydb/dragonfly/pull/3140)
- test: skip test_cluster_migration_cancel, it is broken by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3146](https://togithub.com/dragonflydb/dragonfly/pull/3146)
- chore: update helio by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3150](https://togithub.com/dragonflydb/dragonfly/pull/3150)
- fix: fix bug in cluster/slot_set by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3143](https://togithub.com/dragonflydb/dragonfly/pull/3143)
- chore: recommit client tracking by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3136](https://togithub.com/dragonflydb/dragonfly/pull/3136)
- feat(search): Tag field options (separator, case sensitivity) by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3144](https://togithub.com/dragonflydb/dragonfly/pull/3144)
- feat(search): basic FT.ALTER by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3148](https://togithub.com/dragonflydb/dragonfly/pull/3148)
- chore: Introduce pipeline back-pressure by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3152](https://togithub.com/dragonflydb/dragonfly/pull/3152)
- fix: lua and client tracking by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3163](https://togithub.com/dragonflydb/dragonfly/pull/3163)
- feat: client tracking optout by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3158](https://togithub.com/dragonflydb/dragonfly/pull/3158)
- feat: add noloop subcommand in client tracking by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3164](https://togithub.com/dragonflydb/dragonfly/pull/3164)
- fix(ci): docker not using iouring by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3169](https://togithub.com/dragonflydb/dragonfly/pull/3169)
- fix(ci): add missing docker option on reg tests workflow by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3172](https://togithub.com/dragonflydb/dragonfly/pull/3172)
- fix: acl compatibility by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3147](https://togithub.com/dragonflydb/dragonfly/pull/3147)
- chore: Streamer is rewritten with async interface by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3108](https://togithub.com/dragonflydb/dragonfly/pull/3108)
- feat(json): MSET by [@&#8203;dranikpg](https://togithub.com/dranikpg)
in
[https://github.com/dragonflydb/dragonfly/pull/3167](https://togithub.com/dragonflydb/dragonfly/pull/3167)
- fix(cluster): Wait for flow creation before cancelling it by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3159](https://togithub.com/dragonflydb/dragonfly/pull/3159)
- chore: improve ft.create for vector search by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3178](https://togithub.com/dragonflydb/dragonfly/pull/3178)
- feat: add incoming migration error processing by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3175](https://togithub.com/dragonflydb/dragonfly/pull/3175)
- chore: add parsing support for the rest of VECTOR parameters by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3179](https://togithub.com/dragonflydb/dragonfly/pull/3179)
- fix(cluster): Wait before all access to slot migrations by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3180](https://togithub.com/dragonflydb/dragonfly/pull/3180)
- fix(server): fix bug in replication on cached mode by
[@&#8203;adiholden](https://togithub.com/adiholden) in
[https://github.com/dragonflydb/dragonfly/pull/3156](https://togithub.com/dragonflydb/dragonfly/pull/3156)
- chore: small acl compat changes by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3177](https://togithub.com/dragonflydb/dragonfly/pull/3177)
- chore: allow calling Context::ReportError from I/O dispatch fiber by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3182](https://togithub.com/dragonflydb/dragonfly/pull/3182)
- chore: add a lexer test covering KNN query by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3185](https://togithub.com/dragonflydb/dragonfly/pull/3185)
- chore(search): Add \__vector_score alias by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3186](https://togithub.com/dragonflydb/dragonfly/pull/3186)
- chore: Refactor string span management by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3165](https://togithub.com/dragonflydb/dragonfly/pull/3165)
- chore(ci): run replication tests on arm by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3168](https://togithub.com/dragonflydb/dragonfly/pull/3168)
- chore(search): improve parser error reporting by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3184](https://togithub.com/dragonflydb/dragonfly/pull/3184)
- fix(reply_builder): remove virtual modifier in SendError(ErrorReply)
method by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3191](https://togithub.com/dragonflydb/dragonfly/pull/3191)
- fix(cluster): Support `FLUSHALL` while slot migration is in progress
by [@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3173](https://togithub.com/dragonflydb/dragonfly/pull/3173)
- fix: fix RegisterOnChange methods for journal and db_slice by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3171](https://togithub.com/dragonflydb/dragonfly/pull/3171)
- fix(generic_family): fix RenameGeneric command for non-string data
types by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3181](https://togithub.com/dragonflydb/dragonfly/pull/3181)
- fix(server): Rename confusing flag
`replica_reconnect_on_master_restart` by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3193](https://togithub.com/dragonflydb/dragonfly/pull/3193)
- fix(unit tests): fix generic family info test by
[@&#8203;adiholden](https://togithub.com/adiholden) in
[https://github.com/dragonflydb/dragonfly/pull/3187](https://togithub.com/dragonflydb/dragonfly/pull/3187)
- test: improve cluster_fuzzy_migration test by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3197](https://togithub.com/dragonflydb/dragonfly/pull/3197)
- chore(core): Remove DfImpl inside ScoredMap by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3199](https://togithub.com/dragonflydb/dragonfly/pull/3199)
- chore(tiering): Remove IoMgr by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3198](https://togithub.com/dragonflydb/dragonfly/pull/3198)
- test(cluster): Make sure migration maintains TTL by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3188](https://togithub.com/dragonflydb/dragonfly/pull/3188)
- feat(cluster): Support `STICK` bit in slot migration by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3200](https://togithub.com/dragonflydb/dragonfly/pull/3200)
- chore: Re-enable previously flaky test by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3196](https://togithub.com/dragonflydb/dragonfly/pull/3196)
- feat(acl): add support of multiple passwords by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3189](https://togithub.com/dragonflydb/dragonfly/pull/3189)
- chore(tiering): More advanced tiering tests by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3201](https://togithub.com/dragonflydb/dragonfly/pull/3201)
- chore: add replica-priority flag by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3204](https://togithub.com/dragonflydb/dragonfly/pull/3204)
- chore: fix tiering regtest test by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3208](https://togithub.com/dragonflydb/dragonfly/pull/3208)
- feat(generic_family): Assemble RESTORE and STICK commands into one
commmand during replication of the RENAME command by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3209](https://togithub.com/dragonflydb/dragonfly/pull/3209)
- core(search): Add EF_RUNTIME parameter by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3206](https://togithub.com/dragonflydb/dragonfly/pull/3206)
- fix(sanitizers): failing json test by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3176](https://togithub.com/dragonflydb/dragonfly/pull/3176)
- feat(server): expiry notifications by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3154](https://togithub.com/dragonflydb/dragonfly/pull/3154)
- fix: replicaof_reject_on_load flake by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3203](https://togithub.com/dragonflydb/dragonfly/pull/3203)
- fix(cluster): Don't miss keys when migrating slots by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3218](https://togithub.com/dragonflydb/dragonfly/pull/3218)
- fix(tiering): Fix pending leak during immediate stash error by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3219](https://togithub.com/dragonflydb/dragonfly/pull/3219)
- chore: provide basic logging to catch possible command errors by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3213](https://togithub.com/dragonflydb/dragonfly/pull/3213)
- chore: disable tiering test by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3236](https://togithub.com/dragonflydb/dragonfly/pull/3236)
- fix(transaction): Don't transactionalize empty EVAL inside EXEC by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3231](https://togithub.com/dragonflydb/dragonfly/pull/3231)
- fix: fix deadlock in DFLYCLUSTER CONFIG command and outgoing migration
finaliztion by [@&#8203;BorysTheDev](https://togithub.com/BorysTheDev)
in
[https://github.com/dragonflydb/dragonfly/pull/3239](https://togithub.com/dragonflydb/dragonfly/pull/3239)
- chore(tiered): minor fixes + expose buffer allocation type stats by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3234](https://togithub.com/dragonflydb/dragonfly/pull/3234)
- fix(pytest): timed ticker for simpler conditions by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3242](https://togithub.com/dragonflydb/dragonfly/pull/3242)
- fix(server): Fix SCAN deadlock by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3235](https://togithub.com/dragonflydb/dragonfly/pull/3235)
- chore: introduce back-pressure to tiered storage by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3243](https://togithub.com/dragonflydb/dragonfly/pull/3243)
- chore: improve dfly_bench by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3244](https://togithub.com/dragonflydb/dragonfly/pull/3244)
- chore(tiering): External alloc free page chaining by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3237](https://togithub.com/dragonflydb/dragonfly/pull/3237)
- fix: total_stash_overflows statistic by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3248](https://togithub.com/dragonflydb/dragonfly/pull/3248)
- chore: update action versions by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3250](https://togithub.com/dragonflydb/dragonfly/pull/3250)
- chore(lua): Return which undeclared key was accessed by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3245](https://togithub.com/dragonflydb/dragonfly/pull/3245)
- chore: replace session wide fixtures with scope by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3251](https://togithub.com/dragonflydb/dragonfly/pull/3251)
- chore: pull helio and adjust mimalloc for 32MiB segments by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3174](https://togithub.com/dragonflydb/dragonfly/pull/3174)
- chore: add more logs around the duplicate value case in small_bins by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3254](https://togithub.com/dragonflydb/dragonfly/pull/3254)
- fix: fix move error during migration finalization by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3253](https://togithub.com/dragonflydb/dragonfly/pull/3253)
- chore: upload all the logs from /tmp by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3263](https://togithub.com/dragonflydb/dragonfly/pull/3263)
- fix(tiering): Throttle snapshot load by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3249](https://togithub.com/dragonflydb/dragonfly/pull/3249)
- chore: initiate grow preemptively by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3267](https://togithub.com/dragonflydb/dragonfly/pull/3267)
- chore(monitoring): add more dashboards + memcached by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3268](https://togithub.com/dragonflydb/dragonfly/pull/3268)
- fix(json_family): fix JSON.GET commmand for JSON legacy mode by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3261](https://togithub.com/dragonflydb/dragonfly/pull/3261)
- chore: dfly_bench can send traffic to memcached by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3271](https://togithub.com/dragonflydb/dragonfly/pull/3271)
- chore: print effective QPS of the server. by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3274](https://togithub.com/dragonflydb/dragonfly/pull/3274)
- chore: debugging fixes by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3275](https://togithub.com/dragonflydb/dragonfly/pull/3275)
- chore: more debug checks around tiered storage by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3277](https://togithub.com/dragonflydb/dragonfly/pull/3277)
- chore(license): Fix typo in LICENSE.md text by
[@&#8203;softmoth](https://togithub.com/softmoth) in
[https://github.com/dragonflydb/dragonfly/pull/3283](https://togithub.com/dragonflydb/dragonfly/pull/3283)
- fix(test): Verify that save has not finished by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3278](https://togithub.com/dragonflydb/dragonfly/pull/3278)
- Create scorecard.yml by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3270](https://togithub.com/dragonflydb/dragonfly/pull/3270)
- chore: Disable cluster_mgr_test by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3279](https://togithub.com/dragonflydb/dragonfly/pull/3279)
- fix: Increase key count to make test more robust by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3286](https://togithub.com/dragonflydb/dragonfly/pull/3286)
- fix: properly clean tiered state upon flash by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3281](https://togithub.com/dragonflydb/dragonfly/pull/3281)
- fix(bug): crash on takeover and info replication by
[@&#8203;adiholden](https://togithub.com/adiholden) in
[https://github.com/dragonflydb/dragonfly/pull/3282](https://togithub.com/dragonflydb/dragonfly/pull/3282)

##### New Contributors

- [@&#8203;softmoth](https://togithub.com/softmoth) made their first
contribution in
[https://github.com/dragonflydb/dragonfly/pull/3283](https://togithub.com/dragonflydb/dragonfly/pull/3283)

##### Huge thanks to all the contributors! ❤️

**Full Changelog**:
dragonflydb/dragonfly@v1.19.0...v1.20.0

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined),
Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you
are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the
rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about these
updates again.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR has been generated by [Renovate
Bot](https://togithub.com/renovatebot/renovate).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNy40MjYuMiIsInVwZGF0ZWRJblZlciI6IjM3LjQyNi4yIiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6WyJyZW5vdmF0ZS9jb250YWluZXIiLCJ0eXBlL21pbm9yIl19-->
kireque referenced this pull request in kireque/home-ops Jul 10, 2024
…nfly ( v1.19.2 → v1.20.1 ) (#762)

This PR contains the following updates:

| Package | Update | Change |
|---|---|---|
|
[docker.dragonflydb.io/dragonflydb/dragonfly](https://togithub.com/dragonflydb/dragonfly)
| minor | `v1.19.2` -> `v1.20.1` |

---

### Release Notes

<details>
<summary>dragonflydb/dragonfly
(docker.dragonflydb.io/dragonflydb/dragonfly)</summary>

###
[`v1.20.1`](https://togithub.com/dragonflydb/dragonfly/releases/tag/v1.20.1)

[Compare
Source](https://togithub.com/dragonflydb/dragonfly/compare/v1.20.0...v1.20.1)

##### Dragonfly v1.20.1

This is a patch release.

fix: S3 access for loading/saving snapshots
([#&#8203;3296](https://togithub.com/dragonflydb/dragonfly/issues/3296))

Signed-off-by: kostas <[email protected]>

###
[`v1.20.0`](https://togithub.com/dragonflydb/dragonfly/releases/tag/v1.20.0)

[Compare
Source](https://togithub.com/dragonflydb/dragonfly/compare/v1.19.2...v1.20.0)

##### Dragonfly v1.20.0

Some prominent changes include:

- Improvements around client side caching
([#&#8203;3136](https://togithub.com/dragonflydb/dragonfly/issues/3136)
[#&#8203;3158](https://togithub.com/dragonflydb/dragonfly/issues/3158))
Specifically, rueidis is now supported
([#&#8203;2454](https://togithub.com/dragonflydb/dragonfly/issues/2454))
- Improvements around search and vector search APIs, FT.ALTER is now
supported
([#&#8203;3144](https://togithub.com/dragonflydb/dragonfly/issues/3144),
[#&#8203;3148](https://togithub.com/dragonflydb/dragonfly/issues/3148),
[#&#8203;3178](https://togithub.com/dragonflydb/dragonfly/issues/3178),
[#&#8203;3186](https://togithub.com/dragonflydb/dragonfly/issues/3186))
- JSON.MSET is added
([#&#8203;3167](https://togithub.com/dragonflydb/dragonfly/issues/3167))
- Expiry notifications are now supported
([#&#8203;3154](https://togithub.com/dragonflydb/dragonfly/issues/3154))

##### What's Changed

- test(cluster_mgr): Add tests for cluster_mgr.py by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3129](https://togithub.com/dragonflydb/dragonfly/pull/3129)
- chore: get rid of kv_args and replace it with slices to full_args by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3101](https://togithub.com/dragonflydb/dragonfly/pull/3101)
- fix: Fix live-lock in connection test by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3135](https://togithub.com/dragonflydb/dragonfly/pull/3135)
- chore: call breaker_cb\_ on shutdown by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3128](https://togithub.com/dragonflydb/dragonfly/pull/3128)
- chore: Add option to disable aws dependency by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3077](https://togithub.com/dragonflydb/dragonfly/pull/3077)
- feat(cluster): Add important logs by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3138](https://togithub.com/dragonflydb/dragonfly/pull/3138)
- chore: a small cleanup by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3140](https://togithub.com/dragonflydb/dragonfly/pull/3140)
- test: skip test_cluster_migration_cancel, it is broken by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3146](https://togithub.com/dragonflydb/dragonfly/pull/3146)
- chore: update helio by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3150](https://togithub.com/dragonflydb/dragonfly/pull/3150)
- fix: fix bug in cluster/slot_set by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3143](https://togithub.com/dragonflydb/dragonfly/pull/3143)
- chore: recommit client tracking by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3136](https://togithub.com/dragonflydb/dragonfly/pull/3136)
- feat(search): Tag field options (separator, case sensitivity) by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3144](https://togithub.com/dragonflydb/dragonfly/pull/3144)
- feat(search): basic FT.ALTER by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3148](https://togithub.com/dragonflydb/dragonfly/pull/3148)
- chore: Introduce pipeline back-pressure by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3152](https://togithub.com/dragonflydb/dragonfly/pull/3152)
- fix: lua and client tracking by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3163](https://togithub.com/dragonflydb/dragonfly/pull/3163)
- feat: client tracking optout by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3158](https://togithub.com/dragonflydb/dragonfly/pull/3158)
- feat: add noloop subcommand in client tracking by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3164](https://togithub.com/dragonflydb/dragonfly/pull/3164)
- fix(ci): docker not using iouring by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3169](https://togithub.com/dragonflydb/dragonfly/pull/3169)
- fix(ci): add missing docker option on reg tests workflow by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3172](https://togithub.com/dragonflydb/dragonfly/pull/3172)
- fix: acl compatibility by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3147](https://togithub.com/dragonflydb/dragonfly/pull/3147)
- chore: Streamer is rewritten with async interface by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3108](https://togithub.com/dragonflydb/dragonfly/pull/3108)
- feat(json): MSET by [@&#8203;dranikpg](https://togithub.com/dranikpg)
in
[https://github.com/dragonflydb/dragonfly/pull/3167](https://togithub.com/dragonflydb/dragonfly/pull/3167)
- fix(cluster): Wait for flow creation before cancelling it by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3159](https://togithub.com/dragonflydb/dragonfly/pull/3159)
- chore: improve ft.create for vector search by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3178](https://togithub.com/dragonflydb/dragonfly/pull/3178)
- feat: add incoming migration error processing by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3175](https://togithub.com/dragonflydb/dragonfly/pull/3175)
- chore: add parsing support for the rest of VECTOR parameters by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3179](https://togithub.com/dragonflydb/dragonfly/pull/3179)
- fix(cluster): Wait before all access to slot migrations by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3180](https://togithub.com/dragonflydb/dragonfly/pull/3180)
- fix(server): fix bug in replication on cached mode by
[@&#8203;adiholden](https://togithub.com/adiholden) in
[https://github.com/dragonflydb/dragonfly/pull/3156](https://togithub.com/dragonflydb/dragonfly/pull/3156)
- chore: small acl compat changes by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3177](https://togithub.com/dragonflydb/dragonfly/pull/3177)
- chore: allow calling Context::ReportError from I/O dispatch fiber by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3182](https://togithub.com/dragonflydb/dragonfly/pull/3182)
- chore: add a lexer test covering KNN query by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3185](https://togithub.com/dragonflydb/dragonfly/pull/3185)
- chore(search): Add \__vector_score alias by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3186](https://togithub.com/dragonflydb/dragonfly/pull/3186)
- chore: Refactor string span management by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3165](https://togithub.com/dragonflydb/dragonfly/pull/3165)
- chore(ci): run replication tests on arm by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3168](https://togithub.com/dragonflydb/dragonfly/pull/3168)
- chore(search): improve parser error reporting by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3184](https://togithub.com/dragonflydb/dragonfly/pull/3184)
- fix(reply_builder): remove virtual modifier in SendError(ErrorReply)
method by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3191](https://togithub.com/dragonflydb/dragonfly/pull/3191)
- fix(cluster): Support `FLUSHALL` while slot migration is in progress
by [@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3173](https://togithub.com/dragonflydb/dragonfly/pull/3173)
- fix: fix RegisterOnChange methods for journal and db_slice by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3171](https://togithub.com/dragonflydb/dragonfly/pull/3171)
- fix(generic_family): fix RenameGeneric command for non-string data
types by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3181](https://togithub.com/dragonflydb/dragonfly/pull/3181)
- fix(server): Rename confusing flag
`replica_reconnect_on_master_restart` by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3193](https://togithub.com/dragonflydb/dragonfly/pull/3193)
- fix(unit tests): fix generic family info test by
[@&#8203;adiholden](https://togithub.com/adiholden) in
[https://github.com/dragonflydb/dragonfly/pull/3187](https://togithub.com/dragonflydb/dragonfly/pull/3187)
- test: improve cluster_fuzzy_migration test by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3197](https://togithub.com/dragonflydb/dragonfly/pull/3197)
- chore(core): Remove DfImpl inside ScoredMap by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3199](https://togithub.com/dragonflydb/dragonfly/pull/3199)
- chore(tiering): Remove IoMgr by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3198](https://togithub.com/dragonflydb/dragonfly/pull/3198)
- test(cluster): Make sure migration maintains TTL by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3188](https://togithub.com/dragonflydb/dragonfly/pull/3188)
- feat(cluster): Support `STICK` bit in slot migration by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3200](https://togithub.com/dragonflydb/dragonfly/pull/3200)
- chore: Re-enable previously flaky test by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3196](https://togithub.com/dragonflydb/dragonfly/pull/3196)
- feat(acl): add support of multiple passwords by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3189](https://togithub.com/dragonflydb/dragonfly/pull/3189)
- chore(tiering): More advanced tiering tests by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3201](https://togithub.com/dragonflydb/dragonfly/pull/3201)
- chore: add replica-priority flag by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3204](https://togithub.com/dragonflydb/dragonfly/pull/3204)
- chore: fix tiering regtest test by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3208](https://togithub.com/dragonflydb/dragonfly/pull/3208)
- feat(generic_family): Assemble RESTORE and STICK commands into one
commmand during replication of the RENAME command by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3209](https://togithub.com/dragonflydb/dragonfly/pull/3209)
- core(search): Add EF_RUNTIME parameter by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3206](https://togithub.com/dragonflydb/dragonfly/pull/3206)
- fix(sanitizers): failing json test by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3176](https://togithub.com/dragonflydb/dragonfly/pull/3176)
- feat(server): expiry notifications by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3154](https://togithub.com/dragonflydb/dragonfly/pull/3154)
- fix: replicaof_reject_on_load flake by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3203](https://togithub.com/dragonflydb/dragonfly/pull/3203)
- fix(cluster): Don't miss keys when migrating slots by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3218](https://togithub.com/dragonflydb/dragonfly/pull/3218)
- fix(tiering): Fix pending leak during immediate stash error by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3219](https://togithub.com/dragonflydb/dragonfly/pull/3219)
- chore: provide basic logging to catch possible command errors by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3213](https://togithub.com/dragonflydb/dragonfly/pull/3213)
- chore: disable tiering test by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3236](https://togithub.com/dragonflydb/dragonfly/pull/3236)
- fix(transaction): Don't transactionalize empty EVAL inside EXEC by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3231](https://togithub.com/dragonflydb/dragonfly/pull/3231)
- fix: fix deadlock in DFLYCLUSTER CONFIG command and outgoing migration
finaliztion by [@&#8203;BorysTheDev](https://togithub.com/BorysTheDev)
in
[https://github.com/dragonflydb/dragonfly/pull/3239](https://togithub.com/dragonflydb/dragonfly/pull/3239)
- chore(tiered): minor fixes + expose buffer allocation type stats by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3234](https://togithub.com/dragonflydb/dragonfly/pull/3234)
- fix(pytest): timed ticker for simpler conditions by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3242](https://togithub.com/dragonflydb/dragonfly/pull/3242)
- fix(server): Fix SCAN deadlock by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3235](https://togithub.com/dragonflydb/dragonfly/pull/3235)
- chore: introduce back-pressure to tiered storage by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3243](https://togithub.com/dragonflydb/dragonfly/pull/3243)
- chore: improve dfly_bench by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3244](https://togithub.com/dragonflydb/dragonfly/pull/3244)
- chore(tiering): External alloc free page chaining by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3237](https://togithub.com/dragonflydb/dragonfly/pull/3237)
- fix: total_stash_overflows statistic by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3248](https://togithub.com/dragonflydb/dragonfly/pull/3248)
- chore: update action versions by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3250](https://togithub.com/dragonflydb/dragonfly/pull/3250)
- chore(lua): Return which undeclared key was accessed by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3245](https://togithub.com/dragonflydb/dragonfly/pull/3245)
- chore: replace session wide fixtures with scope by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3251](https://togithub.com/dragonflydb/dragonfly/pull/3251)
- chore: pull helio and adjust mimalloc for 32MiB segments by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3174](https://togithub.com/dragonflydb/dragonfly/pull/3174)
- chore: add more logs around the duplicate value case in small_bins by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3254](https://togithub.com/dragonflydb/dragonfly/pull/3254)
- fix: fix move error during migration finalization by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3253](https://togithub.com/dragonflydb/dragonfly/pull/3253)
- chore: upload all the logs from /tmp by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3263](https://togithub.com/dragonflydb/dragonfly/pull/3263)
- fix(tiering): Throttle snapshot load by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3249](https://togithub.com/dragonflydb/dragonfly/pull/3249)
- chore: initiate grow preemptively by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3267](https://togithub.com/dragonflydb/dragonfly/pull/3267)
- chore(monitoring): add more dashboards + memcached by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3268](https://togithub.com/dragonflydb/dragonfly/pull/3268)
- fix(json_family): fix JSON.GET commmand for JSON legacy mode by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3261](https://togithub.com/dragonflydb/dragonfly/pull/3261)
- chore: dfly_bench can send traffic to memcached by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3271](https://togithub.com/dragonflydb/dragonfly/pull/3271)
- chore: print effective QPS of the server. by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3274](https://togithub.com/dragonflydb/dragonfly/pull/3274)
- chore: debugging fixes by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3275](https://togithub.com/dragonflydb/dragonfly/pull/3275)
- chore: more debug checks around tiered storage by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3277](https://togithub.com/dragonflydb/dragonfly/pull/3277)
- chore(license): Fix typo in LICENSE.md text by
[@&#8203;softmoth](https://togithub.com/softmoth) in
[https://github.com/dragonflydb/dragonfly/pull/3283](https://togithub.com/dragonflydb/dragonfly/pull/3283)
- fix(test): Verify that save has not finished by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3278](https://togithub.com/dragonflydb/dragonfly/pull/3278)
- Create scorecard.yml by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3270](https://togithub.com/dragonflydb/dragonfly/pull/3270)
- chore: Disable cluster_mgr_test by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3279](https://togithub.com/dragonflydb/dragonfly/pull/3279)
- fix: Increase key count to make test more robust by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3286](https://togithub.com/dragonflydb/dragonfly/pull/3286)
- fix: properly clean tiered state upon flash by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3281](https://togithub.com/dragonflydb/dragonfly/pull/3281)
- fix(bug): crash on takeover and info replication by
[@&#8203;adiholden](https://togithub.com/adiholden) in
[https://github.com/dragonflydb/dragonfly/pull/3282](https://togithub.com/dragonflydb/dragonfly/pull/3282)

##### New Contributors

- [@&#8203;softmoth](https://togithub.com/softmoth) made their first
contribution in
[https://github.com/dragonflydb/dragonfly/pull/3283](https://togithub.com/dragonflydb/dragonfly/pull/3283)

##### Huge thanks to all the contributors! ❤️

**Full Changelog**:
dragonflydb/dragonfly@v1.19.0...v1.20.0

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined),
Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you
are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the
rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about these
updates again.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR has been generated by [Renovate
Bot](https://togithub.com/renovatebot/renovate).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNy40MjYuMiIsInVwZGF0ZWRJblZlciI6IjM3LjQyNi40IiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6WyJyZW5vdmF0ZS9jb250YWluZXIiLCJ0eXBlL21pbm9yIl19-->

Co-authored-by: kireque-bot[bot] <143391978+kireque-bot[bot]@users.noreply.github.com>
lumiere-bot bot referenced this pull request in coolguy1771/home-ops Jul 13, 2024
…20.1 ) (#5021)

This PR contains the following updates:

| Package | Update | Change |
|---|---|---|
|
[ghcr.io/dragonflydb/dragonfly](https://togithub.com/dragonflydb/dragonfly)
| minor | `v1.19.2` -> `v1.20.1` |

---

### Release Notes

<details>
<summary>dragonflydb/dragonfly (ghcr.io/dragonflydb/dragonfly)</summary>

###
[`v1.20.1`](https://togithub.com/dragonflydb/dragonfly/releases/tag/v1.20.1)

[Compare
Source](https://togithub.com/dragonflydb/dragonfly/compare/v1.20.0...v1.20.1)

##### Dragonfly v1.20.1

This is a patch release.

fix: S3 access for loading/saving snapshots
([#&#8203;3296](https://togithub.com/dragonflydb/dragonfly/issues/3296))

Signed-off-by: kostas <[email protected]>

###
[`v1.20.0`](https://togithub.com/dragonflydb/dragonfly/releases/tag/v1.20.0)

[Compare
Source](https://togithub.com/dragonflydb/dragonfly/compare/v1.19.2...v1.20.0)

##### Dragonfly v1.20.0

Some prominent changes include:

- Improvements around client side caching
([#&#8203;3136](https://togithub.com/dragonflydb/dragonfly/issues/3136)
[#&#8203;3158](https://togithub.com/dragonflydb/dragonfly/issues/3158))
Specifically, rueidis is now supported
([#&#8203;2454](https://togithub.com/dragonflydb/dragonfly/issues/2454))
- Improvements around search and vector search APIs, FT.ALTER is now
supported
([#&#8203;3144](https://togithub.com/dragonflydb/dragonfly/issues/3144),
[#&#8203;3148](https://togithub.com/dragonflydb/dragonfly/issues/3148),
[#&#8203;3178](https://togithub.com/dragonflydb/dragonfly/issues/3178),
[#&#8203;3186](https://togithub.com/dragonflydb/dragonfly/issues/3186))
- JSON.MSET is added
([#&#8203;3167](https://togithub.com/dragonflydb/dragonfly/issues/3167))
- Expiry notifications are now supported
([#&#8203;3154](https://togithub.com/dragonflydb/dragonfly/issues/3154))

##### What's Changed

- test(cluster_mgr): Add tests for cluster_mgr.py by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3129](https://togithub.com/dragonflydb/dragonfly/pull/3129)
- chore: get rid of kv_args and replace it with slices to full_args by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3101](https://togithub.com/dragonflydb/dragonfly/pull/3101)
- fix: Fix live-lock in connection test by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3135](https://togithub.com/dragonflydb/dragonfly/pull/3135)
- chore: call breaker_cb\_ on shutdown by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3128](https://togithub.com/dragonflydb/dragonfly/pull/3128)
- chore: Add option to disable aws dependency by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3077](https://togithub.com/dragonflydb/dragonfly/pull/3077)
- feat(cluster): Add important logs by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3138](https://togithub.com/dragonflydb/dragonfly/pull/3138)
- chore: a small cleanup by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3140](https://togithub.com/dragonflydb/dragonfly/pull/3140)
- test: skip test_cluster_migration_cancel, it is broken by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3146](https://togithub.com/dragonflydb/dragonfly/pull/3146)
- chore: update helio by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3150](https://togithub.com/dragonflydb/dragonfly/pull/3150)
- fix: fix bug in cluster/slot_set by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3143](https://togithub.com/dragonflydb/dragonfly/pull/3143)
- chore: recommit client tracking by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3136](https://togithub.com/dragonflydb/dragonfly/pull/3136)
- feat(search): Tag field options (separator, case sensitivity) by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3144](https://togithub.com/dragonflydb/dragonfly/pull/3144)
- feat(search): basic FT.ALTER by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3148](https://togithub.com/dragonflydb/dragonfly/pull/3148)
- chore: Introduce pipeline back-pressure by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3152](https://togithub.com/dragonflydb/dragonfly/pull/3152)
- fix: lua and client tracking by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3163](https://togithub.com/dragonflydb/dragonfly/pull/3163)
- feat: client tracking optout by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3158](https://togithub.com/dragonflydb/dragonfly/pull/3158)
- feat: add noloop subcommand in client tracking by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3164](https://togithub.com/dragonflydb/dragonfly/pull/3164)
- fix(ci): docker not using iouring by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3169](https://togithub.com/dragonflydb/dragonfly/pull/3169)
- fix(ci): add missing docker option on reg tests workflow by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3172](https://togithub.com/dragonflydb/dragonfly/pull/3172)
- fix: acl compatibility by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3147](https://togithub.com/dragonflydb/dragonfly/pull/3147)
- chore: Streamer is rewritten with async interface by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3108](https://togithub.com/dragonflydb/dragonfly/pull/3108)
- feat(json): MSET by [@&#8203;dranikpg](https://togithub.com/dranikpg)
in
[https://github.com/dragonflydb/dragonfly/pull/3167](https://togithub.com/dragonflydb/dragonfly/pull/3167)
- fix(cluster): Wait for flow creation before cancelling it by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3159](https://togithub.com/dragonflydb/dragonfly/pull/3159)
- chore: improve ft.create for vector search by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3178](https://togithub.com/dragonflydb/dragonfly/pull/3178)
- feat: add incoming migration error processing by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3175](https://togithub.com/dragonflydb/dragonfly/pull/3175)
- chore: add parsing support for the rest of VECTOR parameters by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3179](https://togithub.com/dragonflydb/dragonfly/pull/3179)
- fix(cluster): Wait before all access to slot migrations by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3180](https://togithub.com/dragonflydb/dragonfly/pull/3180)
- fix(server): fix bug in replication on cached mode by
[@&#8203;adiholden](https://togithub.com/adiholden) in
[https://github.com/dragonflydb/dragonfly/pull/3156](https://togithub.com/dragonflydb/dragonfly/pull/3156)
- chore: small acl compat changes by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3177](https://togithub.com/dragonflydb/dragonfly/pull/3177)
- chore: allow calling Context::ReportError from I/O dispatch fiber by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3182](https://togithub.com/dragonflydb/dragonfly/pull/3182)
- chore: add a lexer test covering KNN query by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3185](https://togithub.com/dragonflydb/dragonfly/pull/3185)
- chore(search): Add \__vector_score alias by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3186](https://togithub.com/dragonflydb/dragonfly/pull/3186)
- chore: Refactor string span management by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3165](https://togithub.com/dragonflydb/dragonfly/pull/3165)
- chore(ci): run replication tests on arm by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3168](https://togithub.com/dragonflydb/dragonfly/pull/3168)
- chore(search): improve parser error reporting by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3184](https://togithub.com/dragonflydb/dragonfly/pull/3184)
- fix(reply_builder): remove virtual modifier in SendError(ErrorReply)
method by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3191](https://togithub.com/dragonflydb/dragonfly/pull/3191)
- fix(cluster): Support `FLUSHALL` while slot migration is in progress
by [@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3173](https://togithub.com/dragonflydb/dragonfly/pull/3173)
- fix: fix RegisterOnChange methods for journal and db_slice by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3171](https://togithub.com/dragonflydb/dragonfly/pull/3171)
- fix(generic_family): fix RenameGeneric command for non-string data
types by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3181](https://togithub.com/dragonflydb/dragonfly/pull/3181)
- fix(server): Rename confusing flag
`replica_reconnect_on_master_restart` by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3193](https://togithub.com/dragonflydb/dragonfly/pull/3193)
- fix(unit tests): fix generic family info test by
[@&#8203;adiholden](https://togithub.com/adiholden) in
[https://github.com/dragonflydb/dragonfly/pull/3187](https://togithub.com/dragonflydb/dragonfly/pull/3187)
- test: improve cluster_fuzzy_migration test by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3197](https://togithub.com/dragonflydb/dragonfly/pull/3197)
- chore(core): Remove DfImpl inside ScoredMap by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3199](https://togithub.com/dragonflydb/dragonfly/pull/3199)
- chore(tiering): Remove IoMgr by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3198](https://togithub.com/dragonflydb/dragonfly/pull/3198)
- test(cluster): Make sure migration maintains TTL by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3188](https://togithub.com/dragonflydb/dragonfly/pull/3188)
- feat(cluster): Support `STICK` bit in slot migration by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3200](https://togithub.com/dragonflydb/dragonfly/pull/3200)
- chore: Re-enable previously flaky test by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3196](https://togithub.com/dragonflydb/dragonfly/pull/3196)
- feat(acl): add support of multiple passwords by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3189](https://togithub.com/dragonflydb/dragonfly/pull/3189)
- chore(tiering): More advanced tiering tests by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3201](https://togithub.com/dragonflydb/dragonfly/pull/3201)
- chore: add replica-priority flag by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3204](https://togithub.com/dragonflydb/dragonfly/pull/3204)
- chore: fix tiering regtest test by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3208](https://togithub.com/dragonflydb/dragonfly/pull/3208)
- feat(generic_family): Assemble RESTORE and STICK commands into one
commmand during replication of the RENAME command by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3209](https://togithub.com/dragonflydb/dragonfly/pull/3209)
- core(search): Add EF_RUNTIME parameter by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3206](https://togithub.com/dragonflydb/dragonfly/pull/3206)
- fix(sanitizers): failing json test by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3176](https://togithub.com/dragonflydb/dragonfly/pull/3176)
- feat(server): expiry notifications by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3154](https://togithub.com/dragonflydb/dragonfly/pull/3154)
- fix: replicaof_reject_on_load flake by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3203](https://togithub.com/dragonflydb/dragonfly/pull/3203)
- fix(cluster): Don't miss keys when migrating slots by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3218](https://togithub.com/dragonflydb/dragonfly/pull/3218)
- fix(tiering): Fix pending leak during immediate stash error by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3219](https://togithub.com/dragonflydb/dragonfly/pull/3219)
- chore: provide basic logging to catch possible command errors by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3213](https://togithub.com/dragonflydb/dragonfly/pull/3213)
- chore: disable tiering test by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3236](https://togithub.com/dragonflydb/dragonfly/pull/3236)
- fix(transaction): Don't transactionalize empty EVAL inside EXEC by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3231](https://togithub.com/dragonflydb/dragonfly/pull/3231)
- fix: fix deadlock in DFLYCLUSTER CONFIG command and outgoing migration
finaliztion by [@&#8203;BorysTheDev](https://togithub.com/BorysTheDev)
in
[https://github.com/dragonflydb/dragonfly/pull/3239](https://togithub.com/dragonflydb/dragonfly/pull/3239)
- chore(tiered): minor fixes + expose buffer allocation type stats by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3234](https://togithub.com/dragonflydb/dragonfly/pull/3234)
- fix(pytest): timed ticker for simpler conditions by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3242](https://togithub.com/dragonflydb/dragonfly/pull/3242)
- fix(server): Fix SCAN deadlock by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3235](https://togithub.com/dragonflydb/dragonfly/pull/3235)
- chore: introduce back-pressure to tiered storage by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3243](https://togithub.com/dragonflydb/dragonfly/pull/3243)
- chore: improve dfly_bench by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3244](https://togithub.com/dragonflydb/dragonfly/pull/3244)
- chore(tiering): External alloc free page chaining by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3237](https://togithub.com/dragonflydb/dragonfly/pull/3237)
- fix: total_stash_overflows statistic by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3248](https://togithub.com/dragonflydb/dragonfly/pull/3248)
- chore: update action versions by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3250](https://togithub.com/dragonflydb/dragonfly/pull/3250)
- chore(lua): Return which undeclared key was accessed by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3245](https://togithub.com/dragonflydb/dragonfly/pull/3245)
- chore: replace session wide fixtures with scope by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3251](https://togithub.com/dragonflydb/dragonfly/pull/3251)
- chore: pull helio and adjust mimalloc for 32MiB segments by
[@&#8203;kostasrim](https://togithub.com/kostasrim) in
[https://github.com/dragonflydb/dragonfly/pull/3174](https://togithub.com/dragonflydb/dragonfly/pull/3174)
- chore: add more logs around the duplicate value case in small_bins by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3254](https://togithub.com/dragonflydb/dragonfly/pull/3254)
- fix: fix move error during migration finalization by
[@&#8203;BorysTheDev](https://togithub.com/BorysTheDev) in
[https://github.com/dragonflydb/dragonfly/pull/3253](https://togithub.com/dragonflydb/dragonfly/pull/3253)
- chore: upload all the logs from /tmp by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3263](https://togithub.com/dragonflydb/dragonfly/pull/3263)
- fix(tiering): Throttle snapshot load by
[@&#8203;dranikpg](https://togithub.com/dranikpg) in
[https://github.com/dragonflydb/dragonfly/pull/3249](https://togithub.com/dragonflydb/dragonfly/pull/3249)
- chore: initiate grow preemptively by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3267](https://togithub.com/dragonflydb/dragonfly/pull/3267)
- chore(monitoring): add more dashboards + memcached by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3268](https://togithub.com/dragonflydb/dragonfly/pull/3268)
- fix(json_family): fix JSON.GET commmand for JSON legacy mode by
[@&#8203;BagritsevichStepan](https://togithub.com/BagritsevichStepan) in
[https://github.com/dragonflydb/dragonfly/pull/3261](https://togithub.com/dragonflydb/dragonfly/pull/3261)
- chore: dfly_bench can send traffic to memcached by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3271](https://togithub.com/dragonflydb/dragonfly/pull/3271)
- chore: print effective QPS of the server. by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3274](https://togithub.com/dragonflydb/dragonfly/pull/3274)
- chore: debugging fixes by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3275](https://togithub.com/dragonflydb/dragonfly/pull/3275)
- chore: more debug checks around tiered storage by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3277](https://togithub.com/dragonflydb/dragonfly/pull/3277)
- chore(license): Fix typo in LICENSE.md text by
[@&#8203;softmoth](https://togithub.com/softmoth) in
[https://github.com/dragonflydb/dragonfly/pull/3283](https://togithub.com/dragonflydb/dragonfly/pull/3283)
- fix(test): Verify that save has not finished by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3278](https://togithub.com/dragonflydb/dragonfly/pull/3278)
- Create scorecard.yml by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3270](https://togithub.com/dragonflydb/dragonfly/pull/3270)
- chore: Disable cluster_mgr_test by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3279](https://togithub.com/dragonflydb/dragonfly/pull/3279)
- fix: Increase key count to make test more robust by
[@&#8203;chakaz](https://togithub.com/chakaz) in
[https://github.com/dragonflydb/dragonfly/pull/3286](https://togithub.com/dragonflydb/dragonfly/pull/3286)
- fix: properly clean tiered state upon flash by
[@&#8203;romange](https://togithub.com/romange) in
[https://github.com/dragonflydb/dragonfly/pull/3281](https://togithub.com/dragonflydb/dragonfly/pull/3281)
- fix(bug): crash on takeover and info replication by
[@&#8203;adiholden](https://togithub.com/adiholden) in
[https://github.com/dragonflydb/dragonfly/pull/3282](https://togithub.com/dragonflydb/dragonfly/pull/3282)

##### New Contributors

- [@&#8203;softmoth](https://togithub.com/softmoth) made their first
contribution in
[https://github.com/dragonflydb/dragonfly/pull/3283](https://togithub.com/dragonflydb/dragonfly/pull/3283)

##### Huge thanks to all the contributors! ❤️

**Full Changelog**:
dragonflydb/dragonfly@v1.19.0...v1.20.0

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined),
Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you
are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the
rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about these
updates again.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR has been generated by [Renovate
Bot](https://togithub.com/renovatebot/renovate).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNy40MjYuMiIsInVwZGF0ZWRJblZlciI6IjM3LjQyNi40IiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6WyJyZW5vdmF0ZS9jb250YWluZXIiLCJ0eXBlL21pbm9yIl19-->

Co-authored-by: lumiere-bot[bot] <98047013+lumiere-bot[bot]@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants