当程序员开了外挂_作者:雪天蛤蟆跳跳(69)

2020-07-17 雪天蛤蟆跳跳

    但是上传端来问的时候,服务器端是有负载均衡的。一个出口,后面挂了好多个机器,可以想像一下百度的域名,他下面是有好多的物理机的,但是对外只暴露了一个域名,就是baidu,同理,其它大型的网站也基本是这个套路,不过没有百度那么多的机器罢了

    有负载均衡,所以不确实这个提问的动作会具体的落到哪一台,实际上大概率都不会是刚才上传的那一台了。

    所以这个时候有人来问了,就需要任何一个机器都能访问到的主库,可以从这里取出来刚才那个上传任务的一些信息,返回给那个询问的人。

    这是客户端轮询来要结果,其实还有一个是回调,就是在上传图片的时候就写好,一个通知接口,如果成功了,服务器端就调用一下这个接口,告诉它结果。

    然后就是上传的机器怎么把图片的数据存起来的问题了。

    宋飞翼在每个机器上启动了一个任务调度系统。

    这个调度系统会依次把刚才那个消息队列中的消息给消费者,消费者去真正的执行上传的操作。

    其实说白了也就是把一个二进制的数据存到了一个数据库集群中,不过这个是一个特殊的数据库,并不是常见的mysq也是一个数据库,内容存在磁盘里。

    接着再更新一下公共数据库的信息,这样再有人来问的时候,它就能告诉对方应该用哪个地址来访问。

    这样的架构用在线上是很好的,但是用在开发环境基本没有什么太大的用途。

    毕竟开发环境只有两个物理机而已,不能发挥出来他设计的这一套架构的优势。

    其实一般的情况下开发环境都用的是虚拟机,还是低配的那种,而且还有很多的项目都是共用这个。

    宋飞翼说他们的开发环境只有两个物理机还而已,就太气人了。

    可就算不能发挥出来这个架构的优势,那也不应该报警啊!

    宋飞翼想不明白,到底是哪个环节出了问题,居然能b把两台物理机给逼到这个份上。

    回到了工位,他们立刻就登录上了机器查看问题。

    不过那两台服务器卡的厉害,他们登上去都慢的很。

    用inux和windowns、macos,是一个操作系统,互联网服务器多用这种系统特有的几个命令,很快他们就看到了问题出在哪里。

    是cpu占用的特别高,所以把整个系统的负载给拉上去了。

    网络连接、件读写、内存都还好。

    “cpu为什么会占用的这么多。”他们看了一下进程,是nginx一个web服务器进程占用了很高的cpu。

    有一个人在测试群里问了一下,“大家有做过什么操作吗?现在服务器卡的很,负载特别高。”

    没有

    没有

    好几个人都说没有做什么特殊的操作。

    程也看到了这个消息,他在内心深处想,不会是我的问题吧?

    我做了灰盒测试

    程决定还是尽早的坦白,不然被人抓到了把柄,那就不好了。

    “灰盒测试,你是测试了哪里的功能?”有一个开发直接找过来了。

    “测试的是那个下载的时候指定参数的b缩放。”

    “好的,多谢,我知道是哪里的问题了,我去看一下。”

    当他回到他的工位上的时候,宋飞翼也从nginx的日志上看到了一些端倪。

    好像是有几个请求导致的这个问题。

    “应该是缩放那里的问题。”直接跑去问程的那个开发,立刻对其他人说道。

    “嗯,我也找到了这个问题,这个参数怎么这么大?”宋飞翼从日志中看到了一个有问题的参数。

    缩放的时候一般都是有固定的大小的,几百乘几百,最多也就几千乘几千,但是这几个访问的连接,光是ur显示出来就有十几厘米长。

    屏幕上看别的请求都很正常,但这个都多换了一行。

    “卧槽,难道就硬生生去b缩放了,并没有限制一下大小?”宋飞翼想到了一个可能的原因。