当你在浏览器中输入 google.com 并且按下回车之后发生了什么? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
请不要在回答技术问题时复制粘贴 AI 生成的内容
argos
V2EX    程序员

当你在浏览器中输入 google.com 并且按下回车之后发生了什么?

  •  
  •   argos 2017-03-05 21:35:25 +08:00 9976 次点击
    这是一个创建于 3142 天前的主题,其中的信息可能已经有所发展或是发生改变。

    这是一道古老的面试题,不过我们不再局限于平常的回答,而是想办法回答地尽可能具体,不遗漏任何细节。 GitHub 上已经有人整理了相关技术细节,详情请点击左下角阅读原文。

    https://mp.weixin.qq.com/s?__biz=MzIzMDc5NzUwNg==&mid=2247483652&idx=1&sn=658cd37e07d09c9da30854fb30467d82&chksm=e8acb8a9dfdb31bfcea4ea4f91bb83d5bea329ef75a2ebd6281b9d0a0f6dc604b9455aed87e4&mpshare=1&scene=23&srcid=03056Pd20LNHSk0d44wdgW3j%23rd

    52 条回复    2017-03-07 13:13:29 +08:00
    TJT
        1
    TJT  
       2017-03-05 22:29:39 +08:00   14
    少了一步,路由。这些数据包经过数个路由器,最后被路由到一堵墙上,返回了一个消息,又被路由回楼主的浏览器,显示 `Connection reset by peer`.
    kindjeff
        2
    kindjeff  
       2017-03-05 22:36:40 +08:00
    TCP 包被切开封装成 IP 数据包……
    ……
    转成二进制……
    ……
    线路上使用频分 /时分复用……
    ………………
    到达交换设备 /路由器……
    ……
    argos
        3
    argos  
    OP
       2017-03-05 22:37:50 +08:00   1
    @TJT 也有可能 DNS 解析到的 IP 根本就不可达
    TJT
        4
    TJT  
       2017-03-05 22:40:16 +08:00
    @tianshuang 很久以前还没 DNS 污染这回事,那时候访问不存在的网站都是这个消息 :D
    langmoe
        5
    langmoe  
       2017-03-05 22:40:49 +08:00   1
    电脑试图解析域名
    电脑发送了 DNS 解析请求
    数毫秒内得到了一个阿塞拜疆的 IP 地址返回
    尝试访问,失败
    Osk
        6
    Osk  
       2017-03-05 22:43:07 +08:00
    路由器回应: Non-existent domain , 卒
    argos
        7
    argos  
    OP
       2017-03-05 22:44:10 +08:00
    @TJT 我们这一代还算好的,至少还体验过真正的互联网, 00 后才是真正的局域网
    laiyingdong
        8
    laiyingdong  
       2017-03-05 23:06:21 +08:00
    Connecting...
    thekll
        9
    thekll  
       2017-03-05 23:47:28 +08:00 via iPhone
    1 、浏览器发送 google.com 域名解析请求;
    2 、递归 dns 返回僵尸 ip ;
    3 、完。
    Clarke
        10
    Clarke  
       2017-03-06 00:28:16 +08:00 via Android
    真是为难程序员……
    halden
        11
    halden  
       2017-03-06 00:47:28 +08:00
    不仅面试题。。当年我们考 OS 的时候最后一题就这个。。
    dongxiaozhuo
        12
    dongxiaozhuo  
       2017-03-06 00:47:51 +08:00 via iPhone
    当前公司的面试题里面有类似的题目。

    至于出这种题目的原因,可能是有的来面试的人根本不知道 dns 这么个东西。

    至少我面试的人中有不少不知道 dns 。
    isphone
        13
    isphone  
       2017-03-06 00:48:53 +08:00
    出现 404
    Baymaxbowen
        14
    Baymaxbowen  
       2017-03-06 00:52:22 +08:00 via Android
    去年期末考试题
    firegeek
        15
    firegeek  
       2017-03-06 01:58:03 +08:00
    面试必备,翻译的很到位
    Senorsen
        16
    Senorsen  
       2017-03-06 02:15:17 +08:00
    域名被解析到沙特阿拉伯, Over.
    bombless
        17
    bombless  
       2017-03-06 04:47:42 +08:00 via Android
    90 年代末的时候有些网络本来就是局域网,因为运营商不想承担国际流量结算带来的费用。这种情况持续到谷歌被墙都存在。
    stupil
        18
    stupil  
       2017-03-06 08:55:43 +08:00   1
    先从薄膜键盘 ,中断 ,总线 cpu 指令等说起。
    glados01
        19
    glados01  
       2017-03-06 08:56:35 +08:00
    internet 会 break down
    fszaer
        20
    fszaer  
       2017-03-06 09:24:56 +08:00
    dns:不存在的,丢人,你退网吧
    sneezry
        21
    sneezry  
       2017-03-06 09:37:44 +08:00 via iPhone   1
    ACK->
    <-RST
    <-SYN

    Chrisplus
        22
    Chrisplus  
       2017-03-06 10:08:56 +08:00
    是不是还漏掉了 GFW 的部分?
    dreamist
        23
    dreamist  
       2017-03-06 10:53:26 +08:00
    应该是,解析到 google.com 的域名,然后 PAC 列表中查找,命中,把请求发到本地的 1080 端口,本地 server 再把请求转发到某个搬瓦工的机房的电脑上,这台机器帮我访问 google.com 后把结果返回给我。
    zjcqoo
        24
    zjcqoo  
       2017-03-06 11:07:56 +08:00
    发生了什么?发生 keydown 事件。完毕:)
    yoke123
        25
    yoke123  
       2017-03-06 11:15:22 +08:00
    无法访问此网站

    google.com 的响应时间过长。
    请试试以下办法:
    检查网络连接
    检查代理服务器和防火墙
    ERR_CONNECTION_TIMED_OUT
    ehs2013
        26
    ehs2013  
       2017-03-06 11:17:13 +08:00   1
    这帖子里面智障的说 404 的终于没几个了,欣慰
    cxh116
        27
    cxh116  
       2017-03-06 12:26:43 +08:00
    有本事就讲讲 "当访问 Google 的时候,GFW 做了什么?"

    GFW 做什么对屁民来说是黑盒,把黑盒里的技术原理讲清楚才叫 NB .
    xuexb
        28
    xuexb  
       2017-03-06 12:29:01 +08:00
    发生了:
    1. 请求 google.com
    2. 被 Q
    3. 提示无法访问...
    woostundy
        29
    woostundy  
       2017-03-06 12:48:12 +08:00
    我发了一个 pull request ,楼主可以看看。
    redsonic
        30
    redsonic  
       2017-03-06 12:52:03 +08:00
    真正能完整答出来的肯定是早期在微软各个部门混过的,然后给 chrome 提交代码的,当然他如果是个中国人肯定也在数字公司、方正或神州数码混过。
    initdrv
        31
    initdrv  
       2017-03-06 12:54:13 +08:00
    initdrv
        32
    initdrv  
       2017-03-06 12:56:59 +08:00
    图片挂了?好吧,站在梯子上,所以成功看见 GOOGLE 的首页被打开了……
    TJT
        33
    TJT  
       2017-03-06 12:59:16 +08:00
    @tianshuang 希望病魔早日战胜方校长
    salmon5
        34
    salmon5  
       2017-03-06 13:01:49 +08:00
    由于 google 是商业站点, gws 发现你没有带 www ,返回 301 到 http://www.google.com/, gws 发现你没有用 https ,返回
    Alt-Svc:"quic=":443",让你走 https 。
    sfwn
        35
    sfwn  
       2017-03-06 13:02:39 +08:00
    还以为 google 可以直接访问了 : )
    QAPTEAWH
        36
    QAPTEAWH  
       2017-03-06 13:20:29 +08:00
    楼上漏了一步
    - DNS 提供商记录了 lz 的行为
    - 老大哥看着 lz
    Rubbly
        37
    Rubbly  
       2017-03-06 16:58:09 +08:00
    当时是计网的最后一道题,侧重点在网络的那些层上。
    Mark24
        38
    Mark24  
       2017-03-06 18:17:44 +08:00
    发送到 DNS 服务器

    被墙

    返回 超时或者 404
    Penton
        39
    Penton  
       2017-03-06 18:22:49 +08:00
    404 GG
    wyntergreg
        40
    wyntergreg  
       2017-03-06 18:28:22 +08:00
    Google 官网
    Gmail
    Google 学术搜索
    Google 地图
    Google 图片
    ...
    相关软件...
    相关网站...
    网虫们在关注...
    ...
    相关搜索
    ...
    帮助 举报 给百度提建议
    zingl
        41
    zingl  
       2017-03-06 21:27:29 +08:00
    你们都没有说如果浏览器和 /或系统设置了代理服务器的情况,严格来说都不完整
    bayernmunchen
        42
    bayernmunchen  
       2017-03-06 21:41:58 +08:00 via Android
    你访问的地址不存在
    eroneko
        43
    eroneko  
       2017-03-06 21:47:22 +08:00 via Android
    现在改成 Google.cn 结论就差不多了
    RobertYang
        44
    RobertYang  
       2017-03-06 23:31:19 +08:00 via Android
    TCP REST
    PoloLee
        45
    PoloLee  
       2017-03-07 04:44:18 +08:00
    看标题,以为会详细讲一下 GFW ...
    lan894734188
        46
    lan894734188  
       2017-03-07 05:20:18 +08:00 via Android
    浏览器发送 dns 查询
    系统查询缓存
    木有
    系统看看我的 dns 是多少
    系统通过默认路由发出
    路由收到 跟据路由表转发
    .
    .
    .
    .
    .
    路由收到 跟据路由表转发
    dns 收到请求
    dns 查询缓存
    秒 get 到一个神奇的地址
    dns 返回结果
    路由收到 跟据路由表转发
    .
    .
    .
    .
    .
    路由收到 跟据路由表转发
    客户端收到 告诉浏览器
    浏览器尝试访问一个神奇的地址






    连接超时
    bxgty
        47
    bxgty  
       2017-03-07 06:24:50 +08:00
    题主既然说了"不遗漏任何细节"...
    就应该至少说说(最重要的) google 数据中心内部发生了什么
    另外,如果提一下 CDN 也会很好啊
    ragnaroks
        48
    ragnaroks  
       2017-03-07 08:27:21 +08:00
    koebehshian
        49
    koebehshian  
       2017-03-07 08:38:15 +08:00
    没人提 hosts 文件,还有底层的 TCP 窗口,路由,数据链路层拆分成帧,校验,还有物理层的调制解调.
    总得分为三部分:一,电脑的变化.二,传播路径的变化.三,谷歌服务器的变化.文中貌似只提了第一部分
    freeznet
        50
    freeznet  
       2017-03-07 08:47:16 +08:00
    dif
        51
    dif  
       2017-03-07 11:41:08 +08:00
    404
    billwsy
        52
    billwsy  
       2017-03-07 13:13:29 +08:00
    没提到 AS15169 里面的故事呢
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2678 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 27ms UTC 13:48 PVG 21:48 LAX 06:48 JFK 09:48
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86