Your Delegation Methods Might Not Be Called In Swift 3

One of the most obvious changes in Swift 3 is its naming convention. Apple also renamed lots of methods when releasing Xcode 8.

To make new Swift APIs to be compatible with existing Objective-C APIs, Swift compiler converts Swift 3 methods to corresponding Objective-C selectors, but sometimes such conversion does not happen.

The worst case is, you implement a delegation method, but it is never be called, and you do not know why.

Continue reading

Posted in Code, iOS, Mac | Tagged , , , , , | Leave a comment

Upgrade to Xcode 8

Xcode 8 was out along with iOS 10, watchOS 3, tvOS 10 and macOS 10.12 Sierra last month. We spent a couple of days to upgrade our development environment and build machines of our continuous integration system to Xcode 8, just like many other developers do.

It was not as easy as just to click on the “Upgrade” button in Mac App Store. Things might be broken and need to be fixed. Upgrade is always somehow painful, but a yearly routine.

On the other hand, Apple added several additional validations that validates your new uploaded builds on iTunes Connect. If you cannot pass these validations, your builds will be invalid and you cannot complete app submission.

You may want to read our experience before upgrading to Xcode 8. We also suggest you to upload some new builds recently to see if you can pass these new validations.

Continue reading

Posted in Code, iOS, Mac | Tagged , , , , | Leave a comment

KKBOX 的 WWDC 2016 讀書會影片

KKBOX 今年也舉辦了 WWDC 影片的讀書會,我們挑選了一些我們比較有興趣的主題,在公司內分享。您可以從下方找到我們的讀書會錄影,以及每場讀書會對應的 WWDC 官方影片。

Continue reading

Posted in Code, iOS, Mac | Tagged , , , | 2 Comments

KKBOX 的音樂檔案儲存技術

前情提要

時間拉回到 2013 年,KKBOX 在當年的 COSCUP 曾介紹過如何使用 MogileFS 這套 DFS(Distributed file systems),儲存其音樂服務的各種檔案。

Slide: 全台灣最宅的科科科技如何利用 MogileFS 儲存數千萬個音樂檔案
錄影:

現在的狀況

時隔三年,雖然各間雲端服務商都有提供可靠的儲存技術可以使用,但 KKBOX 還是繼續使用原本的 MogileFS 來儲存大量的音樂檔案,隨著串接的唱片及版權公司逐年增加,音檔數量一直不斷成長。2013 年突破 1,000 萬首,2016/8/1 最新公布的數字(賀!KKBOX曲庫國際級水準 擴增至超過3000萬首歌!)是 3,000 萬首,這是取得授權上架的數字,實際上 KKBOX 後端的曲庫數量是超過這個數字。

MogileFS 規模

  • 儲存伺服器超過 75 台。
  • 總硬碟超過 2,300 顆。
  • 總儲存空間超過 10 PB
  • 使用 8 個機櫃。

Metadata Database

儲存檔案 Metadata 的 Database 技術沒有變化,依然使用 MySQL 搭配 HeartbeatDRBD 達到 High Availability

Tracker

Tracker 原本利用部分 storage server 分擔 replicate 工作,但遇到效能問題,所以改使用 4 台 dedicated 的伺服器負責 Tracker 角色。

每台 Tracker 都是兩張 1Gbps NIC 設定 802.3ad 模式的 Linux Bonding。

Storage Server 硬體規格

  • 系統碟用 2 顆 500GB SATA 硬碟設定成 RAID 1
  • 36 顆 6TB WD 紅標硬碟儲存 MogileFS 檔案。
  • 兩張 1Gbps NIC 利用 Linux Bonding Driver 設定標準 802.3ad 模式 LACP。
  • 一台 storage server 有 200TB 的空間。
  • 一機櫃 10 台 storage server 能提供 2PB 空間。

網路架構

  • tracker 和 storage server 都是兩條 1Gbps LACP 接到 Top-of-Rack 的 L2 Switch。
  • 每台 Top-of-Rack 都是兩條 10Gbps 光纖 LACP 到資料中心的 Core Router。

