程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> windows定時執行PHP的技巧,windowsphp技巧

windows定時執行PHP的技巧,windowsphp技巧

編輯:關於PHP編程

windows定時執行PHP的技巧,windowsphp技巧


windows定時執行PHP相信不少讀者(PHP愛好者)在工作、學習的過程中經常抱怨:在WIN如何讓PHP定時自動發信呢??如何讓MYSQL實現自動備份而無後顧之憂呢??如 果完全依靠手工進行當然也可以實現,但操作上似乎過於繁瑣了一點!別著急,利用系統的任務計劃程序(Windows 98稱之為計劃任務)可輕易解決這一問題。這一功能往往被很多用戶忽略或者未曾想到:)。

所謂任務計劃就是由計算機自動調用用戶事先設置好的應用程序,從而達到簡化用戶操作的目的。利用Windows 2000的任務計劃程序(相當與*NIX下的cron程序,這裡不再對其詳述),我們可以安排任何腳本、程序或文檔在最恰當的時候運行,從而滿足自己的需 要。下面以Windows 2000為例。

具體來說,我們若需利用任務計劃程序自動運行則應執行如下步驟:

1.單擊“開始”按鈕,然後依次選擇“程序”→“附件”→“系統工具”→“任務計劃”(或者是“設置”→“控制面板”→“任務計劃”),啟動Windows 2000的任務計劃管理程序。

2.在“任務計劃”窗口中雙擊“添加任務計劃”圖標,啟動系統的“任務計劃向導”,然後單擊“下一步”按鈕,在給出的程序列表中選擇需要自動運行的應用程序,然後單擊“下一步”按鈕。
設置適當的任務計劃名稱並選擇自動執行這個任務的時間頻率(如每天、每星期、每月、一次性、每次啟動計算機時、每次登錄時等),然後單擊“下一步”按鈕。
此時系統將會要求用戶對程序運行的具體時間進行設置,如幾號、幾點鐘、哪幾個時間段才能運行等,我們只需根據自己的需要加以設置即可。

4.接下來系統將會要求用戶設置適當的用戶名及密碼,以便系統今後能自動加以運行。

5.最後,我們只需單擊“完成”按鈕即可將相應任務添加到Windows 2000的任務計劃程序中,此後它就會自動“記住”這個任務,一旦系統時間及相關條件與用戶設置的計劃相符,它就會自動調用用戶所指定的應用程序,十分方 便(每次啟動Windows 2000的時候,任務計劃程序都會自動啟動,並在後台運行,確保用戶的計劃能夠按時執行)。

現在我們來測試一下剛才所建的任務是否成功,鼠標右鍵單擊“php”程序圖標(如圖6所示),在彈出的菜單裡面選擇“運行”。一般情況下程序圖標只要這樣 激活運行就可以正常啟動。如果運行失敗可查看用戶和密碼是否設置正確,還有確定“Task Scheduler”服務是否已啟動,本人當初就是為了節省系統資源把它關掉了導致運行失敗,害我找了大半天。另外也可從“系統日志”裡查看到底是什麼原 因造成運行失敗的。

好了,講了這麼多任務計劃的應用,現在我們切入正題,下面將介紹兩個例子:

一、讓PHP定時運行吧!
1、 編輯如下代碼,並保存為test.php:
<?php
$fp = @fopen("test.txt", "a+");
fwrite($fp, date("Y-m-d H:i:s") . " 讓PHP定時運行吧!\n");
fclose($fp);
?>
打開文本輸入:D:\php4\php.exe -q D:\php4\test.php
保存為.bat格式。
D:\php4\php.exe 是php安裝路徑,D:\php4\test.php是要定時運行的程序的路徑。

2、添加一個任務計劃,選擇那個.bat文件

3、時間設置為每隔1分鐘運行一次,然後運行這個任務。

4、現在我們來看看d:\php4\test.txt文件的內容時候是否成功。如果內容為如下所示,那麼恭喜你成功了。

2016-03-03 11:08:01 讓PHP定時運行吧!
2016-03-03 11:09:02 讓PHP定時運行吧!
2016-03-03 11:10:01 讓PHP定時運行吧!
2016-03-03 11:11:02 讓PHP定時運行吧!

二、讓MYSQL實現自動備份變成可能!
1、編輯如下代碼,並保存為backup.php,如果要壓縮可以拷貝一個rar.exe:
<?php
if ($argc != 2 || in_array($argv[1], array('--help', '-?'))) {
?>
backup   Ver 0.01, for Win95/Win98/WinNT/Win2000/WinXP on i32
Copyright (C) 2000 ptker All rights reserved. http://www.dareng.com
This is free software,and you are welcome to modify and redistribute it
under the GPL license

PHP Shell script for the backup MySQL database.

Usage: <?php echo $argv[0]; ?> <option>

   <option> can be database name you would like to backup.
   With the --help, or -? options, you can get this help and exit.
<?php
} else {
$dbname = $argv[1];
$dump_tool = "c:\\mysql\\bin\\mysqldump";
$rar_tool = "d:\\php4\\rar";
@exec("$dump_tool --opt -u user -ppassword $dbname > ./$dbname.sql");
@exec("$rar_tool a -ag_yyyy_mm_dd_hh_mm $dbname.rar $dbname.sql");
@unlink("$dbname.sql");
echo "Backup complete!";
}
?>

2、添加一個任務計劃,在(如圖2所示)這一步輸入命令:
D:\php4\php.exe -q D:\php4\backup.php databasename
3、時間設置為每天運行一次,然後運行這個任務。
4、最後會在d:\php4\目錄下生成一個以數據庫名和當前時間組成的rar文件。
5、恭喜你!大功告成了!
當然備份方式有很多種,讀者可按照自己喜歡的去做!

1. 如果出現錯誤:
           在試著設置任務帳戶信息時出現錯誤
   指定的錯誤是:
   0x80070005:拒絕訪問
   您沒有運行所請求的操作的權限

在上面'"4.接下來系統將會要求用戶設置適當的用戶名及密碼(如圖5所示),以便系統今後能自動加以運行".這裡最好用"system"用戶,密碼可為空.

這個system的權限非常之高,比你的administrator還要高,所以你在運行命令的時候千萬不要亂來,這個可是什麼提示都沒有就會無條件執行的,這個權限下你kill核心進程都行.

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved