1飞主、解決Loading JS bundle from (null)問(wèn)題
今天在新項(xiàng)目上集成codepush趴乡,按照教程iOS端集成代碼如下:
#ifdef DEBUG
jsCodeLocation = [NSURL URLWithString:@"http://localhost:8081/index.ios.bundle?platform=ios&dev=true"];
#else
jsCodeLocation = [CodePush bundleURL];
#endif
運(yùn)行后發(fā)現(xiàn)jsCodeLocation為nil墩朦,隨后App crash商膊,日志提示 Loading JS bundle from (null)
- 原因及解決辦法
檢查代碼和查看文檔后發(fā)現(xiàn)售睹,我們的App的bundle包時(shí)尊残,是放到一個(gè)子目錄(bundles)中的, 所以codepush獲取bundle包時(shí)需指定子目錄绍些,如下:
#ifdef DEBUG
jsCodeLocation = [NSURL URLWithString:@"http://localhost:8081/index.ios.bundle?platform=ios&dev=true"];
#else
jsCodeLocation = [CodePush bundleURLForResource:@"main" withExtension:@"jsbundle" subdirectory:@"bundles"];
#endif
2捞慌、熱更新包更新成功后第一次加載正常,第二次打開(kāi)App時(shí)bundle包被回滾為更新前的包
報(bào)錯(cuò)信息:An update is available, but it is being ignored due to having been previously rolled back
查看react-native-code-push源碼后發(fā)現(xiàn)柬批,正常情況下加載一個(gè)新包成功后要調(diào)用notifyApplicationReady去清空緩存記錄啸澡。
- 解決辦法一:
如果是入口處每次都調(diào)用了CodePush.sync則不會(huì)有問(wèn)題,因?yàn)镃odePush.sync函數(shù)中會(huì)調(diào)用notifyApplicationReady函數(shù)氮帐。 - 解決辦法二:
根頁(yè)面加載完成后調(diào)用CodePush.notifyAppReady函數(shù)嗅虏,告知它已經(jīng)加載成功了,可以清空記錄了上沐。
如:
componentDidMount() {
CodePush.notifyAppReady();
}
3皮服、App不能熱更新,或只能熱更新第一次参咙,第一次更新成功后龄广,就不能更新新的熱更新包了
這個(gè)問(wèn)題其實(shí)是ng緩存引起的,我們使用了lisong/code-push-server 的開(kāi)源代碼自己搭建了熱更新服務(wù)蕴侧,運(yùn)維人員在配置ng時(shí)沒(méi)考慮實(shí)際場(chǎng)景择同,默認(rèn)加了緩存策略,如下:
add_header Cache-Control max-age=36000
導(dǎo)致get請(qǐng)求被緩存了10個(gè)小時(shí)净宵,CodePush.checkForUpdate是用的get請(qǐng)求敲才,且參數(shù)中沒(méi)加時(shí)間戳或隨機(jī)數(shù)裹纳,所以如果服務(wù)器上還沒(méi)有這個(gè)版本的熱更新包時(shí)就調(diào)用了CodePush.checkForUpdate去做檢查,這時(shí)這個(gè)請(qǐng)求就會(huì)被緩存起來(lái)直到失效紧武,如果在緩存失效前我們上傳了新的熱更新包剃氧,這時(shí)是檢查不出有熱更新的。
- 解決辦法:
1阻星、如果覺(jué)得還是需要緩存來(lái)減輕服務(wù)器壓力她我,可以根據(jù)熱更新版本發(fā)布節(jié)奏來(lái)設(shè)置緩存失效時(shí)間
2、如果擔(dān)心緩存影響迫横,可以直接刪除掉此ng配置
ps.測(cè)試環(huán)境建議刪掉此配置番舆,以免測(cè)試人員來(lái)找你麻煩??
持續(xù)更新......