三年來的使用心得

優點

  • 成本相較企業級儲存解決方案(NetApp, EMC, …)低。
  • 容易擴充,KKBOX 從最一開始的 3 台 data node 逐漸成長到現在的超過 75 台。
  • 直接使用 NginxWebDAV module 包裝磁碟讀寫行為,能提供很高的效能,實際使用上能輕易的吃滿 storage server 的 2Gbps 頻寬。

缺點

  • 沒有自動 rebalance 的功能,在擴充容量後需要自行下指令 rebalance,讓各台間的磁碟使用量一致。
  • MogileFS 策略上會優先往磁碟使用量低的 device 寫入新資料,在平常的寫入量就不低的情況下,新增的 data node 數量太少,就容易有磁碟 I/O 及網路傳輸瓶頸。
Posted in Uncategorized | 3 Comments

Open source our Marco Polo DNS Daemon

Today we open source Marco Polo DNS Daemon.

KKBOX provides music services over 6 regions, including Taiwan, Hong Kong, Singapore, Malaysia, Japan, and Thailand. We deploy technologies to improve performance and user experience. We build serveral data centers in Taiwan, and partner with EdgeCast, Akamai, and CloudFront to make sure our users get best performance.

We implemented algorithms in API-level to select best server or CDN vendor for delivering audio data. API-level algorithms gave us flexibility to dispatch clients.

However, there is still something we cannot control in API-level, like image service. We want to dispatch clients to different data centers or CDN vendors in DNS-level.

Marco Polo DNS Daemon is a DNS server written by Perl, which can return different CNAME results based on client’s DNS resolver IP address and edns-client-subnet information. This allows us to control traffic by country code and AS number.

For example, we want to use country code and expect it returns a CNAME record to test.kkcube.com:

$ dig test.kkcube.com.country.mp.kkcube.com @8.8.8.8

And it returns:

;; ANSWER SECTION:
test.kkcube.com.country.mp.kkcube.com. 20 IN CNAME TW.test.kkcube.com.

Which is because I am in Taiwan. And if you want to use AS number:

$ dig test.kkcube.com.asn.mp.kkcube.com @8.8.8.8

Then it will return:

;; ANSWER SECTION:
test.kkcube.com.asn.mp.kkcube.com. 20 IN CNAME  3462.test.kkcube.com.

Which AS3462 belongs to my ISP, HiNet. Now you can setup test.kfs.io CNAME to test.kkcube.com.country.mp.kkcube.com, and setup another DNS record for TW.test.kkcube.com to accelerate Taiwan’s clients.

Please feel free to give us feedback in GitHub.

Posted in DNS | Tagged , , , , , , , , , , , , , | Leave a comment

Android at Google I/O 2016 上集

Google I/O 2016 結束一段時間了,今年總共放出影片 182 部,其中和 Android 相關的影片有 65 部,為了要快速了解今年本部門的守備範圍內有哪些新東西,大家分著把影片看過一輪後再與彼此分享,順便各自寫了些摘要分享出來給國內的 App 開發者們。

Android at Google I/O 2016 中集
Android at Google I/O 2016 下集

Continue reading

Posted in Uncategorized | 2 Comments

Android at Google I/O 2016 中集

Google I/O 2016 結束一段時間了,今年總共放出影片 182 部,其中和 Android 相關的影片有 65 部,為了要快速了解今年本部門的守備範圍內有哪些新東西,大家分著把影片看過一輪後再與彼此分享,順便各自寫了些摘要分享出來給國內的 App 開發者們。

Android at Google I/O 2016 上集
Android at Google I/O 2016 下集

Continue reading

Posted in Uncategorized | 1 Comment

Android at Google I/O 2016 下集

Google I/O 2016 結束一段時間了,今年總共放出影片 182 部,其中和 Android 相關的影片有 65 部,為了要快速了解今年本部門的守備範圍內有哪些新東西,大家分著把影片看過一輪後再與彼此分享,順便各自寫了些摘要分享出來給國內的 App 開發者們。

Android at Google I/O 2016 上集
Android at Google I/O 2016 中集

