2016年11月23日 星期三

[PHP] SQLSTATE[HY000]: General error: 2006 MySQL server has gone away

近日遇到稍微罕見的案例:MySQL server has gone away

PHP Warning:  PDO::exec(): MySQL server has gone away in /.../A.inc on line 104
PHP Warning:  PDO::exec(): Error reading result set's header in /.../A.inc on line 104
PHP Fatal error:  Uncaught exception 'PDOException' with message 'SQLSTATE[HY000]: General error: 2006 MySQL server has gone away' in /.../A.inc:104
Stack trace:
#0 /.../A.inc(104): PDO->exec('SET NAMES utf8')
...

由於這是在執行排程的時候遇到,查詢之後還是決定從 PHP 著手,避免影響 APIs 效能。

下面是處理方式;拿掉註解則可以測試狀況。

$pdo = $this->getPdo();
try {
   // $pdo->exec('SET wait_timeout=1');
   // sleep(3);
   $pdo->exec('SET NAMES utf8');
} catch (PDOException $e) {
   $errInfo = $pdo->errorInfo();
   if ($errInfo[0] === 'HY000' && $errInfo[1] === 2006) {
      // SQLSTATE[HY000]: General error: 2006 MySQL server has gone away
      $this->resetPdo();
      $pdo = $this->getPdo();
      $pdo->exec('SET NAMES utf8');
      return $pdo;
   }
   throw $e;
}
return $pdo;

參考資料:

2016年6月7日 星期二

[PHP] empty() / isset() on String Offsets

一般判斷陣列是否有鍵約莫就是 array_key_exists()、empty()、isset()。 最近遇到的問題是,如果需要判斷多於兩層的鍵存不存在,會出現 Fatal error:

$a = '';
var_dump(empty($a['1']['2'])); // bool(true)
var_dump(isset($a['1']['2'])); // bool(false)
var_dump(empty($a['1']['2']['3'])); // PHP Fatal error:  Cannot use string offset as an array
var_dump(isset($a['1']['2']['3'])); // PHP Fatal error:  Cannot use string offset as an array

$a['1'] = '';
var_dump(empty($a['1']['2']['3'])); // bool(true)
var_dump(isset($a['1']['2']['3'])); // bool(false)
var_dump(empty($a['1']['2']['3']['4'])); // PHP Fatal error:  Cannot use string offset as an array
var_dump(isset($a['1']['2']['3']['4'])); // PHP Fatal error:  Cannot use string offset as an array

$a['1']['2'] = '';
var_dump(empty($a['1']['2']['3']['4'])); // bool(true)
var_dump(isset($a['1']['2']['3']['4'])); // bool(false)
var_dump(empty($a['1']['2']['3']['4']['5'])); // PHP Fatal error:  Cannot use string offset as an array
var_dump(isset($a['1']['2']['3']['4']['5'])); // PHP Fatal error:  Cannot use string offset as an array

但是如果有一個鍵不匹配,就不會發生問題:

$a['x'] = '';
var_dump(empty($a['1']['2']['3'])); // bool(true)
var_dump(isset($a['1']['2']['3'])); // bool(false)
var_dump(empty($a['1']['2']['3']['4'])); // bool(true)
var_dump(isset($a['1']['2']['3']['4'])); // bool(false)

$a['1']['y'] = '';
var_dump(empty($a['1']['2']['3']['4'])); // bool(true)
var_dump(isset($a['1']['2']['3']['4'])); // bool(false)
var_dump(empty($a['1']['2']['3']['4']['5'])); // bool(true)
var_dump(isset($a['1']['2']['3']['4']['5'])); // bool(false)

$a['x']['2'] = '';
var_dump(empty($a['1']['2']['3']['4'])); // bool(true)
var_dump(isset($a['1']['2']['3']['4'])); // bool(false)
var_dump(empty($a['1']['2']['3']['4']['5'])); // bool(true)
var_dump(isset($a['1']['2']['3']['4']['5'])); // bool(false)

[Java] Invalid HTTP method: PATCH

最近系統需要使用 Netty4,所以把衝突的 Netty3 拆掉,然後就出現了例外。 pom.xml <dependency> <groupId>com.ning</groupId> <artifactId>as...