ロック機能
TiDB は、 MySQL 5.7で利用可能なユーザーレベルロック関数のほとんどをサポートします。
サポートされている関数
MySQLの互換性
- TiDB で許可される最小タイムアウトは 1 秒、最大タイムアウトは 1 時間 (3600 秒) です。これは、0 秒と無制限のタイムアウト (
timeout=-1) の両方が許可される MySQL とは異なります。 TiDB は範囲外の値を最も近い許可値に自動的に変換し、timeout=-1秒を 3600 秒に変換します。 - TiDB は、ユーザーレベルのロックによって引き起こされるデッドロックを自動的に検出しません。デッドロックされたセッションは最大 1 時間後にタイムアウトしますが、影響を受けるセッションの 1 つで
KILLを使用して手動で解決することもできます。ユーザーレベルのロックを常に同じ順序で取得することで、デッドロックを防ぐこともできます。 - ロックはクラスター内のすべての TiDB サーバーで有効になります。これは、ロックが単一サーバーに対してローカルである MySQL クラスタやグループ レプリケーションとは異なります。
- 別のセッションから呼び出され、ロックを保持しているプロセスの ID を返せない場合、
IS_USED_LOCK()1を返します。