在所有适配器中,我们需要引入基础适配器Adapter并使用其提供的继承方法。命名空间为:use Domain\Datahub\Instance\Adapter\Adapter;
。
使用$this->getLogStorage()->insertOne([$content], $status);
进行日志记录。其中,$content
为日志内容(数组形式),$status
为日志错误类型。如果$status
为错误,需要引入命名空间LogStatus
,调用方法为$this->getLogStorage()->insertOne([$content], LogStatus::RECORD);
。
在写入调度者时,需要从数据管理中获取一条数据,并根据配置的metaData
中的operation
参数。代码如下:
$operation = null;
if (isset($this->metaData['operation'])) {
$operation = $this->metaData['operation'];
}
$data = $this->getDataStorage()->fetch($operation);
其中,$this->metaData
保存了请求调度者和写入调度者的配置参数,包括对应的$api
接口地址。
此方法主要用于将请求调度者和写入调度者的配置参数转换为接口所需的参数。可以直接调用父类(Adapter)的generateRequestParams
方法。代码如下:
$request = $this->generateRequestParams();
$request = $this->generateRequestParams($data);
在实际过程中,我们可以使用以下代码:
try {
$request = $this->generateRequestParams($data);
} catch (\Throwable $th) {
$this->getLogStorage()->insertOne(['text' => LogMessage::DISPATCH_SOURCE_FAIL, 'response' => $th->getMessage(), 'data' => $data], LogStatus::ERROR);
$this->getDataStorage()->setFetchStatus(DataStatus::CONTINUE);
return $this->dispatch();
}
使用上一步得到的$request
,向请求队列中插入任务数据,并获取任务ID。代码如下:
$jobId = $this->getAsynSourceJobStorage()->insertOne($this->metaData['api'], $request);
调用父类的asynSourceJob
方法,$time
表示多少秒后执行队列任务(0表示立即执行),$jobId
表示任务ID。代码如下:
$this->asynSourceJob($time, $jobId);
调用Adapter父类的asynTargetJob
方法,$this->metaData['api']
表示方案设置的接口地址,$request
表示请求参数,$this->getDataStorage()->ids
表示数据ID,$this->getDataStorage()->dataRange
表示数据范围。代码如下:
$jobId = $this->getAsynTargetJobStorage()->insertOne($this->metaData['api'], $request, $this->getDataStorage()->ids, $this->getDataStorage()->dataRange);
调用getDataStorage
中的setFetchStatus
方法,标记数据状态为队列中。$jobId
表示任务ID。代码如下:
$this->getDataStorage()->setFetchStatus(DataStatus::QUEUE, null, null, new \MongoDB\BSON\ObjectId($jobId));
调用父类的asynTargetJob
方法,$time
表示多少秒后执行队列任务(0表示立即执行),$jobId
表示任务ID。代码如下:
$this->asynTargetJob(round($this->asynTimes), $jobId);
在查询适配器中,如果得到正确的结果集,调用getDataStorage
中的insertOne
方法,将数据写入数据管理。$id
为主键字段,$number
为业务编码字段,$response
表示接口返回的结果集,$jobId
表示任务ID。代码如下:
$this->getDataStorage()->insertOne($id, $number, $response, false, $jobId);
reQueue
在处理响应时,如果响应结果不正确,调用父类的reQueue
方法进行任务重试。代码如下:
$this->reQueue();
在适配器中,我们定义了一个handleError
方法用于处理异常。代码如下:
public function handleError($response, $jobId = null)
{
$throw = new HuidinhuoThrowable($this);
$throw->handle($jobId, $response);
$this->getAsynSourceJobStorage()->updateResponse($jobId, DataStatus::ERROR, $response, 0, $this->active);
$this->getLogStorage()->insertOne(['text' => LogMessage::INVOKE_FAIL, 'response' => $response], LogStatus::ERROR);
return $response;
}
2021-04-10 20:48:05 | |
2021-04-11 00:37:37 | |
2021-03-19 12:12:19 | |
2021-01-17 23:01:53 | |
2021-01-12 07:20:45 | |
2021-01-22 19:19:51 | |
2021-01-09 14:36:09 | |
2021-02-21 05:48:31 | |
2021-02-15 18:30:27 | |
2021-03-04 11:26:57 | |
2021-04-14 00:07:40 | |
2021-02-05 23:53:58 | |
2021-02-27 18:31:00 | |
2021-03-21 07:02:03 | |
2021-04-22 00:27:36 | |
2021-01-24 22:00:13 | |
2021-01-23 00:05:46 | |
2021-04-24 17:23:07 | |
2021-02-08 09:04:50 | |
2021-03-10 21:47:48 | |
2023-01-26 10:15:12 | |
2023-01-26 10:15:11 | |
2023-01-26 10:15:10 | |
2023-01-26 10:15:09 | |
2023-01-26 10:15:08 |
卢剑航 13760755942
数据集成专家 拥有十多年丰富的经验,擅长ERP、MES、数据中台、营销云中台等集成。他能够根据客户需求,为其提供一站式集成解决方案,帮助企业快速实现各类系统数据集成服务。
胡秀丛 15813570600
数据集成顾问 项目总监 她以卓越的数据集成专长,精通ERP、MES系统,以及数据中台的构建与优化。通过创新的一站式解决方案,她助力企业实现数据的无缝对接,提升业务流程效率,确保信息流通无障碍,为企业的数字化转型提供强有力的支持。
何海波 18175716035
数据集成顾问 轻易云的技术专家,拥有丰富的数据集成规划经验。他能够为客户提供专业、全面的数据集成规划方案,熟练掌握多种集成技术和工具,帮助企业在数据集成领域得到长远发展。