【AICon】探索RAG 技术在实际应用中遇到的挑战及应对策略!AICon精华内容已上线73%>>> 了解详情
写点什么

Node 之父 Ryan Dahl:我不想被定义

  • 2017-09-05
  • 本文字数:2387 字

    阅读完需:约 8 分钟

被称为 Node 之父的 Ryan Dahl 在 2012 年离开了 Node 项目,后来加入 Google 的 Brain 团队,从事深度学习方面的研究,主要专注在图像的着色和超解像技术上。拥有深厚数学功底的 Ryan 经历了从 Web 开发到深度学习的跨越,还主导了多个开源项目,如 HTTP 解析器、 libuv 等,可以说是一个技术多面手。他不喜欢被人定义成某个领域的专家。MTJ(Mapping The Journey)网站对 Ryan 进行了一次深度访谈,他在访谈中提及了他的成长经历、Node 的开发始末、个人的职业变迁以及对深度学习和人工智能的看法。

漫漫求学路

Ryan 在圣地亚哥长大,在他六岁的时候,家里就购买了一台 Apple IIc 电脑,这对他后来走上技术之路产生了一定影响。在念完圣地亚哥社区大学之后,Ryan 到加利福尼亚大学圣迭戈分校继续攻读数学硕士学位。硕士毕业之后又到罗彻斯特大学继续攻读数学博士学位,在这期间他学习了代数拓扑学。数学曾经让他着迷,他觉得数学是一门非常美妙的学科。不过有一天,他意识到数学并不能被完美地应用到现实生活当中,他也不想余生就做一个数学家,于是他就中途退出博士学位计划,跑到南美洲呆了一年。他在那里找到了一份 Web 开发工作,开始了他的职业生涯。

Node 的诞生

在离开南美洲后,Ryan 和他的女朋友去了德国。因为 Ryan 的女朋友是德国人,她要回到大学继续深造。在那里,有个叫 Chris Neukirchen 的人开发了一个叫作 Rack 的 Web 服务器,这个服务器拥有非常简单的接口——接收请求,返回响应。与此同时,在从事自由职业的过程中,Ryan 接触到了 Nginx 的一些模块,他发现 Nginx 的很多东西都是异步的。于是他想,如果把 Rack 和 Nginx 的非阻塞 IO 结合起来,那会变成一个怎样的东西呢?

2008 年 12 月,Google 发布了 V8 引擎,这为 Node 的诞生奠定了坚实的基础。Ryan 开始把玩 V8 引擎,它既有趣又简洁,而且运行速度很快,Ryan 突然想到:JavaScript 本身就是单线程的,而且浏览器发起的 AJAX 请求就是非阻塞的。如果将 JavaScript 和异步 IO 以及一个简单的 HTTP 服务器集合在一起,就会变成一个很酷的东西。就这样,在接下来的四年,Ryan 开发出了如今被广泛使用的 Node。

Node 不是万能的

虽然 Ryan 已经离开 Node 项目很多年了,但当年开发和布道 Node 的经历似乎还历历在目。Ryan 四处发表演讲,试图说服人们相信阻塞式 IO 是错误的方式,如果使用非阻塞的方式来处理所有的事情,那么就可以解决很多难点。比如,可以完全把线程忘掉,在单个进程里处理所有的异步请求。那个时候,Ryan 相信这就是一切,直到 Go 语言的出现。其实 Go 语言早在 2009 年就发布了,Ryan 在 2012 年才注意到它。Go 语言的运行时适当地使用了绿色线程(即用户线程),在运行时和操作系统之间所有的 IO 操作都是非阻塞的,但是它提供给用户的接口却是阻塞式的。在 Ryan 看来,这是一种更好的编程模型。为什么这么说呢?假设你的应用程序要做两件事情,分别是 A 和 B。你发起请求 A,等待响应,出错。发起请求 B,等待响应,出错。Go 语言的阻塞模型可以非常容易地处理这些异常,而换到了 Node 里,要处理异常就要跳到另一个函数里去,事情就会变得复杂。

Node 的非阻塞模型没有了多线程,但却多出了“回调地狱”问题。Ryan 认为 Node 并不适合用来开发大规模的服务端应用,相比之下,Go 语言会是更好的选择。而 Node 能够真正一展拳脚的地方是客户端。

低调

在加入 Joyent 成为全职的 Node 开发人员之后,Ryan 也随之成为更加重量级的人物。参加各种大会,被粉丝要求合影拍照,随便写点东西都会有很多人响应。但 Ryan 并不喜欢这种状态,他说:

我是一个程序员,我想写代码,我想无拘无束地表达我的想法。我并不喜欢这种状态……

离开 Node 项目

