Parse tags %MEM% and %VCPUS% in {app,net}vm-template.conf (#115)

This commit is contained in:
Marek Marczykowski 2011-03-16 13:39:54 -04:00
parent 379a5620c8
commit ef6a3e576b
2 changed files with 44 additions and 2 deletions

View File

@ -68,6 +68,8 @@ default_templatevm_conf_template = "templatevm.conf" # needed for TemplateVM clo
default_appmenus_templates_subdir = "apps.templates" default_appmenus_templates_subdir = "apps.templates"
default_kernels_subdir = "kernels" default_kernels_subdir = "kernels"
default_firewall_conf_file = "firewall.xml" default_firewall_conf_file = "firewall.xml"
default_memory = 400
default_servicevm_vcpus = 1
# do not allow to start a new AppVM if Dom0 mem was to be less than this # do not allow to start a new AppVM if Dom0 mem was to be less than this
dom0_min_memory = 700*1024*1024 dom0_min_memory = 700*1024*1024
@ -174,7 +176,9 @@ class QubesVm(object):
netvm_vm = None, netvm_vm = None,
installed_by_rpm = False, installed_by_rpm = False,
updateable = False, updateable = False,
label = None): label = None,
memory = default_memory,
vcpus = None):
assert qid < qubes_max_qid, "VM id out of bounds!" assert qid < qubes_max_qid, "VM id out of bounds!"
@ -209,6 +213,15 @@ class QubesVm(object):
# PCI devices - used only by NetVM # PCI devices - used only by NetVM
self.pcidevs = "" self.pcidevs = ""
self.memory = memory
# By default allow use all VCPUs
if vcpus is None:
qubes_host = QubesHost()
self.vcpus = qubes_host.no_cpus
else:
self.vcpus = vcpus
if not dry_run and xend_session.session is not None: if not dry_run and xend_session.session is not None:
self.refresh_xend_session() self.refresh_xend_session()
@ -685,9 +698,13 @@ class QubesTemplateVm(QubesVm):
conf_templatevm_template = open (src_template_vm.templatevm_conf_template, "r") conf_templatevm_template = open (src_template_vm.templatevm_conf_template, "r")
conf_file = open(self.conf_file, "w") conf_file = open(self.conf_file, "w")
rx_templatename = re.compile (r"%TEMPLATENAME%") rx_templatename = re.compile (r"%TEMPLATENAME%")
rx_mem = re.compile (r"%MEM%")
rx_vcpus = re.compile (r"%VCPUS%")
for line in conf_templatevm_template: for line in conf_templatevm_template:
line = rx_templatename.sub (self.name, line) line = rx_templatename.sub (self.name, line)
line = rx_mem.sub (str(self.memory), line)
line = rx_vcpus.sub (str(self.vcpus), line)
conf_file.write(line) conf_file.write(line)
conf_templatevm_template.close() conf_templatevm_template.close()
@ -906,12 +923,16 @@ class QubesCowVm(QubesVm):
rx_vmdir = re.compile (r"%VMDIR%") rx_vmdir = re.compile (r"%VMDIR%")
rx_template = re.compile (r"%TEMPLATEDIR%") rx_template = re.compile (r"%TEMPLATEDIR%")
rx_pcidevs = re.compile (r"%PCIDEVS%") rx_pcidevs = re.compile (r"%PCIDEVS%")
rx_mem = re.compile (r"%MEM%")
rx_vcpus = re.compile (r"%VCPUS%")
for line in conf_template: for line in conf_template:
line = rx_vmname.sub (self.name, line) line = rx_vmname.sub (self.name, line)
line = rx_vmdir.sub (self.dir_path, line) line = rx_vmdir.sub (self.dir_path, line)
line = rx_template.sub (self.template_vm.dir_path, line) line = rx_template.sub (self.template_vm.dir_path, line)
line = rx_pcidevs.sub (self.pcidevs, line) line = rx_pcidevs.sub (self.pcidevs, line)
line = rx_mem.sub (str(self.memory), line)
line = rx_vcpus.sub (str(self.vcpus), line)
conf_appvm.write(line) conf_appvm.write(line)
conf_template.close() conf_template.close()
@ -1036,6 +1057,9 @@ class QubesNetVm(QubesCowVm):
if "label" not in kwargs or kwargs["label"] is None: if "label" not in kwargs or kwargs["label"] is None:
kwargs["label"] = default_servicevm_label kwargs["label"] = default_servicevm_label
if "vcpus" not in kwargs or kwargs["vcpus"] is None:
kwargs["vcpus"] = default_servicevm_vcpus
super(QubesNetVm, self).__init__(**kwargs) super(QubesNetVm, self).__init__(**kwargs)
@property @property
@ -1117,6 +1141,8 @@ class QubesNetVm(QubesCowVm):
private_img=self.private_img, private_img=self.private_img,
installed_by_rpm=str(self.installed_by_rpm), installed_by_rpm=str(self.installed_by_rpm),
label=self.label.name, label=self.label.name,
memory=str(self.memory),
vcpus=str(self.vcpus),
) )
return element return element
@ -1262,6 +1288,8 @@ class QubesProxyVm(QubesNetVm):
private_img=self.private_img, private_img=self.private_img,
installed_by_rpm=str(self.installed_by_rpm), installed_by_rpm=str(self.installed_by_rpm),
label=self.label.name, label=self.label.name,
memory=str(self.memory),
vcpus=str(self.vcpus),
) )
return element return element
@ -1507,7 +1535,10 @@ class QubesAppVm(QubesCowVm):
private_img=self.private_img, private_img=self.private_img,
installed_by_rpm=str(self.installed_by_rpm), installed_by_rpm=str(self.installed_by_rpm),
updateable=str(self.updateable), updateable=str(self.updateable),
label=self.label.name) label=self.label.name,
memory=str(self.memory),
vcpus=str(self.vcpus),
)
return element return element
def start(self, debug_console = False, verbose = False, preparing_dvm = False): def start(self, debug_console = False, verbose = False, preparing_dvm = False):

View File

@ -57,6 +57,10 @@ def main():
help="Create ProxyVM") help="Create ProxyVM")
parser.add_option ("-n", "--net", action="store_true", dest="netvm", default=False, parser.add_option ("-n", "--net", action="store_true", dest="netvm", default=False,
help="Create NetVM") help="Create NetVM")
parser.add_option ("-m", "--mem", dest="mem", default=None,
help="Initial memory size (in MB)")
parser.add_option ("-c", "--vcpus", dest="vcpus", default=None,
help="VCPUs count")
parser.add_option ("-q", "--quiet", action="store_false", dest="verbose", default=True) parser.add_option ("-q", "--quiet", action="store_false", dest="verbose", default=True)
(options, args) = parser.parse_args () (options, args) = parser.parse_args ()
@ -127,6 +131,13 @@ def main():
vm = qvm_collection.add_new_proxyvm(vmname, template_vm, label = label) vm = qvm_collection.add_new_proxyvm(vmname, template_vm, label = label)
else: else:
vm = qvm_collection.add_new_appvm(vmname, template_vm, label = label) vm = qvm_collection.add_new_appvm(vmname, template_vm, label = label)
if options.mem is not None:
vm.memory = options.mem
if options.vcpus is not None:
vm.vcpus = options.vcpus
try: try:
vm.create_on_disk(verbose=options.verbose) vm.create_on_disk(verbose=options.verbose)
vm.add_to_xen_storage() vm.add_to_xen_storage()