總覽
Koog 提供了一種使用 AIAgentStorage 存儲和傳遞資料的方式,這是一個鍵值存儲系統,旨在以型別安全的方式在不同節點甚至子圖之間傳遞資料。
存儲空間可透過代理節點中提供的 storage 屬性(storage: AIAgentStorage)存取,從而實現在 AI 代理系統的不同元件之間無縫共用資料。
鍵值結構
鍵值資料存儲結構依賴於 AIAgentStorageKey 資料類別。有關 AIAgentStorageKey 的更多資訊,請參閱以下章節。
AIAgentStorageKey
存儲使用類型化金鑰系統,以確保在存儲和檢索資料時的型別安全。
AIAgentStorageKey<T> 類別代表用於識別和存取資料的存儲金鑰。以下是此類別的主要特性:
泛型型別參數
T指定了與此金鑰相關聯的資料型別,確保型別安全。每個金鑰都有一個
name屬性,這是一個字串識別碼,便於識別和偵錯。每個金鑰執行個體都是唯一的。
name不用於決定唯一性,因此可以有多個具有相同名稱的金鑰。這允許重用現有的策略元件,而不會有意外覆蓋存儲中資料的風險。
使用範例
以下章節提供了一個建立存儲金鑰並使用其存儲和檢索資料的實際範例。
定義代表資料的類別
存儲您想要傳遞的資料的第一步是建立一個代表資料的類別。以下是包含基本使用者資料的簡單類別範例:
class UserData(
val name: String,
val age: Int
)<!--- KNIT example-data-transfer-between-nodes-01.kt -->
record UserData(
String name,
int age
) {}<!--- KNIT exampleDataTransferBetweenNodesJava01.java -->
定義完成後,請使用該類別建立存儲金鑰,如下所述。
建立存儲金鑰
為定義的資料結構建立類型化存儲金鑰:
=== "Kotlin"
<!--- INCLUDE
import ai.koog.agents.core.agent.entity.createStorageKey
class UserData(
val name: String,
val age: Int
)
-->
```kotlin
val userDataKey = createStorageKey<UserData>("user-data")
```
<!--- KNIT example-data-transfer-between-nodes-02.kt -->
=== "Java"
<!--- INCLUDE
import ai.koog.agents.core.agent.entity.AIAgentStorage;
import ai.koog.agents.core.agent.entity.AIAgentStorageKey;
import ai.koog.serialization.TypeToken;
class exampleDataTransferBetweenNodesJava02 {
record UserData(
String name,
int age
) {}
public static void main(String[] args) {
-->
<!--- SUFFIX
}
}
-->
```java
AIAgentStorageKey<UserData> userDataKey = AIAgentStorage.createStorageKey("user-data", TypeToken.of(UserData.class));
```
<!--- KNIT exampleDataTransferBetweenNodesJava02.java -->
createStorageKey 函式接受一個用於識別和偵錯目的的字串參數,以及一個代表值型別的 TypeToken(在 Java 中使用;Kotlin 則會自動使用具體化泛型)。
存儲資料
若要使用建立的存儲金鑰儲存資料,請在節點中使用 storage.set(key: AIAgentStorageKey<T>, value: T) 方法:
=== "Kotlin"
<!--- INCLUDE
import ai.koog.agents.core.dsl.builder.strategy
import ai.koog.agents.core.dsl.builder.node
import ai.koog.agents.core.agent.entity.createStorageKey
class UserData(
val name: String,
val age: Int
)
val userDataKey = createStorageKey<UserData>("user-data")
-->
```kotlin
val nodeSaveData by node<Unit, Unit> {
storage.set(userDataKey, UserData("John", 26))
}
```
<!--- KNIT example-data-transfer-between-nodes-03.kt -->
=== "Java"
<!--- INCLUDE
import ai.koog.agents.core.agent.entity.AIAgentNode;
import ai.koog.agents.core.agent.entity.AIAgentStorage;
import ai.koog.agents.core.agent.entity.AIAgentStorageKey;
import ai.koog.serialization.TypeToken;
public class exampleDataTransferBetweenNodesJava03 {
record UserData(
String name,
int age
) {}
public static void main(String[] args) {
AIAgentStorageKey<UserData> userDataKey = AIAgentStorage.createStorageKey("user-data", TypeToken.of(UserData.class));
-->
<!--- SUFFIX
}
}
-->
```java
var nodeSaveData = AIAgentNode.builder("nodeSaveData")
.withInput(String.class)
.withOutput(String.class)
.withAction((input, ctx) -> {
ctx.getStorage().set(userDataKey, new UserData("John", 26));
return "";
})
.build();
```
<!--- KNIT exampleDataTransferBetweenNodesJava03.java -->
檢索資料
若要檢索資料,請在節點中使用 storage.get 方法:
=== "Kotlin"
<!--- INCLUDE
import ai.koog.agents.core.agent.entity.createStorageKey
import ai.koog.agents.core.dsl.builder.strategy
import ai.koog.agents.core.dsl.builder.node
class UserData(
val name: String,
val age: Int
)
fun main() {
val userDataKey = createStorageKey<UserData>("user-data")
val str = strategy<String, Unit>("my-strategy") {
-->
<!--- SUFFIX
}
}
-->
```kotlin
val nodeRetrieveData by node<String, Unit> { message ->
storage.get(userDataKey)?.let { userFromStorage ->
println("Hello dear $userFromStorage, here's a message for you: $message")
}
}
```
<!--- KNIT example-data-transfer-between-nodes-04.kt -->
=== "Java"
<!--- INCLUDE
import ai.koog.agents.core.agent.entity.AIAgentNode;
import ai.koog.agents.core.agent.entity.AIAgentStorage;
import ai.koog.agents.core.agent.entity.AIAgentStorageKey;
import ai.koog.serialization.TypeToken;
public class exampleDataTransferBetweenNodesJava04 {
record UserData(
String name,
int age
) {}
public static void main(String[] args) {
AIAgentStorageKey<UserData> userDataKey = AIAgentStorage.createStorageKey("user-data", TypeToken.of(UserData.class));
-->
<!--- SUFFIX
}
}
-->
```java
var nodeRetrieveData = AIAgentNode.builder("nodeRetrieveData")
.withInput(String.class)
.withOutput(String.class)
.withAction((message, ctx) -> {
var userData = ctx.getStorage().get(userDataKey);
System.out.println("Hello dear %s, here's a message for you: %s".formatted(userData, message));
return "";
})
.build();
```
<!--- KNIT exampleDataTransferBetweenNodesJava04.java -->
API 文件
有關 AIAgentStorage 類別的完整參考,請參閱 AIAgentStorage。
有關 AIAgentStorage 類別中可用的各個函式,請參閱以下 API 參考:
附加資訊
AIAgentStorage是執行緒安全的,使用 Mutex 來確保並行存取得到正確處理。- 檢索值時,型別轉換會自動處理,確保整個應用程式的型別安全。
- 對於值的不可為 null 存取,請使用
getValue方法,如果金鑰不存在,該方法會拋出例外。 - 您可以使用
clear方法完全清除存儲,這將移除所有存儲的鍵值對。
