“古老的 Sys IPC 仍然有好幾種有效用途。三種 IPC 對象是共用記憶體,號誌和訊息。”當使用到 IPC 的這些對象時,你需要為每個對象建立一個 Key。雖然理論上來說我們在定義一個 IPC Key 的時候可以使用任意自己喜歡的 Key ,但為了避免與其他的程式產生定義重複,在 UNIX/Linux 中一般會使用 key_t ftok(const char *path, int id) 函數來產生一個比較唯一的 Key 值。然而,“每個人都討厭 System V IPC。它比打孔紙帶還慢,使用與檔案系統完全無關少得可憐的名字空間,使用人類討厭的數字給它的對象命名,並且還常常自己忘記自己的對象,你的系統管理員經常需要用 ipcs(1) 尋找那些丟失了的對象並且用 ipcrm(1) 刪除它們,還得求老天保佑不要在用光記憶體以後才發現問題。” 對於來實現進程監控/自動重啟Bash Shell 指令碼來說,在指令碼裡面寫入程式碼進當前程式用到的 Key 值肯定不是個好辦法,最好是實現相同演算法的 ftok 函數。
複製代碼 代碼如下:
#!/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}