2008年8月21日 星期四

Apache 安裝設定教學

加入書籤: HemiDemi MyShare Baidu Google Bookmarks Yahoo! My Web Del.icio.us Digg technorati furl

官方網站:http://www.apache.org/
安裝步驟
  1. 下載並執行 Apache HTTP Server 2.2.9
  2. 安裝精靈起始(Installation Wizard)畫面:
    • 直接按 Next。
  3. 使用許可協議(License Agreement)畫面:
    • 點選 I accept the terms in the license agreement。
    • 按 Next。
  4. 讀我檔案(Read This First)畫面:
    • 直接按 Next。
  5. 伺服器資訊設定(Server Information)畫面:
    • Network Domain 與 Server Name 請依照實際情況填寫,若不知道可填 localhost。
    • Administrator's Email Address 則是填自己的 Email 信箱。
    • 按 Next。
  6. 安裝類型選擇(Setup Type)畫面:
    • 點選 Custom。
    • 按 Next。
  7. 自訂安裝元件選擇(Custom Setup)畫面:
    • 直接按 Next。
  8. 安裝確認(Ready to Install the Program)畫面:
    • 直接按 Install。
  9. 安裝完成(Installation Wizard Completed)畫面:
    • 按 Finish。
    • 安裝成功。
設定步驟

可將右下角小時鐘旁的Apache Monitor小圖示關閉,不影響伺服器運作。

httpd.conf 設定

用記事本開啟 C:\Program Files\Apache Group\Apache2\conf\httpd.conf,並按照以下原則進行修改。

請自行以關鍵字尋找並取代預設設定,若沒有預設設定則新增在檔案最後面即可。

強調的部分請依實際情況修改。

請注意斜線(/)與反斜線(\)的不同,以免造成不必要的錯誤。

