Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
N
neoppod
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
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Levin Zimmermann
neoppod
Commits
12d6f138
Commit
12d6f138
authored
Mar 02, 2018
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
.
parent
a9b10a45
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
77 additions
and
37 deletions
+77
-37
go/neo/t/benchplot
go/neo/t/benchplot
+62
-24
go/neo/t/neotest
go/neo/t/neotest
+15
-13
No files found.
go/neo/t/benchplot
View file @
12d6f138
...
@@ -85,6 +85,27 @@ def seriesof(B):
...
@@ -85,6 +85,27 @@ def seriesof(B):
return S
return S
# xseriesof, similarly to seriesof, extracts series from benchmark B, but omits non-interesting ones.
def xseriesof(B):
S = seriesof(B)
if S is None:
return None
# working directly with fs1 is very fast and makes seeing other variants hard.
del S['
fs1
-
zwrk
.
go
']
# only show !log for neo/py as this are faster
for k in S.keys():
m = re.match(r'
.
*
(
\
(
!
log
\
)).
*
$
', k)
if m is None:
continue
k_ = k[:m.start(1)] + k[m.end(1):] # without "(!log)"
#print '
hide
%
s
(
have
%
s
)
' % (k_, k)
S.pop(k_, None) # discard
return S
# yticklabel_forvalue returns text for ytick label dedicated to showing particular value.
# yticklabel_forvalue returns text for ytick label dedicated to showing particular value.
#
#
...
@@ -104,6 +125,23 @@ def yticklabel_forvalue(yv, yvprev, yvnext):
...
@@ -104,6 +125,23 @@ def yticklabel_forvalue(yv, yvprev, yvnext):
return l
return l
# stylefor is {} name -> Line2D style kw, so that we can always use e.g. the
# same colors for plots for the same server.
def _(**kw): return kw
stylefor = {
'
neo
/
go
/
fs1
-
zwrk
.
go
': _(color='
C0
'),
'
neo
/
go
/
fs1
(
!
sha1
)
-
zwrk
.
go
(
!
sha1
)
': _(color='
C0
', ls='
dashed
'),
'
neo
/
go
/
sqlite
-
zwrk
.
go
': _(color='
C1
'),
'
neo
/
go
/
sqlite
-
zwrk
.
go
(
!
sha1
)
': _(color='
C1
', ls='
dashed
'),
'
zeo
/
py
/
fs1
-
zwrk
.
go
': _(color='
C2
'),
'
neo
/
py
(
!
log
)
/
sqlite
-
zwrk
.
go
': _(color='
C3
'), # ls='
dashed
'), # XXX dashed?
'
neo
/
py
(
!
log
)
/
sql
-
zwrk
.
go
': _(color='
C4
'), # ls='
dashed
'), # XXX dashed?
}
del _
# r0 is invisible something
# r0 is invisible something
# (useful as e.g. proxy in text-only legend)
# (useful as e.g. proxy in text-only legend)
r0 = Rectangle((0,0), 1, 1, fill=False, edgecolor='
none
', visible=False)
r0 = Rectangle((0,0), 1, 1, fill=False, edgecolor='
none
', visible=False)
...
@@ -112,7 +150,7 @@ r0 = Rectangle((0,0), 1, 1, fill=False, edgecolor='none', visible=False)
...
@@ -112,7 +150,7 @@ r0 = Rectangle((0,0), 1, 1, fill=False, edgecolor='none', visible=False)
#
#
# S should be {} name -> BenchSeries.
# S should be {} name -> BenchSeries.
#
#
# The whole plot is labeled as labkey.
# The whole plot is labeled as labkey.
XXX <- no longer so
def plotseries(ax, labkey, S):
def plotseries(ax, labkey, S):
#plt.title("ZODB server handling read requests")
#plt.title("ZODB server handling read requests")
#plt.title("----") # XXX don'
t
use
vspace
#plt.title("----") # XXX don'
t
use
vspace
...
@@ -131,7 +169,7 @@ def plotseries(ax, labkey, S):
...
@@ -131,7 +169,7 @@ def plotseries(ax, labkey, S):
err1
=
[
s
.
avg
-
s
.
min
for
_
,
s
in
bs
.
series
]
err1
=
[
s
.
avg
-
s
.
min
for
_
,
s
in
bs
.
series
]
err2
=
[
s
.
max
-
s
.
avg
for
_
,
s
in
bs
.
series
]
err2
=
[
s
.
max
-
s
.
avg
for
_
,
s
in
bs
.
series
]
# XXX ecolor='black'
# XXX ecolor='black'
ax
.
errorbar
(
x
,
y
,
yerr
=
[
err1
,
err2
],
capsize
=
2
,
label
=
name
)
ax
.
errorbar
(
x
,
y
,
yerr
=
[
err1
,
err2
],
capsize
=
2
,
label
=
name
,
**
stylefor
[
name
]
)
# XXX fmt for line
# XXX fmt for line
# XXX always use the same colors for the same lines (e.g. picking by hash)
# XXX always use the same colors for the same lines (e.g. picking by hash)
...
@@ -146,7 +184,6 @@ def plotseries(ax, labkey, S):
...
@@ -146,7 +184,6 @@ def plotseries(ax, labkey, S):
yticks_
.
add
(
int
(
y
[
-
1
]))
yticks_
.
add
(
int
(
y
[
-
1
]))
# first legend showing labels from labkey
# first legend showing labels from labkey
# https://matplotlib.org/tutorials/intermediate/legend_guide.html#multiple-legends-on-the-same-axes
# https://matplotlib.org/tutorials/intermediate/legend_guide.html#multiple-legends-on-the-same-axes
lh
=
[
r0
]
*
len
(
labkey
)
lh
=
[
r0
]
*
len
(
labkey
)
...
@@ -207,29 +244,22 @@ def plotseries(ax, labkey, S):
...
@@ -207,29 +244,22 @@ def plotseries(ax, labkey, S):
ax2
.
set_yticklabels
(
ytick_labv
)
ax2
.
set_yticklabels
(
ytick_labv
)
# plotlat1 makes plot of benchmark latencies for serial (1 client) case.
def
plotlat1
(
ax
,
S
):
# XXX use the same color/style for name as in different plot
for
name
in
S
:
b
=
S
[
name
].
series
[
0
]
if
b
[
0
]
!=
1
:
# n
continue
s
=
b
[
1
]
# stats
ax
.
errorbar
(
1
,
s
.
avg
,
yerr
=
[[
s
.
avg
-
s
.
min
],
[
s
.
max
-
s
.
avg
]],
capsize
=
2
,
label
=
name
,
**
stylefor
[
name
])
#ax.legend() # XXX temp
# xseriesof, similarly to seriesof, extracts series from benchmark B, but omits non-interesting ones.
def
xseriesof
(
B
):
S
=
seriesof
(
B
)
if
S
is
None
:
return
None
# working directly with fs1 is very fast and makes seeing other variants hard.
del
S
[
'fs1-zwrk.go'
]
# only show !log for neo/py as this are faster
for
k
in
S
.
keys
():
m
=
re
.
match
(
r'.*(\
(!log
\)).*$'
,
k
)
if
m
is
None
:
continue
k_
=
k
[:
m
.
start
(
1
)]
+
k
[
m
.
end
(
1
):]
# without "(!log)"
#print 'hide %s (have %s)' % (k_, k)
S
.
pop
(
k_
,
None
)
# discard
return
S
def
main
():
def
main
():
...
@@ -244,13 +274,13 @@ def main():
...
@@ -244,13 +274,13 @@ def main():
Bu
=
Bl
[
labkey
].
byunit
()
Bu
=
Bl
[
labkey
].
byunit
()
fig
=
plt
.
figure
(
figsize
=
(
2
*
8
,
10
))
# XXX figsize - temp?
fig
=
plt
.
figure
(
figsize
=
(
2
*
7.5
,
10
))
# XXX figsize - temp?
fig
.
suptitle
(
"ZODB server handling read requests"
)
fig
.
suptitle
(
"ZODB server handling read requests"
)
fig
.
text
(
0.5
,
0.04
,
"XXX number of clients running simultaneously"
,
ha
=
'center'
)
fig
.
text
(
0.5
,
0.04
,
"XXX number of clients running simultaneously"
,
ha
=
'center'
)
ax1
=
plt
.
subplot
(
121
)
ax1
=
plt
.
subplot
(
121
)
ax1
.
set_title
(
u'
requests
object/s (↑ is better)'
)
# XXX add vspace between title and plot
ax1
.
set_title
(
u'
#requests,
object/s (↑ is better)'
)
# XXX add vspace between title and plot
# XXX req/s hardcoded. XXX other units?
# XXX req/s hardcoded. XXX other units?
Sreq
=
xseriesof
(
Bu
[
Unit
(
'req/s'
)])
Sreq
=
xseriesof
(
Bu
[
Unit
(
'req/s'
)])
...
@@ -262,11 +292,11 @@ def main():
...
@@ -262,11 +292,11 @@ def main():
ax2
=
plt
.
subplot
(
122
)
ax2
=
plt
.
subplot
(
122
)
ax2
.
set_title
(
u'latency µs/object (↓ is better)'
)
ax2
.
set_title
(
u'latency
,
µs/object (↓ is better)'
)
Slat
=
xseriesof
(
Bu
[
Unit
(
u'latency-µs/object'
)])
Slat
=
xseriesof
(
Bu
[
Unit
(
u'latency-µs/object'
)])
if
Slat
is
not
None
:
if
Slat
is
not
None
:
#
XXX
use same colors/styles for corresponding lines in ax1
#
FIXME
use same colors/styles for corresponding lines in ax1
plotseries
(
ax2
,
labkey
,
Slat
)
plotseries
(
ax2
,
labkey
,
Slat
)
# don't show legend in latency plot - instead show latency details for client=1
# don't show legend in latency plot - instead show latency details for client=1
...
@@ -285,14 +315,22 @@ def main():
...
@@ -285,14 +315,22 @@ def main():
ax2
.
add_patch
(
BboxPatch
(
rect
,
fill
=
False
,
fc
=
"none"
,
ec
=
"0.5"
,
lw
=
0.5
))
ax2
.
add_patch
(
BboxPatch
(
rect
,
fill
=
False
,
fc
=
"none"
,
ec
=
"0.5"
,
lw
=
0.5
))
ax2
.
add_patch
(
BboxConnectorPatch
(
ax21
.
bbox
,
rect
,
3
,
2
,
4
,
1
,
ec
=
"0.5"
,
lw
=
0.5
))
ax2
.
add_patch
(
BboxConnectorPatch
(
ax21
.
bbox
,
rect
,
3
,
2
,
4
,
1
,
ec
=
"0.5"
,
lw
=
0.5
))
plotlat1
(
ax21
,
Slat
)
else
:
else
:
plt
.
text
(
"xxx not found"
)
plt
.
text
(
"xxx not found"
)
#fig.legend()
#fig.legend()
fig
.
legend
([
r0
,
r0
],
[
"aaa"
,
"bbb"
])
fig
.
legend
([
r0
,
r0
],
[
"aaa"
,
"bbb"
])
#fig.tight_layout()
fig
.
subplots_adjust
(
left
=
0.05
,
# no big marging on the left
#wspace=0.1
)
plt
.
show
()
plt
.
show
()
return
# XXX temp to show only first
...
...
go/neo/t/neotest
View file @
12d6f138
...
@@ -1080,18 +1080,20 @@ zbench() {
...
@@ -1080,18 +1080,20 @@ zbench() {
# go-only part of zbench
# go-only part of zbench
zbench_go
()
{
zbench_go
()
{
url
=
$1
url
=
$1
topic
=
$2
topic
=
$2
-%s
zhashok
=
$3
zhashok
=
$3
nrun tzodb_go
-log_dir
=
$log
zhash
-check
=
$zhashok
-bench
=
$topic
-%s -
$zhashfunc
$url
test
"
$X_NEOGO_SHA1_SKIP
"
=
y
&&
topic
=
"
$topic
(!sha1)"
||
:
nrun tzodb_go
-log_dir
=
$log
zhash
-check
=
$zhashok
-bench
=
$topic
-%s -
$zhashfunc
-useprefetch
$url
nrun tzodb_go
-log_dir
=
$log
zhash
-check
=
$zhashok
-bench
=
$topic
-
$zhashfunc
$url
nrun tzodb_go
-log_dir
=
$log
zhash
-check
=
$zhashok
-bench
=
$topic
-
$zhashfunc
-useprefetch
$url
# XXX running processes in parallel is deprecated in favour of zwrk.
# XXX running processes in parallel is deprecated in favour of zwrk.
# echo -e "\n# ${Npar} clients in parallel"
# echo -e "\n# ${Npar} clients in parallel"
# nrunpar tzodb_go -log_dir=$log zhash -check=$zhashok -bench=$topic
-%s
·P$Npar -$zhashfunc $url
# nrunpar tzodb_go -log_dir=$log zhash -check=$zhashok -bench=$topic·P$Npar -$zhashfunc $url
for
i
in
${
Nparv
}
;
do
for
i
in
${
Nparv
}
;
do
echo
-e
"
\n
#
$i
clients in parallel"
echo
-e
"
\n
#
$i
clients in parallel"
nrun tzodb_go
-log_dir
=
$log
zwrk
-nclient
$i
-check
=
$zhashok
-bench
=
$topic
-%s
-
$zhashfunc
$url
nrun tzodb_go
-log_dir
=
$log
zwrk
-nclient
$i
-check
=
$zhashok
-bench
=
$topic
-
$zhashfunc
$url
done
done
}
}
...
@@ -1168,7 +1170,7 @@ zbench_local() {
...
@@ -1168,7 +1170,7 @@ zbench_local() {
xneoctl
set
cluster stopping
xneoctl
set
cluster stopping
wait
wait
echo
-e
"
\n
*** NEO/go fs1 (sha1 disabled)"
echo
-e
"
\n
*** NEO/go fs1 (sha1 disabled
on: storage, client
)"
X_NEOGO_SHA1_SKIP
=
y NEOgofs1
X_NEOGO_SHA1_SKIP
=
y NEOgofs1
X_NEOGO_SHA1_SKIP
=
y zbench_go neo://
$neocluster
@
$Mbind
"neo/go/fs1(!sha1)"
$zhashok
X_NEOGO_SHA1_SKIP
=
y zbench_go neo://
$neocluster
@
$Mbind
"neo/go/fs1(!sha1)"
$zhashok
xneoctl
set
cluster stopping
xneoctl
set
cluster stopping
...
@@ -1180,9 +1182,9 @@ zbench_local() {
...
@@ -1180,9 +1182,9 @@ zbench_local() {
xneoctl
set
cluster stopping
xneoctl
set
cluster stopping
wait
wait
echo
-e
"
\n
*** NEO/go sqlite (sha1 disabled)"
echo
-e
"
\n
*** NEO/go sqlite (sha1 disabled
on: client
)"
X_NEOGO_SHA1_SKIP
=
y
NEOgolite
NEOgolite
X_NEOGO_SHA1_SKIP
=
y zbench_go neo://
$neocluster
@
$Mbind
"neo/go/sqlite
(!sha1)
"
$zhashok
X_NEOGO_SHA1_SKIP
=
y zbench_go neo://
$neocluster
@
$Mbind
"neo/go/sqlite"
$zhashok
xneoctl
set
cluster stopping
xneoctl
set
cluster stopping
wait
wait
}
}
...
@@ -1279,7 +1281,7 @@ zbench_cluster() {
...
@@ -1279,7 +1281,7 @@ zbench_cluster() {
xneoctl
set
cluster stopping
xneoctl
set
cluster stopping
wait
wait
echo
-e
"
\n
*** NEO/go fs1 (sha1 disabled)"
echo
-e
"
\n
*** NEO/go fs1 (sha1 disabled
on: storage, client
)"
X_NEOGO_SHA1_SKIP
=
y NEOgofs1
X_NEOGO_SHA1_SKIP
=
y NEOgofs1
on
$url
X_NEOGO_SHA1_SKIP
=
y ./neotest zbench-client
--goonly
neo://
$neocluster
@
$Mbind
"
\\\"
neo/go/fs1(!sha1)
\\\"
"
$zhashok
on
$url
X_NEOGO_SHA1_SKIP
=
y ./neotest zbench-client
--goonly
neo://
$neocluster
@
$Mbind
"
\\\"
neo/go/fs1(!sha1)
\\\"
"
$zhashok
xneoctl
set
cluster stopping
xneoctl
set
cluster stopping
...
@@ -1291,9 +1293,9 @@ zbench_cluster() {
...
@@ -1291,9 +1293,9 @@ zbench_cluster() {
xneoctl
set
cluster stopping
xneoctl
set
cluster stopping
wait
wait
echo
-e
"
\n
*** NEO/go sqlite (sha1 disabled)"
echo
-e
"
\n
*** NEO/go sqlite (sha1 disabled
on: client
)"
X_NEOGO_SHA1_SKIP
=
y
NEOgolite
NEOgolite
on
$url
X_NEOGO_SHA1_SKIP
=
y ./neotest zbench-client
--goonly
neo://
$neocluster
@
$Mbind
"
\\\"
neo/go/sqlite
(!sha1)
\\\"
"
$zhashok
on
$url
X_NEOGO_SHA1_SKIP
=
y ./neotest zbench-client
--goonly
neo://
$neocluster
@
$Mbind
"
\\\"
neo/go/sqlite
\\\"
"
$zhashok
xneoctl
set
cluster stopping
xneoctl
set
cluster stopping
wait
wait
}
}
...
...
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