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

Add setting to control the maximum swap space #10978

Merged
merged 40 commits into from
Apr 17, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
40 commits
Select commit Hold shift + click to select a range
2130e4d
moved from 'temporary_file_manager' branch
Tishj Mar 1, 2024
d20a0f7
Merge branch 'temporary_file_manager' into maximum_swap_space
Tishj Mar 1, 2024
9d5d254
Merge branch 'temporary_file_manager' into maximum_swap_space
Tishj Mar 1, 2024
1e441a6
create the exception, thrown whenever we try to increase the temp dir…
Tishj Mar 1, 2024
b7d9997
increase to 5x memory limit
Tishj Mar 7, 2024
3d10568
collect information about the disk when possible
Tishj Mar 8, 2024
a0d98f4
further thinking
Tishj Mar 8, 2024
8c8ffe6
test that explicitly set values are not overridden when we create the…
Tishj Mar 8, 2024
d3ecab6
add initial tests
Tishj Mar 8, 2024
a97bcb7
more tests with different max swap sizes
Tishj Mar 8, 2024
0227e2d
fix up comment
Tishj Mar 8, 2024
d56137a
check if the config was set explicitly or not in DatabaseInstance::Co…
Tishj Mar 8, 2024
b37d193
avoid modifying the passed in DBConfig
Tishj Mar 8, 2024
1491dd7
fix up some behavior
Tishj Mar 8, 2024
8b2b5cd
make the in-memory database detection better
Tishj Mar 8, 2024
96fc46e
initialize temp_directory to '.tmp' for every version of in-memory co…
Tishj Mar 8, 2024
8ad8353
use 90% of the available disk space by default
Tishj Mar 8, 2024
63e37c9
Merge remote-tracking branch 'upstream/main' into maximum_swap_space
Tishj Mar 11, 2024
29678c5
RESET temp_directory should use the same behavior as DatabaseInstance…
Tishj Mar 11, 2024
9e5d10f
add missing PRAGMA statement, because of a bug the temp directory was…
Tishj Mar 11, 2024
dfc5e70
the tight constraints we set are broken when --force-storage is used,…
Tishj Mar 12, 2024
0eee4f2
Merge remote-tracking branch 'upstream/main' into maximum_swap_space
Tishj Mar 13, 2024
95df992
Merge remote-tracking branch 'upstream/main' into maximum_swap_space
Tishj Mar 20, 2024
4848acf
move the setting into the buffer manager + temporary directory handle
Tishj Mar 21, 2024
1708612
get rid of FileSizeMonitor, just pass along the TemporaryFileManager &
Tishj Mar 21, 2024
03fc90e
remove named connection, should be stripped when it gets into the dat…
Tishj Mar 21, 2024
eebc24c
test error when setting a limit that's too low
Tishj Mar 21, 2024
5774dc6
delay the available disk space lookup until we have made sure the dir…
Tishj Mar 23, 2024
fb8315c
Merge remote-tracking branch 'upstream/main' into maximum_swap_space
Tishj Mar 27, 2024
b82b9c1
Merge remote-tracking branch 'upstream/main' into maximum_swap_space
Tishj Mar 28, 2024
affb50b
fix merge conflicts
Tishj Mar 28, 2024
80f6b7d
Merge remote-tracking branch 'upstream/main' into maximum_swap_space
Tishj Mar 30, 2024
815c155
remove dead code, fix tidy issue
Tishj Apr 2, 2024
a8de19b
Merge remote-tracking branch 'upstream/main' into maximum_swap_space
Tishj Apr 3, 2024
df40291
use INVALID_INDEX-1 to indicate unlimited swap space
Tishj Apr 9, 2024
180e4a2
Merge remote-tracking branch 'upstream/main' into maximum_swap_space
Tishj Apr 9, 2024
6b8c631
test setting the maximum swap space to unlimited
Tishj Apr 9, 2024
da941a5
Merge remote-tracking branch 'upstream/main' into maximum_swap_space
Tishj Apr 11, 2024
5e4938b
create an assertion out of this, TemporaryDirectoryHandle should neve…
Tishj Apr 12, 2024
c93ab90
handle failing GetAvailableDiskSpace
Tishj Apr 12, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
test that explicitly set values are not overridden when we create the…
… temp_directory
  • Loading branch information
Tishj committed Mar 8, 2024
commit 8c8ffe6ef20c7983f336c3e9d001a447b848367c
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
# name: test/sql/storage/max_swap_space.test
# group: [storage]
# name: test/sql/storage/temp_directory/max_swap_space.test
# group: [temp_directory]

require skip_reload

Expand Down Expand Up @@ -106,6 +106,3 @@ CREATE TABLE t2 AS SELECT * FROM range(1000000);
query I
select current_setting('max_temp_directory_size') a where a == '0 bytes'
----

## TODO: test that the explicitly set value by the user does not get overridden when 'temp_directory' is set to a directory that doesn't exist yet
# when the 'temp_directory' is created by us - the explicitly set value should not be overridden
29 changes: 29 additions & 0 deletions test/sql/storage/temp_directory/max_swap_space_explicit.test
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
# name: test/sql/storage/temp_directory/max_swap_space_explicit.test
# group: [temp_directory]

require skip_reload

statement ok
PRAGMA memory_limit='2MB'

# --- Not changed when set explicitly by the user

# If we set 'max_temp_directory_size' explicitly, it will not be overridden
statement ok
set max_temp_directory_size='15gb'

# When we change the temp_directory to something that doesnt exist
statement ok
set temp_directory = '__TEST_DIR__/this_directory_should_not_exist__swap_space'

query I nosort explicitly_set
select current_setting('max_temp_directory_size')
----

statement ok
CREATE TABLE t2 AS SELECT * FROM range(1000000);

# The 'temp_directory' was created, but the value of 'max_temp_directory_size' was set explicitly, so it was unaltered
query I nosort explicitly_set
select current_setting('max_temp_directory_size')
----