“古老的 Sys IPC 仍然有好幾種有效的用途。三種 IPC 對象是共享內存,信號燈和消息。”當使用到 IPC 的這些對象時,你需要為每個對象創(chuàng)建一個 Key。雖然理論上來說我們在定義一個 IPC Key 的時候可以使用任意自己喜歡的 Key ,但為了避免與其他的程序產(chǎn)生定義重復,在 UNIX/Linux 中一般會使用 key_t ftok(const char *path, int id) 函數(shù)來生成一個比較唯一的 Key 值。然而,“每個人都討厭 System V IPC。它比打孔紙帶還慢,使用與文件系統(tǒng)完全無關少得可憐的名字空間,使用人類討厭的數(shù)字給它的對象命名,并且還常常自己忘記自己的對象,你的系統(tǒng)管理員經(jīng)常需要用 ipcs(1) 查找那些丟失了的對象并且用 ipcrm(1) 刪除它們,還得求老天保佑不要在用光內存以后才發(fā)現(xiàn)問題?!?對于來實現(xiàn)進程監(jiān)控/自動重啟Bash Shell 腳本來說,在腳本里面硬編碼進當前程序用到的 Key 值肯定不是個好辦法,最好是實現(xiàn)相同算法的 ftok 函數(shù)。
#!/bin/sh
let key=0
function ftok() {
pathname=$1;
proj_id=$2;
str_st_ino=`stat --format='%i' "${pathname}" 2>/dev/null`;
str_st_dev=`stat --format='%d' "${pathname}" 2>/dev/null`;
if [ "x${str_st_ino}" = "x" -o "x${str_st_dev}" = "x" ] ; then
return 1;
fi
let st_ino=${str_st_ino}
let st_dev=${str_st_dev}
# 注意這里的位操作運算符需要加轉義符
let key1=${st_ino}\16#FFFF
let key2=${st_dev}\16#FF
let key2=${key2}\\16
let key3=${proj_id}\16#FF
let key3=${key3}\\24
let key=${key1}\|${key2}
let key=${key}\|${key3}
}
function echohelp(){
echo "ftok generator"
echo "Usage:ftok pathname projid"
exit 5
}
if [ $# -ne 2 ] ; then
echohelp
fi
sPathName=$1
let nProjectID=$2
if [ "${sPathName:0:1}" != "/" ] ; then
sPathName=${PWD}/${sPathName}
fi
if ! test -f ${sPathName} ; then
echo "No File Found![${sPathName}]"
exit 4
fi
ftok "${sPathName}" "${nProjectID}"
echo ${key}