基于swoole做并发处理方案调研

本文调研了题库服务的并发处理方案,针对自动判题逻辑的耗时问题,提出了使用Go和Swoole进行异步并行处理的方法。目标是实现最高并发1000个请求,以提升服务效率。
摘要由CSDN通过智能技术生成

一、需求背景

题库服务,自动判题逻辑处理耗时较长,每张试卷也会包含多道题目,若采用同步处理,耗时时间会成倍增加,需要改为并行异步处理。

二、实现功能

同时最高并发1000个请求做异步处理

三、基于go实现

// +build ignore

package main

import (
        "fmt"
        "time"
)

type Req struct {
        ID int `json:id`
}

type Resp struct {
        ID  int `json:id`
        Res int `json:res`
}

type Data struct {
        ReqChan  chan *Req  `json:req_chan`
        RespChan chan *Resp `json:resp_chan`
}

func deal(data Data) {
        for i := 0; i < 10; i++ {
                go dealSingle(data.ReqChan, data.RespChan)
        }
}
func dealSingle(reqChan chan *Req, respChan chan *Resp) {
        for {
                if v, ok := <-reqChan; ok {
                        respChan <- &Resp{ID: v.ID, Res: v.ID * v.ID}
                }
                time.Sleep(time.S
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值