攻城獅作為各類互聯網企業在網絡上攻城略地的戰斗者,每時每刻都背負著巨量的開發需求,以及近乎無量的代碼債務,為了碼出質量,為了鄙視自私自利的物質社會,精神已實現超脫的同學們發明了烏托邦式的開源社區,把自己已經做好的優秀代碼共享到網絡中,從而造福全人類。
為優秀的他們點贊~~
為了保證代碼質量,一般經過一段時間開發及沉淀后就會形成一個新版本封包推出,使用者無需關心代碼實現邏輯就可以直接拿來用,極大的滿足各類伸手黨的欲望。
隨著這個非常有覺悟的群體不斷壯大,開發界于是就不斷涌現出各類優秀的庫,為it的前進直接就裝上了火箭推進器。
而程序猿們開發過程不再整天沉浸在各類算法編寫上面,可以直接從現成的庫中選擇合適的工具,于是作為應用層面的開發者們,算法和基礎知識不再是限制他們的束縛,豐富的知識面(類庫認知)能為他們插上飛翔的翅膀。
可是,工具太多太豐富也帶來了一些問題,我這里舉例幾個看看大家是否有共鳴:
當然,隨著技術發展硬件單價不斷下降,能通過資源投入就能解決的問題都不是問題了,可真相真的是這樣嗎?
隨著微服務不斷在大大小小的企業落地,“無狀態”服務的理念也逐步成為一種標配。
為什么無狀態呢?
還有嗎?肯定還有,我就不一一列舉了
微服務技術可以很好的和容器技術結合在一起,甚至可以說是天生一對,微服務關注于業務的“微”,而容器則提供標準環境以及進程級啟動的“小”。
在無狀態的微服務中
如此純凈的微服務在當前開發結果下,實際包會增大許多,同時運行內存也要求多了許多。
老鐵,可還記得64M跑Java的年代。。。
我們為了代碼質量和開發效率所以引入了一堆第三方庫,這是導致問題的根源了,拿到為了區區內存就放棄引入類庫,回到原始人階段嗎?
因噎廢食,我想到了這個詞,這并不是我們想要的。
實際上,我們使用第三方庫時候,多數只是需要用到其中某些功能甚至某幾個類,可以為包是整體加載的,導致了我們不需要用到的類也進入到我們的虛擬機中,膨脹了我們的內存占用,因此,或許按需加載可以解決我們這類問題?
我們都知道,JVM對類的操作是通過一系列的ClassLoader來實現的,由JVM的啟動開始一直到我們的業務代碼執行,缺少了ClassLoader都不行。BootstrapClassLoader
是負責裝載Java核心類的,ExtClassLoader
則是負責裝載JVM外部類庫,最后才到裝載我們應用程序的AppClassLoader
。
我們的程序有多少個包AppClassLoader
就需要裝多少個到內存,所以內存占用難以避免,為Java“吃內存”美名做了一番貢獻。
如果我們要實現按需裝載的話,就要對這個裝載鏈進行重新設計,這也就是fast-loader的來源了。
我們不再讓APPClassLoader
接觸到應用,作為中間人我們加入FastClassLoader
,由它去裝載應用包,這樣我們就能對類裝載進行干涉,從而實現按需裝載類了。
具體內容請留意下一篇。
創新互聯www.cdcxhl.cn,專業提供香港、美國云服務器,動態BGP最優骨干路由自動選擇,持續穩定高效的網絡助力業務部署。公司持有工信部辦法的idc、isp許可證, 機房獨有T級流量清洗系統配攻擊溯源,準確進行流量調度,確保服務器高可用性。佳節活動現已開啟,新人活動云服務器買多久送多久。
新聞名稱:fast-loader(一)起源-創新互聯
文章URL:http://vcdvsql.cn/article24/ceojje.html
成都網站建設公司_創新互聯,為您提供網站改版、品牌網站建設、建站公司、微信公眾號、網站制作、域名注冊
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