目錄
GraphQL自動緩存機制
自動失效緩存
規範化GraphQL緩存
GraphQL緩存的邊緣情況
首頁 web前端 css教學 使用GraphQL緩存

使用GraphQL緩存

Mar 19, 2025 am 09:36 AM

Working With GraphQL Caching

GraphQL緩存機制解析:打破緩存誤區

您可能聽說過諸如“GraphQL不支持緩存”或“GraphQL不關心緩存”之類的說法。對於許多人來說,這是一個大問題。但事實並非如此。 GraphQL官方文檔中提到了多種緩存技術,可見其開發團隊非常重視緩存及其性能優勢。

本文旨在澄清GraphQL與緩存之間的關係,並介紹不同的緩存技術以及如何利用緩存優化GraphQL查詢。

GraphQL自動緩存機制

考慮以下用於獲取帖子及其作者的查詢:

 query getPost {
  post(slug: "working-with-graphql-caching") {
    id
    title
    author {
      id
      name
      avatar
    }
  }
}

實現GraphQL自動緩存的“秘訣”是__typename元字段,所有GraphQL API都提供此字段。顧名思義, __typename返回對象的類型名稱。此字段甚至可以手動添加到現有查詢中,大多數GraphQL客戶端或CDN會自動添加它,例如urql。服務器接收到的查詢可能如下所示:

 query getPost {
  post(slug: "working-with-graphql-caching") {
    __typename
    id
    title
    author {
      __typename
      id
      name
    }
  }
}

包含__typename的響應可能如下所示:

 {
  data: {
    __typename: "Post",
    id: 5,
    title: "Working with GraphQL Caching",
    author: {
      __typename: "User",
      id: 1,
      name: "Jamie Barton"
    }
  }
}

__typename是GraphQL緩存的關鍵,因為它允許我們緩存結果,並知道它包含Post ID 5和User ID 1。

Apollo和Relay等庫也提供一定程度的內置緩存,用於自動緩存。由於它們已經知道緩存中的內容,因此它們可以利用緩存而不是遠程API來獲取客戶端在查詢中請求的內容。

自動失效緩存

假設帖子作者使用editPost變異修改了帖子的標題:

 mutation {
  editPost(input: { id: 5, title: "Working with GraphQL Caching" }) {
    id
    title
  }
}

由於GraphQL客戶端會自動添加__typename字段,因此此變異的結果會立即告訴緩存Post ID 5已更改,並且包含該帖子的任何緩存查詢結果都需要失效:

 {
  data: {
    __typename: "Post",
    id: 5,
    title: "Working with GraphQL Caching"
  }
}

下次用戶發送相同的查詢時,查詢將從源獲取新數據,而不是使用緩存中的過期結果。

規範化GraphQL緩存

