從硅谷公司哪家強,到人人在議的泡沫問題,大數(shù)據(jù)和人工智能如何結(jié)合?2015年的科技前瞻是怎樣一副圖景?來自硅谷的Coursera軟件工程師董飛將其近日在斯坦福公開講座上的干貨和各種場合的問答整理出來和大家分享。文中有他的一手從業(yè)經(jīng)驗,也有其對親身就職或深度研究過的一些公司具體分析,如Hadoop、Amazon、LinkedIn等。董飛的知乎頁面在這里,郵箱是dongfeiwww@gmail.com。
1、目前硅谷最火最有名的高科技創(chuàng)業(yè)公司都有哪些?
在硅谷大家非常熱情的談創(chuàng)業(yè)談機會,我也通過自己的一些觀察和積累,看到了不少最近幾年涌現(xiàn)的熱門創(chuàng)業(yè)公司。我給大家一個列表,這個是華爾街網(wǎng)站的全世界創(chuàng)業(yè)公司融資規(guī)模評選。它本來的標(biāo)題是 billion startup club,我在去年國內(nèi)講座也分享過,不到一年的時間,截至到 2015 年 1 月 17 日,現(xiàn)在的排名和規(guī)模已經(jīng)發(fā)生了很大的變化。
首先估值在 10 Billlon 的達(dá)到了 7 家,而一年前一家都沒有。第二;第一名是中國人家喻戶曉的小米;第三,前 20 名中,絕大多數(shù)(8 成在美國,在加州,在硅谷,在舊金山?。┍热?Uber, Airbnb, Dropbox, Pinterest;第四,里面也有不少相似模式成功的,比如 Flipkart 就是印度市場的淘寶,Uber 與 Airbnb 都是共享經(jīng)濟(jì)的范疇。所以大家還是可以在移動 (Uber),大數(shù)據(jù)(Palantir),消費級互聯(lián)網(wǎng),通訊 (Snapchat),支付 (Square),O2O App 里面尋找下大機會。這里面很多公司我都親自面試和感受過他們的環(huán)境。
2、有如此之多的高估值公司,是否意味著存在很大的泡沫?
看了那么多高估值公司,很多人都覺得非常瘋狂,這是不是很大泡沫了,泡沫是不是要破了,是很多人的疑問。我認(rèn)為在硅谷這個充滿夢想的地方,投資人鼓勵創(chuàng)業(yè)者大膽去做同樣也助長了泡沫,很多項目在幾個月的時間就會估值翻 2,3 倍,如 Uber,Snapchat 上我也驚訝于他們的巨額融資規(guī)模。那么這張圖就是講“新興技術(shù)炒作”周期,把各類技術(shù)按照技術(shù)成熟度和期望值分類。
創(chuàng)新萌芽 Innovation Trigger”、“期望最頂點 Peak ofInflated Expectation”、“下調(diào)預(yù)期至低點 Trough of Disillusion”、“回歸理想 Slope ofEnlightenment”、“生產(chǎn)率平臺 Plateau of Productivity”,越往左,技術(shù)約新潮,越處于概念階段;越往右,技術(shù)約成熟,約進(jìn)入商業(yè)化應(yīng)用,發(fā)揮出提高生產(chǎn)率的效果??v軸代表預(yù)期值,人們對于新技術(shù)通常會隨著認(rèn)識的深入,預(yù)期不斷升溫,伴之以媒體炒作而到達(dá)頂峰;隨之因技術(shù)瓶頸或其他原因,預(yù)期逐漸冷卻至低點,但技術(shù)技術(shù)成熟后,期望又重新上升,重新積累用戶,然后就到了可持續(xù)增長的健康軌道上來。
Gartner 公司每年發(fā)布技術(shù)趨勢炒作圖。今年和去年的圖對比顯示,物聯(lián)網(wǎng)、自動駕駛汽車、消費級 3D 打印、自然語言問答等概念正在處于炒作的頂峰。而大數(shù)據(jù)已從頂峰滑落,NFC 和云計算接近谷底。
3、未來,高科技創(chuàng)業(yè)的趨勢是什么?
我先提一個最近看的一部電影《Imitation Game》,講計算機邏輯的奠基者艾倫圖靈(計算機屆最高獎以他命名)艱難的一生,他當(dāng)年為破譯德軍密碼制作了圖靈機為二戰(zhàn)勝利作出卓越貢獻(xiàn),挽回幾千萬人的生命,可在那個時代因為同性戀被判化學(xué)閹割,自殺結(jié)束了短暫的 42 歲生命。他的一個偉大貢獻(xiàn)就是在人工智能的開拓工作,他提出圖靈測試(Turing Test),測試某機器是否能表現(xiàn)出與人等價或無法區(qū)分的智能。
今天人工智能已經(jīng)有了很大進(jìn)步,從專家系統(tǒng)到基于統(tǒng)計的學(xué)習(xí),從支持向量機到神經(jīng)網(wǎng)絡(luò)深度學(xué)習(xí),每一步都帶領(lǐng)機器智能走向下一個階梯。
在 Google 資深科學(xué)家吳軍博士(數(shù)學(xué)之美,浪潮之巔作者),他提出當(dāng)前技術(shù)發(fā)展三個趨勢,第一,云計算和和移動互聯(lián)網(wǎng),這是正在進(jìn)行時;第二,機器智能,現(xiàn)在開始發(fā)生,但對社會的影響很多人還沒有意識到;第三,大數(shù)據(jù)和機器智能結(jié)合,這是未來時,一定會發(fā)生,有公司在做,但還沒有太形成規(guī)模。他認(rèn)為未來機器會控制 98%的人,而現(xiàn)在我們就要做個選擇,怎么成為剩下的 2%?
4、為什么大數(shù)據(jù)和機器智能結(jié)合的未來一定會到來?
其實在工業(yè)革命之前(1820 年),世界人均 GDP 在 1800 年前的兩三千年里基本沒有變化,而從 1820 年到 2001 年的 180 年里,世界人均 GDP 從原來的 667 美元增長到 6049 美元。由此足見,工業(yè)革命帶來的收入增長的確是翻天覆地的。這里面發(fā)生了什么,大家可以去思考一下。但人類的進(jìn)步并沒有停止或者說穩(wěn)步增長,在發(fā)明了電力,電腦,互聯(lián)網(wǎng),移動互聯(lián)網(wǎng),全球年 GDP 增長從萬分之 5 到 2%,信息也是在急劇增長,根據(jù)計算,最近兩年的信息量是之前 30 年的總和,最近 10 年是遠(yuǎn)超人類所有之前累計信息量之和。在計算機時代,有個著名的摩爾定律,就是說同樣成本每隔 18 個月晶體管數(shù)量會翻倍,反過來同樣數(shù)量晶體管成本會減半,這個規(guī)律已經(jīng)很好的 match 了最近 30 年的發(fā)展,并且可以衍生到很多類似的領(lǐng)域:存儲、功耗、帶寬、像素。
馮諾伊曼是 20 世紀(jì)最重要的數(shù)學(xué)家之一,在現(xiàn)代計算機、博弈論和核武器等諸多領(lǐng)域內(nèi)有杰出建樹的最偉大的科學(xué)全才之一。他提出(技術(shù))將會逼近人類歷史上的某種本質(zhì)的奇點,在那之后 全部人類行為都不可能以我們熟悉的面貌繼續(xù)存在。這就是著名的奇點理論。目前會越來越快指數(shù)性增長,美國未來學(xué)家 Ray Kurzweil 稱人類能夠在 2045 年實現(xiàn)數(shù)字化永生,他自己也創(chuàng)辦奇點大學(xué),相信隨著信息技術(shù)、無線網(wǎng)、生物、物理等領(lǐng)域的指數(shù)級增長,將在 2029 年實現(xiàn)人工智能,人的壽命也將會在未來 15 年得到大幅延長。
5、國外值得關(guān)注的大數(shù)據(jù)公司都有哪些?國內(nèi)又有哪些?
這是 2014 年總結(jié)的 Big Data 公司列表,我們大致可以分成基礎(chǔ)架構(gòu)和應(yīng)用,而底層都是會用到一些通用技術(shù),如 Hadoop,Mahout,HBase,Cassandra,我在下面也會涵蓋。我可以舉幾個例子,在分析這一塊,cloudera,hortonworks,mapr 作為 Hadoop 的三劍客,一些運維領(lǐng)域,mangodb,couchbase 都是 nosql 的代表,作為服務(wù)領(lǐng)域 AWS 和 Google BigQuery 劍拔弩張,在傳統(tǒng)數(shù)據(jù)庫,Oracle 收購了 MySQL,DB2 老牌銀行專用,Teradata 做了多年數(shù)據(jù)倉庫。上面的 Apps 更多,比如社交消費領(lǐng)域 Google, Amazon, Netflix, Twitter, 商業(yè)智能:SAP,GoodData,一些在廣告媒體領(lǐng)域:TURN,Rocketfuel,做智能運維 sumologic 等等。去年的新星 Databricks 伴隨著 Spark 的浪潮震撼 Hadoop 的生態(tài)系統(tǒng)。
對于迅速成長的中國市場,大公司也意味著大數(shù)據(jù),BAT 三家都是對大數(shù)據(jù)的投入也是不惜余力。
我 5 年前在百度的時候,就提出框計算的東東,最近兩年他們成立了硅谷研究院,挖來 Andrew Ng 作為首席科學(xué)家,研究項目就是百度大腦,在語音、圖片識別大幅提高精確度和召回率,最近還做了個無人自行車,非常有趣。騰訊作為最大的社交應(yīng)用對大數(shù)據(jù)也是情有獨鐘,自己研發(fā)了 C++ 平臺的海量存儲系統(tǒng)。淘寶去年雙十一主戰(zhàn)場,2 分鐘突破 10 億,交易額突破 571 億,背后是有很多故事,當(dāng)年在百度做 Pyramid(按 Google 三輛馬車打造的金字塔三層分布式系統(tǒng))的有志之士,繼續(xù)在 OceanBase 創(chuàng)造神話。而阿里云當(dāng)年備受爭議,馬云也懷疑是不是被王堅忽悠,最后經(jīng)歷了雙十一的洗禮證明了阿里云的靠譜。小米的雷軍對大數(shù)據(jù)也是寄托厚望,一方面這么多數(shù)據(jù)幾何級數(shù)增長,另一方面存儲帶寬都是巨大成本,沒價值就會破產(chǎn)。
6、Hadoop是現(xiàn)今最流行的大數(shù)據(jù)技術(shù),在它出現(xiàn)的當(dāng)時,是什么造成了Hadoop的流行?當(dāng)時Hadoop具有哪些設(shè)計上的優(yōu)勢?
看 Hadoop 從哪里開始的,不得不提 Google 的先進(jìn)性,在 10 多年前,Google 出了 3 篇 paper 論述分布式系統(tǒng)的做法,分別是 GFS, MapReduce, BigTable, 非常 NB 的系統(tǒng),但沒人見過,在工業(yè)界很多人癢癢的就想按其思想去仿作,當(dāng)時 Apache Nutch Lucene 的作者 Doug Cutting 也是其中之一,后來他們被 Yahoo 收購,專門成立 Team 去投入做,就是 Hadoop 的開始和大規(guī)模發(fā)展的地方,之后隨著 Yahoo 的牛人去了 Facebook, Google, 也有成立了 Cloudera, Hortonworks 等大數(shù)據(jù)公司,把 Hadoop 的實踐帶到各個硅谷公司。而 Google 還沒有停止,又出了新的三輛馬車,Pregel, Caffeine, Dremel, 后來又有很多步入后塵,開始新一輪開源大戰(zhàn)。
為啥 Hadoop 就比較適合做大數(shù)據(jù)呢?首先擴展很好,直接通過加節(jié)點就可以把系統(tǒng)能力提高,它有個重要思想是移動計算而不是移動數(shù)據(jù),因為數(shù)據(jù)的移動是很大的成本需要網(wǎng)絡(luò)帶寬。其次它提出的目標(biāo)就是利用廉價的普通計算機(硬盤),這樣雖然可能不穩(wěn)定(磁盤壞的幾率),但通過系統(tǒng)級別上的容錯和冗余達(dá)到高可靠性。并且非常靈活,可以使用各種 data,二進(jìn)制,文檔型,記錄型。使用各種形式(結(jié)構(gòu)化,半結(jié)構(gòu)化,非結(jié)構(gòu)化所謂的 schemaless),在按需計算上也是個技巧。
7、圍繞在Hadoop周圍的有哪些公司和產(chǎn)品?
提到 Hadoop 一般不會說某一個東西,而是指生態(tài)系統(tǒng),在這里面太多交互的組件了,涉及到 IO,處理,應(yīng)用,配置,工作流。在真正的工作中,當(dāng)幾個組件互相影響,你頭疼的維護(hù)才剛剛開始。我也簡單說幾個:Hadoop Core 就三個 HDFS,MapReduce,Common,在外圍有 NoSQL: Cassandra, HBase, 有 Facebook 開發(fā)的數(shù)據(jù)倉庫 Hive,有 Yahoo 主力研發(fā)的 Pig 工作流語言,有機器學(xué)習(xí)算法庫 Mahout,工作流管理軟件 Oozie,在很多分布式系統(tǒng)選擇 Master 中扮演重要角色的 Zookeeper。
8、能否用普通人都能理解的方式解釋一下Hadoop的工作原理?
我們先說 HDFS,所謂 Hadoop 的分布式文件系統(tǒng),它是能真正做到高強度容錯。并且根據(jù) locality 原理,對連續(xù)存儲做了優(yōu)化。簡單說就是分配大的數(shù)據(jù)塊,每次連續(xù)讀整數(shù)個。如果讓你自己來設(shè)計分布式文件系統(tǒng),在某機器掛掉還能正常訪問該怎么做?首先需要有個 master 作為目錄查找(就是 Namenode),那么數(shù)據(jù)節(jié)點是作為分割好一塊塊的,同一塊數(shù)據(jù)為了做備份不能放到同一個機器上,否則這臺機器掛了,你備份也同樣沒辦法找到。HDFS 用一種機架位感知的辦法,先把一份拷貝放入同機架上的機器,然后在拷貝一份到其他服務(wù)器,也許是不同數(shù)據(jù)中心的,這樣如果某個數(shù)據(jù)點壞了,就從另一個機架上調(diào)用,而同一個機架它們內(nèi)網(wǎng)連接是非??斓?,如果那個機器也壞了,只能從遠(yuǎn)程去獲取。這是一種辦法,現(xiàn)在還有基于 erasure code 本來是用在通信容錯領(lǐng)域的辦法,可以節(jié)約空間又達(dá)到容錯的目的,大家感興趣可以去查詢。
接著說 MapReduce,首先是個編程范式,它的思想是對批量處理的任務(wù),分成兩個階段,所謂的 Map 階段就是把數(shù)據(jù)生成 key, value pair, 再排序,中間有一步叫 shuffle,把同樣的 key 運輸?shù)酵粋€ reducer 上面去,而在 reducer 上,因為同樣 key 已經(jīng)確保在同一個上,就直接可以做聚合,算出一些 sum, 最后把結(jié)果輸出到 HDFS 上。對應(yīng)開發(fā)者來說,你需要做的就是編寫 Map 和 reduce 函數(shù),像中間的排序和 shuffle 網(wǎng)絡(luò)傳輸,容錯處理,框架已經(jīng)幫你做好了。
9、MapReduce模型本身也有一些問題?
第一:需要寫很多底層的代碼不夠高效,第二:所有的事情必須要轉(zhuǎn)化成兩個操作 Map/Reduce,這本身就很奇怪,也不能解決所有的情況。
10、Spark從何而來?Spark相比于Hadoop MapReduce設(shè)計上有什么樣的優(yōu)勢?
其實 Spark 出現(xiàn)就是為了解決上面的問題。先說一些 Spark 的起源。發(fā)自 2010 年 Berkeley AMPLab,發(fā)表在 hotcloud 是一個從學(xué)術(shù)界到工業(yè)界的成功典范,也吸引了頂級 VC:Andreessen Horowitz 的 注資. 在 2013 年,這些大牛(Berkeley 系主任,MIT 最年輕的助理教授)從 Berkeley AMPLab 出去成立了 Databricks,引無數(shù) Hadoop 大佬盡折腰,它是用函數(shù)式語言 Scala 編寫,Spark 簡單說就是內(nèi)存計算(包含迭代式計算,DAG 計算, 流式計算 )框架,之前 MapReduce 因效率低下大家經(jīng)常嘲笑,而 Spark 的出現(xiàn)讓大家很清新。 Reynod 作為 Spark 核心開發(fā)者, 介紹 Spark 性能超 Hadoop 百倍,算法實現(xiàn)僅有其 1/10 或 1/100。在去年的 Sort benchmark 上,Spark 用了 23min 跑完了 100TB 的排序,刷新了之前 Hadoop 保持的世界紀(jì)錄。
11、如果想從事大數(shù)據(jù)方面的工作,是否可以推薦一些有效的學(xué)習(xí)方法?有哪些推薦的書籍?
我也有一些建議,首先還是打好基礎(chǔ),Hadoop 雖然是火熱,但它的基礎(chǔ)原理都是書本上很多年的積累,像算法導(dǎo)論,Unix 設(shè)計哲學(xué),數(shù)據(jù)庫原理,深入理解計算機原理,Java 設(shè)計模式,一些重量級的書可以參考。Hadoop 最經(jīng)典的 the definitive guide, 我在知乎上也有分享。
其次是選擇目標(biāo),如果你像做數(shù)據(jù)科學(xué)家,我可以推薦coursera的data science課程,通俗易懂。學(xué)習(xí) Hive,Pig 這些基本工具,如果做應(yīng)用層,主要是把 Hadoop 的一些工作流要熟悉,包括一些基本調(diào)優(yōu),如果是想做架構(gòu),除了能搭建集群,對各個基礎(chǔ)軟件服務(wù)很了解,還要理解計算機的瓶頸和負(fù)載管理,Linux 的一些性能工具。最后還是要多加練習(xí),大數(shù)據(jù)本身就是靠實踐的,你可以先按 API 寫書上的例子,能夠先調(diào)試成功,在下面就是多積累,當(dāng)遇到相似的問題能找到對應(yīng)的經(jīng)典模式,再進(jìn)一步就是實際問題,也許周邊誰也沒遇到,你需要些靈感和網(wǎng)上問問題的技巧,然后根據(jù)實際情況作出最佳選擇。
12、與大數(shù)據(jù)技術(shù)關(guān)系最緊密的就是云計算,您曾在Amazon 云計算部門工作過,能否簡單介紹一下亞馬遜的Redshift框架嗎?
我在 Amazon 云計算部門工作過,所以還是比較了解 AWS,總體上成熟度很高,有大量 startup 是基于其開發(fā),比如有名的 Netflix,Pinterest,Coursera。Amazon 還是不斷創(chuàng)新,每年召開 reInvent 大會推廣新的云產(chǎn)品和分享成功案例,在這里面我隨便說幾個:像 S3 是簡單面向?qū)ο蟮拇鎯?,DynamoDB 是對關(guān)系型數(shù)據(jù)庫的補充,Glacier 對冷數(shù)據(jù)做歸檔處理,Elastic MapReduce 直接對 MapReduce 做打包提供計算服務(wù),EC2 就是基礎(chǔ)的虛擬主機,Data Pipeline 會提供圖形化界面直接串聯(lián)工作任務(wù)。
Redshift,它是一種(massively parallel computer)架構(gòu),是非常方便的數(shù)據(jù)倉庫解決方案,就是 SQL 接口,跟各個云服務(wù)無縫連接,最大特點就是快,在 TB 到 PB 級別非常好的性能,我在工作中也是直接使用,它還支持不同的硬件平臺,如果想速度更快,可以使用 SSD 的,當(dāng)然支持容量就小些。
13、Linkedin都采用了哪些大數(shù)據(jù)開源技術(shù)?
在 Linkedin,有很多數(shù)據(jù)產(chǎn)品,比如 People you may like, job you may be interested, 你的用戶訪問來源,甚至你的 career path 都可以挖掘出來。那么在 Linkedin 也是大量用到開源技術(shù),我這里就說一個最成功的 Kafka,它是一個分布式的消息隊列,可以用在 tracking,機器內(nèi)部 metrics,數(shù)據(jù)傳輸。數(shù)據(jù)在前端后端會經(jīng)過不同的存儲或者平臺,每個平臺都有自己的格式,如果沒有一個 unified log,會出現(xiàn)災(zāi)難型的 O(m*n) 的數(shù)據(jù)對接復(fù)雜度,如果你設(shè)定的格式一旦發(fā)生變化,也是要修改所有相關(guān)的。所以這里提出的中間橋梁就是 Kafka,大家約定用一個格式作為傳輸標(biāo)準(zhǔn),然后在接受端可以任意定制你想要的數(shù)據(jù)源(topics), 最后實現(xiàn)的線性的 O(m+n) 的復(fù)雜度。對應(yīng)的設(shè)計細(xì)節(jié),還是要參考設(shè)計文檔。這里面主要作者 Jay Kreps,Rao Jun 出來成立了 Kafka 作為獨立發(fā)展的公司。
在 Linkedin,Hadoop 作為批處理的主力,大量應(yīng)用在各個產(chǎn)品線上,比如廣告組。我們一方面需要去做一些靈活的查詢分析廣告主的匹配,廣告預(yù)測和實際效果,另外在報表生成方面也是 Hadoop 作為支持。如果你想去面試 Linkedin 后端組,我建議大家去把 Hive, Pig, Azkaban(數(shù)據(jù)流的管理軟件),Avro 數(shù)據(jù)定義格式,Kafka,Voldemort 都去看一些設(shè)計理念,Linkedin 有專門的開源社區(qū),也是 build 自己的技術(shù)品牌。
14、談一談Coursera在大數(shù)據(jù)架構(gòu)方面和其他硅谷創(chuàng)業(yè)公司相比有什么特點?是什么原因和技術(shù)取向造成了這些特點?
Coursera 是一個有使命驅(qū)動的公司,大家不是為了追求技術(shù)的極致,而是為了服務(wù)好老師,同學(xué),解決他們的痛點,分享他們的成功。這點是跟其他技術(shù)公司最大的區(qū)別。從一方面來說,現(xiàn)在還是早期積累階段,大規(guī)模計算還沒有來臨,我們只有積極學(xué)習(xí),適應(yīng)變化才能保持創(chuàng)業(yè)公司的高速成長。
Coursera 作為創(chuàng)業(yè)公司,非常想保持敏捷和高效。從技術(shù)上來說,所有的都是在基于 AWS 開發(fā),可以想像隨意啟動云端服務(wù),做一些實驗。我們大致分成產(chǎn)品組,架構(gòu)組,和數(shù)據(jù)分析組。我把所有用到的開發(fā)技術(shù)都列在上面。因為公司比較新,所以沒有什么歷史遺留遷移的問題。大家大膽的使用 Scala 作為主要編程語言,采用 Python 作為腳本控制,比如產(chǎn)品組就是提供的課程產(chǎn)品,里面大量使用 Play Framework,Javascript 的 backbone 作為控制中樞。而架構(gòu)組主要是維護(hù)底層存儲,通用服務(wù),性能和穩(wěn)定性。
我在的數(shù)據(jù)組由 10 多人構(gòu)成,一部分是對商業(yè)產(chǎn)品,核心增長指標(biāo)做監(jiān)控,挖掘和改進(jìn)。一部分是搭建數(shù)據(jù)倉庫完善跟各個部門的無縫數(shù)據(jù)流動,也用到很多技術(shù)例如使用 Scalding 編寫 Hadoop MapReduce 程序,也有人做 AB testing 框架, 推薦系統(tǒng),盡可能用最少人力做影響力的事情。其實除了開源世界,我們也積極使用第三方的產(chǎn)品,比如 sumologic 做日志錯誤分析,Redshift 作為大數(shù)據(jù)分析平臺,Slack 做內(nèi)部通訊。而所有的這些就是想解放生產(chǎn)力,把重心放到用戶體驗,產(chǎn)品開發(fā)和迭代上去。
相關(guān)閱讀