PushKvCache
产品支持情况
产品  | 
是否支持  | 
|---|---|
√  | 
|
√  | 
|
x  | 
|
x  | 
|
x  | 
|
x  | 
函数功能
推送Cache到远端节点。
函数原型
1 2 3 4 5  | Status PushKvCache(const Cache &src_cache, const CacheIndex &dst_cache_index, uint32_t src_batch_index = 0U, int64_t size = -1, const KvCacheExtParam &ext_param = {});  | 
参数说明
参数名称  | 
输入/输出  | 
取值说明  | 
|---|---|---|
src_cache  | 
输入  | 
本地目的Cache。仅需指定调用RegisterKvCache返回的cache_id。  | 
dst_cache_index  | 
输入  | 
远端目的Cache的索引。  | 
src_batch_index  | 
输入  | 
本地源batch的下标。  | 
size  | 
输入  | 
当前只支持默认值-1。  | 
ext_param  | 
输入  | 
当前支持ext_param中src_layer_range的sencond与first的差值和dst_layer_range的sencond与first的差值一致。src_layer_range和dst_layer_range的first和second默认值都是-1,表示全部的层。取值范围都是[0, 最大可用层索引],且first小于等于second。 最大可用层索引值的计算公式如下。 (CacheDesc::num_tensors / KvCacheExtParam::tensor_num_per_layer) - 1 当前支持tensor_num_per_layer取值范围是[1, 当前cache的tensor总数],默认值为2。当src_layer_range或dst_layer_range取值为非默认值时, tensor_num_per_layer可以保持默认值,也可以输入其他值,输入其他值的时,tensor_num_per_layer的取值还需要被当前cache的tensor总数整除。  | 
返回值
- LLM_SUCCESS:成功
 - LLM_PARAM_INVALID:参数错误
 - LLM_NOT_YET_LINK:与远端cluster没有建链
 - LLM_TIMEOUT:推送超时
 - LLM_KV_CACHE_NOT_EXIST:本地或远端KV Cache不存在
 - 其他:失败
 
约束说明
该接口调用之前,需要先调用LinkLlmClusters接口完成初始化。