0

これはファイルロックを実装するコード例であるため、アプリケーションは1つのインスタンスしか開くことができません。現在は機能していますが、ロックファイルをホームフォルダー(Ubuntu)に保存します。アプリケーションがクラッシュした場合、ロックファイルは削除されません。これは適切ではありません。

代わりにコードを変更してc:/ tmp-folderに保存する場所がわかりませんか?

#!/usr/bin/python
# -*- coding: utf-8 -*-


#implements a lockfile if program already is open
import os
import socket
from fcntl import flock

class flock(object):
    '''Class to handle creating and removing (pid) lockfiles'''

    # custom exceptions
    class FileLockAcquisitionError(Exception): pass
    class FileLockReleaseError(Exception): pass

    # convenience callables for formatting
    addr = lambda self: '%d@%s' % (self.pid, self.host)
    fddr = lambda self: '<%s %s>' % (self.path, self.addr())
    pddr = lambda self, lock: '<%s %s@%s>' %\
                              (self.path, lock['pid'], lock['host'])

    def __init__(self, path, debug=None):
        self.pid   = os.getpid()
        self.host  = socket.gethostname()
        self.path  = path
        self.debug = debug # set this to get status messages

    def acquire(self):
        '''Acquire a lock, returning self if successful, False otherwise'''
        if self.islocked():
            if self.debug:
                lock = self._readlock()
                print 'Previous lock detected: %s' % self.pddr(lock)
            return False
        try:
            fh = open(self.path, 'w')
            fh.write(self.addr())
            fh.close()
            if self.debug:
                print 'Acquired lock: %s' % self.fddr()
        except:
            if os.path.isfile(self.path):
                try:
                    os.unlink(self.path)
                except:
                    pass
            raise (self.FileLockAcquisitionError,
                   'Error acquiring lock: %s' % self.fddr())
        return self

    def release(self):
        '''Release lock, returning self'''
        if self.ownlock():
            try:
                os.unlink(self.path)
                if self.debug:
                    print 'Released lock: %s' % self.fddr()
            except:
                raise (self.FileLockReleaseError,
                       'Error releasing lock: %s' % self.fddr())
        return self

    def _readlock(self):
        '''Internal method to read lock info'''
        try:
            lock = {}
            fh   = open(self.path)
            data = fh.read().rstrip().split('@')
            fh.close()
            lock['pid'], lock['host'] = data
            return lock
        except:
            return {'pid': 8**10, 'host': ''}

    def islocked(self):
        '''Check if we already have a lock'''
        try:
            lock = self._readlock()
            os.kill(int(lock['pid']), 0)
            return (lock['host'] == self.host)
        except:
            return False

    def ownlock(self):
        '''Check if we own the lock'''
        lock = self._readlock()
        return (self.fddr() == self.pddr(lock))

    def __del__(self):
        '''Magic method to clean up lock when program exits'''
        self.release()

#now testing to see if file is locked = other instance of this program is running already

lock = flock('tmp.lock', True).acquire()
if lock:
    print 'doing stuff'
else:
    print 'locked!'
    exit()


#end of lockfile
4

2 に答える 2

1

tempfileを使用する

于 2011-04-15T10:20:52.623 に答える
0

スクリプトの最後に:

lock = flock('tmp.lock', True).acquire()

'tmp.lock'、現在のディレクトリ内のファイルへのパスです。必要なパスに変更します。つまり、'c:/tmp-folder/tmp.lock'

lock = flock('c:/tmp-folder/tmp.lock', True).acquire()

ただし、@ g19fanaticが指摘しているように、Windows('c:/ ...')またはLinux(Ubuntu)システムを使用していますか?

于 2011-04-15T10:18:31.667 に答える