よくある問題
-
長いテーブル作成文では、不完全な構文エラープロンプトが発生する場合があります。手動トラブルシューティングのための構文エラーの可能性は以下の通りです:
- 構文構造エラー。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;と入力してより多くのヘルプ情報を取得できます。