ajax请求会新建立一个线程吗,javascript - 一个页面中如果存在多个ajax访问后台,此刻后台是单线程的吗?还是多线程...

如果后端采用的是thinkphp框架,页面多个ajax访问后台服务器,后台服务器此时是异步单线程还是多线程操作?求了解的朋友能和我说说

回复内容:

如果后端采用的是thinkphp框架,页面多个ajax访问后台服务器,后台服务器此时是异步单线程还是多线程操作?求了解的朋友能和我说说

默认是多进程非多线程,一个进程处理一个请求。php多线程需要安装扩展实现,但是还是同一进程接收一个http请求,除非自己用php实现个web服务器,然后分发请求用多线程处理,就可以实现一个线程一个请求。

apache默认是prefork工作模式,php作为一个module模块,一个请求新建一个进程响应,最大进程数量取决于apache配置。nginx是通过fast-cgi与php-fpm通讯,也是一个请求一个进程,最大进程数量取决于php-fpm配置。

如果一个请求后端处理时间过长阻塞了,此时多个相同请求把进程数量开满了,后面所有请求就会出现等待可用套接字情况

这个取决你的服务器端,是单线程还是多线程,甚至多进程。

我理解的单线程和多线程是这样的,

比如你用一个表单上传文件, 这只是一个请求, 你只发起了上传文件这一个请求, 服务器在收到你的上传文件请求后, 发现你的这文件可真大啊, 他想要是自己一个人扛的话估计晚上10点都不能下班, 然后就自动(fork)了一些帮手, 相当于产生了一些新的线程, 来帮助他完成文件上传,多人协作肯定很快了, 所以你分分钟就完成了你的大文件上传, 这就是多线程,

单线程就是一个人苦逼的处理到天亮吧,

所以, 服务器是否是单线程或是多线程的, 不取决于你client发起的多少请求, 客服端同时发起一万个请求(无论同步还是异步), 这叫并发, 和多线程没什么关系得,

单线程是无法实现并发请求的。

可以脑补这样一个场景:用户的下行速度是 1k,然后请求了一个 1M 的图片,如果服务器单线程的话,下一个请求要等 17 分钟才开始响应,显然不可能让你这么玩。

所以 Web 服务器必然是多线程。

线程数方面,一般是 4 以上的个位数,不过这个是浏览器的限制,单页面发起的请求数是有限制的,多了会扔进列队里等,这就是为什么有时候也个页面引用了谷歌的 CDN 文件,却连网页图片也卡了加载不出来的原因。

我疑惑的事情是这样的:我疑惑的是apache+php是阻塞的,nginx+php是异步的。所以如果是apache服务器的话,php那边是阻塞的响应ajax请求吗?

php是单进程单线程模型。 你说的ajax请求,也相当于一个http请求,所以不存在多线程之分。 js的ajax却是异步请求实现的!!!

client 端并发跟server端处理请求方式(单线程,多线程)取决于应用场景,大多数场景下,server端并行非阻塞

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
jQuery本身并不支持多线程处理Ajax请求JavaScript单线程的,意味着它一次只能执行一个任务。然而,你可以使用jQuery的异步请求功能来实现并发处理多个Ajax请求。 jQuery提供了`$.ajax()`方法来发送异步请求。你可以通过设置`async`参数为`false`来实现同步请求,但这导致浏览器在请求完成之前被阻塞,影响用户体验。因此,通常建议使用异步请求。 以下是一个使用jQuery进行异步请求的示例: ```javascript $.ajax({ url: 'example.com/api', method: 'GET', async: true, success: function(response) { // 请求成功的回调函数 console.log(response); }, error: function(xhr, status, error) { // 请求失败的回调函数 console.log(error); } }); ``` 如果你需要处理多个Ajax请求,可以使用jQuery的`$.when()`和`$.then()`方法来实现并发处理。`$.when()`方法接受多个Deferred对象作为参数,并返回一个的Deferred对象,该对象在所有给定的Deferred对象都解决(即成功)时解决。然后,你可以使用`$.then()`方法来处理所有请求成功后的回调。 以下是一个处理多个Ajax请求的示例: ```javascript var request1 = $.ajax({ url: 'example.com/api1', method: 'GET' }); var request2 = $.ajax({ url: 'example.com/api2', method: 'GET' }); $.when(request1, request2).then(function(response1, response2) { // 处理请求1和请求2的响应 console.log(response1); console.log(response2); }); ``` 请注意,以上示例请求是并发发送的,但是在`$.then()`方法处理响应时,你可以根据需要进行进一步的处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值