跳到主要內容

你所不知道的 foodpanda

 

image

2020 左右,隨著新冠疫情流行,台灣也逐漸流行起一股懶人旋風。懶懶躺在沙發上,動動手指滑滑螢幕,生鮮或美食就能快速又安全地由可愛的粉紅色熊貓外送員送達您門口。多數人知道 foodpanda 是台灣最大生鮮美食外送平台,也不少人知道 foodpanda 在台灣不斷擴張業務範圍,但 foodpanda 也有許多台灣科技圈所不知道的事。

例如,foodpanda 其實並非台灣本土廠商,也非只專注在亞洲區域。foodpanda 隸屬於德國 Delivery Hero 集團,業務橫跨歐洲、亞洲、美洲及北非,旗下更有十多個生鮮美食外送品牌。除此之外,foodpanda 於 2021 年時也在台灣正式成立全球第三個 Tech Hub。做為四大產品 RD 研發中心之一,台灣與德國柏林、新加坡及土耳其伊斯坦堡的人才緊密地合作,專注於打造 end-to-end 的顧客體驗。諸如月費方案 Panda Pro、外帶自取、餐廳內用 (目前仍未在台灣上市) 等功能。期待能持續吸收優秀人才、與其它三個跨國研發中心合作,打造後疫情時代新的成長引擎。

事實上,台灣的 foodpanda 研發團隊並不僅止於打造台灣本土產品。反之,我們所建立的平台及產品,已成功於近 20 個國家、10 個品牌上市。要在快速的步調下,打造持續進步且符合不同國家文化客戶需求的產品,我們依靠的是

  1. 專案團隊成員一條龍組合
    從 Product Manager、Engineering Manager、iOS/Android/Web/Backend developer、QA、Product Designer、Product Analyst 全都在同一個 product line squad。讓相同產品的團隊成員能緊密合作、第一手快速了解市場、滿足需求。
    image

  2. 國際專業團隊緊密合作
    foodpanda 的 iOS/Android/Web/Backend 等專業工程師,都各自設有其跨 squad 的 chapter 組織。讓工程師能在專案團隊以外,有跨國跨團隊專業能力交流的機會。在 chapter 中,相同技術域領的專家們,會一起制定共同的實作標準、分享在專案中遇到類似的挑戰,並且找出可能的應對方案。因此,在 foodpanda 我們不只打產品專案團隊的速度戰、還打整個集團的整合能力團體戰,讓德國、新加坡、台灣、伊斯坦堡的工程師們用最有效率的方式縝密整合、攻城略地。
    image

  3. 關注個人成長
    foodpanda 的面試關卡極具挑戰性,能夠通過面試進到 foodpanda 的工程師通常都具備獨立作業的能力、有優秀的工程技術、以及良好的溝通和英文能力。除此之外,由於工作性質需開發跨國上市產品、密切與其它國家工程師合作,我們期待能幫助每位成員都能持續成長以面對接踵而來的挑戰。制度設計上的每週 1:1 和主管聊工作中的規劃與挑戰、甚至是中長期的生涯成長規劃,以及各式各樣的學習機會、跨組織連結創造個人及團隊成績,都是 foodpanda 成長文化中不可或缺的一部份。

  4. 致力於建立尊重多元意見的開放團隊
    在 foodpanda 工作,每天都需要與不同國籍、不同專業背景、不同文化的同事合作。我們不斷在組織設計、溝通制度及核心文化上進行精進,期許在 foodpanda 中的每個成員,都能充分表達自己的意見、有了解彼此的管道,更重要的是能彼此包容創造出 1 加 1 大於 2 的效果。
    image

Backend Solution 簡要分享

foodpanda 平台相關集團的品牌在全球多個國家運行,同時,我們的訂單數量也每年高速在增長,至今每月已有數千萬張訂單。為了同時面對高流量的挑戰,且保持系統的可擴充性 (Scalability),我們主要使用 Golang 建置完善的微服務架構 (Microservices),搭配 AWS 服務 (SNS/SQS, DynamoDB 等) 和開源的部署工具 (Kubernetes, Terraform) 來應對這些挑戰。
後端平常再開發時也很常會使用到開源軟體以增進開發效率。舉例來說當我們的微服務想要加入斷路器模式 (Circuit Breaker Pattern) 時,就有使用到 Netflix 的 Hystrix 套件。

Web Frontend Solution 簡要分享

