我同一时间给服务器发送 1000 个 ajax 请求,服务器就崩了,得重启。 万一有人想搞我的网站,也同时发 1000 个 ajax 过来,那我网站不就崩了? 有没有办法让服务器接受大量请求不崩溃的办法?
1
zjsxwc 2023-10-24 08:28:42 +08:00
- jvm 的加大内存。
- 改换用 php-fpm 重写。 - 改用 serverless 重新。 |
2
gbw1992 2023-10-24 08:29:52 +08:00 1
|
3
lsk569937453 2023-10-24 08:30:51 +08:00 4
如果你的服务器并发超过 1000 的话,那就赚老鼻子钱了,招高级程序员给你打工吧。
|
4
seers 2023-10-24 08:35:39 +08:00 via iPhone
上消息队列
|
5
opengps 2023-10-24 08:37:28 +08:00
1000 并发(并发一般是指 1 秒内的并发请求数量)是非常优秀的业务指标了。
这个时候你需要的是多机器多站点的去做负载均衡做集群架构部署,而不是拼了命的提高单机性能。道理就好比你的 cpu 主频这么多年也就是个 GHz 了,于其提高单个性能不如再来一个 cpu 满足需要 |
6
sdjl 2023-10-24 08:51:52 +08:00
那我网站不就崩了? 是的,就崩了。
有没有办法让服务器接受大量请求不崩溃的办法? 对方要搞你,主要是搞钱(例如搞你的 CDN 流量费),不是搞崩。通常情况下,怕搞钱不怕搞崩。 说回楼主的问题,如何提高并发能力。 1 、静态资源都走 CDN 。 2 、能缓存等请求尽量缓存,特别是重复的数据库查询。 3 、开多进程守护,例如 8 个、80 个、200 个等等。 4 、进程之间记得共享缓存数据,节约内存和时间。 5 、做好并发写攻击的防御(特别是涉及到金钱的程序)。 6 、该崩就崩,人都是要死的,何况程序,别怕。 |
7
sdjl 2023-10-24 08:53:06 +08:00
2 、能缓存请求就尽量缓存,特别是重复的数据库查询。
|
8
blackeeper 2023-10-24 08:53:53 +08:00
想让服务器不蹦?那么你可以选择换
1 ,更好的 CPU 、 2 ,更大的内存条 3 ,速度更快的硬盘 SSD 4 ,网口,以及超大带宽 5 ,换操作系统 6 ,....... 还有一堆可以升级的地方,都是可以避免崩溃的地方,关键在于你业务服务器的瓶颈在哪儿 |
9
sdjl 2023-10-24 08:56:19 +08:00
“服务器就崩了,得重启” 这里可能是因为你的进程有异常,没有 catch 住,然后进程死掉了。
建议从最外围运行的地方 catch 异常,如发现未知异常就 catch 住,然后重启进程或线程,确保异常不会导致进程变“死进程”。 |
10
dode 2023-10-24 09:01:59 +08:00
限制连接数量和请求速度
|
11
sumarker 2023-10-24 09:03:44 +08:00
加机器 做负载
|
12
dif 2023-10-24 09:13:48 +08:00
个人网站,崩就崩了。别误伤账单就行。
另外,合理利用缓存,尽量使用静态化解决。 |
13
nuyan 2023-10-24 09:20:49 +08:00
想搞你,无非你能做的就是技术+金钱。最简单的就是花钱往死往死加机器。
|
14
BinaryDH 2023-10-24 09:41:40 +08:00
真正的解决办法是,限流熔断
|
15
newaccount 2023-10-24 09:57:59 +08:00
个人网站 1000 并发……
公司网站 tomcat 做到 20 并发能不崩我就不继续测了,通过负载均衡拉到七八十应付爬虫就足够足够的 |
16
realJamespond 2023-10-24 10:00:12 +08:00
把带宽调低,物理限速
|
17
janus77 2023-10-24 10:05:03 +08:00
理论上是这样,可是同时发 1000 个请求也是要很高成本的,换句话说如果你的项目不是企业级项目,没有商业价值,那就不会有哪个黑客来花大价钱攻击你,因为他得不到什么东西。
当然如果你只是单纯想提高一下安全性和性能的话,楼上很多做法都可以来一遍,各个环节能提升的地方都可以提升,就看你愿不愿意花钱了 |
18
IDAEngine 2023-10-24 10:06:03 +08:00
开 API 网关,把高价值客户调度到高性能服务器,低价值客户调度到易受攻击的节点
|
19
jioswu 2023-10-24 10:15:10 +08:00
换语言是成本最低的,前提是自己会,否则加机器上负载均衡
|
20
pkoukk 2023-10-24 10:34:29 +08:00
你这其实是两个问题
1 、怎么防止被打 2 、怎么提高服务性能 方案太多了,一切以你的预算为前提 |
21
qwertyzzz 2023-10-24 10:37:20 +08:00
自己先主动崩
|
22
freezebreze 2023-10-24 10:52:16 +08:00
鸵鸟模式
|
23
dashabi 2023-10-24 12:29:49 +08:00
并发 1000 ?我站每天有 8 万访问,在线人数 2000-3000.都没达到 并发 1000 、、厉害啊。
是每个请求处理时间长???有 1000 并发,,弄个高档服务器。 |
24
MeteorCat 2023-10-24 12:45:22 +08:00 via Android
买高防清洗掉攻击 IP
|
25
alsas 2023-10-24 14:01:47 +08:00
加机器
|
27
ShuWei 2023-10-24 15:27:21 +08:00
先在入口限流吧,然后再排查下为什么彻底宕了,估计是有 bug 修修
|