Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
slapos.core
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.core
Commits
726cda79
Commit
726cda79
authored
Aug 03, 2012
by
Cédric de Saint Martin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Adding local cache to slap lib, and use it in slapgrid
parent
cea91eb4
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
35 additions
and
17 deletions
+35
-17
slapos/grid/slapgrid.py
slapos/grid/slapgrid.py
+21
-8
slapos/slap/slap.py
slapos/slap/slap.py
+14
-9
No files found.
slapos/grid/slapgrid.py
View file @
726cda79
...
@@ -38,6 +38,7 @@ from random import random
...
@@ -38,6 +38,7 @@ from random import random
import
socket
import
socket
import
subprocess
import
subprocess
import
StringIO
import
StringIO
import
shutil
import
sys
import
sys
import
tempfile
import
tempfile
import
time
import
time
...
@@ -125,7 +126,6 @@ def parseArgumentTupleAndReturnSlapgridObject(*argument_tuple):
...
@@ -125,7 +126,6 @@ def parseArgumentTupleAndReturnSlapgridObject(*argument_tuple):
"(ie.:slappartX, slappartY),"
"(ie.:slappartX, slappartY),"
"this option will make all others computer partitions be ignored."
)
"this option will make all others computer partitions be ignored."
)
# Parses arguments
# Parses arguments
if
argument_tuple
==
():
if
argument_tuple
==
():
# No arguments given to entry point : we parse sys.argv.
# No arguments given to entry point : we parse sys.argv.
...
@@ -225,11 +225,24 @@ def parseArgumentTupleAndReturnSlapgridObject(*argument_tuple):
...
@@ -225,11 +225,24 @@ def parseArgumentTupleAndReturnSlapgridObject(*argument_tuple):
else
:
else
:
signature_certificate_list
=
None
signature_certificate_list
=
None
# Parse
cache / binary
options
# Parse
shacache / binary cache
options
option_dict
[
"binary-cache-url-blacklist"
]
=
[
option_dict
[
"binary-cache-url-blacklist"
]
=
[
url
.
strip
()
for
url
in
option_dict
.
get
(
"binary-cache-url-blacklist"
,
""
url
.
strip
()
for
url
in
option_dict
.
get
(
"binary-cache-url-blacklist"
,
""
).
split
(
'
\
n
'
)
if
url
]
).
split
(
'
\
n
'
)
if
url
]
# Set local cache option, use default one if not defined
# XXX-Cedric: put one cache per cp/sr/ur
# XXX-Cedric: clean after run
local_cache
=
option_dict
.
get
(
'local-cache'
,
# We put by default on instance_root, because we know this path
os
.
path
.
join
(
option_dict
[
'instance_root'
],
'cache'
))
# XXX-Cedric should be shutil.mkdtemp())
# Clean old rubbish cache
if
os
.
path
.
exists
(
local_cache
):
shutil
.
rmtree
(
local_cache
)
# Create new one
os
.
mkdir
(
local_cache
)
# Sleep for a random time to avoid SlapOS Master being DDOSed by an army of
# Sleep for a random time to avoid SlapOS Master being DDOSed by an army of
# SlapOS Nodes configured with cron.
# SlapOS Nodes configured with cron.
if
option_dict
[
"now"
]:
if
option_dict
[
"now"
]:
...
@@ -278,6 +291,7 @@ def parseArgumentTupleAndReturnSlapgridObject(*argument_tuple):
...
@@ -278,6 +291,7 @@ def parseArgumentTupleAndReturnSlapgridObject(*argument_tuple):
develop
=
option_dict
.
get
(
'develop'
,
False
),
develop
=
option_dict
.
get
(
'develop'
,
False
),
software_release_filter_list
=
option_dict
.
get
(
'only_sr'
,
None
),
software_release_filter_list
=
option_dict
.
get
(
'only_sr'
,
None
),
computer_partition_filter_list
=
option_dict
.
get
(
'only_cp'
,
None
),
computer_partition_filter_list
=
option_dict
.
get
(
'only_cp'
,
None
),
local_cache
=
local_cache
,
),
),
option_dict
])
option_dict
])
...
@@ -367,7 +381,8 @@ class Slapgrid(object):
...
@@ -367,7 +381,8 @@ class Slapgrid(object):
shadir_key_file
=
None
,
shadir_key_file
=
None
,
develop
=
False
,
develop
=
False
,
software_release_filter_list
=
None
,
software_release_filter_list
=
None
,
computer_partition_filter_list
=
None
):
computer_partition_filter_list
=
None
,
local_cache
=
None
):
"""Makes easy initialisation of class parameters"""
"""Makes easy initialisation of class parameters"""
# Parses arguments
# Parses arguments
self
.
software_root
=
os
.
path
.
abspath
(
software_root
)
self
.
software_root
=
os
.
path
.
abspath
(
software_root
)
...
@@ -396,7 +411,7 @@ class Slapgrid(object):
...
@@ -396,7 +411,7 @@ class Slapgrid(object):
# Configures logger
# Configures logger
self
.
logger
=
logging
.
getLogger
(
'Slapgrid'
)
self
.
logger
=
logging
.
getLogger
(
'Slapgrid'
)
# Creates objects from slap module
# Creates objects from slap module
self
.
slap
=
slap
.
slap
(
)
self
.
slap
=
slap
.
slap
(
local_cache
)
# XXX-Cedric give it as well to childs
self
.
slap
.
initializeConnection
(
self
.
master_url
,
key_file
=
self
.
key_file
,
self
.
slap
.
initializeConnection
(
self
.
master_url
,
key_file
=
self
.
key_file
,
cert_file
=
self
.
cert_file
,
master_ca_file
=
self
.
master_ca_file
)
cert_file
=
self
.
cert_file
,
master_ca_file
=
self
.
master_ca_file
)
self
.
computer
=
self
.
slap
.
registerComputer
(
self
.
computer_id
)
self
.
computer
=
self
.
slap
.
registerComputer
(
self
.
computer_id
)
...
@@ -898,10 +913,8 @@ class Slapgrid(object):
...
@@ -898,10 +913,8 @@ class Slapgrid(object):
# Warn the SlapOS Master that a partition generates corrupted xml
# Warn the SlapOS Master that a partition generates corrupted xml
# report
# report
else
:
else
:
computer_partition_usage
=
self
.
slap
.
registerComputerPartition
(
computer_partition
.
setUsage
(
usage
)
self
.
computer_id
,
computer_partition_id
)
computer_partition_usage_list
.
append
(
computer_partition
)
computer_partition_usage
.
setUsage
(
usage
)
computer_partition_usage_list
.
append
(
computer_partition_usage
)
filename_delete_list
.
append
(
filename
)
filename_delete_list
.
append
(
filename
)
else
:
else
:
logger
.
debug
(
"Usage report %r not found, ignored"
%
file_path
)
logger
.
debug
(
"Usage report %r not found, ignored"
%
file_path
)
...
...
slapos/slap/slap.py
View file @
726cda79
...
@@ -562,7 +562,8 @@ class ConnectionHelper:
...
@@ -562,7 +562,8 @@ class ConnectionHelper:
def
getFullComputerInformation
(
self
,
computer_id
):
def
getFullComputerInformation
(
self
,
computer_id
):
# Check if cache (file) is enabled and exists: return directly from cache
# Check if cache (file) is enabled and exists: return directly from cache
if
self
.
cache_location
:
if
self
.
cache_location
:
computer_cache_location
=
os
.
path
.
join
(
cache_location
,
'computer.xml'
)
computer_cache_location
=
os
.
path
.
join
(
self
.
cache_location
,
'computer.xml'
)
if
self
.
cache_location
and
os
.
path
.
exists
(
computer_cache_location
):
if
self
.
cache_location
and
os
.
path
.
exists
(
computer_cache_location
):
return
xml_marshaller
.
loads
(
open
(
computer_cache_location
,
"r"
).
read
())
return
xml_marshaller
.
loads
(
open
(
computer_cache_location
,
"r"
).
read
())
# Fetch up-to-date information if no valid cache or cache is not enabled
# Fetch up-to-date information if no valid cache or cache is not enabled
...
@@ -570,7 +571,7 @@ class ConnectionHelper:
...
@@ -570,7 +571,7 @@ class ConnectionHelper:
# If cache enabled: set it
# If cache enabled: set it
if
self
.
cache_location
and
not
os
.
path
.
exists
(
computer_cache_location
):
if
self
.
cache_location
and
not
os
.
path
.
exists
(
computer_cache_location
):
cache
=
self
.
response
.
read
()
cache
=
self
.
response
.
read
()
open
(
computer_cache_location
,
"w
+
"
).
write
(
cache
)
open
(
computer_cache_location
,
"w"
).
write
(
cache
)
return
xml_marshaller
.
loads
(
cache
)
return
xml_marshaller
.
loads
(
cache
)
return
xml_marshaller
.
loads
(
self
.
response
.
read
())
return
xml_marshaller
.
loads
(
self
.
response
.
read
())
...
@@ -674,7 +675,7 @@ class slap:
...
@@ -674,7 +675,7 @@ class slap:
'rotocol'
%
(
slapgrid_uri
,
scheme
))
'rotocol'
%
(
slapgrid_uri
,
scheme
))
self
.
_connection_helper
=
ConnectionHelper
(
connection_wrapper
,
self
.
_connection_helper
=
ConnectionHelper
(
connection_wrapper
,
netloc
,
path
,
key_file
,
cert_file
,
master_ca_file
,
timeout
,
netloc
,
path
,
key_file
,
cert_file
,
master_ca_file
,
timeout
,
cache_location
)
self
.
cache_location
)
def
registerSoftwareRelease
(
self
,
software_release
):
def
registerSoftwareRelease
(
self
,
software_release
):
"""
"""
...
@@ -697,25 +698,29 @@ class slap:
...
@@ -697,25 +698,29 @@ class slap:
Registers connected representation of computer partition and
Registers connected representation of computer partition and
returns Computer Partition class object
returns Computer Partition class object
"""
"""
# If local cache directory location is defined: we'll use a file inside it
if
self
.
cache_location
:
if
self
.
cache_location
:
partition_cache_location
=
os
.
path
.
join
(
cache_location
,
partition_cache_location
=
os
.
path
.
join
(
self
.
cache_location
,
'partition%s%s.xml'
%
(
computer_guid
,
partition_id
))
'partition%s%s.xml'
%
(
computer_guid
,
partition_id
))
# If cache for this partition exists: use it
if
self
.
cache_location
and
os
.
path
.
exists
(
partition_cache_location
):
if
self
.
cache_location
and
os
.
path
.
exists
(
partition_cache_location
):
cache
=
open
(
partition_cache_location
,
"r"
).
read
()
xml_result
=
open
(
partition_cache_location
,
"r"
).
read
()
# Otherwise: go to server
else
:
else
:
self
.
_connection_helper
.
GET
(
'/registerComputerPartition?'
\
self
.
_connection_helper
.
GET
(
'/registerComputerPartition?'
\
'computer_reference=%s&computer_partition_reference=%s'
%
(
'computer_reference=%s&computer_partition_reference=%s'
%
(
computer_guid
,
partition_id
))
computer_guid
,
partition_id
))
xml_result
=
self
.
_connection_helper
.
response
.
read
()
# If cache is defined, let's write it.
if
self
.
cache_location
and
not
os
.
path
.
exists
(
partition_cache_location
):
if
self
.
cache_location
and
not
os
.
path
.
exists
(
partition_cache_location
):
cache
=
self
.
_connection_helper
.
response
.
read
()
open
(
partition_cache_location
,
"w"
).
write
(
xml_result
)
open
(
partition_cache_location
,
"w+"
).
write
(
cache
)
result
=
xml_marshaller
.
loads
(
xml_result
)
result
=
xml_marshaller
.
loads
(
cache
)
# XXX: dirty hack to make computer partition usable. xml_marshaller is too
# XXX: dirty hack to make computer partition usable. xml_marshaller is too
# low-level for our needs here.
# low-level for our needs here.
result
.
_connection_helper
=
self
.
_connection_helper
result
.
_connection_helper
=
self
.
_connection_helper
return
result
return
result
def
registerOpenOrder
(
self
):
def
registerOpenOrder
(
self
):
return
OpenOrder
(
connection_helper
=
self
.
_connection_helper
)
return
OpenOrder
(
connection_helper
=
self
.
_connection_helper
)
...
...
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