Continue reading

Posted in Uncategorized | 1 Comment

KKBOX for UWP (10.0.22.0)

<KKBOX for UWP 新體驗新方向> 介紹 KKBOX 在 Windows 10 新版本的功能介紹,不知道大家是否已經安裝且享受它了呢?

團隊持續努力開發與修正新的版本,今天要介紹 10.0.22.0 版本的相關內容。

  • 新增播放定時器功能

設定自動關閉音樂的時間,讓您聽著最愛的音樂入睡,不用擔心過度耗電的問題!Desktop/Mobile 均支援。

sleep_timer

 

  • 新增在我的音樂庫內搜尋歌曲

相信您聽過很多讓您回味無窮的歌曲,但是不小心忘記放在我的音樂庫裡面的哪一個歌單了?沒有問題,新增了讓您可搜尋我的音樂庫,歌曲不再忘記在哪裡。
search_mylibrary_1

 

  • Desktop 新增整頁模式或是分割模式顯示的按鈕

根據用戶的回饋: 希望在 Desktop 模式可以保持跟 Mobile 一樣的體驗。新增了讓您在Desktop 自行決定享受體驗的方式。

  • 分割模式

split_view

  • 整頁模式

single_view

  • 維持瀏覽記錄

過去只要您切換不同的 tabs (ex: 我的音樂庫,綫上精選,電臺…) 目前瀏覽的記錄就消失,無法使用返回鍵看到剛才的瀏覽的內容,造成使用上很不便利。該版本修正它,讓您可以悠遊的瀏覽與返回想要的內容。
history

 

  • 調整線上搜尋的主頁

過去進入線上搜尋只會顯示熱門關鍵字,無法有效地幫助您找到想要的歌曲。因此,調整爲預設顯示適合您的搜尋內容。
search

 

  • 增加聊天室特別功能

跟隨喜歡的台長或是藝人時,聊天室裏面總是很多看不完的訊息,想要直接看台長或是清掉現在的訊息。沒問題,現在提供給您。
dj

如果您自己是開台的台長可在聊天室裡面 tag 對象,針對他發言哦。
dj2
一起開台來變成名人且得到更多新功能吧!

 

  • 給予我們評分

KKBOX for UWP 的版本需要您的支援,如果在使用過程裡面跳出請求您幫忙評分時,要記得幫忙到 Store 裡面給予評分哦。好的壞的都希望您提供寶貴的意見。感謝!
wp_ss_20160621_0001

 

修正 Bugs 與 UI/UX 優化:

  • 調整效能
  • 修正隨機播放無法使用
  • 修正下載後的歌曲無法播放,點擊離線歌曲播放跟歌詞不一致
  • 優化在手機版本的橫向顯示
  • 莫明閃退
  • 修正歌曲同步失敗問題

 

以上是這次 10.0.22.0 釋出的相關功能與修正。錯誤修正是我們的義務,過程造成所有用戶的不便,真的深表歉意。我們會加強各方面的檢查。

想知道更多功能與體驗新版本的魅力嗎?

到【Get it on Windows 10】下載吧! 一起享受 KKBOX 在 Windows 10 上的新體驗。

如果您的設備還不是 Windows 10 請走這邊  [Desktop 升級] 或 [Mobile 升級]。

KKBOX .NET Team 將持續開發更穩定與接近其他平臺所支援的功能,讓喜愛 KKBOX 與熟悉 Windows 的用戶都能有享受更好的音樂生活。

KKBOX 需要您的支援,Windows 10 / Windows 10 Mobile 更需要您的認同。

如果有任何問題歡迎寫信到  uwp-dev-intl@kkbox.com,非常感謝。

Posted in Windows | Tagged , , | Leave a comment

在 KKBOX 中使用 Python 的經驗

KKStream 的工程師 Drake Guan 上個月在台北的 Python 聚會—Taipei.py—當中,分享了 KKBOX 過去幾年如何導入 Python 程式語言的經驗。您可以在 slide share 網站中找到這份分享的投影片。

Posted in Events, Uncategorized | Tagged , | Leave a comment