日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql case break_按月转移日志表中日志时,mysql总是报‘MySQL server has gone away’这样的错!...

發(fā)布時(shí)間:2025/4/16 数据库 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql case break_按月转移日志表中日志时,mysql总是报‘MySQL server has gone away’这样的错!... 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

我有一段清除數(shù)據(jù)庫日志的腳用來按月清除數(shù)據(jù)庫中的日志文件然后再把它們按月分表存儲(chǔ),腳本平時(shí)運(yùn)行正常但是每到月初一定會(huì)報(bào)一次‘MySQL server has gone away’這樣的錯(cuò),不知道為什么!

腳本代碼如下:

class PaizuTableHandler extends ScriptBase

{

public static $mysql = null;

const LOG_PAIZU_TABLE = 'log_user_paiju';

public function logic()

{

if(empty(self::$mysql)){

self::$mysql = $this->mysql('logs');

}

set_time_limit(0);

while (true)

{

$date = date("Y-m-d");

$dataTime = strtotime($date);

$timestampStart = $dataTime - 3600*24; //昨天

$timestampEnd = mktime(0,0,0,date("m"),1,date("Y"));//本月月初 例如:2017-07-01 00:00:00

$timestampEnd_lastmoth = mktime(0, 0 , 0,date("m")-1,1,date("Y"));//上月月初 例如:2017-06-01 00:00:00

$transferLastMonth = mktime(0,0,0,date("m"),5,date("Y")); //月初第5天(轉(zhuǎn)移上月數(shù)據(jù))

if($timestampStart < $timestampEnd){

sleep(60);

continue;

}

$table = self::LOG_PAIZU_TABLE.'_'.date("Ym");//本月的表

$lastMothTable = self::LOG_PAIZU_TABLE.'_'.date("Ym",mktime(0, 0 , 0,date("m")-1,1,date("Y")));//上個(gè)月的表

$hasTable = self::$mysql->tableExists($table); //判斷是否有本月的表

$hasTableLast = self::$mysql->tableExists($lastMothTable); //判斷是否有上個(gè)月的表

$createFlag = $hasTable ? true : false; //本月的表是否存在

$createFlagLast = $hasTableLast ? true : false; //上個(gè)月的表是否存在

if( empty( $createFlag ) ){

try {

//創(chuàng)建表

$createSql = "CREATE TABLE {$table} LIKE log_user_paiju";

$ret = self::$mysql->query($createSql);

if(!$ret){

//拋出異常

$errorMessage = self::$mysql -> error_no() . ": " . self::$mysql ->error();

throw new Exception($errorMessage);

}

} catch(Exception $ex) {

echo 'TIME:'.date("Y-m-d H:i:s")."\n";

echo 'TIME_START~TIME_END:'.date("Y-m-d H:i:s",$timestampStart)."~".date("Y-m-d H:i:s",$timestampEnd)."\n";

$msg = 'Error:'.$ex->getMessage()."\n";

$msg.= $ex->getTraceAsString()."\n";

$msg.= '異常行號(hào):'.$ex->getLine()."\n";

$msg.= '所在文件:'.$ex->getFile()."\n";

//將異常信息記錄到日志中PHP異常處理之

echo $msg;

echo "\n";

break;

}

}

if( $createFlag ){

try {

//查詢本月當(dāng)天應(yīng)清空數(shù)據(jù)有沒有清空

$sql = "select * from log_user_paiju where UNIX_TIMESTAMP(`time`) between {$timestampEnd} and {$timestampStart} order by `time` desc limit 100";

$result = self::$mysql->query($sql);

$rs = self::$mysql -> fetch_row($result);

if( !$result ){

//拋出異常

$errorMessage = self::$mysql -> error_no() . ": " . self::$mysql ->error();

throw new Exception($errorMessage);

}

//處理上月數(shù)據(jù)(本月第5天把 上個(gè)月的數(shù)據(jù)全部放到上個(gè)月的表中(要放最少2天前))

$last_rs = array();

if($dataTime == $transferLastMonth && !empty( $createFlagLast ) && empty($rs)){

$last_sql = "select * from log_user_paiju where UNIX_TIMESTAMP(`time`) between {$timestampEnd_lastmoth} and {$timestampEnd} order by `time` desc limit 100";

$last_sql1 = "INSERT INTO {$lastMothTable}(uid,paiju_score,paizu_score,`time`,paizu_id,seq,room_id,server_id,creator,`status`,mahjongType,cid) SELECT uid,paiju_score,paizu_score,`time`,paizu_id,seq,room_id,server_id,creator,`status`,mahjongType,cid FROM log_user_paiju where UNIX_TIMESTAMP(`time`) between {$timestampEnd_lastmoth} and {$timestampEnd} order by `time` desc limit 100";

$last_sql2 = "delete from log_user_paiju where UNIX_TIMESTAMP(`time`) between {$timestampEnd_lastmoth} and {$timestampEnd} order by `time` desc limit 100";

$result1 = self::$mysql->query($last_sql);

//var_dump($result1);

if(!$result1){

//拋出異常

$errorMessage = self::$mysql -> error_no() . ": " . self::$mysql ->error();

throw new Exception($errorMessage);

}

$last_rs = self::$mysql -> fetch_row($result1);

if($last_rs){

if($r = self::$mysql->query($last_sql1)){

self::$mysql->query($last_sql2);

}else{

//拋出異常

$errorMessage = self::$mysql -> error_no() . ": " . self::$mysql ->error();

throw new Exception($errorMessage);

}

}

}

//處理本月數(shù)據(jù)

$sql1 = "INSERT INTO {$table}(uid,paiju_score,paizu_score,`time`,paizu_id,seq,room_id,server_id,creator,`status`,mahjongType,cid) SELECT uid,paiju_score,paizu_score,`time`,paizu_id,seq,room_id,server_id,creator,`status`,mahjongType ,cid FROM log_user_paiju where UNIX_TIMESTAMP(`time`) between {$timestampEnd} and {$timestampStart} order by `time` desc limit 100";

$sql2 = "delete from log_user_paiju where UNIX_TIMESTAMP(`time`) between {$timestampEnd} and {$timestampStart} order by `time` desc limit 100";

if(empty($rs) && empty($last_rs)){

sleep(60);

}

if($rs){

if($r1=self::$mysql->query($sql1)){

!self::$mysql->query($sql2);

}else{

//拋出異常

$errorMessage = self::$mysql -> error_no() . ": " . self::$mysql ->error();

throw new Exception($errorMessage);

}

}

} catch(Exception $ex) {

echo 'TIME:'.date("Y-m-d H:i:s")."\n";

echo 'TIME_START~TIME_END:'.date("Y-m-d H:i:s",$timestampStart)."~".date("Y-m-d H:i:s",$timestampEnd)."\n";

$msg = 'Error:'.$ex->getMessage()."\n";

$msg.= $ex->getTraceAsString()."\n";

$msg.= '異常行號(hào):'.$ex->getLine()."\n";

$msg.= '所在文件:'.$ex->getFile()."\n";

//將異常信息記錄到日志中PHP異常處理之

echo $msg;

echo "\n";

break;

}

}

usleep(3000);

}

}

}