在 Node 如日中天的时候,Ryan 离开了项目。首先,他当时已经在这个项目上开发了四年时间,已经实现了他的预期目标。他原先的想法是把 Node 做成简单紧凑的小型化核心,让其他人基于这个核心开发出更多的模块。后来他们不断增加新模块,涵盖了网络协议到文件系统的访问,甚至还把 Node 移植到了 Windows 平台上。随着代码量的膨胀,开始出现大量的 bug,不过在那个时候已经有很多人可以修复这些 bug,无需 Ryan 操心了。在 Ryan 看来,如果继续留在这个项目里,无非就是修修 bug。而且随着 Go 语言的发展,他发现 Node 并不适合用来构建服务器端应用,再加上他不喜欢头上的“光环”,所以决定离开这个项目。

新的起点

在离开 Joyent 和 Node 项目之后,Ryan 去了纽约,开始开发属于自己的项目。他做了一些项目,但都不算太成功,后来他接触到了卷积神经网络和图像分类技术,对机器学习产生了兴趣。两年前,Google 发布了 TensorFlow,同时启动了 Google Brain Residency 计划(为期一年的深度学习研究,有机会与 Brain 团队的人一起工作),Ryan 加入了这个计划,并最终成功成为 Brain 团队的一员。Ryan 的研究方向是图像着色和超解像技术。

对人工智能的看法

Ryan 认为,目前的机器学习系统还很简单,离真正的人工智能还差得很远。但是技术在发展,硬件也在发展,人类正在为人工智能的发展奠定坚实的基础。在未来的 20 年,机器学习技术将被广泛地应用在各个领域,人类一定能够从中获益。

不想被定义

Ryan 从做 Web 开发开始,转而进入机器学习领域,这两个领域看起来相差了十万八千里,但因为 Ryan 拥有牢固的数学背景,所以这种转变对他而言似乎也是一件很自然的事情。不过他不想被定义成某个领域的专家,他说:

人们喜欢把人和他所在的领域联系起来,但我不喜欢那样。我既不想被认为是一个 JavaScript 专家,也不想被认为是一个机器学习专家。探索无限的可能性是一件有趣的事情。创造前所未有的、对人类有益的事物会让人激动不已。


感谢郭蕾对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2017-09-05 19:007497
用户头像

发布了 322 篇内容, 共 133.7 次阅读, 收获喜欢 142 次。

关注

评论

发布
暂无评论
发现更多内容

XOR异或运算在计算机中的应用

王坤祥

XOR 异或运算 对称加密

Python 有哪些黑魔法?

极客时间

Python 编程语言

LeetCode 前1000题二叉树题目系统总结

Yano

面试 算法 LeetCode 二叉树 刷题

项目实施要避免哪些坑?

顾强

项目管理

centos7.6操作系统安装

桥哥技术之路

Linux

Docker运行常用软件:MySQL,Redis,Nginx,RabbitMQ,Neuxs,Gitlab

读钓

MySQL nginx Docker gitlab

Ledge:这可能是距今最好的『DevOps + 研发效能』知识平台

Phodal

DevOps 敏捷开发 软件开发 研发效能

都在说实时数据架构,你了解多少?

Apache Flink

大数据 flink 流计算 实时计算

Sentinel在docker中获取CPU利用率的一个BUG

捉虫大师

Java sentinel cpu

身为程序员,怎么接私活赚外快?

爱看书的小代码

MacOS配置网络命令

编程随想曲

macos network

18个PPT,29个提问解答,都在这儿啦!

Apache Flink

大数据 flink 流计算 实时计算

读书·行路·问心·求道

黄崇远@数据虫巢

读书笔记 个人成长 读书

一个工程师向电信公司的维权

D

如何在非 sudo 用户下运行 docker 命令?

愚一

Docker DevOps

用jdk8的stream实现斐波那契数列

编号94530

jdk stream 斐波那契 fibonacci

SpringBoot中如何优雅的使用多线程

读钓

Java spring Spring Boot

记一次spring注解@Value不生效的深度排查

捉虫大师

spring Spring Boot dubbo

一次漫长的dubbo网关内存泄露排查经历

捉虫大师

dubbo 内存泄露

什么是物联网中台

老任物联网杂谈

物联网中台 IOT Platform 物联网平台

当dubbo多注册中心碰上标签路由

捉虫大师

dubbo

Linux系统优化

桥哥技术之路

Linux

在Kubernetes上运行SpringBoot应用

铁花盆

Docker Kubernetes Spring Boot

Apache Beam 大数据处理一站式分析

李孟聊AI

Java 大数据 数据中台 数据交换 Beam

思维导图学《Linux性能优化实战》

Yano

Linux 后端

skywalking内存泄露排查

捉虫大师

dubbo 内存泄露

一行代码实现网站可编辑,并解决网站禁止复制的限制

王坤祥

复制 破解 DOM

零基础应该如何学习爬虫技术?

极客时间

Python 编程 爬虫

以为是青铜,没想到是王者的dubbo标签路由

捉虫大师

dubbo

nacos的一致性协议distro介绍

捉虫大师

nacos

IPFS 星际传输协议的入门(二)

AIbot

区块链 分布式数据库

Node之父Ryan Dahl:我不想被定义_语言 & 开发_薛命灯_InfoQ精选文章