lslock /tmp
File /tmp/locks/my.lock is locked by PID 5421
lslock
comes with two executables, lslock
and lslock-test
.
lslock
checks a given directory (and subdirectories) for any locked files and outputs them.lslock-test
locks a given number of files in a given directory and is used to check the validity oflslock
.
See lslock --help
or lslock-test --help
for parameters.
lslock
was tested on Ubuntu 12.04, but should work on Linux with Python >= 2.7. For a leaner method of testing for locks on specific files, check out lsof.
Make sure you have python and pip installed. If you are on a debian/ubuntu based system, you can install them via
sudo apt-get update
sudo apt-get install -y python-pip python-dev build-essential
sudo pip install --upgrade pip virtualenv
Then run the following to be able to run lslock
and lslock-test
. If you are not using a virtualenv, you might need to run this as sudo as well.
cd <path-to-repo>
virtualenv venv
. venv/bin/activate
pip install -e .
Make sure you have vagrant installed. Then run vagrant up
in the cloned repository. You are now able to connect with ssh vagrant@172.25.12.6:22
, password vagrant
and find the contents of this repository at /vagrant/
.
Create the virtual env with virtualenv /vagrant/venv
and activate it with . /vagrant/venv/bin/activate
. Install the dependencies via pip install -e /vagrant/
.
You can run the tests via nosetests /vagrant/lslock.py
.
- Make sure that lslock actually follows symlinks. It currently errors on
lslock /
- For large data sets (like
/
) lslock will take a long time and probably die of memory exhaustion. Check lsock:72ff to compare files in batches instead of all at once. - For lslock-test, use the actuall lslock methods to check for locked files instead of circumventing the call.