微服務 (Microservices) 對大家來說一定不陌生,隨著容器化技術的成熟,我們可以將原本複雜的龐大架構根據商業邏輯拆分為多個服務。除了有獨立維護的方便性外,擴展和部屬也不會受其他服務限制。而在前端的世界裡,也有著所謂 microfrontend 的架構。

我們使用 react 將視覺組件按組織需求分成不同區塊,讓不同團隊間能夠一起協作。組織上除了解決業務問題,也在跨組織間有密切跨國跨團隊的合作,例如技術債的更新。除了日常任務,我們也會透過 cypress 等自動測試功能導入開發流程,讓新功能引入時,能夠儘快的知道有沒有問題產生。我們也鼓勵大家互相審查交付的程式碼,每次將程式碼推上 github 後,除了進行一連串的單元測試,風格檢查,還會要求跨團隊的的交互審查。這些審查除了幫助我們避免實作的問題之外,也讓不同團隊能夠即時的交流。

以 foodpanda 網頁為例,無論是餐廳列表、菜單,亦或是結帳頁,均是由一個獨立的 squad 來負責開發及維護,並且能做到指定國家/區域的部署。而台灣的外帶自取 squad、餐廳內用 squad 等則負責 end-to-end 組合各獨立元件並添加業務所需要的變化。

這也是 foodpanda 如何在龐大的 codebase 與組織架構下,能順暢地進行跨國跨團隊多人協作的原因。搭配完整的 CI/CD 流程與 Github Actions 快速產生出各個 microfrontend 的 Docker image,也許在你閱讀這篇文章時,我們德國的同事們也正在發佈新版本呢。

除此之外,我們也實作了一套通用的 feature flag system。有 iOS/Android 開發經驗的人都知道,審查過程是如此繁複且冗長,萬一不小心送出了有問題的代碼,很容易造成大災難。

因此有經驗的企業在功能設計都會用 feature flag 來控制功能的啟閉,甚至提供商業維運團隊以A/B Test 進行市場實驗,找出最佳功能、業務組合。而我們的 flag system 除了有直覺的介面外,還能夠設定許多條件,如平台、版本、國家、甚至是特定帳號。重要的是,這些都不必由工程師親自操作,非技術人員也能無礙的進行操作與設定,這也是為什麼我們能簡單的在多個國家多個品牌下實現客製化的原因之一。

給期待挑戰、與世界各地高手們併肩作戰的你

目前 foodpanda Taiwan tech hub,在 squad 中需要的每個角色諸如 QA、Product Analyst、Product Designer、iOS/Android/Backend (golang)/Frontend (react) engineer、Product Manager、Engineering Manager 都有在徵才喔!

如果想了解更多,請參考職缺網頁

Post Credit : Andrew Wu, Derek Tzeng, Hector Yang, Nelson Lin (依字母排序)

留言

這個網誌中的熱門文章

利用 Jitsi 建立個人化的視訊會議平台

  近期因為疫情的關係,越來越多企業開始實施分流或在家工作,視訊會議的需求也日益增加。 在商用解決方案選擇上,有不少企業會選擇知名品牌的產品,例如  Cisco Webex 、 Google Meet 、 Microsoft Teams 、 Zoom  都是很不錯的方案。 KKBOX 集團在去年便試行及做好充分 work from home 的準備,今年五月也因應疫情升溫,全員 work from home 至今兩個月有餘。 當然,取之 Open Source,也要對社群有些貢獻。在這一屆 COSCUP,我們要來介紹 Open Source 圈中也很知名,效果也很不錯的一套視訊會議平台: Jitsi 。 除了基本的視訊會議功能外,在最後我們也會示範如何透過 Jitsi 畫面輸出到 YouTube/Twitch 或其他支援 RTMP 的平台進行直播。 由於篇幅有限,且 Jitsi 可以調整的細節非常多。今天我們純粹很快速的示範,如何簡單的建置出一個 Jitsi 環境,並提供單場會議內容錄影或直播。 Jitsi 的文件可以在 這裡 找到。 今天透過 AWS Lightsail 的 $10/month instance(1 core CPU + 2GB RAM + 60GB SSD),作業系統則是 Ubuntu 20.04 來示範。當然,使用其他 VPS 亦可,大同小異,這邊直接跳過 VPS 相關的建置過程。 *firewall 相關資料參考 這裡 及 這裡 。 針對系統做必要的更新 基本的 apt repository 更新: $ sudo apt update 因為後面要示範的會議錄影及直播需要使用 ALSA loopback device,如果是 EC2 or Lightsail 則需要額外安裝 generic kernel( 註 ): $ sudo apt install linux-image-generic linux-headers-generic linux-image-extra- virtual 接著做系統套件們的更新: $ sudo apt dist-upgrade $ sudo apt autoremove 如果是 AWS EC2 or Lightsail 則需要另外再將預設的 AWS optimized kernel...

