如果不使用框架,純原生Java編寫,是需要了解Java并發(fā)編程的,主要就是學習Doug Lea開發(fā)的那個java.util.concurrent包下面的API;
十余年的沙河網(wǎng)站建設(shè)經(jīng)驗,針對設(shè)計、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時及時工作處理。營銷型網(wǎng)站的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整沙河建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計,從而大程度地提升瀏覽體驗。創(chuàng)新互聯(lián)建站從事“沙河網(wǎng)站設(shè)計”,“沙河網(wǎng)站推廣”以來,每個客戶項目都認真落實執(zhí)行。
如果使用框架,那么在代碼層面確實不會需要太多的去關(guān)注并發(fā)問題,反而是由于高并發(fā)會給系統(tǒng)造成很大壓力,要在緩存、數(shù)據(jù)庫操作上要多加考慮。
即使是使用框架,在工作中還是會用到多線程,就拿常見的CRUD接口來說,比如一個非常耗時的save接口,有多耗時呢?我們假設(shè)整個save執(zhí)行完要10分鐘,所以,在save的時候,就需要采用異步的方式,也就是單獨用一個線程去save,然后直接給前端返回200。
可見,就算只是簡單的CRUD,也有可能用到多線程的。
當然,這只是一個簡單的例子,要想學習Java的精髓,并發(fā)還是要學的;不管你只是業(yè)務(wù)開發(fā),還是在開發(fā)框架。
對于并發(fā)操作,都要上鎖的,設(shè)置一個字段記錄抽到獎的人數(shù),每抽到一個就讓update該字段值+1,更新過程中數(shù)據(jù)庫會自動給數(shù)據(jù)庫上鎖,直到commit提交,這里就避免了你說的同時查詢的問題。
你指的高并發(fā)量大概有多少?\x0d\x0a幾點需要注意:\x0d\x0a盡量使用緩存,包括用戶緩存,信息緩存等,多花點內(nèi)存來做緩存,可以大量減少與數(shù)據(jù)庫的交互,提高性能。\x0d\x0a用jprofiler等工具找出性能瓶頸,減少額外的開銷。\x0d\x0a優(yōu)化數(shù)據(jù)庫查詢語句,減少直接使用hibernate等工具的直接生成語句(僅耗時較長的查詢做優(yōu)化)。\x0d\x0a優(yōu)化數(shù)據(jù)庫結(jié)構(gòu),多做索引,提高查詢效率。\x0d\x0a統(tǒng)計的功能盡量做緩存,或按每天一統(tǒng)計或定時統(tǒng)計相關(guān)報表,避免需要時進行統(tǒng)計的功能。\x0d\x0a\x0d\x0a能使用靜態(tài)頁面的地方盡量使用,減少容器的解析(盡量將動態(tài)內(nèi)容生成靜態(tài)html來顯示)。\x0d\x0a解決以上問題后,使用服務(wù)器集群來解決單臺的瓶頸問題。\x0d\x0a基本上以上述問題解決后,達到系統(tǒng)最優(yōu)。\x0d\x0a\x0d\x0a至于樓上有人提到別用JAVA來做,除非是低層的連接數(shù)過大(如大量的端口占用需求),這種情況下考慮直接C來寫,其他的可以用JAVA來做。\x0d\x0a\x0d\x0a可以網(wǎng)上購買視頻做教育學習。