Source code for ElementsExamples.SpawnExample
#
# Copyright (C) 2012-2020 Euclid Science Ground Segment
#
# This library is free software; you can redistribute it and/or modify it under
# the terms of the GNU Lesser General Public License as published by the Free
# Software Foundation; either version 3.0 of the License, or (at your option)
# any later version.
#
# This library 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 Lesser General Public License for more
# details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with this library; if not, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
#
""" Small example for a python based script using multiprocessing
"""
import argparse
import multiprocessing
import time
import ElementsKernel.Logging as log
[docs]def worker_func(i):
logger = log.getLogger('SpawnTest')
logger.info("Hello from %d", i)
[docs]def defineSpecificProgramOptions():
"""
@brief Allows to define the (command line and configuration file) options
specific to this program
@details See the Elements documentation for more details.
@return An ArgumentParser.
"""
parser = argparse.ArgumentParser()
#
# !!! Write your program options here !!!
# e.g. parser.add_argument('--string-value', type=str, help='A string option')
#
return parser
[docs]def mainMethod(args):
"""
@brief The "main" method.
@details This method is the entry point to the program. In this sense, it is
similar to a main (and it is why it is called mainMethod()).
"""
logger = log.getLogger('SpawnTest')
logger.info('#')
logger.info('# Entering SpawnTest mainMethod()')
logger.info('#')
num_procs = 4
time.sleep(2)
with multiprocessing.get_context("spawn").Pool(num_procs) as p:
p.map(worker_func, [i for i in range(num_procs)])
logger.info('#')
logger.info('# Exiting SpawnTest mainMethod()')
logger.info('#')