鑽石級贊助商 - KKBOX 帶你打造具備 NLP 功能的 Telegram Bot (上)

打造具備 NLP 功能的 Telegram Bot(上) 最近因為一些契機學了 Python 3,用它做了一個 Telegram Bot ( GitHub 連結 ),裡面用到 NLP Service,用上下兩篇文章記錄一下實作過程還有眉角。上篇首先教大家如何做一個最基本的回聲 Chatbot,接下來我們可以透過 NLP 服務,讓 Chatbot 根據使用者不同的訊息做回答,這樣就變成更加人性化的聊天機器人囉! 使用的工具及服務: Python 3 (for develop) pipenv (for dependency management) OLAMI (for NLP) ngrok (for testing) Step 1. Creating new bot Telegram 很有趣的地方在於,與其他通訊軟體(Line、Messenger)相比,開發者管理 Bot 的方式也是透過官方提供的一位 Bot 在處理的,它叫做 BotFather (眾 Bot 之父 XD)。如果已經有 Telegram 帳號,只要加 BotFather 為好友,就可以開始管理你的 Bot。 加入 BotFather 好友後,它會親切地問候,並告訴你他能為你提供什麼服務。 I can help you create and manage Telegram bots. If you're new to the Bot API, please see the manual ([https://core.telegram.org/bots](https://core.telegram.org/bots)). You can control me by sending these commands: /newbot - create a new bot /mybots - edit your bots [beta] /mygames - edit your games ([https://core.telegram.org/bots/games](https://core.telegram.org/bots/games)) [beta] Edit Bots /setname - change a bot's name /setdescr...

實戰 Vibe Coding:利用 Amazon Q Developer CLI 打造經典平台跳躍遊戲

本篇文章將介紹如何透過 Amazon Q Developer CLI 建構一款完整的 2D 平台跳躍遊戲,從初始生成、功能增強,到最終打造出具備多關卡、多樣互動元素的遊戲體驗。特別的是,過程中開發者並未撰寫任何一行程式碼,僅透過自然語言指令與 CLI 對話完成所有工作,實踐「Vibe Coding」( 氛圍編碼 )。 本文作者為 Haowen Huang, AWS Senior Developer Advocate. 擁有 20 年以上電信、互聯網以及雲端運算等行業架構設計、技術及創業管理等豐富經驗,曾任職於 Microsoft、Sun Microsystems 等企業,專注為遊戲、電商、媒體和廣告等企業客戶提供 AI/ML、數據分析和企業數字化轉型等解決方案諮詢服務。 引言 本篇文章 ( English Version ) 將介紹如何使用 Amazon Q Developer CLI ,以 無需撰寫任何程式碼 的方式,打造一款經典的 2D 平台跳躍遊戲。透過「Vibe Coding」( 氛圍編碼 ) 的開發流程,開發者可以藉由簡單的語言提示詞 (prompt),逐步完成從遊戲雛型、功能擴充到完整關卡設計的開發流程。 整體開發流程將分為三個步驟: 1. 生成遊戲雛型 2. 功能擴充強化與畫面調整 3. 導入參考架構建立完整遊戲 環境建置 使用者需先安裝並設定 Amazon Q Developer CLI 。對於 macOS 使用者,可透過下列步驟完成安裝: 下載並安裝 Amazon Q Developer CLI 登入 Builder ID 完成認證 開啟終端機控制與無障礙設定 執行 q doctor 指令檢查 Amazon Q Developer CLI 是否安裝成功: 遊戲開發方面,建議使用 Python 語言與 Pygame 套件,可透過下列指令完成安裝;Pygame 提供以下功能支援: 畫面與動畫渲染 音效播放 鍵盤與搖桿輸入控制 物理模擬與碰撞偵測 多種媒體格式支援(圖片與音效) $ q doctor $ pip install pygame 第一步驟:初步生成遊戲雛型 透過簡單的一句 prompt,Amazon Q Developer CLI 結合 Pyg...