Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
A
apachedex
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
Arnaud Fontaine
apachedex
Commits
642766ae
Commit
642766ae
authored
Apr 05, 2013
by
Vincent Pelletier
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fill in missing points.
parent
15b9c556
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
57 additions
and
9 deletions
+57
-9
README
README
+8
-0
TODO
TODO
+0
-1
apachedex/__init__.py
apachedex/__init__.py
+49
-8
No files found.
README
View file @
642766ae
...
...
@@ -90,3 +90,11 @@ A log file with a site section to ignore. Order does not matter::
A mix of both above examples. Order matters !::
apachedex --skip-base /site1/ignored --base /site1 /site2
Notes
=====
When there are no hits for more than a graph period, placeholders are
generated for 0 hit (which is the reality) and 100% apdex (this is
arbitrary). Those placeholders only affect graphs, and do not affect
averages nor table content.
TODO
View file @
642766ae
- use some templating system instead of hardcoded html strings
- provide some form of raw data output, not just html
- allow user to specify min & max dates
- fill blanks in graphhistory with 0 hits & 100% apdex, and remove graph dots
- filter(out ?) by user agent
- automatically select period from log data ?
apachedex/__init__.py
View file @
642766ae
...
...
@@ -388,10 +388,41 @@ def _asHourString(timestamp):
day
,
month
,
year
=
date
.
split
(
'/'
)
return
'%s/%02i/%s %s'
%
(
year
,
MONTH_VALUE_DICT
[
month
],
day
,
hour
)
# Key: argument (represents table granularity)
# Value:
# - cheap conversion from apache date format to graph granularity
# must be sortable consistently with time flow
# - conversion from gaph granularity to table granularity
# - graph granularity caption
# - format string to parse and generate graph granularity into/from
# datetime.datetime instance
# - period during which a placeholder point will be added if there is no data
# point
period_parser
=
{
'year'
:
(
_asMonthString
,
lambda
x
:
x
.
split
(
'/'
,
1
)[
0
],
'month'
),
'month'
:
(
_asDayString
,
lambda
x
:
'/'
.
join
(
x
.
split
(
'/'
,
2
)[:
2
]),
'day'
),
'day'
:
(
_asHourString
,
lambda
x
:
x
.
split
(
' '
)[
0
],
'hour'
),
'year'
:
(
_asMonthString
,
lambda
x
:
x
.
split
(
'/'
,
1
)[
0
],
'month'
,
'%Y/%m'
,
# Longest month: 31 days
timedelta
(
31
),
),
'month'
:
(
_asDayString
,
lambda
x
:
'/'
.
join
(
x
.
split
(
'/'
,
2
)[:
2
]),
'day'
,
'%Y/%m/%d'
,
# Longest day: 24 hours + 1h DST (never more ?)
timedelta
(
seconds
=
3600
*
25
),
),
'day'
:
(
_asHourString
,
lambda
x
:
x
.
split
(
' '
)[
0
],
'hour'
,
'%Y/%m/%d %H'
,
# Longest hour: 60 * 60 seconds + 1 leap second.
timedelta
(
seconds
=
3601
),
),
}
def
main
():
...
...
@@ -476,7 +507,8 @@ def main():
assert
not
key
,
key
matchline
=
re
.
compile
(
line_regex
).
match
matchrequest
=
REQUEST_PATTERN
.
match
asDate
,
decimator
,
graph_period
=
period_parser
[
args
.
period
]
asDate
,
decimator
,
graph_period
,
date_format
,
placeholder_delta
=
\
period_parser
[
args
.
period
]
site_list
=
args
.
path
default_site
=
args
.
default
if
default_site
is
None
:
...
...
@@ -607,8 +639,19 @@ def main():
for
site_id
,
data
in
per_site
.
iteritems
():
out
.
write
(
'<h1>Site: %s</h1>'
%
site_id
)
daily_data
=
data
.
getApdexData
()
date_list
=
[
int
(
time
.
mktime
(
time
.
strptime
(
x
[
0
],
'%Y/%m/%d'
+
{
'day'
:
' %H'
}.
get
(
args
.
period
,
''
)))
*
1000
)
for
x
in
daily_data
]
current_date
=
datetime
.
strptime
(
daily_data
[
0
][
0
],
date_format
)
new_daily_data
=
[]
append
=
new_daily_data
.
append
for
measure
in
daily_data
:
measure_date
=
datetime
.
strptime
(
measure
[
0
],
date_format
)
while
current_date
<
measure_date
:
append
((
current_date
.
strftime
(
date_format
),
100
,
0
))
current_date
+=
placeholder_delta
append
(
measure
)
current_date
=
measure_date
+
placeholder_delta
daily_data
=
new_daily_data
date_list
=
[
int
(
time
.
mktime
(
time
.
strptime
(
x
[
0
],
date_format
))
*
1000
)
for
x
in
daily_data
]
timeformat
=
'%Y<br/>%m/%d<br/>%H:%M'
# There is room for about 10 labels on the X axis.
minTickSize
=
(
max
(
1
,
...
...
@@ -630,7 +673,6 @@ def main():
'labelWidth'
:
yLabelWidth
,
},
'lines'
:
{
'show'
:
True
},
'points'
:
{
'show'
:
True
},
},
)
graph
(
'Hits (per %s)'
%
graph_period
,
...
...
@@ -647,7 +689,6 @@ def main():
'tickDecimals'
:
0
,
},
'lines'
:
{
'show'
:
True
},
'points'
:
{
'show'
:
True
},
},
)
out
.
write
(
data
.
asHTML
(
decimator
))
...
...
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