您好,登錄后才能下訂單哦!
這篇文章主要介紹了PHP中超時的設置方法有哪些,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
打開php.ini文件,找到:
max_execution_time=30
修改為:
max_execution_time=600
如果你沒有服務器修改權限,可通過內置PHP腳本的方法設置超時時間,在需要執行長時間操作的PHP文件中添加以下代碼:
<?php ini_set('max_execution_time', 600);//秒為單位,自己根據需要定義
還可以通過.htaccess 文件設置超時時間,在文件中添加以下代碼:
php_value max_execution_time 600
(2)重新設置腳本執行時間,并重置計時器
set_time_limit ( int $seconds ) : bool
seconds------最大的執行時間,單位為秒。如果設置為0(零),沒有時間方面的限制。
設置允許腳本運行的時間,單位為秒。如果超過了此設置,腳本返回一個致命的錯誤。默認值為30秒,或者是在php.ini的max_execution_time被定義的值,如果此值存在。
當此函數被調用時,set_time_limit()會從零開始重新啟動超時計數器。換句話說,如果超時默認是30秒,在腳本運行了了25秒時調用 set_time_limit(20),那么,腳本在超時之前可運行總時間為45秒。
Curl 是常用的訪問HTTP協議接口的lib庫,性能高,還有一些并發支持的功能等。
curl_setopt($ch, opt) 可以設置一些超時的設置,主要包括:
a 、CURLOPT_TIMEOUT 設置CURL允許執行的最長秒數。
b、CURLOPT_TIMEOUT_MS 設置CURL允許執行的最長毫秒數。
c、 CURLOPT_CONNECTTIMEOUT 在發起連接前等待的時間,如果設置為0,則無限等待。
d、 CURLOPT_CONNECTTIMEOUT_MS 嘗試連接等待的時間,以毫秒為單位。如果設置為0,則無限等待。
e、 CURLOPT_DNS_CACHE_TIMEOUT 設置在內存中保存DNS信息的時間,默認為120秒。
<?php $socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP); socket_set_option($socket,SOL_SOCKET,SO_RCVTIMEO,array("sec"=> 1, "usec"=> 0 ) ); // 接收 socket_set_option($socket,SOL_SOCKET,SO_SNDTIMEO,array("sec"=> 3, "usec"=> 0 ) ); // 發送
雖然PHP中對fsockopen()方法有連接socket的超時參數,但是沒有類似C中的連接成功后對數據的讀寫超時參數設置。沒關系,PHP中對stream提供了一系列的方法以防止超時。
stream_set_blocking( $fp , false )
設置數據流為阻塞模式,以防止數據沒讀完就退出
如果模式為 false, 給定的 socket 描述符將切換到非塊模式, 如果為 true, 則切換到塊模式. 這個效果類似于 fgets() 從 socket 讀的情況. 在非塊模式 fgets() 將會立即返回,而在塊模式將等待數據滿足要求。
stream_set_timeout( $fp , 10 )
設置超時,應該在成功建立連接之后立即加上此句,后面的參數單位為秒
從封裝協議文件指針中取得報頭/元數據,返回的是一個數組,其中格式為:
Array ( [stream_type] => tcp_socket [mode] => r+ [unread_bytes] => 0 [seekable] => [timed_out] => [blocked] => 1 [eof] => )
其中索引timed_out為超時信息,超時則為true,未超時則為false,我們可以籍由此來判斷socket是否超時,需要注意的是此句應該加在每次需要等待的語句之后,比如fwrite(),fread(),并且每讀一次,都要判斷一次是否超時,而對于一個連接只需一次超時設置stream_set_timeout( $fp , 10 )就可以了。
$fp = @fsockopen( $ip , $port, $errNo , $errstr, 30 ); if( !$fp ) { return false; } else { stream_set_timeout( $fp , 3 ) ; //發送數據 fwrite( $fp , $packet ) ; $status = stream_get_meta_data( $fp ) ; //發送數據超時 if( $status['timed_out'] ) { echo "Write time out" ; fclose( $fp ); return false; } //讀取數據 $buf = fread( $fp , 16 ) ; $status = stream_get_meta_data( $fp ) ; //讀取數據超時 if( $status['timed_out'] ) { echo "Read time out" ; fclose( $fp ); return false; } }
從 PHP5 開始,file_get_content 已經支持 context 了(手冊上寫著:5.0.0 Added the context support. ),也就是說,從5.0開始,file_get_contents 其實也可以 POST 數據。類似的還有,fopen(也是從PHP5開始加入context支持),file (PHP5加入支持)。
<?php $get_opts = array( 'http'=>array( 'method' => "GET", 'timeout' => 1,//單位秒, 默認使用php.ini中default_socket_timeout的設置 ) ); $post_opts = array( 'http'=>array( 'method' => "POST", 'timeout' => 60,//單位秒, 可用ini_set('default_socket_timeout', 120);進行默認設置 'content' => http_build_query($param_array, '', '&') ) ); $opts = $get_opts; $res = file_get_contents($url, FALSE, stream_context_create($opts)); //返回string,失敗返回FALSE
ini_set('default_socket_timeout', 30); //定義響應超時為30秒 try { $options = array( 'cache_wsdl' => 0, 'connection_timeout' => 5, //定義連接超時為5秒,默認php.ini中default_socket_timeout的值 ); libxml_disable_entity_loader(false); $client = new \SoapClient($url, $options); return $client->__soapCall($function_name, $arguments); } catch (\SoapFault $e) { //超時、連接不上 if($e->faultcode == 'HTTP'){ throw new TimeoutException('連接或請求超時', $e->getCode()); } }
soap請求也可以使用資源流context,可以將請求超時寫到stream_context_create( )中。
try { $arrContextOptions=array("ssl"=>array( "verify_peer"=>false, "verify_peer_name"=>false,'crypto_method' => STREAM_CRYPTO_METHOD_TLS_CLIENT)); //$arrContextOptions=array("http"=>array( "method"=>'GET', 'timeout'=>10)); $options = array( 'soap_version'=>SOAP_1_2, 'exceptions'=>true, 'trace'=>1, 'cache_wsdl'=>WSDL_CACHE_NONE, 'stream_context' => stream_context_create($arrContextOptions) ); $client = new SoapClient('https://url/dir/file.wsdl', $options); } catch (Exception $e) { echo "<h3>Exception Error!</h3>"; echo $e->getMessage(); }
感謝你能夠認真閱讀完這篇文章,希望小編分享的“PHP中超時的設置方法有哪些”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。