卖逼视频免费看片|狼人就干网中文字慕|成人av影院导航|人妻少妇精品无码专区二区妖婧|亚洲丝袜视频玖玖|一区二区免费中文|日本高清无码一区|国产91无码小说|国产黄片子视频91sese日韩|免费高清无码成人网站入口

數(shù)據(jù)庫語句是怎么優(yōu)化的 怎么提高api接口的穩(wěn)定性?

怎么提高api接口的穩(wěn)定性?這個(gè)問題我就結(jié)合著自己的項(xiàng)目來說一說。我們現(xiàn)在的項(xiàng)目是沒有前臺(tái)頁面的,只對(duì)外提供接口服務(wù),甚至我們項(xiàng)目都沒有交易類的服務(wù),都是單純的查詢類服務(wù)。項(xiàng)目最初的建設(shè)目標(biāo)就是為了緩

怎么提高api接口的穩(wěn)定性?

這個(gè)問題我就結(jié)合著自己的項(xiàng)目來說一說。

我們現(xiàn)在的項(xiàng)目是沒有前臺(tái)頁面的,只對(duì)外提供接口服務(wù),甚至我們項(xiàng)目都沒有交易類的服務(wù),都是單純的查詢類服務(wù)。項(xiàng)目最初的建設(shè)目標(biāo)就是為了緩解核心系統(tǒng)數(shù)據(jù)查詢的壓力,或者你們可以把我們項(xiàng)目看成幾個(gè)核心項(xiàng)目的緩存層(因?yàn)橛卸鄠€(gè)核心系統(tǒng),我們項(xiàng)目還可以提供跨系統(tǒng)的查詢,這一點(diǎn)也很重要)。

打鐵還需自身硬,要提高接口的穩(wěn)定性和響應(yīng)速度,首先代碼要寫好:

我們項(xiàng)目采用了關(guān)系型數(shù)據(jù)庫做中間庫,數(shù)據(jù)經(jīng)過加工后落地到MongoDB和Redis,對(duì)外的提供的服務(wù),只會(huì)查詢MongoDB和Redis;

數(shù)據(jù)加工很重要,關(guān)系型數(shù)據(jù)庫中需要多表關(guān)聯(lián)的查詢,現(xiàn)在只查詢MongoDB的一個(gè)collection就可以了。(因?yàn)橐鰯?shù)據(jù)加工,所以數(shù)據(jù)和生產(chǎn)庫比,有一定的延遲,這個(gè)一定要看業(yè)務(wù)場(chǎng)景是否允許有延遲);

MongoDB采用副本集 分片的部署,副本集保證數(shù)據(jù)庫的穩(wěn)定性,掛掉一臺(tái),還有其他幾臺(tái)可以使用;分片保證數(shù)據(jù)量增大后,可以平行擴(kuò)容。(現(xiàn)在數(shù)據(jù)量大概在億級(jí),個(gè)位數(shù));

服務(wù)部署還采用比較傳統(tǒng)的,N臺(tái)服務(wù)器前面掛負(fù)載均衡;上各種監(jiān)控,隨時(shí)關(guān)注接口調(diào)用和資源使用情況;

嚴(yán)格的參數(shù)校驗(yàn),避免做無用的查詢;

大原則就是:【能查緩存就不要查數(shù)據(jù)庫,能不查的話就更好】

除了自身架構(gòu)之外,還有些非自身的控制:

內(nèi)部系統(tǒng)在調(diào)用接口的時(shí)候,主要通過網(wǎng)絡(luò)權(quán)限的控制,除此之外不做任何的限制,包括鑒權(quán);

如果是互聯(lián)網(wǎng)端的接入,還是需要依賴網(wǎng)關(guān);由網(wǎng)關(guān)做鑒權(quán)、限流、降級(jí)、熔斷等;

參與對(duì)方系統(tǒng)功能的設(shè)計(jì)(這一點(diǎn)很神奇),因?yàn)榇蠖鄶?shù)時(shí)候都是公司內(nèi)部的系統(tǒng),所以在做需求討論的時(shí)候,最好能看一下對(duì)方系統(tǒng)的調(diào)用場(chǎng)景;很有可能調(diào)整一下什么時(shí)候調(diào)用接口,就能大大減少接口的調(diào)用次數(shù);

建議調(diào)用方設(shè)置合理的超時(shí)時(shí)間,并有合理的重試機(jī)制;

如果可以的話,最好可以采用異步調(diào)用的機(jī)制;

如果接口要依賴于另外系統(tǒng)的接口,也需要額外的做一些考慮(依賴的接口返回慢或者報(bào)錯(cuò),自己的接口肯定會(huì)有問題);比如數(shù)據(jù)時(shí)效性要求不高的話,可以考慮把對(duì)方接口返回的數(shù)據(jù)緩存下來(設(shè)置失效時(shí)間,保證一段時(shí)間后能把最新的數(shù)據(jù)刷新回來),但如果數(shù)據(jù)時(shí)效性要求非常高,可以考慮使用熔斷;不過說實(shí)話,還沒見過誰敢用熔斷的....

希望我的回答,能夠幫助到你!我將持續(xù)分享Java開發(fā)、架構(gòu)設(shè)計(jì)、程序員職業(yè)發(fā)展等方面的見解,希望能得到你的關(guān)注。

oral數(shù)據(jù)庫讀寫速度怎么提升?

優(yōu)化數(shù)據(jù)庫大幅度提高Oracle的性能

幾個(gè)簡(jiǎn)單的步驟大幅提高Oracle性能–我優(yōu)化數(shù)據(jù)庫的三板斧。

數(shù)據(jù)庫優(yōu)化的討論可以說是一個(gè)永恒的主題。資深的Oracle優(yōu)化人員通常會(huì)要求提出性能問題的人對(duì)數(shù)據(jù)庫做一個(gè)statspack,貼出數(shù)據(jù)庫配置等等。還有的人認(rèn)為要抓出執(zhí)行最慢的語句來進(jìn)行優(yōu)化。但實(shí)際情況是,提出疑問的人很可能根本不懂執(zhí)行計(jì)劃,更不要說statspack了。而我認(rèn)為,數(shù)據(jù)庫優(yōu)化,應(yīng)該首先從大的方面考慮:網(wǎng)絡(luò)、服務(wù)器硬件配置、操作系統(tǒng)配置、Oracle服務(wù)器配置、數(shù)據(jù)結(jié)構(gòu)組織、然后才是具體的調(diào)整。實(shí)際上網(wǎng)絡(luò)、硬件等往往無法決定更換,應(yīng)用程序一般也無法修改,因此應(yīng)該著重從數(shù)據(jù)庫配置、數(shù)據(jù)結(jié)構(gòu)上來下手,首先讓數(shù)據(jù)庫有一個(gè)良好的配置,然后再考慮具體優(yōu)化某些過慢的語句。我在給我的用戶系統(tǒng)進(jìn)行優(yōu)化的過程中,總結(jié)了一些基本的,簡(jiǎn)單易行的辦法來優(yōu)化數(shù)據(jù)庫,算是我的三板斧,呵呵。不過請(qǐng)注意,這些不一定普遍使用,甚至有的會(huì)有副作用,但是對(duì)OLTP系統(tǒng)、基于成本的數(shù)據(jù)庫往往行之有效,不妨試試。