shell腳本如下:

#!/bin/sh

# scripts daemon, add to /etc/crontab

# */1 * * * * root PATH/script.sh --daemon

# run on root

if [ "$(uname -s|grep -F 'CYGWIN')" = "" ] && [ $UID -ne 0 ]; then

echo "superuser privileges are required to run this script."

exit 1

fi

# settings

PHP_CLI="/usr/bin/php -c /usr/local/php/etc/php.ini"

SCRIPTS="PaijuLogHandler PaijuTableHandler PaizuTableHandler ClubDiamondLogHandler"

# paths

BASE_PATH=$(cd $(dirname $0) && pwd)

BASE_SCRIPT="$BASE_PATH/script.php"

LOGS_PATH="$BASE_PATH/data/logs/bash.log"

USAGE="Usage: $(basename $0) [-d|-a|-k SCRIPT]\n\

-d, --daemon\t\tthe daemon mode, runing checking\n\

-a, --killall\t\tkill the all scripts\n\

-k, --kill SCRIPT\tkill the SCRIPT\n\

-h, --help\t\tthis help text"

function get_pid()

{

echo $(ps -ef|grep -F "$1"|grep -v "grep"|awk '{print $2}')

}

function kill_script()

{

PID=$(get_pid "$1")

if [ "$PID" = "" ]; then

echo "$1 not found"

else

kill -9 $PID

echo "$1 has been killed, pid: $PID"

fi

}

