#1. 스스로 특정 파일(예를들어 /tmp/my_program/launch.lock) 이 존재하는지 체크하고, (없으면 생성)
#2. flock()를 LOCK_EX | LOCK_NB 를 사용하여 호출해보세요.
#3. 만약 flock()이 에러를 리턴하면, 누군가 해당 프로그램을 이미 구동하고 있는것이고, 아니면 쓰면됩니다.
#4. 프로그램 종료이 종료되면서, 해당 파일 디스크립터는 자동으로 닫기고, 따라서 lock도 자동으로 해제됩니다.
그냥 #1. 에서 파일이 존재하면, 누군가 쓰고있는것이고, 없으면 아무도 안쓰고 있는것이라고 판단해도 충분하지 않으냐,
왜 심지어 파일이 없어서 자기가 직접 파일을 생성해도
#2에서 flock()을 이용해 자신이 만든 파일에 lock()을 얻느냐는 궁금증을 가지신다면,
그것은 파일이 존재하는지 체크 하는 부분과 파일을 생성하는것이 atomic operation이 아니기 때문입니다.
최소한, flock()을 이용하여 해당파일에 lock을 얻고 해제하는것은 커널이 보장해주는 atomicity이기때문에 안심하고 사용할수 있는것입니다.
atomicity 가 무엇이고, 이유를 설명한 부분이 잘 이해가 안가신다면, 그냥 궁금해하지말고, 위에서 언급한 순서대로 flock()을 사용하세요.
그리고, 사용하기전에, flock의 man page를 꼭, 꼼꼼히 읽어보세요.
주의사항이 많습니다. fork()하거나, dup()을 이용할때의 이슈들도 잘 읽어보세요.
man 2 flockflock()을
man 2 flock
flock()을 사용하세요.
프로그램이 시작할때마다,
#1. 스스로 특정 파일(예를들어 /tmp/my_program/launch.lock) 이 존재하는지 체크하고, (없으면 생성)
#2. flock()를 LOCK_EX | LOCK_NB 를 사용하여 호출해보세요.
#3. 만약 flock()이 에러를 리턴하면, 누군가 해당 프로그램을 이미 구동하고 있는것이고, 아니면 쓰면됩니다.
#4. 프로그램 종료이 종료되면서, 해당 파일 디스크립터는 자동으로 닫기고, 따라서 lock도 자동으로 해제됩니다.
그냥 #1. 에서 파일이 존재하면, 누군가 쓰고있는것이고, 없으면 아무도 안쓰고 있는것이라고 판단해도 충분하지 않으냐,
왜 심지어 파일이 없어서 자기가 직접 파일을 생성해도
#2에서 flock()을 이용해 자신이 만든 파일에 lock()을 얻느냐는 궁금증을 가지신다면,
그것은 파일이 존재하는지 체크 하는 부분과 파일을 생성하는것이 atomic operation이 아니기 때문입니다.
최소한, flock()을 이용하여 해당파일에 lock을 얻고 해제하는것은 커널이 보장해주는 atomicity이기때문에 안심하고 사용할수 있는것입니다.
atomicity 가 무엇이고, 이유를 설명한 부분이 잘 이해가 안가신다면, 그냥 궁금해하지말고, 위에서 언급한 순서대로 flock()을 사용하세요.
그리고, 사용하기전에, flock의 man page를 꼭, 꼼꼼히 읽어보세요.
주의사항이 많습니다. fork()하거나, dup()을 이용할때의 이슈들도 잘 읽어보세요.
killall 명령어가 인자로 '프로세스 명칭'을 받는건데요,
killall [프로세스 이름] 이라고 입력하면 해당 프로세스는 모조리 kill 해버립니다.
즉, 커널소스를 검색해서 killall.c 혹은 kill.c 를 참고해서
프로세스가 떠있는지, 없는지 검사하면 되지 않을까요 ?
------------------ System programmer...^^
- unix 전통적으로는 pid를 기록한 lock
- unix 전통적으로는 pid를 기록한 lock file (익명님이 쓰신 것)을 체크하는 식으로 많이들 씁니다.
- 그 외에 커널 object를 만들어서 체크하는 방법도 있고요.
댓글 달기