Commit Graph

155 Commits

Author SHA1 Message Date
bors[bot]
8bc7dd8b03 Merge #143
143: Shared update store r=irevoire a=MarinPostma

This PR changes the updates process so that only one instance of an update store is shared among indexes.

This allows updates to always be processed sequentially without additional synchronization, and fixes the bug where all the first pending update for each index were reported as processing whereas only one was.

EDIT:

I ended having to rewrite the whole `UpdateStore` to allow updates being really queued and processed sequentially in the ordered they were added. For that purpose I created a `pending_queue` that orders the updates by a global update id.

To find the next `update_id` to use, both globally and for each index, I have created another database that contains the next id to use.

Finally, all updates that have been processed (with success or otherwise) are all stores in an `updates` database.

The layout for the keys of these databases are such that it is easy to iterate over the elements for a particular index, and greatly reduces the amount of code to do so, compared to the former implementation.

I have also simplified the locking mechanism for the update store, thanks to the StateLock data structure, that allow both an arbitrary number of readers and a single writer to concurrently access the state. The current state can be either Idle, Processing, or Snapshotting. When an update or snapshotting is ongoing, the process holds the state lock until it is done processing its task. When it is done, it sets bask the state to Idle.

I have made other small improvements here and there, and have let some other for work, such as:
- When creating an update file to hold a request's content, it would be preferable to first create a temporary file, and then atomically persist it when we have written to it. This would simplify the case when there is no data to be written to the file, since we wouldn't have to take care about cleaning after ourselves.
- The logic for content validation must be factored.
- Some more tests related to error handling in the process_pending_update function.
- The issue #159

close #114


Co-authored-by: Marin Postma <postma.marin@protonmail.com>
2021-04-27 18:41:55 +00:00
Marin Postma
a961f0ce75 fix clippy warnings 2021-04-27 18:28:46 +02:00
Marin Postma
bb79a15c04 reenable ranking rules route 2021-04-27 15:29:00 +02:00
Marin Postma
4fe2a13c71 rewrite update store 2021-04-27 15:20:52 +02:00
Marin Postma
51829ad85e review fixes 2021-04-27 15:10:57 +02:00
Marin Postma
c78f351300 fix tests 2021-04-27 15:10:57 +02:00
Marin Postma
ee675eadf1 fix stats 2021-04-27 15:10:55 +02:00
Marin Postma
33830d5ecf fix snapshots 2021-04-27 15:09:55 +02:00
Marin Postma
2b154524bb fix filtered out pending update 2021-04-27 15:09:23 +02:00
Marin Postma
b626d02ffe simplify index actor run loop 2021-04-27 15:09:22 +02:00
Marin Postma
9ce68d11a7 single update store instance 2021-04-27 15:09:21 +02:00
Marin Postma
5a38f13cae multi_index udpate store 2021-04-27 15:07:13 +02:00
Clémentine Urquizar
1ba46f8f77 Disable clippy rule 2021-04-27 12:43:00 +02:00
Clémentine Urquizar
f80ea24d2b Add tests on every platform and fix clippy errors 2021-04-27 12:42:59 +02:00
Marin Postma
5014f74649 put mini-dashboard in out-dir 2021-04-27 09:32:17 +02:00
Clémentine Urquizar
f3b6bf55a6 Update version for the next release (alpha4) 2021-04-26 19:05:16 +02:00
Marin Postma
c2461e5066 review fixes 2021-04-26 10:20:46 +02:00
Marin Postma
e4bd1bc5ce update actix-web-static-file rev 2021-04-22 11:42:41 +02:00
Marin Postma
90f57c1329 update CI & Dockerfile 2021-04-22 11:22:09 +02:00
Marin Postma
6af769af20 bump mini-dashboard 2021-04-22 10:45:05 +02:00
Marin Postma
6bcf20c70e serve static site 2021-04-22 10:26:54 +02:00
Marin Postma
bb79695e44 load mini-dashboard assets 2021-04-22 10:26:54 +02:00
Marin Postma
ea5517bc8c add mini-dashboard feature 2021-04-22 10:26:54 +02:00
Clémentine Urquizar
a72d2f66cd use <em> tags instead of <mark> tags for highlighting 2021-04-21 19:14:55 +02:00
Marin Postma
dd2914873b fix document fields order 2021-04-20 21:30:30 +02:00
Marin Postma
d9a29cae60 fix ignored displayed attributes 2021-04-20 21:23:35 +02:00
Marin Postma
7a737d2bd3 support wildcard 2021-04-20 21:23:35 +02:00
Marin Postma
881b099c8e add tests 2021-04-20 21:23:34 +02:00
Marin Postma
c6bb36efa5 implement _formated 2021-04-20 21:23:28 +02:00
Marin Postma
526a05565e add SearchHit structure 2021-04-20 21:22:48 +02:00
Clémentine Urquizar
b8e535579f Update version for the next release (alpha3) 2021-04-20 16:11:07 +02:00
Marin Postma
f8c338e3a7 add test for dedicated distinct route 2021-04-20 15:49:17 +02:00
Marin Postma
6c470cf687 enable distinct-attribute setting route 2021-04-20 11:34:18 +02:00
Marin Postma
ec63e13896 bump actix 2021-04-20 11:29:32 +02:00
Marin Postma
1746132c7d add test set/reset distinct attribute 2021-04-20 11:29:08 +02:00
mpostma
ec230c2835 enable distinct 2021-04-20 11:29:06 +02:00
Marin Postma
45665245dc bump actix 2021-04-20 11:07:23 +02:00
bors[bot]
94c5c5843b Merge #149
149: Handle star in attributes_to_retrieve r=MarinPostma a=curquiza

Closes #147

Co-authored-by: Clémentine Urquizar <clementine@meilisearch.com>
2021-04-19 17:29:21 +00:00
Clémentine Urquizar
8eceba98d3 Handle star in attributes_to_retrieve 2021-04-19 18:20:19 +02:00
Clémentine Urquizar
2c380731b9 Update milli version to v0.1.1 2021-04-19 16:03:39 +02:00
bors[bot]
7ce74f95a2 Merge #146
146: Remove another unused legacy file r=MarinPostma a=irevoire

When doing #135 I missed an old useless file in the scr/routes directory

Co-authored-by: tamo <tamo@meilisearch.com>
2021-04-15 18:05:28 +00:00
tamo
ec3a08ea0c remove another unused legacy file 2021-04-15 14:44:43 +02:00
Clémentine Urquizar
b0717b75d9 Update tokenizer to v0.2.1 2021-04-14 19:06:18 +02:00
Alexey Shekhirin
f87afbc558 fix(http): commit date & SHA in startup message 2021-04-13 20:16:18 +03:00
Alexey Shekhirin
9eaf048a06 fix(http): use BTreeMap instead of HashMap to preserve stats order 2021-04-13 11:59:07 +03:00
Alexey Shekhirin
adfdb99abc feat(http): calculate updates' and uuids' dbs size 2021-04-09 15:59:12 +03:00
Alexey Shekhirin
ae1655586c fixes after review 2021-04-09 14:40:48 +03:00
Alexey Shekhirin
698a1ea582 feat(http): store processing as RwLock<Option<Uuid>> in index_actor 2021-04-09 14:34:43 +03:00
Alexey Shekhirin
87412f63ef feat(http): implement is_indexing for stats 2021-04-09 14:34:42 +03:00
Alexey Shekhirin
09d9a29176 test(http): server & index stats 2021-04-09 14:34:42 +03:00