Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
slapos.package
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
Ivan Tyagov
slapos.package
Commits
b63f7492
Commit
b63f7492
authored
May 21, 2013
by
Jondy Zhao
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add netreport.py
parent
65296116
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
299 additions
and
3 deletions
+299
-3
windows/netreport/README
windows/netreport/README
+40
-0
windows/netreport/src/netreport.py
windows/netreport/src/netreport.py
+251
-0
windows/netreport/src/tests.py
windows/netreport/src/tests.py
+8
-3
No files found.
windows/netreport/README
View file @
b63f7492
...
...
@@ -8,4 +8,44 @@ $ python setup.py build
Test basic functions
====================
Maybe no test modules installed in the cygwin python. We need copy all
the test library files to python library path.
$ cd src
$ python tests.py
Here are example of src/Makefile:
PYTHON = /opt/slapos/bin/python
.PHONY : test
build: netuse.c
(cd ..; $(PYTHON) setup.py build)
test: build
$(PYTHON) tests.py
Then run test:
$ cd src
$ make test
Use Cases
=========
Slave Node
----------
Master Node
-----------
Exchange Data Format
====================
Issues
======
1. Some records may be lost if the computer is shutdown in unnormal way.
windows/netreport/src/netreport.py
0 → 100644
View file @
b63f7492
# -*- coding: utf-8 -*-
##############################################################################
#
# Copyright (c) 2012 Vifib SARL and Contributors.
# All Rights Reserved.
#
# WARNING: This program as such is intended to be used by professional
# programmers who take the whole responsibility of assessing all potential
# consequences resulting from its eventual inadequacies and bugs
# End users who are looking for a ready-to-use solution with commercial
# guarantees and support are strongly advised to contract a Free Software
# Service Company
#
# 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 3
# 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.
#
##############################################################################
#
# Paramters:
#
# computer_id, which computer sends this report
#
# server_name, if it's not empty, only the net drives in this server
# will be involved in the report.
#
# report_internal, in seconds
#
# data_file, save report state and unsending records last time, pickle format.
#
# main process
#
# read data from json file
#
# check start state, there are 3 cases
#
# case 1: first report
#
# Send init report to server
#
# case 2: normal report
#
# case 3: unexpected error
#
# Request server to send back last report information
#
# If there are unsend reports in json file, send them first
#
# Start sending report thread, the thread will enter loop as the following:
#
# Are there unsend records?
#
# Yes, send those.
#
# Resend failed, insert the records in the current buffer to unsending queue.
#
# No.
#
# Send records in the current buffer
#
# Failed, insert all the records in the currnet buffer to unsending queue.
#
# If main process quit?
#
# Enter main loop:
#
# If report interval is out,
#
# Yes, insert a record to the current bffer
#
# No, sleep for (report_interval / 2 + 1) seconds
#
# If user wants to quit
#
# Yes, break main loop
#
# After quit from main loop,
#
# Stop sending report thread
#
# Save unsending queue, report id and state to pickle file.
#
import
argparse
from
datetime
import
datetime
import
logger
import
netuse
import
os.path
import
pickle
import
Queue
import
slapos.slap.slap
import
sys
from
time
import
sleep
REPORT_STATE_INIT
=
0
REPORT_STATE_RUNNING
=
1
REPORT_STATE_STOP
=
2
def
parseArgumentTuple
():
parser
=
argparse
.
ArgumentParser
()
parser
.
add_argument
(
"--master-url"
,
help
=
"The master server URL. Mandatory."
,
required
=
True
)
parser
.
add_argument
(
"--computer-id"
,
help
=
"The computer id defined in the server."
,
required
=
True
)
parser
.
add_argument
(
"--cert-file"
,
help
=
"Path to computer certificate file."
,
default
=
"/etc/slapos/ssl/computer.crt"
)
parser
.
add_argument
(
"--key-file"
,
help
=
"Path to computer key file."
,
default
=
"/etc/slapos/ssl/computer.key"
)
parser
.
add_argument
(
"--report-interval"
,
help
=
"Interval in seconds to send report to master."
,
default
=
300
)
parser
.
add_argument
(
"--data-file"
,
help
=
"File used to save report data."
,
default
=
"net_drive_usage_report.data"
)
parser
.
add_argument
(
"--server-name"
,
help
=
"Interval in seconds to send report to master."
,
default
=
None
)
option
=
parser
.
parse_args
()
# Build option_dict
option_dict
=
{}
for
argument_key
,
argument_value
in
vars
(
option
).
iteritems
():
option_dict
.
update
({
argument_key
:
argument_value
})
return
option_dict
class
NetDriveUsageReporter
(
object
):
queue_size
=
512
def
__init__
(
self
,
option_dict
):
for
option
,
value
in
option_dict
.
items
():
setattr
(
self
,
option
,
value
)
self
.
slap
=
slapos
.
slap
.
slap
()
self
.
slap_computer
=
None
self
.
report_sequence_no
=
0
self
.
_queue
=
Queue
.
queue
(
self
.
queue_size
)
self
.
_state_file
=
self
.
data_file
+
".state"
def
initializeConnection
(
self
):
connection_dict
=
{}
connection_dict
[
'key_file'
]
=
self
.
key_file
connection_dict
[
'cert_file'
]
=
self
.
cert_file
self
.
slap
.
initializeConnection
(
self
.
master_url
,
**
connection_dict
)
self
.
slap_computer
=
self
.
slap
.
registerComputer
(
self
.
computer_id
)
def
run
(
self
):
self
.
initializeConnection
()
self
.
_loadReportState
()
self
.
_sendReportInQueue
()
self
.
report_state
=
REPORT_STATE_RUNNING
pickle
.
dump
(
self
.
report_state
,
self
.
_state_file
)
current_timestamp
=
datetime
.
now
()
while
True
:
last_timestamp
=
datetime
.
now
()
d
=
last_timestamp
-
current_timestamp
if
d
.
seconds
<
self
.
report_interval
:
sleep
(
self
.
report_interval
)
continue
current_timestamp
=
last_timestamp
r
=
self
.
getUsageReport
()
self
.
sendUsageReport
(
r
)
self
.
_saveReportState
()
self
.
report_state
=
REPORT_STATE_STOP
pickle
.
dump
(
self
.
report_state
,
self
.
_state_file
)
def
_loadReportState
(
self
):
if
not
os
.
path
.
exists
(
self
.
data_file
):
s
=
{
"sequence-no"
:
-
1
,
"computer-id"
:
self
.
computer_id
,
"queue"
:
[],
}
pickle
.
dump
(
s
,
self
.
data_file
)
else
:
s
=
pickle
.
load
(
self
.
data_file
)
if
not
s
.
get
(
"computer-id"
,
""
)
==
self
.
computer_id
:
pass
# data file is not expected
if
s
.
get
(
"state"
,
None
)
==
REPORT_STATE_RUNNING
:
pass
# get sequence no from master sever
self
.
report_sequence_no
=
s
[
"sequence-no"
]
for
r
in
s
[
"queue"
]:
self
.
_queue
.
put
(
r
)
def
_saveReportState
(
self
):
q
=
[]
try
:
while
not
self
.
_queue
.
empty
():
q
.
append
(
self
.
_queue
.
get_nowait
())
except
Queue
.
Empty
:
pass
s
=
{
"computer-id"
:
self
.
computer_id
,
"sequence-no"
:
self
.
report_sequence_no
,
"queue"
:
q
,
}
pickle
.
dump
(
s
,
self
.
data_file
)
def
getUsageReport
(
self
):
self
.
report_sequence_no
+=
1
return
netuse
.
usagereport
()
def
sendUsageReport
(
self
,
report
):
if
self
.
_sendReportInQueue
():
if
not
self
.
_postData
(
report
):
self
.
_queue
.
put
(
report
)
else
:
self
.
_queue
.
put
(
report
)
def
_postData
(
self
,
r
):
"""Send a marshalled dictionary of the net drive usage record
serialized via_getDict.
"""
self
.
slap_computer
.
reportNetDriveUsage
(
r
)
def
_sendReportInQueue
(
self
):
try
:
while
True
:
r
=
self
.
_queue
.
get_nowait
()
if
not
self
.
_postData
(
r
):
return
False
except
Queue
.
Empty
:
pass
return
True
def
main
():
reporter
=
NetDriveUsageReporter
(
parseArgumentTuple
())
reporter
.
run
()
if
__name__
==
'__main__'
:
main
()
windows/netreport/src/tests.py
View file @
b63f7492
...
...
@@ -5,15 +5,20 @@ import os
import
tempfile
import
shutil
import
netuse
sys
.
path
.
insert
(
0
,
os
.
getcwd
())
import
test.test_support
netuse
=
test
.
test_support
.
import_module
(
'netuse'
)
threading
=
test
.
test_support
.
import_module
(
'threading'
)
import
unittest
class
BaseTestCase
(
unittest
.
TestCase
):
def
setUp
(
self
):
pass
self
.
_threads
=
test
.
test_support
.
threading_setup
()
def
tearDown
(
self
):
pass
test
.
test_support
.
threading_cleanup
(
*
self
.
_threads
)
test
.
test_support
.
reap_children
()
class
NetUsageTests
(
BaseTestCase
):
...
...
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