よくある問題
-
長いテーブル作成文では、不完全な構文エラープロンプトが発生する可能性があります。手動トラブルシューティングのための可能な構文エラーは以下の通りです:
- 構文構造エラー。HELP CREATE TABLEを注意深く読み、関連する構文構造を確認してください。
- 予約語。ユーザー定義名が予約語と重複する場合、バッククォート``で囲む必要があります。すべてのカスタム名にこの記号を使用することを推奨します。
- 中国語文字または全角文字。UTF8エンコードされていない中国語文字や隠れた全角文字(スペース、句読点など)は構文エラーを引き起こす可能性があります。不可視文字を表示するテキストエディタを使用して検査することを推奨します。
-
Failed to create partition [xxx]. Timeout
Dorisはパーティション粒度に基づいてテーブルを順次作成します。パーティションの作成に失敗すると、このエラーが発生する可能性があります。パーティションを使用していない場合でも、テーブル作成に問題があると
Failed to create partitionが報告される可能性があります。これは、前述の通り、Dorisが指定されたパーティションのないテーブルに対して変更不可能なデフォルトパーティションを作成するためです。このエラーに遭遇した場合、通常はBEがデータタブレットを作成する際に問題が発生したためです。以下の手順でトラブルシューティングできます:
- fe.logで、対応するタイムスタンプの
Failed to create partitionログエントリを検索してください。このログエントリでは、{10001-10010}のような一連の数字ペアが見つかる可能性があります。ペアの最初の数字はBackend ID、2番目の数字はTablet IDを表します。例えば、この数字ペアはBackend ID 10001でTablet ID 10010の作成が失敗したことを示します。 - 対応するBackendのbe.INFOログに移動し、対応する時間期間内でTablet ID関連のログを検索してエラーメッセージを見つけてください。
- 以下は一般的なタブレット作成失敗エラーの例ですが、これらに限定されません:
- BEが関連タスクを受信しませんでした。この場合、be.INFOでTablet ID関連のログを見つけることができないか、BEが成功を報告しているが実際には失敗している場合があります。これらの問題については、Installation and Deploymentセクションを参照してFEとBE間の接続性を確認してください。
- 事前割り当てメモリの失敗。これは、テーブルの行のバイト長が100KBを超えているためかもしれません。
Too many open files。開いているファイルハンドル数がLinuxシステムの制限を超えています。Linuxシステムのハンドル制限を変更する必要があります。
- fe.logで、対応するタイムスタンプの
- データタブレットの作成でタイムアウトが発生する場合、fe.confファイルで
tablet_create_timeout_second=xxxおよびmax_create_table_timeout_second=xxxを設定してタイムアウトを延長することもできます。デフォルトでは、tablet_create_timeout_secondは1秒、max_create_table_timeout_secondは60秒に設定されています。全体のタイムアウトはmin(tablet_create_timeout_second * replication_num, max_create_table_timeout_second)として計算されます。具体的なパラメータ設定については、FE 設定セクションを参照してください。
- テーブル作成コマンドが長時間結果を返さない。
- Dorisのテーブル作成コマンドは同期コマンドです。このコマンドのタイムアウトは現在、単純に(tablet num * replication num)秒として設定されています。多くのデータタブレットが作成され、その一部の作成に失敗した場合、エラーが返される前に長い待機時間が発生する可能性があります。
- 通常の状況では、テーブル作成文は数秒または数十秒以内に返されるはずです。1分を超える場合は、操作を直接キャンセルし、FEまたはBEログで関連エラーを確認することを推奨します。
その他のヘルプ
データパーティショニングの詳細情報については、CREATE TABLEコマンドマニュアルを参照するか、MySQLクライアントでHELP CREATE TABLE;と入力してより多くのヘルプ情報を取得できます。