2 # -*- coding: iso-8859-1 -*-
3 # Copyright (C) 2007-2014 CEA/DEN, EDF R&D, OPEN CASCADE
5 # Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
6 # CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
8 # This library is free software; you can redistribute it and/or
9 # modify it under the terms of the GNU Lesser General Public
10 # License as published by the Free Software Foundation; either
11 # version 2.1 of the License.
13 # This library is distributed in the hope that it will be useful,
14 # but WITHOUT ANY WARRANTY; without even the implied warranty of
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 # Lesser General Public License for more details.
18 # You should have received a copy of the GNU Lesser General Public
19 # License along with this library; if not, write to the Free Software
20 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
25 ## \file killSalomeWithPort.py
26 # Stop all %SALOME servers from given sessions by killing them
28 # The sessions are indicated by their ports on the command line as in :
30 # killSalomeWithPort.py 2811 2815
34 import os, sys, pickle, signal, commands,glob
35 from salome_utils import verbose
38 def getPiDict(port,appname='salome',full=True,hidden=True,hostname=None, with2809pid=False):
40 Get file with list of SALOME processes.
41 This file is located in the user's home directory
42 and named .<user>_<host>_<port>_SALOME_pidict
50 - appname : application name (default is 'SALOME')
51 - full : if True, full path to the file is returned, otherwise only file name is returned
52 - hidden : if True, file name is prefixed with . (dot) symbol; this internal parameter is used
53 to support compatibility with older versions of SALOME
55 from salome_utils import generateFileName, getTmpDir
58 hostname = os.getenv("NSHOST")
59 if hostname: hostname = hostname.split(".")[0]
62 # full path to the pidict file is requested
64 # new-style dot-prefixed pidict files
65 # are in the system-dependant temporary diretory
68 # old-style non-dot-prefixed pidict files
69 # are in the user's home directory
70 dir = os.getenv("HOME")
75 if port == 2809 and with2809pid:
76 suffix = suffix + "-%s"%(os.getpid())
77 return generateFileName(dir,
81 with_hostname=hostname or True,
83 with_app=appname.upper())
85 def appliCleanOmniOrbConfig(port):
87 Remove omniorb config files related to the port in SALOME application:
88 - ${OMNIORB_USER_PATH}/.omniORB_${USER}_${HOSTNAME}_${NSPORT}.cfg
89 - ${OMNIORB_USER_PATH}/.omniORB_${USER}_last.cfg
90 the last is removed only if the link points to the first file.
92 from salome_utils import generateFileName, getUserName
93 omniorbUserPath = os.getenv("OMNIORB_USER_PATH")
94 if omniorbUserPath is None:
95 #Run outside application context
98 omniorb_config = generateFileName(omniorbUserPath, prefix="omniORB",
104 last_running_config = generateFileName(omniorbUserPath, prefix="omniORB",
109 if os.access(last_running_config,os.F_OK):
110 if not sys.platform == 'win32':
111 pointedPath = os.readlink(last_running_config)
112 if pointedPath[0] != '/':
113 pointedPath=os.path.join(os.path.dirname(last_running_config), pointedPath)
115 if pointedPath == omniorb_config:
116 os.unlink(last_running_config)
120 os.remove(last_running_config)
124 if os.access(omniorb_config,os.F_OK):
125 os.remove(omniorb_config)
128 if os.path.lexists(last_running_config):return
130 #try to relink last.cfg to an existing config file if any
131 files = glob.glob(os.path.join(omniorbUserPath,".omniORB_"+getUserName()+"_*.cfg"))
136 if stat.st_atime > current:
137 current=stat.st_atime
140 if sys.platform == "win32":
142 shutil.copyfile(os.path.normpath(current_config), last_running_config)
145 os.symlink(os.path.normpath(current_config), last_running_config)
151 ########## kills all salome processes with the given port ##########
153 def shutdownMyPort(port, cleanup=True):
155 Shutdown SALOME session running on the specified port.
162 from PortManager import releasePort
167 from salome_utils import generateFileName
169 # set OMNIORB_CONFIG variable to the proper file
170 omniorbUserPath = os.getenv("OMNIORB_USER_PATH")
172 if omniorbUserPath is not None:
173 kwargs["with_username"]=True
175 omniorbUserPath = os.path.realpath(os.path.expanduser('~'))
176 omniorb_config = generateFileName(omniorbUserPath, prefix="omniORB",
182 os.environ['OMNIORB_CONFIG'] = omniorb_config
183 os.environ['NSPORT'] = str(port)
185 # give the chance to the servers to shutdown properly
188 from omniORB import CORBA
189 from LifeCycleCORBA import LifeCycleCORBA
191 orb = CORBA.ORB_init([''], CORBA.ORB_ID)
192 lcc = LifeCycleCORBA(orb)
193 lcc.shutdownServers()
194 # give some time to shutdown to complete
196 # shutdown omniNames and notifd
206 def __killMyPort(port, filedict):
208 with open(filedict, 'r') as fpid:
210 from salome_utils import generateFileName
211 if sys.platform == "win32":
212 username = os.getenv( "USERNAME" )
214 username = os.getenv('USER')
215 path = os.path.join('/tmp/logs', username)
216 fpidomniNames = generateFileName(path,
218 suffix="Pid_omniNames",
221 if not sys.platform == 'win32':
222 cmd = 'pid=`ps -eo pid,command | egrep "[0-9] omniNames -start %s"` ; echo $pid > %s' % ( str(port), fpidomniNames )
226 with open(fpidomniNames) as fpidomniNamesFile:
227 lines = fpidomniNamesFile.readlines()
229 os.remove(fpidomniNames)
232 pidfield = l.split()[0] # pid should be at the first position
233 if sys.platform == "win32":
235 if verbose(): print 'stop process '+pidfield+' : omniNames'
236 win32pm.killpid(int(pidfield),0)
238 if verbose(): print 'stop process '+pidfield+' : omniNames'
239 os.kill(int(pidfield),signal.SIGKILL)
250 process_ids=pickle.load(fpid)
251 for process_id in process_ids:
252 for pid, cmd in process_id.items():
253 if verbose(): print "stop process %s : %s"% (pid, cmd[0])
255 if sys.platform == "win32":
257 win32pm.killpid(int(pid),0)
259 os.kill(int(pid),signal.SIGKILL)
263 if verbose(): print " ------------------ process %s : %s not found"% (pid, cmd[0])
265 pass # for pid, cmd ...
266 pass # for process_id ...
273 cmd='ps -eo pid,command | egrep "[0-9] omniNames -start '+str(port)+'" | sed -e "s%[^0-9]*\([0-9]*\) .*%\\1%g"'
274 pid = commands.getoutput(cmd)
276 while pid and len(a.split()) < 2:
277 a = commands.getoutput("kill -9 " + pid)
278 pid = commands.getoutput(cmd)
282 print "Cannot find or open SALOME PIDs file for port", port
287 def killMyPort(port):
289 Kill SALOME session running on the specified port.
293 from salome_utils import getShortHostName, getHostName
294 print "Terminating SALOME on port %s..."%(port)
296 # try to shutdown session normally
297 import threading, time
298 threading.Thread(target=shutdownMyPort, args=(port,False)).start()
299 time.sleep(3) # wait a little, then kill processes (should be done if shutdown procedure hangs up)
303 filedict = getPiDict(port, hidden=True, with2809pid=False)
305 all_files = glob.glob("%s*"%filedict)
307 __killMyPort(port, f)
309 # new-style dot-prefixed pidict file
310 filedict = getPiDict(port, hidden=True)
311 # provide compatibility with old-style pidict file (not dot-prefixed)
312 if not os.path.exists(filedict): filedict = getPiDict(port, hidden=False)
313 # provide compatibility with old-style pidict file (short hostname)
314 if not os.path.exists(filedict): filedict = getPiDict(port, hidden=True, hostname=getShortHostName())
315 # provide compatibility with old-style pidict file (not dot-prefixed, short hostname)
316 if not os.path.exists(filedict): filedict = getPiDict(port, hidden=False, hostname=getShortHostName())
317 # provide compatibility with old-style pidict file (long hostname)
318 if not os.path.exists(filedict): filedict = getPiDict(port, hidden=True, hostname=getHostName())
319 # provide compatibility with old-style pidict file (not dot-prefixed, long hostname)
320 if not os.path.exists(filedict): filedict = getPiDict(port, hidden=False, hostname=getHostName())
321 __killMyPort(port, filedict)
323 appliCleanOmniOrbConfig(port)
326 def killNotifdAndClean(port):
328 Kill notifd daemon and clean application running on the specified port.
333 filedict=getPiDict(port)
334 with open(filedict, 'r') as f:
337 for pid,process in d.items():
338 if 'notifd' in process:
339 cmd='kill -9 %d'% pid
344 #traceback.print_exc()
347 appliCleanOmniOrbConfig(port)
349 def killMyPortSpy(pid, port):
352 if sys.platform == "win32":
353 from win32pm import killpid
354 if killpid(int(pid), 0) != 0:
365 from time import sleep
368 filedict = getPiDict(port, hidden=True)
369 if not os.path.exists(filedict):
373 orb = omniORB.CORBA.ORB_init(sys.argv, omniORB.CORBA.ORB_ID)
374 import SALOME_NamingServicePy
375 ns = SALOME_NamingServicePy.SALOME_NamingServicePy_i(orb)
377 session = ns.Resolve("/Kernel/Session")
382 status = session.GetStatSession()
384 # -- session is in naming service but has crash
388 if not status.activeGUI:
394 if __name__ == "__main__":
395 if len(sys.argv) < 2:
397 print " %s <port>" % os.path.basename(sys.argv[0])
399 print "Kills SALOME session running on specified <port>."
402 if sys.argv[1] == "--spy":
403 if len(sys.argv) > 3:
406 killMyPortSpy(pid, port)
410 for port in sys.argv[1:]: