古老的 Sys IPC 仍然有好幾種有效的用途。三種 IPC 對(duì)象是共享內(nèi)存,信號(hào)燈和消息?!碑?dāng)使用到 IPC 的這些對(duì)象時(shí),你需要為每個(gè)對(duì)象創(chuàng)建一個(gè) Key。雖然理論上來說我們?cè)诙x一個(gè) IPC Key 的時(shí)候可以使用任意自己喜歡的 Key ,但為了避免與其他的程序產(chǎn)生定義重復(fù),在 UNIX/Linux 中一般會(huì)使用 key_t ftok(const char *path, int id) 函數(shù)來生成一個(gè)比較唯一的 Key 值。然而,“每個(gè)人都討厭 System V IPC。它比打孔紙帶還慢,使用與文件系統(tǒng)完全無關(guān)少得可憐的名字空間,使用人類討厭的數(shù)字給它的對(duì)象命名,并且還常常自己忘記自己的對(duì)象,你的系統(tǒng)管理員經(jīng)常需要用 ipcs(1) 查找那些丟失了的對(duì)象并且用 ipcrm(1) 刪除它們,還得求老天保佑不要在用光內(nèi)存以后才發(fā)現(xiàn)問題?!?對(duì)于來實(shí)現(xiàn)進(jìn)程監(jiān)控/自動(dòng)重啟Bash Shell 腳本來說,在腳本里面硬編碼進(jìn)當(dāng)前程序用到的 Key 值肯定不是個(gè)好辦法,最好是實(shí)現(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}
# 注意這里的位操作運(yùn)算符需要加轉(zhuǎn)義符
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}
更多信息請(qǐng)查看IT技術(shù)專欄