Beispiel #1
0
        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);
        }
Beispiel #2
0
        //同步方法
        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);
        }
Beispiel #4
0
        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));
        }
Beispiel #5
0
 /// <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);