Google Android 採用 Apache License: 為什麼不是 GPL?

jollen 發表於 December 2, 2007 7:43 PM

Google 讓基於 Android 技術平臺的「應用程式」採用 [Apache License, Version 2] 的授權條款。許多 Free & Open Source Software(FOSS)採取 GPL 的授權條款,目前 OpenMoko 的架構,也都是選用基於 GPL 授權條款的 FOSS。

Android 與 OpenMoko 一個是開放手機平臺,另一個則是開放源碼手機平臺;前幾日對二個平臺做了差異比較,並且製作了一份 [OpenMoko vs. Android 主要差異比較表],可透過此表約略了解二個手機平臺之間的不同。

為什麼 Android 的應用程式要採取 Apache License 的授權方式?由 [Apache Software Foundation] 所發展的軟體,也都改採 Apache License 授權的故事來看,我想 Android 平臺的應用程式選擇 Apache License 的授權條款,也是很合理的。這要由 Apache License 與 GPL 之間的二個大差異講起。

第一、GPL 要求程式碼在重新散佈或修改時,必須提供原始程式碼(source code),並且也要基於 GPL 條款進行授權。因此,我們無法由原始授權者取得 GPL 軟體後,就無法再做「再授權」的動作。Apache License 則不然。如果軟體是基於 Apache License 授權,我們在重新散佈或進行程式碼修改時,就不會被要求必須要提供原始程式碼;同時,Apache License 授權也允許他人對軟體做「再授權」的動作。

第二、若是程式包含專利技術,使用 Apache License 時,表示授權者願意將程式的專利技術授權出來(Patent License)。但是,GPL 授權則不允許專利授權,因此在某些情況下,使用 GPL 授權的軟體可能會有侵害專利權的問題。

另外,Apache License 也對商標(trademarks)做保護,「不」允許他人使用原始授權人的 trademark、product name 與 service mark,除非是基於「合理」用途,並且附上 Apache License 的 NOTICE 聲明檔案。在 Android 的 SDK 裡,隨處可見 NOTICE 聲明檔。

Android vs. OpenMoko

Android 的授權方式,以及 OHA 的成立,代表著 Google 對未來手機市場的策略將會是一個建構舞台者的角色。Android 的出現對 OpenMoko 是否構成威脅,我倒覺得不必將 Android 當成是 OpenMoko 的假想敵,因為OpenMoko 未來潛在的競爭對手,恐怕不是 Android,而是使用者。走好自己路,是目前比較穩健的做法。

對開放或開源的手機平臺來說,最大的受益者是開發者以及使用者。就現況而言,顯然開發者對 Android 還沒有產生太大的興趣,OpenMoko 在開發者這個族群做得還算不錯。不過,OpenMoko 要能吸引真正使用者,還有努力的空間,所以 OpenMoko 真正要搞定的應該是使用者,倒不必太在意 Android 對他的影響。

至少就開發者族群來講,Android 還在起步階段;Google 現階段也很努力地在經營開發者族群。開發者的確是開放手機業者的兵家必爭之地。當然,最後還是必須在使用者族群裡分出高下。

總結來看,目前 Android 還沒有一個真正的商業模式。Terrence Russell 在他的 blog [Google: Android Has No Built-in Business Model] 提到,Android 的主要開發者之一 Richard Miner 告訴他:"For Android, there is no built-in business model"。至少就我目前的觀察來說,我是相信這個說法的。

也別忘記,Google 總是喜歡做實驗,任何新的 Google 服務都要在 Lab 裡育成,也會被掛上 Lab 的 logo。Android 是 Google 的新服務,或許現在他還是個「Android Lab」,只是沒有被掛上 Lab 字眼。Google 正在對開放手機平臺做大規模的實驗。

Jollen's Blog 使用 Github issues 與讀者交流討論。請點擊上方的文章專屬 issue,或 open a new issue

您可透過電子郵件 jollen@jollen.org,或是 Linkedin 與我連絡。更歡迎使用微信,請搜尋 WeChat ID:jollentw