OCAPI キャッシング 23.1
REST API は HTTP に基づいているため、Open Commerce API によってデベロッパーはクライアントアプリケーションキャッシュを作成するか、プロキシキャッシュを利用できるようになります。API は標準の HTTP キャッシュヘッダー情報を提供します。
Business Manager で、一部の Open Commerce API リソースの最大キャッシュ回数 (または最大期間) を構成できます。現在、キャッシュ設定を構成できるのは Shop API のみです。
キャシュ機能を使用するには、Business Manager でサイトのページキャッシングを有効にする必要があります 。
最大期間は、レスポンスドキュメントがキャッシュに保持される期間を秒単位で決定します。ランタイムには、構成した最大期間を使用して HTTP レスポンスのキャッシュコントロールヘッダーに追加される値が計算されます。たとえば、categories リソースの最大期間を 900 秒に構成するとします。最初の GET リクエストの後、HTTP ヘッダーに含まれる値は 900 です。同じドキュメントに対する 2 回目の GET リクエストが 120 秒後に受信された場合、HTTP ヘッダーの値は 780 になります。
レスポンスキャッシュヘッダーは、Shop API で categories
、content
、content_search
、custom_objects
、folders
、products
、product_search
、promotions
、search_suggestions
、site
、および stores
リソースの GET リクエストおよび HEAD リクエストに対してのみ送信されます。
リソースごとのキャッシュ時間は Open Commerce API 設定で構成します。整数のプロパティ cache_time
は、キャッシュ時間を秒単位で定義します。キャッシュ時間を指定しないと、デフォルトは 60 秒になります。構成可能な最小キャッシュ時間は 0 秒、最大は 86,400 秒 (24 時間) です。
以下にキャッシュ時間の構成の例を示します。
API は、次の例に示すように、キャッシュ時間を *Cache-Control: max-age*
ヘッダーとして返します。
例 1: 商品の入手可能性情報のリクエスト:
例 2: 商品の価格情報のリクエスト:
例 3: expand パラメーターを使用した商品の入手可能性情報と価格情報のリクエスト:
expand パラメーターを使用した単一のリクエストでは、Open Commerce API によって Cache-Control ヘッダーにリクエストされたリソースの最小のキャッシュ時間が挿入されます。
クエリパラメーターは、プロキシキャッシュやブラウザーキャッシュなどの Web キャッシュの鍵の一部です。OCAPI の自己生成 URL では、クエリパラメーターが常にアルファベット順に並べられます。この決定性の並べ順によって、キャッシュヒット率が確実に向上します。
キャッシュヒット率を確実に上げて、パフォーマンスを向上させるには、OCAPI URL を常にクライアントアプリケーションで作成し、クエリパラメーターをアルファベット順に並べます。
Meta API でもキャッシュが有効になっています。リソースのデフォルトのキャッシュ時間は 1 日で、構成することはできません。Meta API ドキュメントのインスタンスキャッシュをクリアするには、Business Manager のページキャッシュを無効にすることが必要です。