public async Task <RpcResult <TaskVoidRes> > EnqueueAsync(EnqueueTaskReq req, int timeOut = 3000) { AmpMessage message = AmpMessage.CreateRequestMessage(2001, 101); message.FriendlyServiceName = "TaskProducerService.Enqueue"; message.Data = req.ToByteArray(); var response = await base.CallInvoker.AsyncCall(message, timeOut); if (response == null) { throw new RpcException("error,response is null !"); } var result = new RpcResult <TaskVoidRes>(); if (response.Code != 0) { result.Code = response.Code; } if (response.Data == null) { result.Data = new TaskVoidRes(); } else { result.Data = TaskVoidRes.Parser.ParseFrom(response.Data); } return(result); }
//同步方法 public RpcResult <TaskVoidRes> EnqueueTransfor(EnqueueTaskReq req) { AmpMessage message = AmpMessage.CreateRequestMessage(2001, 104); message.FriendlyServiceName = "TaskProducerService.EnqueueTransfor"; message.Data = req.ToByteArray(); var response = base.CallInvoker.BlockingCall(message); if (response == null) { throw new RpcException("error,response is null !"); } var result = new RpcResult <TaskVoidRes>(); if (response.Code != 0) { result.Code = response.Code; } if (response.Data == null) { result.Data = new TaskVoidRes(); } else { result.Data = TaskVoidRes.Parser.ParseFrom(response.Data); } return(result); }
//调用委托 private async Task <AmpMessage> ProcessEnqueueAsync(AmpMessage req) { EnqueueTaskReq request = null; if (req.Data == null) { request = new EnqueueTaskReq(); } else { request = EnqueueTaskReq.Parser.ParseFrom(req.Data); } req.FriendlyServiceName = "TaskProducerService.Enqueue"; var result = await EnqueueAsync(request); var response = AmpMessage.CreateResponseMessage(req.ServiceId, req.MessageId); response.FriendlyServiceName = "TaskProducerService.Enqueue"; response.Code = result.Code; if (result.Data != null) { response.Data = result.Data.ToByteArray(); } return(response); }
public override Task <RpcResult <TaskVoidRes> > EnqueueTransforAsync(EnqueueTaskReq req) { RpcResult <TaskVoidRes> res = new RpcResult <TaskVoidRes>(); _jobClient.Enqueue <IHangfireJobService>(x => x.Enqueue(0, 1, $"{req.ServiceId}|{req.MessageId}|{req.Data}", null)); return(Task.FromResult(res)); }
/// <summary> /// 队列任务 /// </summary> /// <param name="req"></param> /// <returns></returns> public override Task <RpcResult <TaskVoidRes> > EnqueueAsync(EnqueueTaskReq req) { return(EnqueueTransforAsync(req)); }
//抽象方法 public abstract Task <RpcResult <TaskVoidRes> > EnqueueAsync(EnqueueTaskReq req);