I just noticed a problem with terminating a process (from the multiprocessing
library) of a method on Linux. I have an application that works with the multiprocessing
library, but ... when I call the terminate
function on Windows, everything works fine, on the other hand, Linux does not work with this solution. As a substitute for the killing process, I was forced to use
os.system('kill -9 {}'.format(pid))
I know this is not too smart, but it works. So I'm just wondering why this code works on Windows, but on Linux it fails.
Example:
from multiprocessing import Process import os process=Process(target=foo,args=('bar',)) pid=process.pid process.terminate()
My configuration: python 3.2.0 build 88445; Linux-2.6.32-Debian-6.0.4
This is a sample from my code. I hope this will be enough.
def start_test(timestamp,current_test_suite,user_ip): global_test_table[timestamp] = current_test_suite setattr(global_test_table[timestamp], "user_ip", user_ip) test_cases = global_test_table[timestamp].test_cases_table test_cases = test_cases*int(global_test_table[timestamp].count + 1) global_test_table[timestamp].test_cases_table = test_cases print(test_cases) print(global_test_table[timestamp].test_cases_table) case_num = len(test_cases) Report.basecounter = Report.casecounter = case_num setattr(global_test_table[timestamp], "case_num", case_num) setattr(global_test_table[timestamp], "user_current_test", 0) try: dbobj=MySQLdb.connect(*dbconnector) dbcursor=dbobj.cursor() dbcursor.execute(sqlquery_insert_progress.format(progress_timestamp = str(timestamp), user_current_test = global_test_table[timestamp].user_current_tes$ except :... for i in range(case_num): user_row = global_test_table[timestamp] current_test_from_tests_table = user_row.test_cases_table[i] unittest.TextTestRunner(verbosity=2).run(suite(CommonGUI.get_address(CommonGUI,current_test_from_tests_table[1], current_test_from_tests_table[2], user$ global_test_table[timestamp].user_current_test = i + 1 try: dbobj=MySQLdb.connect(*dbconnector) dbcursor=dbobj.cursor() dbcursor.execute(sqlquery_update_progress.format(progress_timestamp = str(timestamp), user_current_test = global_test_table[timestamp].user_current$ except :... @cherrypy.expose() def start_test_page(self, **test_suite): timestamp = str(time.time()) user_ip = cherrypy.request.remote.ip if on_server(): sys.stdout=sys.stderr=open("/var/log/cherrypy/test_gui/{file}.log".format(file=timestamp),"a") current_test_suite = self.parse_result(**test_suite)