設定完成後必須重新啟動伺服器以套用新的設定。

  • 網頁目錄及權限設定

    設定說明:

    • 以 D:\www 目錄作為網頁存放路徑。
    • 若目錄中沒有索引頁(index.html等),則傳回 403 Forbidden,不會列出目錄中檔案。
    DocumentRoot "D:/www"
    <Directory />
    Options None
    AllowOverride FileInfo
    Order allow,deny
    Allow from all
    </Directory>


    另外,建議以<Directory</Directory>為關鍵字,搜尋並將不相關的目錄設定標記起來,使其沒有作用。




  • 索引頁檔名設定

    設定說明:




    • 依次以index.html與index.xml為首頁檔名。



    DirectoryIndex index.html index.xml



  • 錯誤頁面設定

    設定說明:




    • 在發生 403 Forbidden 與 404 Not Found 時,以 /error/*error.php 的內容取代錯誤訊息。



    ErrorDocument 403 /error/403error.php
    ErrorDocument 404 /error/404error.php



  • 使用 mod_deflate 增進傳輸效能設定

    設定說明:




    • 在瀏覽器可以接受的情況下,傳送壓縮過的內容以增進傳輸效率,但會增加伺服器負擔。


    • DeflateCompressionLevel 設定壓縮等級。


    • AddOutputFilterByType 根據 MIME Type 設定要壓縮的檔案類型。


    • AddOutputFilter 根據副檔名設定要壓縮的檔案類型。



    LoadModule deflate_module modules/mod_deflate.so
    <ifmodule mod_deflate.c>
    DeflateCompressionLevel 9
    AddOutputFilterByType DEFLATE text/html text/xml text/css application/x-httpd-php
    AddOutputFilter DEFLATE html htm xml php css
    </ifmodule>


2008年7月29日 星期二

完整版-資料備份精靈 Ver 2.04

加入書籤: HemiDemi MyShare Baidu Google Bookmarks Yahoo! My Web Del.icio.us Digg technorati furl

FileBackupPro

  • 資料備份精靈程式說明:

資料備份精靈是一套全中文介面的檔案備份工具,完全免費讓大家使用,非常適用在個人工作室以及公司行號的電腦資料備份,軟體可以設定備份的時間,時間一到自動備份您的資料,並且可以指定您所要備份的類型,您不至於備份到您不想備份的檔案,相當的方便,無限的備份清單,不管硬碟上有多少檔案,都可以完整的備份,以及區域網路端備份... 等等,簡單的使用者介面,輕鬆上手,備份不求人,不管是我的最愛‧以重要的 Outlook Express 郵件等等,都可以備份起來。

雖然資料備份精靈在功能上比不上收費軟體,但是在使用上絕對符合一般使用者的需求。

  • 資料備份精靈的相關功能如下:

0) 全新的備份核心,除了強化備份速度之外,正在使用的檔案也可以備份(壓縮備份除外)。
1) 可以自動每分鐘、每小時、每天、每週、每月定時備份檔案。
2) 完整的區域網路備份,備份方式為:

近端 ←→ 遠端
遠端 ←→ 近端
遠端 ←→ 遠端
PS:遠端備份僅限於「區域網路」內

3) 內建檔案壓縮功能,備份檔案格式為 7-ZIP 壓縮格式(7-ZIP / WinRAR 3.5 以上均支援)。
4) 可以指定不壓縮 (最快)、快速壓縮以及最大壓縮 (最耗時) 的壓縮範圍可供選擇。
5) 可以指定壓縮時是否加入密碼保護(若忘記密碼我也沒法度解決喔!)。
6) 可以指定不想備份的日期,從星期一至星期天都可自由指定。
7) 可以指定檔案 / 資料夾排除功能,本軟體有內定數個系統資料夾與檔案的排除專案。
8) 內建完整、遞增、同步、壓縮備份功能。
9) 可限制備份檔案大小,降低備份時所花費的時間。
10) 副檔名編輯功能,除了本軟體內建之外,還可自行增加。
11) 備份專案匯入/匯出功能。
12) 簡單的備份專案還原功能。
13) 詳細的備份日誌檢視功能,可知道到底備份多少檔案。
14) 內建數個備份專案,可備份我的最愛、電子郵件 ... 等等。
15) 檔案刪除可決定是否要將刪除的檔案移到資源回收筒內。
17) 支援新版作業系統 Windows Vista 32 位元,但不支援 64 位元喔。
18) 支援 Jazz 及 Zip、USB 行動碟、USB 硬碟等外接裝置的備份。
19) 支援 Unicode 檔案、資料夾備份。
20) 程式不用安裝,所有程式不超過 400K,解壓縮後就可以使用,無須擾人的 OCX 元件。

  • 系統需求:

作業系統 :Windows 2000/XP/2003/Vista 32 位元
中央處理器:Intel Pentium III 500 MHz 以上處理器。
記憶體 :64 MB 以上,建議使用 256 MB 或更高。
硬碟 :1 MB 之安裝空間。
螢幕解析度:800*600、1024*768(建議)

原始出處-紅淚網

原始著作下載點 ( 中華電信)
鏡像下載點 ( 台灣 FTP 聯盟 )

監控程序的小工具-Magic Process

加入書籤: HemiDemi MyShare Baidu Google Bookmarks Yahoo! My Web Del.icio.us Digg technorati furl

MagicProcess

MagicProcess提供詳細的應用程式清單、監控程式的運作,藉此可用來判斷病毒或者後門程式,與 Windows 的工作管理員大致上是差不多的軟體管理工具。
主要的功能有:
1.可以列出所有應用程序以及程序中所使用的相關模組,用滑鼠雙擊該程式就可以觀看。
2.可以結束所有應用程式、包含作業系統所載入的核心程式。
3.可以修改所有應用程式的優先順序。
4.可以結束應用程序並且刪除您所終止的應用程式檔案。
5.可以監控應用程式的所有一切動作,有助於您的分析與判斷是否為病毒或後門程式。
6.可以利用滑鼠右鍵來選擇已經存在的應用程式、模組的相關資訊,以及資料夾的所在地。
7.可以排除使用者所指定的應用程式,可避免病毒作怪。
8.可以觀看應用程式所使用的網路連線,有助於您的分析與判斷是否為病毒或後門程式。
9.可以中斷指定應用程式的網路連線。
10.可以觀看已經開啟的任何視窗,與 Windows 大致上是一樣的功能。
11.可以觀看 CPU 的使用率(支援雙核心),與 Windows 工作管理員常駐列是完全相同的。
12.程式相關屬性都可以利用 Google、Yahoo、Msn 搜尋相關的資訊。
13.可以釋放應用程式的記憶體。
14.內建數十個 Windows 系統內建的系統工具程式。
15.無須 OCX 等擾人的控制元件,程式不到 150 KB。
16.支援 Unicode。
17.支援 Windows 2000/XP/2003/Vista。

原著作下載點 (中華電信)
鏡像下載點 ( 台灣 FTP 聯盟 )

原始出處-紅淚網

2008年7月8日 星期二

網頁認證的方式.htaccess使用技巧

加入書籤: HemiDemi MyShare Baidu Google Bookmarks Yahoo! My Web Del.icio.us Digg technorati furl

.htaccess 網頁認證的方式,是以目錄為一個驗證的節點,凡要經過此目錄才能瀏覽的網頁,

皆需要透過 .htaccess 的驗證之後才可以存取。

舉例:

我有一個學術單位的網頁,網址為 http://sparc.nfu.edu.tw/~test/test/

是要讓大家都可以來瀏覽的;不過我有一些比較機密性的文件,僅可以提供某些特定的人來瀏覽,

於是這些機密性的文件我都將它放置到網頁根目錄底下的 admin目錄當中,

如今我要讓來存取網址為 http://sparc.nfu.edu.tw/~test/admin/(任何檔案)

都需要透過驗證才能夠瀏覽,我可以這麼做:

步驟1.建立 .htaccess

在 admin 目錄中,建立一個 .htaccess 的檔案,

.htaccess 的檔案內容為 :

AuthName "Admin Login"

AuthUserFile /home1/test/.passwd

AuthType Basic

require valid-user

各欄位的意義:

1. AuthName "Admin Login"

用來設定如下紅色方框內的文字

123

2. AuthUserFile /home1/test/.passwd

AuthUserFile 用來設定給 .htaccess 驗證時,要使用的帳號密碼資料的位置,

需使用絕對路徑的方式來設定。

/home1/test/.passwd 帳號密碼資料檔,是由我們自行產生的(在 步驟2 會說明)。

3. AuthType Basic

認證的類型;我們使用 Apache 預設的類型,Basic就可以了

4. require valid-user

讓密碼檔內的使用者都能夠登入(即上面AuthUserFile所指定的檔案)

步驟2. 產生帳號密碼檔

利用 htpasswd 指令來幫我們產生帳號密碼檔

語法:htpasswd [ 參數 ] < 帳號密碼檔 > < 要新建的登入帳號 >

1. 若現在我要新建一個登入帳號 為 test

而這個時候 /home1/test/.passwd 帳號密碼檔

還不存在,則我需要輸入下列指令:

htpasswd –c /home1/test/.passwd test

(-c 參數用來產生帳號密碼檔 )

基於安全性上的考量,帳號密碼檔 請勿放置在WWW目錄內(含WWW以下目錄中),

建議使用者可將帳號密碼檔放置在 使用者家目錄 即可。

輸入完之後,它會請您輸入此使用者 test 的密碼,輸入完,

便會產生 /home1/test/.passwd 帳號密碼檔案,

並且在 /home1/test/.passwd 檔案裡面您會看到 test 這個帳號,

與其加密過後的密碼。

(需特別注意的是,如果 /home1/test/.passwd 已經存在的話,

請不要再使用 –c 參數,因為它會覆蓋掉原本/home1/test/.passwd

的內容,只留下我們此次建立的帳號資料 )

2. 如果現在我要再新建一個登入帳號 為 admin,

而這個時候 /home1/test/.passwd 已經存在,

則我只需要輸入下列指令,

htpasswd /home1/test/.passwd admin

然後它依然會請您輸入此使用者的密碼,輸入完畢後,

/home1/test/.passwd 就會看到,

您剛剛新建的使用者帳號及密碼的資料了。

經過 步驟1 與 步驟2 的設定之後,

只要有人要來瀏覽我的 http://sparc.nfu.edu.tw/~test/admin/(任何檔案)

就必須要輸入帳號密碼,此時只要輸入在 步驟2 所建立的帳號密碼,就可以登入了。

-------------------------------------------------------------------------------

現在有了一個更方便的工具,那就是 .htaccess 檔案產生器(htaccess Generator)透過網頁的勾選與設定,在按下 Generator .htaccess File 後便可以得到一個 htaccess 檔,非常方便。

【網站網址】http://cooletips.de/htaccess/

2008年6月25日 星期三

SQL 資料庫災難復原 (使用 Binary Log)

加入書籤: HemiDemi MyShare Baidu Google Bookmarks Yahoo! My Web Del.icio.us Digg technorati furl

當 MySQL Server 因為各種無法預期的原因而損毀(Crash)的時候,你就必須要進行災難復原。若是您有做好定期的資料庫備份那麼災難還原的時候應該會輕鬆很多,只要將備份起來的資料還原回去即可,但光是這樣子還是會造成部份資料的遺失,例如 "現在" 至 "最後一次備份" 之間的資料,這時我們可以透過 MySQL 提供的 Binary Log 機制將可能遺失的資料降至最低。
Binary Log 的運作原理很簡單,它只是單純的將所有會修改到資料庫內容的操作記錄在 Log 檔案中,然後透過這個 Binary Log 你就可以重新執行所有會修改到資料庫內容的操作。例如若你最後一次備份的時間是 1/1 AM 0:00 ,並且有啟用 Binary Log 功能記錄 1/1 AM 0:00 這個時間點以後所有會修改到資料庫內容的操作,假設你的 MySQL Server 在 1/2 AM 10:00 故障,你就可以將 1/1 AM 0:00 備份的資料還原回去,然後利用 Binary Log 將 1/1 AM 0:00 ~ 1/2 AM 10:00 之間所有的操作重新執行一次,這樣子一來你就可以將資料庫還原到當機的那個時間點。
使用 Binary Log 進行災難復原的步驟:

  1. 啟用 Binary Log
  2. 使用 mysqlbinlog 將 Binary Log 轉換成可執行的 SQL 指令

在接下來的文章中會使用的範例與假設:
  1. 最後一次備份的時間點為 1/1 AM 0:00
  2. MySQL Server 在 1/2 AM 10:00 故障

一、啟用 Binary Log

修改 MySQL Server 的系統設定檔(eg. /etc/my.cnf),在 [mysqld] 區塊中加上 log-bin=mysql-bin 選項,然後重新啟動 MySQL Server,例如:

引用:

[mysqld]
log-bin=mysql-bin

啟用後你應該可以在 MySQL 的 Data Dir 裡面發現如下的檔案:

mysql-bin.index
mysql-bin.000001
mysql-bin.000002
...............
mysql-bin.00000X

MySQL 在以下幾種情況會進行 lograrote:
  1. 執行 Flush Logs 指令
  2. MySQL Server 重新啟動
  3. 設定檔中有進行額外的設定

註:
請注意,當您使用 mysqldump 進行資料庫備份時請記得加上 --flush-logs 選項,例如:

引用:

mysqldump --flush-logs -u root -p 資料庫名稱 > example.sql

這麼做的目的是在備份時讓 MySQL Server 進行 logrotate,這樣子日後要辨別 "最後一次備份時間點" 之後的 Binary Log 會比較方便,因為若你沒有主動(或透過設定)去刪除 Binary Log,則只要你的硬碟空間夠大,MySQL 會無限期的保存 Binary Log,也就是說你的 Binary Log 裡面所記載的資料有可能包含 "最後一次備份時間點" 之前的資料。


二、使用 mysqlbinlog 將 Binary Log 轉換成可執行的 SQL 指令

Binary Log 是無法被 MySQL Server 直接執行、也無法直接以人眼去閱讀的,必須要先使用 MySQL 所提供的 mysqlbinlog 程式,將 Binary Log 轉換為 MySQL Server 可以執行的 SQL 指令。mysqlbinlog 的語法如下:

引用:

mysqlbinlog -H --set-charset="utf8" --start-datatime="2007-01-01 00:00:00" --stop-datatime="2007-01-02 10:00:00" mysql-bin.[0-9]* > example.sql

-H:Display a hex dump of the log in comments.
--set-charset:設定編碼
--start-datatime:要轉換的開始時間點
--stop-datatime:要轉換的結束時間點
mysql-bin.[0-9]*:這裡要注意的是,要一次處理所有的 Binary Log,因為儲存在 Binary Log 中的資料有可能會 "跨檔案",例如從 mysql-bin.000001 的結尾接到 mysql-bin.000002 的開頭。
example.sql:轉換出來的文字檔的檔案名稱,這個名稱可以自已取。
需要加 -H 選項的原因如下:

引用:

mysqlbinlog didn't escape the string content of user variables, and did not deal well when these variables were in non-ASCII character sets; this is now fixed by always printing the string content of user variables in hexadecimal. The character set and collation of the string is now also printed. (Bug #3875)


實際執行轉換後的 Binary Log

很簡單,只要一行簡單的指令:

引用:

mysql < example.sql

如果沒有什麼錯誤訊息發生,那麼只要等它執行完就大功告成了。話又說回來,要是執行失敗呢?這是有可能的。MySQL 在處理 Binary Log 時有一些 Bug 存在,它的 Bug Report 似乎是說在最新版本的 MySQL Server 中已修正此 Bug,我沒有實際測試過所以不清楚,但若是你和我一樣也遇到這個 Bug 的話,也不用太擔心。這些問題其實不難解決,自己 Workaround 即可。
目前我看到的情況有:

  1. Comment 沒有正確標示
  2. Comment 語法錯誤
  3. 不正確的使用 DELIMITER
  4. 奇怪的 STOP 指令(我不太確定這是做什麼用的)

自己用 sed 去修改轉換過後的 example.sql 即可。

引用:

sed -f replace.rules example.sql > final.sql

replace.rules檔案的內容:

引用:

s/\(Query.*thread\)/#\1/g
s/\(###.*###\)//g
s/DELIMITER ;//g
s/Stop//g

上面幾行的意義:
s/\(Query.*thread\)/#\1/g


MySQL 的 Binary Log 在處理 Comment 的時候,有的時候會漏加 "#" 符號在 Comment Line 的最前面。例如本來是:

引用:

Query thread_id=227528 exec_time=- error_code=0

要改成:

引用:

#Query thread_id=227528 exec_time=- error_code=0


s/\(###.*###\)//g

在某些 SQL statement(例如 REPLACE INTO search)的最後面會有一些 Comment 存在,但這些 Comment 的語法不正確反而會造成執行失敗,故刪除之。
類似以下的行都應該刪除:

引用:

### Bitfield: user.options ###
### SAVE ORDERED IDS TO SEARCH CACHE ###

........等等


s/DELIMITER ;//g

刪除不正確的 DELIMITER 指令,像以下這樣就是不正確的:

引用:

DELIMITER ;


s/Stop//g
有的時候會在 Binary Log 中出現 Stop 這個指令而導致執行失敗,故刪除之。但我不太確定這個 Stop 指令實質上的用途是什麼。

使用 mysqldump備份 DB

加入書籤: HemiDemi MyShare Baidu Google Bookmarks Yahoo! My Web Del.icio.us Digg technorati furl

[MySQL] 使用 mysqldump備份 DB

mysqldump 做備份,如果要儘可能把完整的資料匯出,可以加上 --single-transaction,備份前 mysqldump 會先執行 BEGIN ,取得 READ LOCK 後,便能確定資料在執行 mysqldump 的過程中不會受到其它連線存取的干擾,也能 Dump 出較完整的資料。(使用此參數需有 READ LOCK 權限)

mysqldump --single-transaction --all-databases > all_db.sql

注意:
1.表單較大時可以加上 --quick
2.MySQL Cluster 不支援 --single-transaction

然而使用 --single-transaction 時最好搭配 --flush-logs--master-data 來維持 Binary Log 的完整性。(使用這二個參數皆需有 RELOAD 權限)

mysqldump --single-transaction --flush-logs --master-data --all-databases > all_db.sql

Binary Log 採用的是遞增備份,--flush-logs 便是把目前的 Binary Log 給 flush 出來 (若目前 MASTER_LOG_FILE 已經到 mysql-bin.000005,產生出來的檔案便是 mysql-bin.000006),完成之後才進行 Dump 的作業。

而 --master-data (預設值為1) 則是在 Dump 出來的 SQL 語法中加入下面這一行,以記錄目前 Dump 的時間點。

CHANGE MASTER TO MASTER_LOG_FILE=mysql-bin.000006',MASTER_LOG_POS=4;

如果在未來執行匯入時 SQL 語法時, MySQL 便能很清楚的知道這次 Dump 出來的 SQL 在 Binary Log 中是屬於哪個位置。

註: 若不需理會 Binary Log 的位置時 (例如進行完整備份作業),只要將 --master-data 設為 2 便會將 CHANGE MASTER 給註解起來純供參考用。

免費Blog架站軟體

加入書籤: HemiDemi MyShare Baidu Google Bookmarks Yahoo! My Web Del.icio.us Digg technorati furl

網路上有很多免費的Blog可以用,但是總是不夠客製化,版面也都侷限於BSP所提供的面版,就算會CSS、HTML等語法,但總是綁手綁腳的,加上每個BSP提供的功能又不同,所以總是有些不便,若各位想要讓你的Blog更炫、更與眾不同,那可以試試下面幾套優質的Blog架站軟體,若你有覺得其他好的架站軟體,也歡迎推薦!!

  1. Movable Type (第三屆年度網誌獎獲選為年度最佳網誌出版工具 (best web application for weblogs))
    中文文件說明:Ultimate Handbook or Movable Type 文件集
  2. WordPress中文 WordPress
  3. LifeType
  4. Bo-Blog :對岸的架站軟體,在文章、人氣的統計做的不錯,可以簡繁轉換(plugin),功能頗多
  5. TatterTools :簡稱為TT,有繁體中文的論壇,功能越加越多,也蠻方便使用的。
  6. F2Blog:有繁、簡、英三個網頁版本,於2006.5.12日正式成立開發小組,有提供Plugin及Skin。
  7. Simple PHP Blog:(SPHPBlog)最大的特點是不需要資料庫,使用純文字檔案儲存內容,程式輕巧安裝簡單,基本功能如RSS Feeds,留言,文章分類,Trackback,防Spam,圖片上傳,佈景配色等均有。

2008年6月23日 星期一

Phtrain手機台鐵高鐵時刻生成器

加入書籤: HemiDemi MyShare Baidu Google Bookmarks Yahoo! My Web Del.icio.us Digg technorati furl

Phtain

對於常改點的台鐵,記不住新時刻嗎?「Phtrain」網站,提供台鐵與高鐵時刻表,搜尋到新時刻

,再將時刻表以圖片形式下載存入手機,即可不必花任何手機上網費,就帶著時刻表趴趴走

,無形中也省下不少紙張。

多種圖片格式提供不怕你的手機太挑剔,Phtrain提供多樣的圖片格式,一定滿足你的手機。

方便又省時有了Phtrain,你就可以隨時隨地,在手機上觀看時刻表,不用在浪費時間等待。

官網 : http://tw.nfair.net/phtrain/index.php

狀態廣告

EasyReadMore