self.slice_id = rec['slice_id']
self.disk_usage_initialized = False
self.initscriptchanged = False
self.slice_id = rec['slice_id']
self.disk_usage_initialized = False
self.initscriptchanged = False
- _root_context_arch=None
- @staticmethod
- def root_context_arch():
- if not Sliver_VS._root_context_arch:
- Sliver_VS._root_context_arch=commands.getoutput("uname -i")
- return Sliver_VS._root_context_arch
-
- @staticmethod
- def personality (arch):
- personality="linux32"
- if arch.find("64")>=0:
- personality="linux64"
- return personality
-
@staticmethod
def create(name, vref = None):
logger.verbose('Sliver_VS:create - name=%s'%name)
@staticmethod
def create(name, vref = None):
logger.verbose('Sliver_VS:create - name=%s'%name)
refname="-".join( (pldistro,fcdistro,arch) )
# check the template exists -- there's probably a better way..
refname="-".join( (pldistro,fcdistro,arch) )
# check the template exists -- there's probably a better way..
logger.log("%s (%s) : vref %s not found, using default %s"%(
name,vref,refname,default))
refname=default
logger.log("%s (%s) : vref %s not found, using default %s"%(
name,vref,refname,default))
refname=default
logger.log("%s (%s) : unexpected error follows - using 'default'"%(name,vref))
logger.log(traceback.format_exc())
refname="default"
arch="i386"
logger.log("%s (%s) : unexpected error follows - using 'default'"%(name,vref))
logger.log(traceback.format_exc())
refname="default"
arch="i386"
logger.log_call('/usr/sbin/vuseradd', '-t', refname, name)
# export slicename to the slice in /etc/slicename
file('/vservers/%s/etc/slicename' % name, 'w').write(name)
# set personality: only if needed (if arch's differ)
logger.log_call('/usr/sbin/vuseradd', '-t', refname, name)
# export slicename to the slice in /etc/slicename
file('/vservers/%s/etc/slicename' % name, 'w').write(name)
# set personality: only if needed (if arch's differ)
- if Sliver_VS.root_context_arch() != arch:
- file('/etc/vservers/%s/personality' % name, 'w').write(Sliver_VS.personality(arch))
- logger.log('%s: set personality to %s'%(name,Sliver_VS.personality(arch)))
+ if tools.root_context_arch() != arch:
+ file('/etc/vservers/%s/personality' % name, 'w').write(personality(arch))
+ logger.log('%s: set personality to %s'%(name,personality(arch)))
def start(self, delay=0):
if self.rspec['enabled'] > 0:
def start(self, delay=0):
if self.rspec['enabled'] > 0:
if self.is_running():
logger.log("%s: Setting name to %s" % (self.name, self.slice_id),2)
self.setname(self.slice_id)
if self.is_running():
logger.log("%s: Setting name to %s" % (self.name, self.slice_id),2)
self.setname(self.slice_id)
else: # tell vsh to disable remote login by setting CPULIMIT to 0
logger.log('%s: disabling remote login' % self.name)
self.set_sched_config(0, 0)
else: # tell vsh to disable remote login by setting CPULIMIT to 0
logger.log('%s: disabling remote login' % self.name)
self.set_sched_config(0, 0)