日期:2014-05-16 浏览次数:20686 次
<?php
set_time_limit(0);
if(isset($_SERVER['REMOTE_ADDR'])){
	echo "wrong!";
	exit;
}
require "test3.php";
$dbhost = "192.168.10.18";
$dbuser = "cms";
$dbpw = "j*hKg!3m9)fAl&1%";
$dbname = "cms";
$conn = mysql_connect($dbhost, $dbuser, $dbpw) or die('Could not connect: ' . mysql_error());
mysql_select_db($dbname,$conn) or die('Could not select database master ');
mysql_query("set names 'utf8'",$conn); 
$test3 = new Test3(); 
for($i=10;$i<=20;$i++){
	
	sleep("20");
	getDbLink($conn);
	$rs = mysql_query("select id,dateline,page_num,top_channel_id from cms_article where id={$i} limit 1 ",$conn);
	$line = mysql_fetch_array($rs);
	echo "master :".$line['id']."\n";	
	$test3->selects();
}
function getDbLink(&$conn){
	global $dbhost, $dbuser, $dbpw,$dbname;
	$rsCheck = mysql_query("set names 'utf8'",$conn);
	if(!$rsCheck){ 
		echo "master reconnect \n";
		mysql_close($conn); // 失去数据库连接,如果要重建连接必须要 关闭原来的资源然后再重新建立
		$conn = mysql_connect($dbhost, $dbuser, $dbpw) or die('Could not connect: ' . mysql_error());
		mysql_select_db($dbname,$conn) or die("Could not select database master ".mysql_error());
		mysql_query("set names 'utf8'",$conn); 
	}
	
}
mysql_close($conn);
?><?php
class Test3{
	private $dbhost;
	private $dbuser;
	private $dbpw;
	private $dbname;
	private $dbconn;
	public function __construct(){
		
		$this->dbhost = "192.168.10.16";
		$this->dbuser = "root";
		$this->dbpw = 'gzscwhcb!@#$uiop';
		$this->dbname = "house_mamadb";
		
		$this->dbconn = mysql_connect($this->dbhost, $this->dbuser, $this->dbpw) or die('Could not connect: ' . mysql_error());
		mysql_select_db($this->dbname,$this->dbconn) or die('Could not select database');
		mysql_query("set names 'utf8'",$this->dbconn); 
	}
	
	// 检查数据库连接如果失去数据库连接则重新建立
	function checkDbLink(){
		$rsCheck = mysql_query("set names 'utf8'",$this->dbconn);
		if(!$rsCheck){ 
			echo "test3 reconnect \n";
			mysql_close($this->dbconn); 
			$this->dbconn = mysql_connect($this->dbhost, $this->dbuser, $this->dbpw) or die('Could not connect test3  : ' . mysql_error());
			mysql_select_db($this->dbname) or die('Could not select database test3');
			mysql_query("set names 'utf8'",$this->dbconn); 
		}
	}
	
	
	public function selects(){
		sleep("20");
		$this->checkDbLink();
		$sqlData = "select p_name  from hs_news_pic order by p_id desc limit 1 ";
		$rs = mysql_query($sqlData,$this->dbconn);
		$line = mysql_fetch_array($rs);
		echo "test3  selects  :".$line['p_name']."\n";
	}
	
	
	
	public function __destruct(){
		mysql_close($this->dbconn);
	}
	
}
?>