跳到主要內容

HAVP DNS Error

HAVP最近似乎水土不服,一天到晚出現DNS Error,害我被財務長叫去夾卵蛋。不知道為什麼換成0.86版後常常會需要reload才會正常load網頁,尤其是奇摩股市。所以只好惡搞囉...

印象中用domain name找ip應該叫gethostbyname,果然在sockethandler.cpp第520列找到,加上
// For avoid dns error
struct hostent * MyGetHostByName(const char *name)
{
struct hostent *result = NULL;
result = gethostbyname(name);
if(result == NULL)
{
// Wait for 0.5 sec, 1 second = 1 million microseconds
usleep(500000);
//try again
result = gethostbyname(name);
}
return result;
}
再把
else if ( (server = gethostbyname( domainT.c_str() )) )
換成
else if ( (server = MyGetHostByName( domainT.c_str() )) )
如果再出現,我就得再加幾個dirty檢查,總有一天會成功的吧?!

剛看到gslin這篇,再仔細看gethostbyname man page的bug:
BUGS
These functions use a thread-specific data storage; if the data is needed
for future use, it should be copied before any subsequent calls overwrite
it.

Though these functions are thread-safe, still it is recommended to use
the getaddrinfo(3) family of functions, instead.

Only the Internet address format is currently understood.
這種鳥事誰會知道呀!所以出現錯誤是因為被另一個process呼叫時蓋掉了?

留言

這個網誌中的熱門文章

自然人憑證讀卡機驅動程式

鳥毅用的是第一代的自然人憑證讀卡機,EZ100PU(後來有同事買EZmini可以讀SIM卡似乎更好),每年報稅時用一次。 本來只是要申請些政府業務,一時之間找不到光碟,沒想到在 驅動程式下載 居然看到Linux和Mac的驅動程式,剩下的就是政府單位的網頁和程式應該改版了吧!!!

DBeaver 介面語言

DBeaver是我個人頗常用的一套跨平台Database管理工具,最近升級後發現Windows版本居然變成簡體中文,而且無法切換為英文。

如何將較高版本SQL Server複製到低版本SQL Server (降級為舊版)並保留權限及資料庫圖表

一般若是要將SQL Server裡的Database轉往其他Server時,最簡單的方式就是備份(Backup)後再還原(Restore),或者是䣃離(detach)後附加(attach)。 但是很不幸地,若是由較低版本(e.g. 2008)到較高版本(e.g. 2012)要怎麼辦呢?