|
|
import os
|
|
|
|
|
|
c = get_config()
|
|
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
# Select which launchers to use
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
|
|
# This allows you to control what method is used to start the controller
|
|
|
# and engines. The following methods are currently supported:
|
|
|
# - Start as a regular process on localhost.
|
|
|
# - Start using mpiexec.
|
|
|
# - Start using the Windows HPC Server 2008 scheduler
|
|
|
# - Start using PBS/SGE
|
|
|
# - Start using SSH
|
|
|
|
|
|
|
|
|
# The selected launchers can be configured below.
|
|
|
|
|
|
# Options are:
|
|
|
# - LocalControllerLauncher
|
|
|
# - MPIExecControllerLauncher
|
|
|
# - PBSControllerLauncher
|
|
|
# - SGEControllerLauncher
|
|
|
# - WindowsHPCControllerLauncher
|
|
|
# c.Global.controller_launcher = 'IPython.parallel.apps.launcher.LocalControllerLauncher'
|
|
|
# c.Global.controller_launcher = 'IPython.parallel.apps.launcher.PBSControllerLauncher'
|
|
|
|
|
|
# Options are:
|
|
|
# - LocalEngineSetLauncher
|
|
|
# - MPIExecEngineSetLauncher
|
|
|
# - PBSEngineSetLauncher
|
|
|
# - SGEEngineSetLauncher
|
|
|
# - WindowsHPCEngineSetLauncher
|
|
|
# c.Global.engine_launcher = 'IPython.parallel.apps.launcher.LocalEngineSetLauncher'
|
|
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
# Global configuration
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
|
|
# The default number of engines that will be started. This is overridden by
|
|
|
# the -n command line option: "ipcluster start -n 4"
|
|
|
# c.Global.n = 2
|
|
|
|
|
|
# Log to a file in cluster_dir/log, otherwise just log to sys.stdout.
|
|
|
# c.Global.log_to_file = False
|
|
|
|
|
|
# Remove old logs from cluster_dir/log before starting.
|
|
|
# c.Global.clean_logs = True
|
|
|
|
|
|
# The working directory for the process. The application will use os.chdir
|
|
|
# to change to this directory before starting.
|
|
|
# c.Global.work_dir = os.getcwd()
|
|
|
|
|
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
# Local process launchers
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
|
|
# The command line arguments to call the controller with.
|
|
|
# c.LocalControllerLauncher.controller_args = \
|
|
|
# ['--log-to-file','--log-level', '40']
|
|
|
|
|
|
# The working directory for the controller
|
|
|
# c.LocalEngineSetLauncher.work_dir = u''
|
|
|
|
|
|
# Command line argument passed to the engines.
|
|
|
# c.LocalEngineSetLauncher.engine_args = ['--log-to-file','--log-level', '40']
|
|
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
# MPIExec launchers
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
|
|
# The mpiexec/mpirun command to use in both the controller and engines.
|
|
|
# c.MPIExecLauncher.mpi_cmd = ['mpiexec']
|
|
|
|
|
|
# Additional arguments to pass to the actual mpiexec command.
|
|
|
# c.MPIExecLauncher.mpi_args = []
|
|
|
|
|
|
# The mpiexec/mpirun command and args can be overridden if they should be different
|
|
|
# for controller and engines.
|
|
|
# c.MPIExecControllerLauncher.mpi_cmd = ['mpiexec']
|
|
|
# c.MPIExecControllerLauncher.mpi_args = []
|
|
|
# c.MPIExecEngineSetLauncher.mpi_cmd = ['mpiexec']
|
|
|
# c.MPIExecEngineSetLauncher.mpi_args = []
|
|
|
|
|
|
# The command line argument to call the controller with.
|
|
|
# c.MPIExecControllerLauncher.controller_args = \
|
|
|
# ['--log-to-file','--log-level', '40']
|
|
|
|
|
|
# Command line argument passed to the engines.
|
|
|
# c.MPIExecEngineSetLauncher.engine_args = ['--log-to-file','--log-level', '40']
|
|
|
|
|
|
# The default number of engines to start if not given elsewhere.
|
|
|
# c.MPIExecEngineSetLauncher.n = 1
|
|
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
# SSH launchers
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
|
|
# ipclusterz can be used to launch controller and engines remotely via ssh.
|
|
|
# Note that currently ipclusterz does not do any file distribution, so if
|
|
|
# machines are not on a shared filesystem, config and json files must be
|
|
|
# distributed. For this reason, the reuse_files defaults to True on an
|
|
|
# ssh-launched Controller. This flag can be overridded by the program_args
|
|
|
# attribute of c.SSHControllerLauncher.
|
|
|
|
|
|
# set the ssh cmd for launching remote commands. The default is ['ssh']
|
|
|
# c.SSHLauncher.ssh_cmd = ['ssh']
|
|
|
|
|
|
# set the ssh cmd for launching remote commands. The default is ['ssh']
|
|
|
# c.SSHLauncher.ssh_args = ['tt']
|
|
|
|
|
|
# Set the user and hostname for the controller
|
|
|
# c.SSHControllerLauncher.hostname = 'controller.example.com'
|
|
|
# c.SSHControllerLauncher.user = os.environ.get('USER','username')
|
|
|
|
|
|
# Set the arguments to be passed to ipcontrollerz
|
|
|
# note that remotely launched ipcontrollerz will not get the contents of
|
|
|
# the local ipcontrollerz_config.py unless it resides on the *remote host*
|
|
|
# in the location specified by the --cluster_dir argument.
|
|
|
# c.SSHControllerLauncher.program_args = ['-r', '-ip', '0.0.0.0', '--cluster_dir', '/path/to/cd']
|
|
|
|
|
|
# Set the default args passed to ipenginez for SSH launched engines
|
|
|
# c.SSHEngineSetLauncher.engine_args = ['--mpi', 'mpi4py']
|
|
|
|
|
|
# SSH engines are launched as a dict of locations/n-engines.
|
|
|
# if a value is a tuple instead of an int, it is assumed to be of the form
|
|
|
# (n, [args]), setting the arguments to passed to ipenginez on `host`.
|
|
|
# otherwise, c.SSHEngineSetLauncher.engine_args will be used as the default.
|
|
|
|
|
|
# In this case, there will be 3 engines at my.example.com, and
|
|
|
# 2 at you@ipython.scipy.org with a special json connector location.
|
|
|
# c.SSHEngineSetLauncher.engines = {'my.example.com' : 3,
|
|
|
# 'you@ipython.scipy.org' : (2, ['-f', '/path/to/ipcontroller-engine.json']}
|
|
|
# }
|
|
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
# Unix batch (PBS) schedulers launchers
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
|
|
# SGE and PBS are very similar. All configurables in this section called 'PBS*'
|
|
|
# also exist as 'SGE*'.
|
|
|
|
|
|
# The command line program to use to submit a PBS job.
|
|
|
# c.PBSLauncher.submit_command = ['qsub']
|
|
|
|
|
|
# The command line program to use to delete a PBS job.
|
|
|
# c.PBSLauncher.delete_command = ['qdel']
|
|
|
|
|
|
# The PBS queue in which the job should run
|
|
|
# c.PBSLauncher.queue = 'myqueue'
|
|
|
|
|
|
# A regular expression that takes the output of qsub and find the job id.
|
|
|
# c.PBSLauncher.job_id_regexp = r'\d+'
|
|
|
|
|
|
# If for some reason the Controller and Engines have different options above, they
|
|
|
# can be set as c.PBSControllerLauncher.<option> etc.
|
|
|
|
|
|
# PBS and SGE have default templates, but you can specify your own, either as strings
|
|
|
# or from files, as described here:
|
|
|
|
|
|
# The batch submission script used to start the controller. This is where
|
|
|
# environment variables would be setup, etc. This string is interpreted using
|
|
|
# the Itpl module in IPython.external. Basically, you can use ${n} for the
|
|
|
# number of engine and ${cluster_dir} for the cluster_dir.
|
|
|
# c.PBSControllerLauncher.batch_template = """
|
|
|
# #PBS -N ipcontroller
|
|
|
# #PBS -q $queue
|
|
|
#
|
|
|
# ipcontrollerz --cluster-dir $cluster_dir
|
|
|
# """
|
|
|
|
|
|
# You can also load this template from a file
|
|
|
# c.PBSControllerLauncher.batch_template_file = u"/path/to/my/template.sh"
|
|
|
|
|
|
# The name of the instantiated batch script that will actually be used to
|
|
|
# submit the job. This will be written to the cluster directory.
|
|
|
# c.PBSControllerLauncher.batch_file_name = u'pbs_controller'
|
|
|
|
|
|
# The batch submission script used to start the engines. This is where
|
|
|
# environment variables would be setup, etc. This string is interpreted using
|
|
|
# the Itpl module in IPython.external. Basically, you can use ${n} for the
|
|
|
# number of engine and ${cluster_dir} for the cluster_dir.
|
|
|
# c.PBSEngineSetLauncher.batch_template = """
|
|
|
# #PBS -N ipcontroller
|
|
|
# #PBS -l nprocs=$n
|
|
|
#
|
|
|
# ipenginez --cluster-dir $cluster_dir$s
|
|
|
# """
|
|
|
|
|
|
# You can also load this template from a file
|
|
|
# c.PBSControllerLauncher.batch_template_file = u"/path/to/my/template.sh"
|
|
|
|
|
|
# The name of the instantiated batch script that will actually be used to
|
|
|
# submit the job. This will be written to the cluster directory.
|
|
|
# c.PBSEngineSetLauncher.batch_file_name = u'pbs_engines'
|
|
|
|
|
|
|
|
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
# Windows HPC Server 2008 launcher configuration
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
|
|
# c.IPControllerJob.job_name = 'IPController'
|
|
|
# c.IPControllerJob.is_exclusive = False
|
|
|
# c.IPControllerJob.username = r'USERDOMAIN\USERNAME'
|
|
|
# c.IPControllerJob.priority = 'Highest'
|
|
|
# c.IPControllerJob.requested_nodes = ''
|
|
|
# c.IPControllerJob.project = 'MyProject'
|
|
|
|
|
|
# c.IPControllerTask.task_name = 'IPController'
|
|
|
# c.IPControllerTask.controller_cmd = [u'ipcontroller.exe']
|
|
|
# c.IPControllerTask.controller_args = ['--log-to-file', '--log-level', '40']
|
|
|
# c.IPControllerTask.environment_variables = {}
|
|
|
|
|
|
# c.WindowsHPCControllerLauncher.scheduler = 'HEADNODE'
|
|
|
# c.WindowsHPCControllerLauncher.job_file_name = u'ipcontroller_job.xml'
|
|
|
|
|
|
|
|
|
# c.IPEngineSetJob.job_name = 'IPEngineSet'
|
|
|
# c.IPEngineSetJob.is_exclusive = False
|
|
|
# c.IPEngineSetJob.username = r'USERDOMAIN\USERNAME'
|
|
|
# c.IPEngineSetJob.priority = 'Highest'
|
|
|
# c.IPEngineSetJob.requested_nodes = ''
|
|
|
# c.IPEngineSetJob.project = 'MyProject'
|
|
|
|
|
|
# c.IPEngineTask.task_name = 'IPEngine'
|
|
|
# c.IPEngineTask.engine_cmd = [u'ipengine.exe']
|
|
|
# c.IPEngineTask.engine_args = ['--log-to-file', '--log-level', '40']
|
|
|
# c.IPEngineTask.environment_variables = {}
|
|
|
|
|
|
# c.WindowsHPCEngineSetLauncher.scheduler = 'HEADNODE'
|
|
|
# c.WindowsHPCEngineSetLauncher.job_file_name = u'ipengineset_job.xml'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|