YesYo.com MintState Forums
뒤로    YesYo.com MintState BBS > Tech > PHP
검색
멤버이름    오토
비밀번호 
 

PHP를 이용하여 MYSQL Sleep 프로세스 죽이기

페이지 정보

작성자 MintState 댓글 0건 조회 16,963회 작성일 11-01-18 22:10

본문

PHP에서 자동으로 MYSQL의 디비를 닫아(Closed)주기 때문에 굳이 mysql_close($dbconn); 를 쓸 필요는 없습니다.
그러나 MYSQL의 Sleep 프로레스가 너무 많이 늘어나는 것을 볼수 있습니다.
이것은 MYSQL의 wait timeout의 시간을 너무 많이 주어서 생기는 문제입니다.
서버마다 wait timeout값을 적정값을 설정해야 합니다.
[MySQL] time out(wait_timeout) 계산과 설정 - 여기를 참고하세요

my.cnf 파일을 수정하면 됩니다.
my.cnf 설정파일 - 여기를 참고하세요
램이 2기가인경우 아래 정도입니다.
max_connections = 200
wait_timeout = 30


max_connections 의 기본값은 100 이고 wait_timeout 의 기본값은 28,800 입니다.

다음과 같이 safe_mysqld을 실행시킬때 wait_timeout을 지정하는 방법도 있습니다.
safe_mysqld -O wait_timeout=30

또한 아래와 값이 PHP파일을 만들고 cron으로 주기적으로 돌려도 될것 같습니다.
<?
define('MAX_SLEEP_TIME', 120); 
$dbconn = @mysql_connect($dbConfig['host'],$dbConfig['user'],$dbConfig['pass']);

$result = mysql_list_processes($dbconn);
//mysql_list_processes 대신 아래와 같이 써도 됩니다.
//$result = mysql_query("SHOW PROCESSLIST", $connect); 
while ($row = mysql_fetch_assoc($result)){
    printf("%s %s %s %s %s\n<br />", $row["Id"], $row["Host"], $row["db"],
        $row["Command"], $row["Time"]);
		if ($row["Command"] == "Sleep"  && $row["Time"] > MAX_SLEEP_TIME) { 
				mysql_query("KILL " . $row["Id"], $dbconn);
				echo "KILL ID : ".$row["Id"]."<br />";
		}
}
mysql_free_result($result);
mysql_close($dbconn);
?>


참고로 어느분이 perl로 짜 놓으신 것입니다.
#!/usr/bin/perl
###############################################################################
# MySQL 에서 Sleep 프로세스 죽이기
# 2003.02 by Oh Jung Joon
###############################################################################

###############################################################################
# Variables
###############################################################################
use DBI;

$hostname = "localhost"; 
$database = "mysql";  
$mysql_id = "root"; 
$mysql_pw = "password"; 

$dsn = "DBI:mysql:database=$database;host=$hostname"; 
###############################################################################
 
 $dbh = DBI->connect($dsn,$mysql_id,$mysql_pw) 
  or die "Unable to connect to contacts Database: $dbh->errstr\n";

 $query="show processlist";
 $cursor=$dbh->prepare($query);
 $cursor->execute;

 while (@field = $cursor->fetchrow)
 {
  ($id,$user,$host,$db,$command,$time,$state,$info)=@field;
  print "[$id | $user | $host | $db | $command | $time | $state | $info] ";
  if ( ($command eq 'Sleep') && ($time > 500) )
  {
   $query2="kill $id";
   $dbh->do($query2);
   print "  == > Killed";
  }
  print "\n";
 }
 $cursor->finish;
 $dbh->disconnect;
 exit;

댓글목록

등록된 댓글이 없습니다.

Total 165건 6 페이지
PHP 목록
번호 제목 글쓴이 조회 날짜
40 MintState 16430 02-17
39 MintState 16438 06-30
38 MintState 16555 10-09
37 MintState 16698 02-25
열람중 MintState 16964 01-18
35 MintState 16990 11-03
34 MintState 17021 11-17
33 MintState 17117 11-10
32 MintState 17294 11-17
31 MintState 17407 05-02
30 MintState 17491 01-22
29 MintState 17935 10-29
28 MintState 17947 10-31
27 MintState 18276 11-03
26 MintState 18290 11-03
25 MintState 18301 08-25
24 MintState 18432 07-02
23 MintState 18676 11-03
22 MintState 18689 04-28
21 MintState 19282 11-03
20 MintState 19631 11-03
19 MintState 19985 11-03
18 MintState 19997 11-10
17 MintState 20155 07-02
16 MintState 20294 11-10
게시물 검색
모바일 버전으로 보기
CopyRight ©2004 - 2024, YesYo.com MintState. ™