許多GraphQL客戶端不會緩存整個查詢結果。相反,它們會將緩存數據規範化為兩種數據結構:一種將每個對象與其數據關聯起來(例如,Post #5:{…},User #1:{…}等);另一種將每個查詢與其包含的對象關聯起來(例如,getPost:{Post #5,User #1}等)。

請參閱urql關於規範化緩存的文檔或Apollo的“Demystifying Cache Normalization”以了解具體的示例和用例。

GraphQL緩存的邊緣情況

GraphQL緩存無法自動處理的一個主要邊緣情況是向列表中添加項目。因此,如果createPost變異通過緩存,它不知道要將該項目添加到哪個特定列表中。

最簡單的“解決方法”是在變異中查詢父類型(如果存在)。例如,在下面的查詢中,我們查詢了post上的community關係:

 query getPost {
  post(slug: "working-with-graphql-caching") {
    id
    title
    author {
      id
      name
      avatar
    }

    # Also query the community of the post
    community {
      id
      name
    }
  }
}

然後我們也可以從createPost變異中查詢該community,並使包含該community的任何緩存查詢結果失效:

 mutation createPost {
  createPost(input: { ... }) {
    id
    title

    # Also query and thus invalidate the community of the post
    community {
      id
      name
    }
  }
}

雖然並不完美,但類型化模式和__typename元字段是使GraphQL API非常適合緩存的關鍵。

您可能認為所有這些都是權宜之計,GraphQL仍然不支持傳統的緩存。您不會錯。由於GraphQL通過POST請求運行,您需要卸載到應用程序客戶端並使用上述“技巧”來利用GraphQL的現代瀏覽器緩存。

但是,這種方法並不總是可行的,也不是管理客戶端緩存的最佳方法。對於更棘手的情況,GraphQL客戶端需要您手動更新緩存,但像GraphCDN這樣的服務提供了“類似服務器”的緩存體驗,還提供了一個手動清除API,允許您執行以下操作以獲得更好的緩存控制:

 # Purge all occurrences of a specific object
mutation {
  purgeUser(id: [5])
}
 # Purge by query name
mutation {
  _purgeQuery(queries: [listUsers, listPosts])
}
 # Purge all occurrences of a type
mutation {
  purgeUser
}

現在,無論您在何處使用GraphCDN端點,都不再需要在移動端、Web端等所有客戶端邏輯中重新實現緩存策略。邊緣緩存使您的API速度非常快,並通過在用戶之間共享緩存並將其與每個用戶的客戶端分開來減少負載。

最近在一個項目中使用了GraphCDN,它幫我處理了客戶端或服務器上的緩存配置,讓我能夠繼續我的項目。例如,我可以將我的端點替換為GraphCDN,並免費獲得查詢複雜性(即將推出)、分析等功能。

那麼,GraphQL是否關心緩存?當然關心!它不僅提供了一些內置的自動緩存方法,而且許多GraphQL庫提供了其他方法來實現和管理緩存。

希望本文能幫助您了解GraphQL緩存機制,以及如何在客戶端實現它,以及如何利用CDN來完成所有工作。我的目標不是說服您在所有項目中都使用GraphQL,但如果您正在選擇查詢語言並且緩存是一個重要因素,請知道GraphQL完全能夠勝任這項任務。

以上是使用GraphQL緩存的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1605
29
PHP教程
1510
276
什麼是常見的CSS瀏覽器不一致? 什麼是常見的CSS瀏覽器不一致? Jul 26, 2025 am 07:04 AM

不同瀏覽器對CSS解析存在差異,導致顯示效果不一致,主要包括默認樣式差異、盒模型計算方式、Flexbox和Grid佈局支持程度及某些CSS屬性行為不一致。 1.默認樣式處理不一致,解決方法是使用CSSReset或Normalize.css統一初始樣式;2.舊版IE的盒模型計算方式不同,建議統一使用box-sizing:border-box;3.Flexbox和Grid在邊緣情況或舊版本中表現有差異,應多測試並使用Autoprefixer;4.某些CSS屬性行為不一致,需查閱CanIuse並提供降級

什麼是口音色的物業? 什麼是口音色的物業? Jul 26, 2025 am 09:25 AM

accent-color是CSS中用於自定義復選框、單選按鈕和滑塊等表單元素高亮顏色的屬性;1.它直接改變表單控件選中狀態的默認顏色,如將復選框的藍色勾選標記改為紅色;2.支持的元素包括type="checkbox"、type="radio"和type="range"的輸入框;3.使用accent-color可避免複雜的自定義樣式和額外DOM結構,保持原生可訪問性;4.現代瀏覽器普遍支持,舊瀏覽器需降級處理;5.設置accent-col

如何樣式選擇突出顯示(``:: selection')? 如何樣式選擇突出顯示(``:: selection')? Jul 16, 2025 am 12:50 AM

使用CSS的::selection偽元素可自定義網頁文字選中時的高亮樣式,提升頁面美觀與統一性。 1.基礎設置:通過::selection定義background-color與color,如黃色背景配深灰字體;也可限定特定元素如p::selection。 2.兼容處理:添加-webkit-前綴以兼容Safari及移動端瀏覽器,Firefox和Edge標準支持良好。 3.注意可讀性:避免顏色對比過強或過於花哨,應與整體設計協調,例如深色模式下選用柔和藍底提升視覺舒適度。合理運用可增強界面質感,忽略細節則

瀏覽器默認樣式表如何影響渲染? 瀏覽器默認樣式表如何影響渲染? Jul 19, 2025 am 02:08 AM

瀏覽器默認樣式通過自動應用邊距、填充、字體和表單元素樣式確保基本可讀性,但可能導致跨瀏覽器佈局不一致。 1.默認外邊距和填充改變佈局流,如標題、段落和列表自帶間距;2.默認字體設置影響可讀性,如16px字號和TimesNewRoman字體;3.表單元素在不同瀏覽器顯示差異大,需重置外觀;4.某些標籤如strong和em有默認強調樣式,需顯式覆蓋。解決方法包括使用Normalize.css、重置樣式或全局清除邊距與填充,同時自定義字體和表單樣式以保證一致性。

如何設計段落的第一字母或第一行? 如何設計段落的第一字母或第一行? Jul 19, 2025 am 02:58 AM

要美化段落開頭提升視覺吸引力,常見做法是使用CSS的偽元素或手動設置文檔樣式。網頁開發中可用p::first-letter設置首字母樣式,如放大、加粗、變色,但需注意僅適用於塊級元素;若想突出整段首行,則用p::first-line來加樣式;在Word等文檔軟件中可手動調整首字母格式或創建樣式模板,而InDesign有內置“首字下沉”功能適合出版設計;應用時需注意細節,如避免複雜樣式影響閱讀、確保兼容性和格式一致性。

描述'垂直align”屬性及其典型用例 描述'垂直align”屬性及其典型用例 Jul 26, 2025 am 07:35 AM

1.ItAdjustSelementsLikeImagesRikeImagesOrformInputswithIntExtLineSustLineSlineSlineSlineSlikeLikeLikeBaseline,中間,Super,Super,Super和Sub.2.intablebecells,ItControlScontentalStalteNtalmscontentalMedwithThtop,Middle,Middle,Midder,Midder,經常

描述CSS'反序列”和``反插入屬性''屬性 描述CSS'反序列”和``反插入屬性''屬性 Jul 18, 2025 am 04:00 AM

CSS的counter-reset和counter-increment用於自動編號HTML元素。 1.使用counter-reset初始化或重置計數器,例如section{counter-reset:sub-section;}創建名為sub-section的計數器;2.通過counter-increment遞增計數器,如h3{counter-increment:sub-section;}使每個h3標題編號遞增;3.使用content屬性結合偽元素顯示計數器,如h3::before{content:

如何清除未使用的CSS? 如何清除未使用的CSS? Jul 27, 2025 am 02:47 AM

UseAutomatedToolSlikePurgecsSoruncsStoscanAndRemoveUnusedcss; 2. integratePuratePurgingIntoyourBuildProcessviawebpack,vite,vite,ortailwind ’scontentConfiguration; 3.AuditcsSusageWithChroMedEvtoolScoverAgeTabBeforgeForgingToavoidRemovingNeedEdedStyles; 4.safelistdynamic

See all articles