Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
f62b63dc
Commit
f62b63dc
authored
May 21, 2004
by
joreland@mysql.com
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added unit performance test for scan
parent
1d2b14f7
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
390 additions
and
0 deletions
+390
-0
ndb/include/ndbapi/NdbConnection.hpp
ndb/include/ndbapi/NdbConnection.hpp
+4
-0
ndb/include/ndbapi/NdbOperation.hpp
ndb/include/ndbapi/NdbOperation.hpp
+5
-0
ndb/include/ndbapi/NdbReceiver.hpp
ndb/include/ndbapi/NdbReceiver.hpp
+4
-0
ndb/test/ndbapi/testScanPerf/Makefile
ndb/test/ndbapi/testScanPerf/Makefile
+9
-0
ndb/test/ndbapi/testScanPerf/testScanPerf.cpp
ndb/test/ndbapi/testScanPerf/testScanPerf.cpp
+368
-0
No files found.
ndb/include/ndbapi/NdbConnection.hpp
View file @
f62b63dc
...
...
@@ -687,6 +687,10 @@ NdbConnection::set_send_size(Uint32 send_size)
return
;
}
#ifdef NDB_NO_DROPPED_SIGNAL
#include <stdlib.h>
#endif
inline
int
NdbConnection
::
checkMagicNumber
()
...
...
ndb/include/ndbapi/NdbOperation.hpp
View file @
f62b63dc
...
...
@@ -1074,6 +1074,11 @@ protected:
};
#ifdef NDB_NO_DROPPED_SIGNAL
#include <stdlib.h>
#endif
inline
int
NdbOperation
::
checkMagicNumber
()
...
...
ndb/include/ndbapi/NdbReceiver.hpp
View file @
f62b63dc
...
...
@@ -56,6 +56,10 @@ private:
void
*
m_owner
;
};
#ifdef NDB_NO_DROPPED_SIGNAL
#include <stdlib.h>
#endif
inline
bool
NdbReceiver
::
checkMagicNumber
()
const
{
...
...
ndb/test/ndbapi/testScanPerf/Makefile
0 → 100644
View file @
f62b63dc
include
.defs.mk
TYPE
=
ndbapitest
BIN_TARGET
=
testScanPerf
SOURCES
=
testScanPerf.cpp
include
$(NDB_TOP)/Epilogue.mk
ndb/test/ndbapi/testScanPerf/testScanPerf.cpp
0 → 100644
View file @
f62b63dc
/* Copyright (C) 2003 MySQL AB
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
#include <NDBT.hpp>
#include <NDBT_Test.hpp>
#include <HugoTransactions.hpp>
#include <UtilTransactions.hpp>
#include <random.h>
#include <getarg.h>
struct
Parameter
{
char
*
name
;
unsigned
value
;
unsigned
min
;
unsigned
max
;
};
#define P_BATCH 0
#define P_PARRA 1
#define P_LOCK 2
#define P_FILT 3
#define P_BOUND 4
#define P_ACCESS 5
#define P_FETCH 6
#define P_ROWS 7
#define P_LOOPS 8
#define P_CREATE 9
#define P_LOAD 10
#define P_MAX 11
static
Parameter
g_paramters
[]
=
{
{
"batch"
,
0
,
0
,
1
},
// 0, 15
{
"parallelism"
,
0
,
0
,
1
},
// 0, 1
{
"lock"
,
0
,
0
,
2
},
// read, exclusive, dirty
{
"filter"
,
0
,
0
,
3
},
// all, none, 1, 100
{
"range"
,
0
,
0
,
3
},
// all, none, 1, 100
{
"access"
,
0
,
0
,
2
},
// scan, idx, idx sorted
{
"fetch"
,
0
,
0
,
1
},
// No, yes
{
"size"
,
1000000
,
1
,
~
0
},
{
"iterations"
,
3
,
1
,
~
0
},
{
"create_drop"
,
1
,
0
,
1
},
{
"data"
,
1
,
0
,
1
}
};
static
Ndb
*
g_ndb
=
0
;
static
const
NdbDictionary
::
Table
*
g_table
;
static
const
NdbDictionary
::
Index
*
g_index
;
static
char
g_tablename
[
256
];
static
char
g_indexname
[
256
];
int
create_table
();
int
load_table
();
int
run_scan
();
int
clear_table
();
int
drop_table
();
int
main
(
int
argc
,
const
char
**
argv
){
int
verbose
=
1
;
int
optind
=
0
;
struct
getargs
args
[
1
+
P_MAX
]
=
{
{
"verbose"
,
'v'
,
arg_flag
,
&
verbose
,
"Print verbose status"
,
"verbose"
}
};
const
int
num_args
=
1
+
P_MAX
;
for
(
int
i
=
0
;
i
<
P_MAX
;
i
++
){
args
[
i
+
1
].
long_name
=
g_paramters
[
i
].
name
;
args
[
i
+
1
].
short_name
=
*
g_paramters
[
i
].
name
;
args
[
i
+
1
].
type
=
arg_integer
;
args
[
i
+
1
].
value
=
&
g_paramters
[
i
].
value
;
BaseString
tmp
;
tmp
.
assfmt
(
"min: %d max: %d"
,
g_paramters
[
i
].
min
,
g_paramters
[
i
].
max
);
args
[
i
+
1
].
help
=
strdup
(
tmp
.
c_str
());
args
[
i
+
1
].
arg_help
=
0
;
}
if
(
getarg
(
args
,
num_args
,
argc
,
argv
,
&
optind
))
{
arg_printusage
(
args
,
num_args
,
argv
[
0
],
"tabname1 tabname2 ..."
);
return
NDBT_WRONGARGS
;
}
myRandom48Init
(
NdbTick_CurrentMillisecond
());
g_ndb
=
new
Ndb
(
"TEST_DB"
);
if
(
g_ndb
->
init
()
!=
0
){
g_err
<<
"init() failed"
<<
endl
;
goto
error
;
}
if
(
g_ndb
->
waitUntilReady
()
!=
0
){
g_err
<<
"Wait until ready failed"
<<
endl
;
goto
error
;
}
for
(
int
i
=
optind
;
i
<
argc
;
i
++
){
const
char
*
T
=
argv
[
i
];
g_info
<<
"Testing "
<<
T
<<
endl
;
snprintf
(
g_tablename
,
sizeof
(
g_tablename
),
T
);
snprintf
(
g_indexname
,
sizeof
(
g_indexname
),
"IDX_%s"
,
T
);
if
(
create_table
())
goto
error
;
if
(
load_table
())
goto
error
;
if
(
run_scan
())
goto
error
;
if
(
clear_table
())
goto
error
;
if
(
drop_table
())
goto
error
;
}
if
(
g_ndb
)
delete
g_ndb
;
return
NDBT_OK
;
error:
if
(
g_ndb
)
delete
g_ndb
;
return
NDBT_FAILED
;
}
int
create_table
(){
NdbDictionary
::
Dictionary
*
dict
=
g_ndb
->
getDictionary
();
assert
(
dict
);
if
(
g_paramters
[
P_CREATE
].
value
){
const
NdbDictionary
::
Table
*
pTab
=
NDBT_Tables
::
getTable
(
g_tablename
);
assert
(
pTab
);
NdbDictionary
::
Table
copy
=
*
pTab
;
copy
.
setLogging
(
false
);
if
(
dict
->
createTable
(
copy
)
!=
0
){
g_err
<<
"Failed to create table: "
<<
g_tablename
<<
endl
;
return
-
1
;
}
NdbDictionary
::
Index
x
(
g_indexname
);
x
.
setTable
(
g_tablename
);
x
.
setType
(
NdbDictionary
::
Index
::
OrderedIndex
);
x
.
setLogging
(
false
);
for
(
unsigned
k
=
0
;
k
<
copy
.
getNoOfColumns
();
k
++
){
if
(
copy
.
getColumn
(
k
)
->
getPrimaryKey
()){
x
.
addColumnName
(
copy
.
getColumn
(
k
)
->
getName
());
}
}
if
(
dict
->
createIndex
(
x
)
!=
0
){
g_err
<<
"Failed to create index: "
<<
endl
;
return
-
1
;
}
}
g_table
=
dict
->
getTable
(
g_tablename
);
g_index
=
dict
->
getIndex
(
g_indexname
,
g_tablename
);
assert
(
g_table
);
assert
(
g_index
);
return
0
;
}
int
drop_table
(){
if
(
!
g_paramters
[
P_CREATE
].
value
)
return
0
;
if
(
g_ndb
->
getDictionary
()
->
dropTable
(
g_table
->
getName
())
!=
0
){
g_err
<<
"Failed to drop table: "
<<
g_table
->
getName
()
<<
endl
;
return
-
1
;
}
g_table
=
0
;
return
0
;
}
int
load_table
(){
if
(
!
g_paramters
[
P_LOAD
].
value
)
return
0
;
int
rows
=
g_paramters
[
P_ROWS
].
value
;
HugoTransactions
hugoTrans
(
*
g_table
);
if
(
hugoTrans
.
loadTable
(
g_ndb
,
rows
)){
g_err
.
println
(
"Failed to load %s with %d rows"
,
g_table
->
getName
(),
rows
);
return
-
1
;
}
return
0
;
}
int
clear_table
(){
if
(
!
g_paramters
[
P_LOAD
].
value
)
return
0
;
int
rows
=
g_paramters
[
P_ROWS
].
value
;
UtilTransactions
utilTrans
(
*
g_table
);
if
(
utilTrans
.
clearTable
(
g_ndb
,
rows
)
!=
0
){
g_err
.
println
(
"Failed to clear table %s"
,
g_table
->
getName
());
return
-
1
;
}
return
0
;
}
inline
void
err
(
NdbError
e
){
ndbout
<<
e
<<
endl
;
}
int
run_scan
(){
int
iter
=
g_paramters
[
P_LOOPS
].
value
;
Uint64
start1
;
Uint64
sum1
=
0
;
Uint32
tot
=
g_paramters
[
P_ROWS
].
value
;
for
(
int
i
=
0
;
i
<
iter
;
i
++
){
start1
=
NdbTick_CurrentMillisecond
();
NdbConnection
*
pTrans
=
g_ndb
->
startTransaction
();
if
(
!
pTrans
){
g_err
<<
"Failed to start transaction"
<<
endl
;
err
(
g_ndb
->
getNdbError
());
return
-
1
;
}
NdbScanOperation
*
pOp
;
#ifdef NdbIndexScanOperation_H
NdbIndexScanOperation
*
pIOp
;
#else
NdbScanOperation
*
pIOp
;
#endif
NdbResultSet
*
rs
;
int
par
=
g_paramters
[
P_PARRA
].
value
;
int
bat
=
g_paramters
[
P_BATCH
].
value
;
NdbScanOperation
::
LockMode
lm
;
switch
(
g_paramters
[
P_LOCK
].
value
){
case
0
:
lm
=
NdbScanOperation
::
LM_Read
;
break
;
case
1
:
lm
=
NdbScanOperation
::
LM_Exclusive
;
break
;
case
2
:
lm
=
NdbScanOperation
::
LM_CommittedRead
;
break
;
default:
abort
();
}
if
(
g_paramters
[
P_ACCESS
].
value
==
0
){
pOp
=
pTrans
->
getNdbScanOperation
(
g_tablename
);
assert
(
pOp
);
#ifdef NdbIndexScanOperation_H
rs
=
pOp
->
readTuples
(
lm
,
bat
,
par
);
#else
int
oldp
=
(
par
==
0
?
240
:
par
)
*
(
bat
==
0
?
15
:
bat
);
rs
=
pOp
->
readTuples
(
oldp
>
240
?
240
:
oldp
,
lm
);
#endif
}
else
{
#ifdef NdbIndexScanOperation_H
pOp
=
pIOp
=
pTrans
->
getNdbIndexScanOperation
(
g_indexname
,
g_tablename
);
bool
ord
=
g_paramters
[
P_ACCESS
].
value
==
2
;
rs
=
pIOp
->
readTuples
(
lm
,
bat
,
par
,
ord
);
#else
pOp
=
pIOp
=
pTrans
->
getNdbScanOperation
(
g_indexname
,
g_tablename
);
assert
(
pOp
);
int
oldp
=
(
par
==
0
?
240
:
par
)
*
(
bat
==
0
?
15
:
bat
);
rs
=
pIOp
->
readTuples
(
oldp
>
240
?
240
:
oldp
,
lm
);
#endif
switch
(
g_paramters
[
P_BOUND
].
value
){
case
0
:
// All
break
;
case
1
:
// None
#ifdef NdbIndexScanOperation_H
pIOp
->
setBound
((
Uint32
)
0
,
NdbIndexScanOperation
::
BoundEQ
,
0
);
#else
pIOp
->
setBound
((
Uint32
)
0
,
NdbOperation
::
BoundEQ
,
0
);
#endif
break
;
case
2
:
{
// 1 row
default:
assert
(
g_table
->
getNoOfPrimaryKeys
()
==
1
);
// only impl. so far
abort
();
#if 0
int tot = g_paramters[P_ROWS].value;
int row = rand() % tot;
fix_eq_bound(pIOp, row);
#endif
break
;
}
}
}
assert
(
pOp
);
assert
(
rs
);
int
check
=
0
;
switch
(
g_paramters
[
P_FILT
].
value
){
case
0
:
// All
check
=
pOp
->
interpret_exit_ok
();
break
;
case
1
:
// None
check
=
pOp
->
interpret_exit_nok
();
break
;
case
2
:
{
// 1 row
default:
assert
(
g_table
->
getNoOfPrimaryKeys
()
==
1
);
// only impl. so far
abort
();
#if 0
int tot = g_paramters[P_ROWS].value;
int row = rand() % tot;
NdbScanFilter filter(pOp) ;
filter.begin(NdbScanFilter::AND);
fix_eq(filter, pOp, row);
filter.end();
break;
#endif
}
}
if
(
check
!=
0
){
err
(
pOp
->
getNdbError
());
return
-
1
;
}
assert
(
check
==
0
);
for
(
int
i
=
0
;
i
<
g_table
->
getNoOfColumns
();
i
++
){
pOp
->
getValue
(
i
);
}
int
rows
=
0
;
check
=
pTrans
->
execute
(
NoCommit
);
assert
(
check
==
0
);
int
fetch
=
g_paramters
[
P_FETCH
].
value
;
while
((
check
=
rs
->
nextResult
(
true
))
==
0
){
do
{
rows
++
;
}
while
(
!
fetch
&&
((
check
=
rs
->
nextResult
(
false
))
==
0
));
if
(
check
==
-
1
){
err
(
pTrans
->
getNdbError
());
return
-
1
;
}
assert
(
check
==
2
);
}
if
(
check
==
-
1
){
err
(
pTrans
->
getNdbError
());
return
-
1
;
}
assert
(
check
==
1
);
g_info
<<
"Found "
<<
rows
<<
" rows"
<<
endl
;
pTrans
->
close
();
Uint64
stop
=
NdbTick_CurrentMillisecond
();
start1
=
(
stop
-
start1
);
sum1
+=
start1
;
}
sum1
/=
iter
;
g_err
.
println
(
"Avg time: %Ldms = %d rows/sec"
,
sum1
,
(
1000
*
tot
)
/
sum1
);
return
0
;
}
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