Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
R
rust-rocksdb
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
fangzongwu
rust-rocksdb
Commits
fb75c242
Commit
fb75c242
authored
Sep 28, 2017
by
Kohei Watanabe
Committed by
siddontang
Sep 28, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Read only mode at opening DB (#141)
parent
cc1db4a1
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
162 additions
and
11 deletions
+162
-11
lib.rs
librocksdb_sys/src/lib.rs
+16
-0
rocksdb.rs
src/rocksdb.rs
+53
-11
test.rs
tests/test.rs
+1
-0
test_read_only.rs
tests/test_read_only.rs
+92
-0
No files found.
librocksdb_sys/src/lib.rs
View file @
fb75c242
...
...
@@ -510,6 +510,12 @@ extern "C" {
path
:
*
const
c_char
,
err
:
*
mut
*
mut
c_char
,
)
->
*
mut
DBInstance
;
pub
fn
crocksdb_open_for_read_only
(
options
:
*
mut
Options
,
path
:
*
const
c_char
,
error_if_log_file_exist
:
bool
,
err
:
*
mut
*
mut
c_char
,
)
->
*
mut
DBInstance
;
pub
fn
crocksdb_writeoptions_create
()
->
*
mut
DBWriteOptions
;
pub
fn
crocksdb_writeoptions_destroy
(
writeopts
:
*
mut
DBWriteOptions
);
pub
fn
crocksdb_writeoptions_set_sync
(
writeopts
:
*
mut
DBWriteOptions
,
v
:
bool
);
...
...
@@ -828,6 +834,16 @@ extern "C" {
column_family_handles
:
*
const
*
mut
DBCFHandle
,
err
:
*
mut
*
mut
c_char
,
)
->
*
mut
DBInstance
;
pub
fn
crocksdb_open_for_read_only_column_families
(
options
:
*
const
Options
,
path
:
*
const
c_char
,
num_column_families
:
c_int
,
column_family_names
:
*
const
*
const
c_char
,
column_family_options
:
*
const
*
const
Options
,
column_family_handles
:
*
const
*
mut
DBCFHandle
,
error_if_log_file_exist
:
bool
,
err
:
*
mut
*
mut
c_char
,
)
->
*
mut
DBInstance
;
pub
fn
crocksdb_create_column_family
(
db
:
*
mut
DBInstance
,
column_family_options
:
*
const
Options
,
...
...
src/rocksdb.rs
View file @
fb75c242
...
...
@@ -352,10 +352,38 @@ impl DB {
where
T
:
Into
<
ColumnFamilyDescriptor
<
'a
>>
,
{
DB
::
open_cf_internal
(
opts
,
path
,
cfds
)
DB
::
open_cf_internal
(
opts
,
path
,
cfds
,
None
)
}
fn
open_cf_internal
<
'a
,
T
>
(
opts
:
DBOptions
,
path
:
&
str
,
cfds
:
Vec
<
T
>
)
->
Result
<
DB
,
String
>
pub
fn
open_for_read_only
(
opts
:
DBOptions
,
path
:
&
str
,
error_if_log_file_exist
:
bool
,
)
->
Result
<
DB
,
String
>
{
let
cfds
:
Vec
<&
str
>
=
vec!
[];
DB
::
open_cf_for_read_only
(
opts
,
path
,
cfds
,
error_if_log_file_exist
)
}
pub
fn
open_cf_for_read_only
<
'a
,
T
>
(
opts
:
DBOptions
,
path
:
&
str
,
cfds
:
Vec
<
T
>
,
error_if_log_file_exist
:
bool
,
)
->
Result
<
DB
,
String
>
where
T
:
Into
<
ColumnFamilyDescriptor
<
'a
>>
,
{
DB
::
open_cf_internal
(
opts
,
path
,
cfds
,
Some
(
error_if_log_file_exist
))
}
fn
open_cf_internal
<
'a
,
T
>
(
opts
:
DBOptions
,
path
:
&
str
,
cfds
:
Vec
<
T
>
,
// if none, open for read write mode.
// otherwise, open for read only.
error_if_log_file_exist
:
Option
<
bool
>
,
)
->
Result
<
DB
,
String
>
where
T
:
Into
<
ColumnFamilyDescriptor
<
'a
>>
,
{
...
...
@@ -393,15 +421,29 @@ impl DB {
let
db_cf_ptrs
=
cf_names
.as_ptr
();
let
db_cf_opts
=
cf_options
.as_ptr
();
let
db_cf_handles
=
cf_handles
.as_ptr
();
unsafe
{
ffi_try!
(
crocksdb_open_column_families
(
db_options
,
db_path
,
db_cfs_count
,
db_cf_ptrs
,
db_cf_opts
,
db_cf_handles
))
if
let
Some
(
flag
)
=
error_if_log_file_exist
{
unsafe
{
ffi_try!
(
crocksdb_open_for_read_only_column_families
(
db_options
,
db_path
,
db_cfs_count
,
db_cf_ptrs
,
db_cf_opts
,
db_cf_handles
,
flag
))
}
}
else
{
unsafe
{
ffi_try!
(
crocksdb_open_column_families
(
db_options
,
db_path
,
db_cfs_count
,
db_cf_ptrs
,
db_cf_opts
,
db_cf_handles
))
}
}
};
if
cf_handles
.iter
()
.any
(|
h
|
h
.is_null
())
{
...
...
tests/test.rs
View file @
fb75c242
...
...
@@ -17,3 +17,4 @@ mod test_table_properties;
mod
test_event_listener
;
mod
test_delete_range
;
mod
test_delete_files_in_range
;
mod
test_read_only
;
tests/test_read_only.rs
0 → 100644
View file @
fb75c242
use
rocksdb
::{
ColumnFamilyOptions
,
DBOptions
,
Writable
,
DB
};
use
tempdir
::
TempDir
;
macro_rules!
check_kv
{
(
$db:expr
,
$key:expr
,
$val:expr
)
=>
{
assert_eq!
(
$db
.get
(
$key
)
.unwrap
()
.unwrap
(),
$val
);
};
(
$db:expr
,
$cf:expr
,
$key:expr
,
$val:expr
)
=>
{
assert_eq!
(
$db
.get_cf
(
$cf
,
$key
)
.unwrap
()
.unwrap
(),
$val
);
}
}
#[test]
fn
test_open_for_read_only
()
{
let
temp
=
TempDir
::
new
(
"_rust_rocksdb_test_open_for_read_only"
)
.expect
(
""
);
let
path
=
temp
.path
()
.to_str
()
.unwrap
();
let
mut
opts
=
DBOptions
::
new
();
opts
.create_if_missing
(
true
);
let
rw
=
DB
::
open_default
(
path
)
.unwrap
();
rw
.put
(
b
"k1"
,
b
"v1"
)
.unwrap
();
rw
.put
(
b
"k2"
,
b
"v2"
)
.unwrap
();
rw
.put
(
b
"k3"
,
b
"v3"
)
.unwrap
();
check_kv!
(
rw
,
b
"k1"
,
b
"v1"
);
check_kv!
(
rw
,
b
"k2"
,
b
"v2"
);
check_kv!
(
rw
,
b
"k3"
,
b
"v3"
);
let
r1
=
DB
::
open_for_read_only
(
opts
.clone
(),
path
,
false
)
.unwrap
();
check_kv!
(
r1
,
b
"k1"
,
b
"v1"
);
check_kv!
(
r1
,
b
"k2"
,
b
"v2"
);
check_kv!
(
r1
,
b
"k3"
,
b
"v3"
);
let
r2
=
DB
::
open_for_read_only
(
opts
.clone
(),
path
,
false
)
.unwrap
();
check_kv!
(
r2
,
b
"k1"
,
b
"v1"
);
check_kv!
(
r2
,
b
"k2"
,
b
"v2"
);
check_kv!
(
r2
,
b
"k3"
,
b
"v3"
);
let
r3
=
DB
::
open_for_read_only
(
opts
.clone
(),
path
,
false
)
.unwrap
();
check_kv!
(
r3
,
b
"k1"
,
b
"v1"
);
check_kv!
(
r3
,
b
"k2"
,
b
"v2"
);
check_kv!
(
r3
,
b
"k3"
,
b
"v3"
);
drop
(
rw
);
drop
(
r1
);
drop
(
r2
);
drop
(
r3
);
}
#[test]
fn
test_open_cf_for_read_only
()
{
let
temp
=
TempDir
::
new
(
"_rust_rocksdb_test_open_cf_for_read_only"
)
.expect
(
""
);
let
path
=
temp
.path
()
.to_str
()
.unwrap
();
{
let
mut
rw
=
DB
::
open_default
(
path
)
.unwrap
();
let
cf_opts
=
ColumnFamilyOptions
::
new
();
let
_
=
rw
.create_cf
(
"cf1"
,
cf_opts
.clone
())
.unwrap
();
let
_
=
rw
.create_cf
(
"cf2"
,
cf_opts
.clone
())
.unwrap
();
}
{
let
rw
=
DB
::
open_cf
(
DBOptions
::
new
(),
path
,
vec!
[
"cf1"
,
"cf2"
])
.unwrap
();
let
cf1
=
rw
.cf_handle
(
"cf1"
)
.unwrap
();
rw
.put_cf
(
cf1
,
b
"cf1_k1"
,
b
"cf1_v1"
)
.unwrap
();
rw
.put_cf
(
cf1
,
b
"cf1_k2"
,
b
"cf1_v2"
)
.unwrap
();
rw
.put_cf
(
cf1
,
b
"cf1_k3"
,
b
"cf1_v3"
)
.unwrap
();
check_kv!
(
rw
,
cf1
,
b
"cf1_k1"
,
b
"cf1_v1"
);
check_kv!
(
rw
,
cf1
,
b
"cf1_k2"
,
b
"cf1_v2"
);
check_kv!
(
rw
,
cf1
,
b
"cf1_k3"
,
b
"cf1_v3"
);
let
cf2
=
rw
.cf_handle
(
"cf2"
)
.unwrap
();
rw
.put_cf
(
cf2
,
b
"cf2_k1"
,
b
"cf2_v1"
)
.unwrap
();
rw
.put_cf
(
cf2
,
b
"cf2_k2"
,
b
"cf2_v2"
)
.unwrap
();
rw
.put_cf
(
cf2
,
b
"cf2_k3"
,
b
"cf2_v3"
)
.unwrap
();
check_kv!
(
rw
,
cf2
,
b
"cf2_k1"
,
b
"cf2_v1"
);
check_kv!
(
rw
,
cf2
,
b
"cf2_k2"
,
b
"cf2_v2"
);
check_kv!
(
rw
,
cf2
,
b
"cf2_k3"
,
b
"cf2_v3"
);
}
{
let
r1
=
DB
::
open_cf_for_read_only
(
DBOptions
::
new
(),
path
,
vec!
[
"cf1"
],
false
)
.unwrap
();
let
cf1
=
r1
.cf_handle
(
"cf1"
)
.unwrap
();
check_kv!
(
r1
,
cf1
,
b
"cf1_k1"
,
b
"cf1_v1"
);
check_kv!
(
r1
,
cf1
,
b
"cf1_k2"
,
b
"cf1_v2"
);
check_kv!
(
r1
,
cf1
,
b
"cf1_k3"
,
b
"cf1_v3"
);
let
r2
=
DB
::
open_cf_for_read_only
(
DBOptions
::
new
(),
path
,
vec!
[
"cf2"
],
false
)
.unwrap
();
let
cf2
=
r2
.cf_handle
(
"cf2"
)
.unwrap
();
check_kv!
(
r2
,
cf2
,
b
"cf2_k1"
,
b
"cf2_v1"
);
check_kv!
(
r2
,
cf2
,
b
"cf2_k2"
,
b
"cf2_v2"
);
check_kv!
(
r2
,
cf2
,
b
"cf2_k3"
,
b
"cf2_v3"
);
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment