Martin Sumner
e01efe02f6
Long snaphsot timeout increase
...
Increase this to 90 minutes. The first time all the snapshots are
rebuilt it may take a long time, but they all get scheduled together -
and queued until concurrency limits allow it to be completed.
currently the snapshot is made on initialisation, and only released
when completed (which may be after the queue). so the last couple of
snapshots were over-shooting the 1 hour.
2017-04-13 22:43:29 +01:00
Martin Sumner
618d9cf53b
FoldHeads to output binary
...
so that byte_size will work in sweeper
2017-04-11 11:17:27 +01:00
Martin Sumner
9badc8fbe7
Merge branch 'master' into mas-sweeperfold-i59
2017-04-10 21:49:08 +01:00
martinsumner
60b0b88226
Switch to binary response
...
Force header in fold_heads to be a binary ... as this is what KV expects
2017-04-07 17:08:40 +00:00
martinsumner
6d42abbc1a
Add bybucket to fold_heads
...
give fold_heads equivalent functionality to fold_objects - both can now
be done for allkeys and bybucket
2017-04-07 14:56:28 +00:00
martinsumner
9375baf636
Add unit test for foldheads
...
compare foldheads foldobjects and hahstree_query output
2017-04-07 14:19:25 +00:00
martinsumner
b464e2e28c
Extend foldobjects to support proxy object
...
To allow for folds which probbaly don't need values to not always to
have to fetch the value
2017-04-07 12:09:11 +00:00
Martin Sumner
4e9fa2a206
Timeout long-running snapshots
...
Add logic to timeout long-running snapshots.
2017-04-05 09:16:01 +01:00
martinsumner
400f65f557
Switch to binary metadata
...
Trya nd maintain binary format when stored in Ledger so less
swapping/changing as added and removed.
2017-04-04 10:02:35 +00:00
martinsumner
43bfbe3e0e
Add in scheduler function
...
To assist in scheduling compaction
2017-03-30 15:46:37 +01:00
martinsumner
11ff3129f3
Reduce compaction targets
...
Cmpaction is overly aggressive. It is a lot of work to compact a run of
files for just 20% reduction in disk space, when disk space for the
Journal (i.e. low IOPS disk space should be relatively inexpensive).
Require at least a 40% reduction for a compaction job.
2017-03-30 12:15:36 +01:00
martinsumner
6143fcb664
Remove binary_to_term
...
when fetching don't need to binary_to_term key changes
2017-03-29 15:37:04 +01:00
Martin Sumner
8db73917fb
Need also to remove unused bits
2017-03-22 00:14:37 +00:00
Martin Sumner
15af4942ae
Remove busy log
...
Accounts for 60% of logs
2017-03-22 00:11:17 +00:00
martinsumner
e59585d733
Merge remote-tracking branch 'refs/remotes/origin/mas-etsmem-i52' into mas-sstfiveblocks
2017-03-21 18:25:18 +00:00
martinsumner
eef2199335
Up level for yield to 2
2017-03-21 18:24:11 +00:00
martinsumner
f108871691
Vclock metadata change
...
Test performance ocntinues to be worse since the vlock metadata change.
Reversing out juts in case.
2017-03-21 18:15:56 +00:00
martinsumner
756b46bb4d
Return to merge scan width of 16
...
This was reduced before the use of binary blocks was committed
2017-03-21 17:53:34 +00:00
martinsumner
1fdcdf3b37
Midblock size - lookup
...
No real reason for the midblock to be smaller in lookup slots - so give
the blocks a more consistent size
2017-03-21 17:47:08 +00:00
martinsumner
64e944d9ba
Change to 5 blocks in SST Slot
...
Change to 5 blocks is intended to make the blocks in lookup slots
fractionally smaller, but more importantly to introduce a middle block
that cna be opened in a binary-split style fashion to reduce the number
of blocks that need to be opened for range queries. Worst case for
full slots is 3 blocks now not 4.
2017-03-21 16:54:23 +00:00
martinsumner
682dfc4d59
Revert "Revert "ETS - delete table not objects""
...
This reverts commit c46377584f
.
2017-03-21 12:02:22 +00:00
martinsumner
dd0316eedf
Yield on query selectively
...
Still not clear if yielding is the cause of memory problems, but taking
it away universally has impacted throughput. At the very least we
should continue to yield on high-contention files (those at higher
levels), where the processes are more likely to be quickly terminated
anyway allowing GC to be invoked.
2017-03-21 11:03:29 +00:00
martinsumner
c46377584f
Revert "ETS - delete table not objects"
...
This reverts commit 7dc4913d5a
.
2017-03-21 01:32:41 +00:00
martinsumner
e18d2f2f00
Delete the ETS table from CDB files
...
Rather than simply dereference it - delete it
2017-03-21 01:31:42 +00:00
martinsumner
419541f5dd
Fix to delete_pending state
2017-03-20 23:43:31 +00:00
martinsumner
415ac6017b
Move sst get_kv range back inside process
...
Moved outside to stop blocking, but also avoids copy. Move back out to
see if it may be related to the binary memory leak
2017-03-20 23:22:46 +00:00
martinsumner
7dc4913d5a
ETS - delete table not objects
...
Try and delete the table not just the objects in the table - will this
improve memory leak?
2017-03-20 22:43:22 +00:00
Martin Sumner
eec9d509f9
Add back hash performance tests
...
Need to consider if magic hash is an issue
2017-03-20 20:28:47 +00:00
martinsumner
7154815a2b
Keep vclock as binary
...
No obvious, need at present for vlock to be a term within leveled
2017-03-20 20:28:02 +00:00
martinsumner
f3ffa920af
Trying to standardise binary manipulation of value
...
Looking into theory that use of term_to_binary is imperfect. Also may
be better to compress values only when they are compacted?
2017-03-20 15:43:54 +00:00
martinsumner
5c662aeca1
Additional unit test
...
Need to test scenario where the key list the SST file created from is an
exact multiple of the slot size
2017-03-19 23:42:24 +00:00
martinsumner
431c2cee40
Remove unnecessary line
...
Brnach cannot be reached as firts key is always discovered when it is a
no_loolup
2017-03-19 23:37:50 +00:00
martinsumner
f20aba9c8b
Curtail trimmed slot crazyness
...
There was complicated and confusing code that achieved nothing for
effiency when trimming slots. the expensive part (binary_to_term) was
still needed on every block, and it was hard to get code coverage and
make sense of what it was really trying to achieve.
This is now much simpler - and may set us up for potential further
indexing help.
2017-03-19 21:47:22 +00:00
martinsumner
c203e2ee06
Range queries - pass out as binaries
...
Avoid converting to erlang temr wihtin the FSM and then requiring a copy
outside of the FSM - pass out as a binary
2017-03-17 10:47:20 +00:00
martinsumner
f287895db0
Pass out slots as a binary
...
If we convetr firts to a list, then the list has to be copied - passing
out as binaries means the bulk can be passed as references
2017-03-17 10:43:34 +00:00
martinsumner
80b62cbff2
Debug excessive log
...
Logs excessively during 2i tests. Set to debug for now, until can think
further about this
2017-03-16 20:03:18 +00:00
martinsumner
8b2091cef7
Remaining ledger snapshots log -> debug
...
This log under 2i load appears thousands of times per second. Not
sustainable as an info log. Will need to think about how to manage
this, but setting back to debug for now
2017-03-16 19:37:39 +00:00
martinsumner
5dbd7a2bc2
Check query out of range
...
It doesn't work - so protecting against it in fetch_range is pointless,
will blow up in lookup_slots
2017-03-16 08:43:18 +00:00
martinsumner
6199a2c352
RTrim
...
RTrim only worked in special case of key matching, that would never
occur in real world range query. RTrim should really check for key
passing.
Returning empty list should not be possible - unless the query is
outside of the range entirely (and such a query should never go to this
SST).
2017-03-16 08:37:36 +00:00
martinsumner
dde37566b9
Add unit test for more than one slot
2017-03-15 16:40:43 +00:00
martinsumner
c6d17b998e
Additional unit tests for SST range fetches
...
Resolve some of coverage issues
2017-03-15 11:27:46 +00:00
martinsumner
508da0be45
Additional unit tests
2017-03-14 22:47:48 +00:00
martinsumner
8a5ed1e198
Confirm skip on unknowns when compacting journal
2017-03-14 17:26:39 +00:00
martinsumner
878ec41ffa
Merge remote-tracking branch 'refs/remotes/origin/mas-sstblockv2-i42' into mas-pushmem-i46
...
# Conflicts:
# src/leveled_penciller.erl
2017-03-14 15:43:35 +00:00
martinsumner
4b60c0e35b
Scan width semi-reverted
...
No evidence from valume test that the scan width has made a posiitve
difference - so reverting, but not fully as slots may now be twice as
big, so sticking to half previous value
2017-03-14 01:18:50 +00:00
martinsumner
19bc838d90
Fix bad exit with no FK
2017-03-14 00:52:07 +00:00
martinsumner
a1c49b668a
Fix empty file again
...
No special definition of empty required, as now an empty list when empty
2017-03-14 00:17:09 +00:00
martinsumner
2b0ec1d9cc
Don't double-loop on slots
...
Previous version built a list of slots, then iterated over it to build a
list of binaries. This converts the slot to a binary before building
the list
2017-03-13 23:51:48 +00:00
martinsumner
4f0622d2ac
Merge remote-tracking branch 'refs/remotes/origin/mas-sstblock-i42' into mas-sstblockv2-i42
2017-03-13 21:09:13 +00:00
martinsumner
c5bb150f97
Drop some logs
...
Not found to be interesting so far
2017-03-13 20:30:33 +00:00