case $1 in

-k|--kill)

if [ "$2" = "" ]; then

echo -e $USAGE

exit 0

fi

kill_script "$BASE_SCRIPT request/$2"

;;

-a|--killall)

for SCRIPT in $SCRIPTS; do

kill_script "$BASE_SCRIPT request/$SCRIPT"

done

;;

-d|--daemon)

for SCRIPT in $SCRIPTS; do

SCRIPT="$BASE_SCRIPT request/$SCRIPT"

PID=$(get_pid "$SCRIPT")

if [ "$PID" = "" ]; then

eval "$PHP_CLI $SCRIPT >>/data/logs/scriptlog/log.txt 2>&1 &"

PID=$(get_pid "$SCRIPT")

echo "[$(date +%Y-%m-%d\ %H:%M:%S)] $SCRIPT has been down, restarted: $PID" >> $LOGS_PATH

fi

done

;;

*)

echo -e $USAGE

;;

esac

報(bào)錯(cuò)如下:

TIME:2018-02-02 00:00:48

Error:2006: MySQL server has gone away

總結(jié)

以上是生活随笔為你收集整理的mysql case break_按月转移日志表中日志时,mysql总是报‘MySQL server has gone away’这样的错!...的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 久久亚洲婷婷 | 筱田优av| 老妇裸体性激交老太视频 | 久久久久久久久久一区 | 欧美成人精品一区二区男人看 | 图片一区二区 | 五月婷在线视频 | 亚洲 欧美 日韩 综合 | 青娱乐在线免费观看 | 成人免费在线播放 | 亚洲影视一区二区三区 | 天天干天天日 | 欧美有码在线 | 高潮毛片又色又爽免费 | 2025av在线播放| 熟妇人妻一区二区三区四区 | 欧美成人精品一区二区男人小说 | 日韩视频精品一区 | 久久av免费| 成人福利小视频 | 青青青青在线 | 国产毛茸茸 | 中文字幕精品一区久久久久 | 中文字幕在线观看视频www | 麻豆影视在线播放 | 香蕉成人网 | 夜夜嗨一区二区 | 国产精品久久久久桃色tv | 国产成年人视频 | 99久久久久久久 | 亚洲精品国产99 | 99国产精品一区二区三区 | 国产精品视频网站 | 免费看女生隐私 | 丁香花五月 | 午夜在线观看视频18 | 中文天堂| 久久资源总站 | 天天躁日日躁狠狠躁欧美 | 91精品一区二区三区综合在线爱 | 在线成人欧美 | 中国黄色一级大片 | 靠逼视频免费网站 | 中文字幕在线免费看 | 日韩精品一区二区三区不卡 | 亚洲天堂2015| 涩涩视频在线观看免费 | 青娱乐在线视频观看 | 国产视频一区二区三区四区 | 免费色网址 | 色婷婷av一区二区三区麻豆综合 | 大桥未久av一区二区三区中文 | 97国产精东麻豆人妻电影 | 天天艹av| 亚洲成人网在线 | 国产高清精品一区 | 在线观看毛片网站 | 日韩av综合网 | 中文字幕线人 | 亚洲精品无码久久 | 精品久久久久一区二区国产 | 亚洲网在线观看 | 一区二区不卡在线观看 | 久久久亚洲成人 | 日本久操视频 | 日韩欧美成人一区二区 | 久久欧| 久久伊人久久 | 亚欧洲精品 | 日韩资源在线观看 | 亚洲中午字幕 | 中文字幕7| 天天爽夜夜 | 欧美视频免费看欧美视频 | 色妞www精品视频 | 韩国电影大尺度在线观看 | 久久久久久久毛片 | 日本三级中文字幕在线观看 | 色香蕉影院 | 男女做事网站 | av中文天堂| av看片在线 | 四虎影视永久免费观看 | 香蕉黄色网 | 鲁大师私人影院在线观看 | www国产www| 国产在线播放一区二区三区 | 日韩av在线播放不卡 | 最新av在线网站 | 亚洲一区自拍 | 手机av免费在线观看 | 无套内谢的新婚少妇国语播放 | 国产精品乱码一区二区三区 | 亚洲乱码国产一区三区 | 性工作者十日谈 | 91网站免费视频 | 免费黄色a | 色一情一交一乱一区二区三区 | 亚洲天堂精品在线观看 |