日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

java代碼實現(xiàn)mysql分表操作(用戶行為記錄)

瀏覽:206日期:2022-08-16 15:58:32
設(shè)置項目氣動執(zhí)行次方法(每天檢查一次表記錄)

public class DayInterval implements ServletContextListener{private static SimpleDateFormat simpleDateFormat=new SimpleDateFormat('yyyy-MM-dd HH:mm:ss');public static void showDayTime() {Timer dTimer = new Timer();dTimer.schedule(new TimerTask() {@Overridepublic void run() { System.out.println('每日任務(wù)執(zhí)行:'+simpleDateFormat.format(new Date())); LogTableCreate logTableCreate = new LogTableCreate(); Thread thread=new Thread(logTableCreate); thread.start();}}, 1000 , 24* 60* 60 * 1000);//24* 60* 60 * 1000(第一次一秒后執(zhí)行,以后每次一天后執(zhí)行)}@Overridepublic void contextDestroyed(ServletContextEvent arg0) {//showDayTime();}@Overridepublic void contextInitialized(ServletContextEvent arg0) {showDayTime();}}

LogTableCreate 用來做表分表是否已經(jīng)創(chuàng)建,如現(xiàn)在是9月在啟動時檢查是否存在當(dāng)月表記錄,不存在則創(chuàng)建存在則不創(chuàng)建,另外檢查是否存在10月份表記錄,不存在則創(chuàng)建(提前創(chuàng)建一個也空表,以此類推)。

拷貝代碼修改createsql(建表sql),URL (數(shù)據(jù)庫地址),USER (數(shù)據(jù)庫連接用戶),PASSWORD(數(shù)據(jù)庫連接密碼)

public class LogTableCreate extends TimerTask {private static final Log log = LogFactory.getLog(LogTableCreate.class);public static final String TBASENAME='tb_log';private String createsql = ' (rn' + ' `ID` varchar(64) NOT NULL COMMENT ’主鍵id’,rn' + ' `userid` varchar(255) DEFAULT NULL COMMENT ’用戶id’,rn' + ' `username` varchar(255) DEFAULT NULL COMMENT ’用戶姓名’,rn' + ' `useridcard` varchar(255) DEFAULT NULL COMMENT ’用戶身份證號碼’,rn' + ' `realname` varchar(64) DEFAULT NULL COMMENT ’真實姓名’,rn' + ' `logintime` varchar(255) DEFAULT NULL COMMENT ’登錄時間’,rn' + ' `exittime` varchar(64) DEFAULT NULL COMMENT ’退出時間’,rn' + ' `ippath` varchar(255) DEFAULT NULL COMMENT ’ip地址’,rn' + ' `macpath` varchar(255) DEFAULT NULL COMMENT ’mac地址’,rn' + ' `usercreatedtime` varchar(255) DEFAULT NULL COMMENT ’用戶創(chuàng)建時間’,rn' + ' `userbusidaddress` varchar(255) DEFAULT NULL COMMENT ’用戶錢包地址’,rn' + ' `member` int(11) DEFAULT NULL COMMENT ’是否是會員’,rn' + ' `membertype` int(11) DEFAULT NULL COMMENT ’會員類型’,rn' + ' `spare1` varchar(255) DEFAULT NULL,rn' + ' `spare2` varchar(255) DEFAULT NULL,rn' + ' `spare3` varchar(255) DEFAULT NULL,rn' + ' PRIMARY KEY (`ID`)rn' + ')'; private SimpleDateFormat sdyyyy = new SimpleDateFormat('yyyy'); private SimpleDateFormat sdmm = new SimpleDateFormat('MM'); private static final String URL = ''; private static final String USER = ''; private static final String PASSWORD = ''; //得到表名 public static String gettable() { Date date = new Date(); LogTableCreate logTableCreate=new LogTableCreate();String yyyy = logTableCreate.sdyyyy.format(date);String mm = logTableCreate.sdmm.format(date);String nmm = logTableCreate.getNextMM(mm);return TBASENAME+yyyy+mm; } //得到下一個月private String getNextMM(String mm){String nmm = '';int imm = Integer.parseInt(mm);if(imm>=12){nmm = '01';}else{imm++;if(imm>9)nmm = ''+imm;elsenmm = '0'+imm;}return nmm;} @Overridepublic void run() {Date date = new Date();String yyyy = sdyyyy.format(date);String mm = sdmm.format(date);String nmm = getNextMM(mm);String nyyyy = '';if('01'.equals(nmm)){nyyyy = ''+(Integer.parseInt(yyyy)+1);}else{nyyyy = yyyy;}log.info('日志表檢查及創(chuàng)建:'+yyyy+' - '+mm+' | '+nyyyy+'-'+nmm);String temp = TBASENAME+yyyy+mm; //日志表名稱boolean has = false;try{has = hasTable(temp);}catch(Exception e){log.error('當(dāng)前操作日志表是否存在判斷時發(fā)生錯誤:'+e.getMessage());return;}if(!has){try{createTable(temp);}catch(Exception e){log.error('當(dāng)前操作日志表創(chuàng)建時發(fā)生錯誤:'+e.getMessage());return;}}temp = TBASENAME+nyyyy+nmm;has = false;try{has = hasTable(temp);}catch(Exception e){log.error('待用日志表是否存在判斷時發(fā)生錯誤:'+e.getMessage());return;}if(!has){try{createTable(temp);}catch(Exception e){log.error('待用日志表創(chuàng)建時發(fā)生錯誤:'+e.getMessage());return;}}log.info('日志表檢查及創(chuàng)建結(jié)束');}public boolean hasTable(String table) throws Exception{Class.forName('com.mysql.jdbc.Driver'); //2. 獲得數(shù)據(jù)庫連接 Connection conn = DriverManager.getConnection(URL, USER, PASSWORD);boolean state = false;DatabaseMetaData meta = conn.getMetaData();ResultSet set;set = meta.getTables(null, null, table.toLowerCase(), null);while (set.next()) {state = true;break;}Statement stmt = null;try{stmt = conn.createStatement();}catch(Exception e){log.error('檢查日志表是否存在時發(fā)生錯誤:'+e.getMessage());throw e;}finally{if(stmt!=null)try {stmt.close();} catch (Exception e) {//e.printStackTrace();}}conn.close();return state;}public void createTable(String table)throws Exception{try{Class.forName('com.mysql.jdbc.Driver'); //2. 獲得數(shù)據(jù)庫連接 Connection conn = DriverManager.getConnection(URL, USER, PASSWORD);String sql = 'create table '+table+createsql;Statement stmt = null;stmt = conn.createStatement();stmt.execute(sql);}catch(Exception e){log.error('初始化日志表時發(fā)生錯誤:'+e.getMessage());throw e;}}}

補充:java水平分表_Java開發(fā)分庫分表需要解決的問題及mycat是怎樣實現(xiàn)分庫分表的

引言

從字面上簡單理解,就是把原本存儲于一個庫的數(shù)據(jù)分塊存儲到多個庫上,把原本存儲于一個表的數(shù)據(jù)分塊存儲到多個表上。

數(shù)據(jù)庫中的數(shù)據(jù)量不一定是可控的,在未進(jìn)行分庫分表的情況下,隨著時間和業(yè)務(wù)的發(fā)展,庫中的表會越來越多,表中的數(shù)據(jù)量也會越來越大,相應(yīng)地,數(shù)據(jù)操作,增刪改查的開銷也會越來越大;

另外,由于無法進(jìn)行分布式式部署,而一臺服務(wù)器的資源(CPU、磁盤、內(nèi)存、IO等)是有限的,最終數(shù)據(jù)庫所能承載的數(shù)據(jù)量、數(shù)據(jù)處理能力都將遭遇瓶頸。

分庫分表的必要性

首先我們來了解一下為什么要做分庫分表。在我們的業(yè)務(wù)(web應(yīng)用)中,關(guān)系型數(shù)據(jù)庫本身比較容易成為系統(tǒng)性能瓶頸,單機存儲容量、連接數(shù)、處理能力等都很有限,數(shù)據(jù)庫本身的“有狀態(tài)性”導(dǎo)致了它并不像Web和應(yīng)用服務(wù)器那么容易擴展。那么在我們的業(yè)務(wù)中,是否真的有必要進(jìn)行分庫分表,就可以從上面幾個條件來考慮。

單機儲存容量。您的數(shù)據(jù)量是否在單機儲存中碰到瓶頸。比如餓了么一天產(chǎn)生的用戶行為數(shù)據(jù)就有24T,那么在傳統(tǒng)的單機儲存中肯定是不夠的。

連接數(shù)、處理能力。在我們的用戶量達(dá)到一定程度時,特定時間的并發(fā)量又成了一個大問題,在一個高并發(fā)的網(wǎng)站中秒級數(shù)十萬的并發(fā)量都是很正常的。在普通的單機數(shù)據(jù)庫中秒級千次的操作問題都很大。

所以在我們進(jìn)行分庫分表之前我們最好考慮一下,我們的數(shù)據(jù)量是不是夠大,并發(fā)量是不是夠大。如果您的回答是肯定的,那我們就開始做吧。

事務(wù)問題

解決事務(wù)問題目前有兩種可行的方案:分布式事務(wù)和通過應(yīng)用程序與數(shù)據(jù)庫共同控制實現(xiàn)事務(wù)下面對兩套方案進(jìn)行一個簡單的對比。

方案一:使用分布式事務(wù)

優(yōu)點:交由數(shù)據(jù)庫管理,簡單有效

缺點:性能代價高,特別是shard越來越多時

方案二:由應(yīng)用程序和數(shù)據(jù)庫共同控制

原理:將一個跨多個數(shù)據(jù)庫的分布式事務(wù)分拆成多個僅處 于單個數(shù)據(jù)庫上面的小事務(wù),并通過應(yīng)用程序來總控 各個小事務(wù)。

優(yōu)點:性能上有優(yōu)勢

缺點:需要應(yīng)用程序在事務(wù)控制上做靈活設(shè)計。如果使用 了spring的事務(wù)管理,改動起來會面臨一定的困難。

分庫分表的實施策略。

分庫分表有垂直切分和水平切分兩種。

3.1 何謂垂直切分,即將表按照功能模塊、關(guān)系密切程度劃分出來,部署到不同的庫上。

例如,我們會建立定義數(shù)據(jù)庫workDB、商品數(shù)據(jù)庫payDB、用戶數(shù)據(jù)庫userDB、日志數(shù)據(jù)庫logDB等,分別用于存儲項目數(shù)據(jù)定義表、商品定義表、用戶數(shù)據(jù)表、日志數(shù)據(jù)表等。

3.2 何謂水平切分,當(dāng)一個表中的數(shù)據(jù)量過大時,我們可以把該表的數(shù)據(jù)按照某種規(guī)則,例如userID散列,進(jìn)行劃分,然后存儲到多個結(jié)構(gòu)相同的表,和不同的庫上。

例如,我們的userDB中的用戶數(shù)據(jù)表中,每一個表的數(shù)據(jù)量都很大,就可以把userDB切分為結(jié)構(gòu)相同的多個userDB:part0DB、part1DB等,再將userDB上的用戶數(shù)據(jù)表userTable,切分為很多userTable:userTable0、userTable1等,然后將這些表按照一定的規(guī)則存儲到多個userDB上。

3.3 應(yīng)該使用哪一種方式來實施數(shù)據(jù)庫分庫分表,這要看數(shù)據(jù)庫中數(shù)據(jù)量的瓶頸所在,并綜合項目的業(yè)務(wù)類型進(jìn)行考慮。

如果數(shù)據(jù)庫是因為表太多而造成海量數(shù)據(jù),并且項目的各項業(yè)務(wù)邏輯劃分清晰、低耦合,那么規(guī)則簡單明了、容易實施的垂直切分必是首選。

而如果數(shù)據(jù)庫中的表并不多,但單表的數(shù)據(jù)量很大、或數(shù)據(jù)熱度很高,這種情況之下就應(yīng)該選擇水平切分,水平切分比垂直切分要復(fù)雜一些,它將原本邏輯上屬于一體的數(shù)據(jù)進(jìn)行了物理分割,除了在分割時要對分割的粒度做好評估,考慮數(shù)據(jù)平均和負(fù)載平均,后期也將對項目人員及應(yīng)用程序產(chǎn)生額外的數(shù)據(jù)管理負(fù)擔(dān)。

在現(xiàn)實項目中,往往是這兩種情況兼而有之,這就需要做出權(quán)衡,甚至既需要垂直切分,又需要水平切分。我們的游戲項目便綜合使用了垂直與水平切分,我們首先對數(shù)據(jù)庫進(jìn)行垂直切分,然后,再針對一部分表,通常是用戶數(shù)據(jù)表,進(jìn)行水平切分。

mycat是怎樣實現(xiàn)分庫分表的?mycat里面通過定義路由規(guī)則來實現(xiàn)分片表(路由規(guī)則里面會定義分片字段,以及分片算法)。分片算法有多種,你所說的hash是其中一種,還有取模、按范圍分片等等。在mycat里面,會對所有傳遞的sql語句做路由處理(路由處理的依據(jù)就是表是否分片,如果分片,那么需要依據(jù)分片字段和對應(yīng)的分片算法來判斷sql應(yīng)該傳遞到哪一個、或者哪幾個、又或者全部節(jié)點去執(zhí)行)

總結(jié)

以上就是我對Java開發(fā)分庫分表需要解決的問題及mycat是怎樣實現(xiàn)分庫分表的 問題及其優(yōu)化總結(jié),如有錯誤或未考慮完全的地方,望不吝賜教。

標(biāo)簽: Java
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
97久久超碰| 日韩在线一区二区| 青草av.久久免费一区| 在线看片日韩| 亚洲色图网站| 亚洲精品自拍| 久久亚洲一区| 亚洲精品影院在线观看| 亚州精品视频| 欧美日韩一区二区三区不卡视频| 日韩av一区二区三区| 国产日韩一区| 中文一区一区三区高中清不卡免费| 手机在线电影一区| 在线日韩中文| 蜜臀91精品一区二区三区| 四虎精品一区二区免费| 日韩国产成人精品| 免费在线亚洲| 91tv亚洲精品香蕉国产一区| 亚洲精品一二三区区别| 亚洲一区二区三区高清不卡| 亚洲欧洲专区| 国产精品v一区二区三区| 韩日一区二区| 亚洲手机在线| 一级欧美视频| 免费视频一区二区三区在线观看 | 天堂va蜜桃一区二区三区| 久久一二三区| 国产精品一区二区av交换| 国产精品久久久久久久久免费高清| 久久久国产精品入口麻豆| 日韩国产综合| 亚洲尤物在线| 国产伦精品一区二区三区千人斩 | 日韩视频不卡| 婷婷精品在线| 成人国产精选| 夜久久久久久| 国产日韩欧美一区在线| 亚洲成人不卡| 亚洲精品无播放器在线播放| 国产精品sm| 99久久亚洲精品蜜臀| 亚洲精品麻豆| 日韩和的一区二在线| 中文字幕亚洲精品乱码| 久久精品国产99国产| 亚洲一区二区三区高清| 久久精品国产免费| 蜜桃一区二区三区在线观看| 免费在线观看一区| 亚洲少妇自拍| 精品一区二区三区的国产在线观看 | 久久午夜影视| 国产精品日韩精品中文字幕| 久久精品亚洲人成影院| 四虎成人精品一区二区免费网站 | 久久wwww| 日韩午夜一区| 九九99久久精品在免费线bt| 亚洲欧美成人综合| 国产suv精品一区二区四区视频| 久久国产精品99国产| 精品三级在线| 国产精品亚洲综合色区韩国| 午夜久久tv| 国产一区二区三区网| 日韩精品免费视频一区二区三区 | 六月婷婷一区| 日韩综合一区| 日韩av三区| 亚洲一区不卡| 日韩中文字幕高清在线观看| 日韩欧美四区| 国产模特精品视频久久久久| 成人国产精品一区二区网站| 日韩成人一级| 亚洲成人国产| 国产精品调教| 蜜桃av一区二区在线观看| 成人三级高清视频在线看| 日韩毛片一区| 日韩精品一区第一页| 国产精品久久久亚洲一区| 亚洲欧美久久| 欧美成人国产| 国产va免费精品观看精品视频| 香蕉成人久久| 午夜国产欧美理论在线播放| 色婷婷色综合| 精品久久久网| 欧美亚洲三区| 亚洲福利国产| 激情黄产视频在线免费观看| 国产极品一区| 欧美偷窥清纯综合图区| 美国三级日本三级久久99 | 国产精品一区二区三区四区在线观看| 一区在线视频观看| 精精国产xxxx视频在线野外| 国产乱码精品一区二区亚洲| 亚洲一区久久| 久久国产电影| 欧美日韩视频网站| 精品国产91| 久久只有精品| 欧美成人精品一级| 国产精东传媒成人av电影| 久久国产精品免费精品3p | 黄毛片在线观看| 丰满少妇一区| 精品亚洲精品| 麻豆精品新av中文字幕| 日韩精品国产精品| 视频一区日韩| 亚洲tv在线| 欧美亚洲tv| 国产精品一区二区美女视频免费看| 少妇精品在线| 日韩精品福利一区二区三区| 亚洲三级网站| 亚洲精品乱码日韩| 中文字幕日韩欧美精品高清在线| 伊人精品久久| 日本h片久久| 国产日韩亚洲欧美精品| 国产精品天堂蜜av在线播放| 国产精品欧美大片| 美女高潮久久久| 国产伦一区二区三区| 麻豆精品视频在线| 国产成人精选| 91看片一区| 尤物精品在线| 天海翼亚洲一区二区三区| 欧美偷窥清纯综合图区| 国产精品白丝久久av网站| 精品日韩一区| 91看片一区| 亚洲一区日韩| 日韩高清在线观看一区二区| 欧美日韩亚洲一区三区| 美女高潮久久久| 中文字幕在线官网| 久久视频精品| 亚洲伊人影院| 久久国产三级| 中文在线а√天堂| 五月婷婷六月综合| 免费成人在线影院| 国产一级成人av| 色婷婷综合网| 黄色成人91| 亚州欧美在线| 国产一区精品福利| 免费久久久久久久久| 一级成人国产| 美女国产一区二区三区| 色88888久久久久久影院| 国产一区观看| 午夜精品影视国产一区在线麻豆| 国产精品毛片久久久| 日韩在线免费| 视频一区欧美日韩| 国产精品一区二区av日韩在线| 国产高清不卡| 国产美女精品| 麻豆久久久久久| 黄色av日韩| 欧美黄页在线免费观看| 欧美性感美女一区二区| 亚洲精品激情| 日本美女一区| 亚州精品视频| 91日韩欧美| 综合欧美精品| 精品国产a一区二区三区v免费| 亚州av乱码久久精品蜜桃| 青青草国产成人99久久| xxxxx性欧美特大| 亚洲综合色婷婷在线观看| 成人一区而且| 亚洲一区二区日韩| 91中文字幕精品永久在线| 免费视频最近日韩| 精品视频免费| 亚洲一级淫片| 日韩毛片视频| 91亚洲无吗| 欧美午夜精彩| 久久亚洲精精品中文字幕| 一二三区精品| 91精品婷婷色在线观看| 国产精品视频一区二区三区| 在线成人直播| 国产第一亚洲| 日韩av中文字幕一区二区三区| 99精品在线观看|