Click here to view and discuss this page in DocCommentXchange. In the future, you will be sent there automatically.

SAP Sybase SQL Anywhere 16.0 » SQL Anywhere サーバ SQL の使用法 » パフォーマンスの向上、診断、モニタリング » アプリケーションプロファイリングのチュートリアル » チュートリアル:デッドロックの診断

 

レッスン 1:データベースのセットアップ

アプリケーションプロファイリングのテストデータベース app_profiling.db を設定して、2 つのテーブルと 2 つのプロシージャを作成することにより、デッドロックを作成します。

前提条件

このレッスンでは、このチュートリアルの開始時に、権限のセクションで一覧されているロールと権限を持っていることを前提としています。 チュートリアル:デッドロックの診断

このチュートリアルは、テストデータベース app_profiling.db が作成されていることを前提としています。チュートリアル:アプリケーションプロファイリングのチュートリアル用のテストデータベースの作成を参照してください。

内容と備考

デッドロックは、複数のトランザクションが互いにブロックされている場合に発生します。たとえば、トランザクション A がテーブル B にアクセスする必要があるが、テーブル B はトランザクション B によってロックされ、トランザクション B はテーブル A にアクセスする必要があるが、テーブル A はトランザクション A によってロックされている場合などです。これは環状ブロッキングの競合が発生している状態です。

デッドロックが発生している状況は、SQLCODE -306 と -307 が返されることで分かります。デッドロックを解決するために、SQL Anywhere はデッドロックが作成された最後の文を自動的にロールバックします。文が絶え間なくロールバックされる場合は、パフォーマンス問題が発生しています。

 ♦ タスク
  1. Interactive SQL を起動します。[スタート] » [プログラム] » [SQL Anywhere 16] » [管理ツール] » [Sybase Central] をクリックします。

  2. Interactive SQL で、次のように app_profiling.db に接続します。

    1. [接続] ウィンドウで、テストデータベース app_profiling.db に接続するための情報を以下のフィールドに入力します。

      1. [認証] フィールドで [データベース] を選択します。

      2. [ユーザ ID] フィールドに DBA と入力します。

      3. [パスワード] フィールドに sql と入力します。

      4. [アクション] ドロップダウンリストで、[このコンピュータのデータベースを起動して接続] をクリックします。

      5. [データベースファイル] フィールドに、C:\AppProfilingTutorial\app_profiling.db と入力します。

      6. [開始行] フィールドに、dbeng16 -x tcpip と入力します。

    2. [接続] をクリックします。

  3. Interactive SQL で、次の SQL 文を実行します。

    1. テーブルを 2 つ作成します。

      CREATE TABLE "DBA"."deadlock1" (
         "id" UNSIGNED BIGINT NOT NULL DEFAULT AUTOINCREMENT, 
         "val" CHAR(1) ); 
      CREATE TABLE "DBA"."deadlock2" ( 
         "id" UNSIGNED BIGINT NOT NULL DEFAULT AUTOINCREMENT, 
         "val" CHAR(1) );
    2. 各テーブルに値を挿入します。

      INSERT INTO "deadlock1"("val") VALUES('x');
      INSERT INTO "deadlock2"("val") VALUES('x');
    3. 次の 2 つのプロシージャを作成します。



      CREATE PROCEDURE "DBA"."proc_deadlock1"(  ) 
         BEGIN 
            LOCK TABLE "DBA"."deadlock1" IN EXCLUSIVE MODE; 
            WAITFOR DELAY '00:00:20:000'; 
            UPDATE deadlock2 SET val='y'; 
         END; 
      CREATE PROCEDURE "DBA"."proc_deadlock2"(  ) 
         BEGIN 
            LOCK TABLE "DBA"."deadlock2" IN EXCLUSIVE MODE; 
            WAITFOR DELAY '00:00:20:000'; 
            UPDATE deadlock1 SET val='y'; 
         END;
    4. データベースに加えた変更をコミットします。

      COMMIT;
  4. Interactive SQL を閉じます。

結果

デッドロックの作成に使用する 2 つのテーブルと 2 つのプロシージャが作成されます。

 参照