精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

一個數據開發人員使用的輔助工具

運維 數據庫運維
這是為數據開發人員使用的輔助工具,用于數據庫之間的表同步,說同步并不嚴謹,因為不是實時更新的,更確切的說法是復制,可以方便的從一個數據庫復制表到另一個數據庫,以下遇到同步的詞請理解為復制。

 [[389867]]

介紹

需求背景:

有很多業務系統,他們的數據庫是相互獨立的,俗稱數據孤島,為了做數據統計分析,就需要把這些數據歸集在一個數據庫中,比如數據倉庫,然后多表關聯查詢,方便開發數據應用。希望能有這樣的工具,指定兩個數據庫和表名,就可以將表從源數據庫拷貝到目標數據庫中。具體需求如下:

  • 能自動同步表結構,如:源表加字段,目標表自動加字段。
  • 支持增量或全量復制數據,比如按日期進行復制數據。
  • 支持指定字段同步,只同步關心的那些字段。
  • 支持主流的關系型數據庫: mysql、db2、postgresql、oracle、sqlserver
  • 源表和目標表表名可以不同,字段名也可以不同(已存在目標表的情況下)

因為自己要用,我就自己寫了一個,順便熟悉下 java 開發(之前一直用 Python,不得不說,Java 真浪費時間),本程序的最大用處就是構建集市或數倉所需要的基礎層數據源,歡迎感興趣的朋友一起加入。

程序的使用方法

Docker 方式:

這里用到三個容器:

  • app 也就是主程序本身,app 容器使用的程序文件就是 release 目錄下的文件,已經做了綁定。
  • mysql 測試用的,作為源數據庫,已提前放好了有 7000 條測試數據的表 somenzz_users。
  • postgres 測試用的,作為目標數據庫,沒有數據。

先部署,執行 docker-compose up -d 就會自動完成應用和數據庫的部署:

 

  1. $ git clone https://github.com/somenzz/database-sync.git 
  2. $ cd database-sync 
  3. $ docker-compose up -d 
  4. Creating database-sync_postgres_1 ... done 
  5. Creating database-sync_app_1      ... done 
  6. Creating database-sync_mysql_1    ... done 

這樣三個容器就啟動了,使用 docker ps -a |grep database-sync 可以查看到三個正在運行的容器:

 

 

 

 

現在直接使用 docker exec -i database-sync_app_1 java -jar database-sync-1.3.jar 來執行程序:

 

 

 

 

mysql 容器已有測試數據,release/config/config.json 已經配置好了數據庫的連接,因此可以直接試用,以下演示的是從 mysql 復制表和數據到 postgres:

1. 全量復制,自動建表:

 

  1. docker exec -i database-sync_app_1 java -jar database-sync-1.3.jar mysql_test testdb somenzz_users postgres_test public users --sync-ddl 

 

 

 

如果你不想每次都敲 docker exec -i database-sync_app_1 ,可以進入容器內部執行:

 

  1. (py38env) ➜  database-sync git:(master) ✗ docker exec -it database-sync_app_1 /bin/bash 
  2. root@063b1dc76fe1:/app# ls 
  3. config database-sync-1.3.jar  lib  logs 
  4. root@063b1dc76fe1:/app# java -jar database-sync-1.3.jar mysql_test testdb somenzz_users postgres_test public users -sd 

2. 增量復制:

 

  1. root@063b1dc76fe1:/app# java -jar database-sync-1.3.jar mysql_test testdb somenzz_users postgres_test public zz_users "create_at >= '2018-01-09'" 

 

 

 

3. 指定字段:

 

  1. root@063b1dc76fe1:/app# java -jar database-sync-1.3.jar mysql_test testdb somenzz_users postgres_test public zz_users -ff="user_id,name,age" -tf="user_id,name,age" "create_at >= '2018-01-09'" 

 

 

 

普通方式

程序運行前確保已安裝 java 1.8 或后續版本,已經安裝 maven,然后 clone 源碼,打包:

 

  1. git clone https://gitee.com/somenzz/database-sync.git 
  2. cd database-sync 
  3. mvn package 

此時你會看到 target 目錄,將 target 下的 lib 目錄 和 database-sync-1.3.jar 復制出來,放在同一目錄下,然后再創建一個 config 目錄,在 config 下新建一個 config.json 文件寫入配置信息,然后將這個目錄壓縮,就可以傳到服務器運行了,請注意先充分測試,jdk 要求 1.8+

 

  1. [aaron@hdp002 /home/aaron/App/Java/database-sync]$ ls -ltr 
  2. total 48 
  3. drwxr-xr-x 2 aaron aaron  4096 Apr 23  2020 lib 
  4. -rwxrw-r-- 1 aaron aaron   157 Jun 23  2020 run.sh 
  5. drwxrwxr-x 2 aaron aaron  4096 Jul  3  2020 logs 
  6. -rw-rw-r-- 1 aaron aaron 24773 Mar 16  2021 database-sync-1.3.jar 
  7. drwxr-xr-x 7 aaron aaron  4096 Aug  3  2020 jdk1.8.0_231 
  8. drwxrwxr-x 2 aaron aaron  4096 Feb 19 17:07 config 

你也可以直接下載我打包好的使用。

程序名稱叫 database-sync,運行方式是這樣的:

 

  1. (py38env) ➜  target git:(master) ✗ java -jar database-sync-1.3.jar -h       
  2. Usage:  
  3. java -jar database-sync-1.0.jar [options] {fromDB} {fromSchema} {fromTable} {toDB} {toSchema} {toTable} [whereClause] 
  4. options: 
  5.         -v or --version                            :print version then exit 
  6.         -h or --help                               :print help info then exit 
  7.         -sd or --sync-ddl                          :auto synchronize table structure 
  8.         -ff=col1,col2 or --from-fields=col1,col2   :specify from fields 
  9.         -tf=col3,col4 or --to-fields=col3,col4     :specify to fields 
  10.         --no-feature or -nf                        :will not use database's feature 

幫助說明:

[] 中括號里的內容表示選填,例如 [options] 表示 options 下的參數不是必須的。

1、其中 options 參數解釋如下:

  • --sync-ddl 或者 -sd : 加入該參數會自動同步表結構。
  • --from_fields=col1,col2 或者 -ff=col1,col2 : 指定原表的字段序列,注意 = 前后不能有空格。
  • --to_fields=col3,col4 或者 -tf=col3,col4 : 指定目標表的字段序列,注意 = 前后不能有空格。

2、whereClause 表示 where 條件,用于增量更新,程序再插入數據前先按照 where 條件進行清理數據,然后按照 where 條件從原表進行讀取數據。whereClause 最好使用雙引號包起來,表示一個完整的參數。如:"jyrq='2020-12-31'"

{} 大括號里的內容表示必填。

fromDb 是指配置在 config.json 的數據庫信息的鍵,假如有以下配置文件:

 

  1.       "postgres":{ 
  2.         "type":"postgres"
  3.         "driver":"org.postgresql.Driver"
  4.         "url":"jdbc:postgresql://localhost:5432/apidb"
  5.         "user""postgres"
  6.         "password":"aaron"
  7.         "encoding""utf-8" 
  8.     }, 
  9.  
  10.  
  11.     "aarondb":{ 
  12.         "type":"mysql"
  13.         "driver":"com.mysql.cj.jdbc.Driver"
  14.         "url":"jdbc:mysql://localhost:3306/aarondb?useSSL=false&characterEncoding=utf8&serverTimezone=UTC"
  15.         "user""aaron"
  16.         "password":"aaron" 
  17.     } 

fromDb、toDb 可以是 aarondb 或者 postgres。

  • fromSchema 讀取數據的表的模式名,可以填寫 "".
  • fromTable 讀取數據的表明,必須提供。
  • toSchema 寫入數據表的模式名,可以填寫 "",可以和 fromSchema 不同.
  • toTable 寫入數據表的表名,必須提供,當寫入表不存在時,自動按讀取表的表結構創建,可以和 fromTable 不同。

全量、增量、指定字段的使用樣例請參考 Docker 方式。

配置文件說明

配置文件位于 config/config.json,如下所示:

 

  1.     "sjwb":{ 
  2.         "type":"db2"
  3.         "driver":"com.ibm.db2.jcc.DB2Driver"
  4.         "url":"jdbc:db2://192.168.1.*:50000/wbsj"
  5.         "user""****"
  6.         "password":"****"
  7.         "tbspace_ddl""/*這里可以放置指定表空間的語句*/"
  8.         "encoding":"utf-8" 
  9.     }, 
  10.  
  11.     "dw_test":{ 
  12.         "type":"db2"
  13.         "driver":"com.ibm.db2.jcc.DB2Driver"
  14.         "url":"jdbc:db2://192.168.169.*:60990/dwdb"
  15.         "user""****"
  16.         "password":"****"
  17.         "encoding":"gbk" 
  18.     }, 
  19.  
  20.     "postgres":{ 
  21.         "type":"postgres"
  22.         "driver":"org.postgresql.Driver"
  23.         "url":"jdbc:postgresql://10.99.**.**:5432/apidb"
  24.         "user""****"
  25.         "password":"****"
  26.         "tbspace_ddl""WITH (compression=no, orientation=orc, version=0.12)\ntablespace hdfs\n"
  27.         "encoding":"utf-8" 
  28.     }, 
  29.  
  30.  
  31.     "aarondb":{ 
  32.         "type":"mysql"
  33.         "driver":"com.mysql.cj.jdbc.Driver"
  34.         "url":"jdbc:mysql://localhost:3306/aarondb?useSSL=false&characterEncoding=utf8&serverTimezone=UTC"
  35.         "user""****"
  36.         "password":"****"
  37.         "encoding":"utf-8" 
  38.     }, 
  39.  
  40.     "buffer-rows": 100000 

配置文件說明:

type 表示數據庫類型,均為小寫:

  • mysql
  • postgres
  • db2
  • oracle
  • sqlserver

tbspace_ddl 表示自動建表時指定的表空間,該選項不是必需的,可以刪除。

buffer-rows 表示讀取多少行時一塊寫入目標數據庫,根據服務器內存大小自己做調整,100000 行提交一次滿足大多數情況了。

encoding 用于表結構同步時確定字段長度,比如說源庫的字段是 gbk varchar(10),目標庫是 utf-8,那么就應該為 varchar(15),這樣字段有中文就不會出現截斷或插入失敗問題,程序這里 2 倍,也就是 varchar(20) ,這樣字段長度不會出現小數位。

最后的話

提高數據庫間表的復制效率,如果不需要對源表字段進行轉換,就丟掉低效的 datastage 和 kettle 吧。

 

責任編輯:華軒 來源: Python七號
相關推薦

2012-05-25 13:19:48

Web

2019-06-03 14:20:30

Java數據庫大數據工具

2012-11-30 09:42:48

iOS開發輔助工具資源

2013-11-21 10:56:33

iOS工具資源

2020-06-09 07:57:47

前端開發代碼

2024-07-31 08:50:20

2019-08-14 15:56:23

2012-05-14 18:35:20

Windows Pho

2018-04-08 10:08:43

開發人員工具

2021-04-12 22:24:01

Java開發程序員

2021-11-12 06:03:10

開發人員開發安全意識

2019-10-25 10:21:10

React 工具JavaScript

2013-06-13 10:15:20

WebWeb工具Web開發人員

2021-01-13 22:50:21

開發Web工具

2023-08-30 08:01:37

前端CSS

2012-03-20 13:58:50

JavaScript

2015-02-10 09:24:04

Web開發JavaScript工具

2010-11-02 15:26:32

MVC開發工具

2014-02-26 11:18:02

Android開發偷懶高效

2012-07-20 10:46:44

Web
點贊
收藏

51CTO技術棧公眾號

日本韩国欧美一区二区三区| 男人操女人的视频在线观看欧美| 日韩午夜在线播放| 国产96在线 | 亚洲| 九一国产在线| 国产高清亚洲一区| 日韩av大片免费看| 久操免费在线视频| 青青草国产免费一区二区下载 | 成人高清视频免费观看| 国产99在线|中文| 久草免费新视频| 欧美色爱综合| 亚洲精品二三区| 在线看免费毛片| 亚洲深夜视频| 亚洲资源中文字幕| 亚洲一卡二卡区| 色播色播色播色播色播在线| 精品亚洲aⅴ乱码一区二区三区| 7777精品久久久久久| 午夜国产福利一区二区| 精品日本12videosex| 亚洲国产私拍精品国模在线观看| 国产成年人视频网站| 小h片在线观看| 亚洲亚洲人成综合网络| 天天综合五月天| jizz在线观看视频| 91免费视频观看| 国产区一区二区| av一级黄色片| 精品综合久久久久久8888| 日韩av男人的天堂| 日韩特级黄色片| 在线精品亚洲| 久久久久久久久久久免费| 久草视频手机在线| 欧美大人香蕉在线| 国产香蕉一区二区三区在线视频 | 九九热精品视频国产| 免费黄在线观看| 国产乱码精品一区二区三区四区| 亚洲国产精品高清久久久| 成年人看片网站| 亚洲精品午夜| 精品欧美久久久| 成人做爰69片免费| 国产精品15p| 亚洲加勒比久久88色综合| 91porn在线| 激情av综合| 日韩成人av在线播放| 麻豆国产精品一区| 杨幂一区二区三区免费看视频| 精品无人区乱码1区2区3区在线| 亚洲精品乱码久久| 亚洲另类春色校园小说| 亚洲无线码在线一区观看| a资源在线观看| 日韩午夜电影网| 久久久91精品国产| 久草网在线观看| 亚洲欧洲一区二区天堂久久| 91成人免费观看网站| www亚洲视频| 日本亚洲免费观看| 成人av在线天堂| 精品人妻一区二区三区蜜桃| 成人网在线播放| 蜜桃网站成人| 午夜激情视频在线观看| 亚洲精品久久久蜜桃| 亚洲精品蜜桃久久久久久| 瑟瑟视频在线看| 日本二三区不卡| 日本高清一区二区视频| 国产精品一区二区中文字幕| 亚洲美女喷白浆| 美国黄色特级片| 欧美日韩综合| 日本不卡免费高清视频| 91高潮大合集爽到抽搐| 成人性色生活片| 色播五月综合| 日本电影在线观看| 色婷婷激情一区二区三区| 五月激情五月婷婷| 日韩福利视频一区| 视频在线观看99| 日韩av免费网址| 久久99最新地址| 国偷自产av一区二区三区小尤奈| 国产高清一区在线观看| 一区二区三区波多野结衣在线观看| 美女日批免费视频| 国产乱码精品一区二区三区亚洲人 | 亚洲精品成人a在线观看| 国产白丝袜美女久久久久| 久久电影天堂| 日韩av一卡二卡| 少妇人妻丰满做爰xxx| 国产毛片一区| 99国产在线视频| 超碰免费97在线观看| 亚洲国产一区二区在线播放| 黄色一级二级三级| 免费成人蒂法| 欧美成人剧情片在线观看| 自拍偷拍18p| 波波电影院一区二区三区| 在线不卡日本| 色婷婷综合久久久中字幕精品久久| 91精品国产免费久久综合| 国产免费无遮挡吸奶头视频| 精品动漫一区| 亚洲自拍高清视频网站| 97超碰国产一区二区三区| 黄色一区二区在线观看| 中文字幕第10页| 欧美高清视频手机在在线| 欧洲亚洲女同hd| 姝姝窝人体www聚色窝| 亚洲激情图片一区| 网站在线你懂的| 精品视频免费| 国产99久久久欧美黑人| 色吊丝在线永久观看最新版本| 亚洲高清三级视频| 黑人无套内谢中国美女| 国产精品不卡| 国产日韩av高清| 自拍视频在线播放| 欧美午夜电影在线播放| 国产全是老熟女太爽了| 亚洲一区久久| 欧美激情第一页在线观看| 91豆花视频在线播放| 欧美成人精精品一区二区频| 国产精品久久久精品四季影院| 久久精品国产在热久久| 亚洲精品在线免费看| 欧美日韩尤物久久| 中文字幕亚洲综合| 亚洲综合网av| 亚洲三级在线免费| 女人扒开双腿让男人捅| 国内自拍一区| 国产在线精品一区二区三区| h片在线观看视频免费| 亚洲第一免费网站| 国产午夜免费福利| 国产欧美精品一区二区三区四区| 国产av无码专区亚洲精品| 影视先锋久久| 国产精品丝袜视频| 久草资源在线| 日韩免费观看高清完整版在线观看| 黄色片在线观看网站| 成人三级伦理片| 国产在线精品91| 经典一区二区| 91精品视频专区| 国产三线在线| 亚洲乱码av中文一区二区| 91黑人精品一区二区三区| 国产精品久久99| www.欧美com| 欧美一级网站| 一本一道久久a久久综合精品 | 狠狠色噜噜狠狠色综合久| 午夜伦理福利在线| 色诱女教师一区二区三区| 99免费在线视频| 五月天一区二区三区| 日本xxxxxxxxx18| 狠狠色综合日日| 日本xxxxxxxxxx75| 欧美日韩中字| 春色成人在线视频| 免费亚洲电影| 久久夜精品香蕉| 日韩一二三四| 91精品国产91久久久久久最新毛片 | 青青操视频在线| 欧美久久一区二区| 全部毛片永久免费看| 国产精品视频在线看| av不卡中文字幕| 欧美aaa在线| 全黄性性激高免费视频| 日本成人小视频| 国产日韩一区欧美| 激情中国色综合| 97视频在线观看网址| 二区三区四区高清视频在线观看| 日韩精品久久久久久久玫瑰园| 国产男男gay网站| 日韩欧美一区二区三区| 加勒比av在线播放| 国产精品视频你懂的| 亚洲色图欧美日韩| 国产揄拍国内精品对白| 18岁视频在线观看| 亚洲天堂偷拍| 国产又大又长又粗又黄| 国产a久久精品一区二区三区| 51国产成人精品午夜福中文下载 | 国产视频亚洲| 国产一二三四区在线观看| 国产不卡一区| 久久久久se| 超碰成人福利| 亚洲一区二区三区四区视频| 久久亚洲精品爱爱| 97avcom| 好久没做在线观看| 伦伦影院午夜日韩欧美限制| 国产福利在线看| 国产视频在线观看一区二区| www黄色在线观看| 678五月天丁香亚洲综合网| 精品一区二三区| 欧美色另类天堂2015| 国产 日韩 欧美 成人| 亚洲欧美乱综合| 国精产品久拍自产在线网站| 国产欧美1区2区3区| 泷泽萝拉在线播放| 91在线免费视频观看| 国产婷婷在线观看| 岛国精品在线播放| 精人妻一区二区三区| 国产ts人妖一区二区| 一级 黄 色 片一| 狠狠色丁香久久婷婷综合丁香| 一女二男3p波多野结衣| 免费人成网站在线观看欧美高清| 成年人视频在线免费| 久久精品一区二区国产| 浮妇高潮喷白浆视频| 999亚洲国产精| 成人黄色av片| 国产日韩高清一区二区三区在线| 每日在线更新av| 野花国产精品入口| 免费黄色福利视频| 男女精品网站| 黄色aaa级片| 六月丁香婷婷久久| 婷婷中文字幕在线观看| 国产精品一级片在线观看| 人妻精品久久久久中文字幕69| 国产传媒一区在线| 午夜剧场免费看| 91麻豆精东视频| 国产毛片欧美毛片久久久| 国产欧美精品区一区二区三区| 国产jizz18女人高潮| 亚洲日本青草视频在线怡红院| 免费在线观看av网址| 亚洲h精品动漫在线观看| 国产午夜性春猛交ⅹxxx| 91国内精品野花午夜精品| 在线观看免费高清视频| 欧美一区二区三区免费大片| 亚洲乱码国产乱码精品精软件| 亚洲激情视频在线| www视频在线观看免费| 久久成年人免费电影| а√在线天堂官网| 国产精品激情自拍| 精品视频一区二区三区| 精品欧美日韩| 欧美电影免费| 美女扒开大腿让男人桶| 日欧美一区二区| 欧美性猛交xx| 26uuu精品一区二区三区四区在线| 日本一道本视频| 一区二区成人在线视频| 极品国产91在线网站| 91精品国产一区二区三区香蕉| 性高潮久久久久久久久久| 中文字幕欧美在线| 大香伊人久久| 国产精品三级在线| 成人性生交大片免费看中文视频| 日本一区二区在线| 欧美三区不卡| 午夜国产一区二区三区| 成人一区二区三区视频在线观看| 人妻aⅴ无码一区二区三区| 亚洲欧美色图小说| 午夜精品免费观看| 精品欧美一区二区久久| 在线观看免费版| 欧美一区二粉嫩精品国产一线天| 成人黄色理论片| 日韩欧美视频第二区| 亚洲一级一区| а 天堂 在线| 亚洲国产精品成人综合| 日本韩国欧美中文字幕| 日韩欧美的一区| 最新97超碰在线| 国产999精品| 久久精品凹凸全集| 亚洲色图都市激情| 麻豆精品视频在线观看免费| 91精品国产自产| 亚洲综合成人在线视频| 91麻豆成人精品国产| 亚洲区中文字幕| 麻豆蜜桃在线观看| 99r国产精品视频| 天天做天天爱天天综合网| 少妇性l交大片| www成人在线观看| 精品无码人妻一区二区三| 91精品国产综合久久精品图片| jizz在线观看中文| 国产精品爱啪在线线免费观看| 日韩av资源网| 国产v片免费观看| 成人性生交大片免费| 黄色一级视频免费| 欧美一区二区女人| 黄色在线播放网站| 国产乱肥老妇国产一区二 | 在线观看色网站| 亚洲视频一区二区| 欧美成a人片在线观看久| 久久人人爽爽人人爽人人片av| 亚洲第一毛片| 国产麻豆剧传媒精品国产av| 亚洲一区二区三区美女| 亚洲a视频在线观看| 欧美精品福利在线| 999久久精品| 日本久久久网站| 成人中文字幕在线| 国产精久久久久久| 亚洲国产三级网| 亚洲精品福利电影| 欧美成人dvd在线视频| 视频一区二区三区中文字幕| 加勒比一区二区| 日本黄色一区二区| 91.xxx.高清在线| 91免费视频网站| 欧美深夜福利| 亚洲精品中文字幕在线播放| 欧美日韩免费网站| 蝌蚪视频在线播放| 国产综合久久久久| 牛夜精品久久久久久久99黑人| 亚洲欧美激情一区二区三区| 亚洲午夜一二三区视频| 天天操天天操天天操| 日本韩国欧美精品大片卡二| 成人国产精品一级毛片视频| 午夜剧场高清版免费观看| 亚洲免费在线视频一区 二区| 黄色一级大片在线免费看国产一| 2021国产精品视频| av资源久久| www激情五月| 午夜精品福利一区二区蜜股av| 你懂的好爽在线观看| 国产欧美日韩专区发布| 欧美高清一区| www.色多多| 欧美精品三级在线观看| 91黄页在线观看| 亚洲国产精品123| 国产91丝袜在线播放九色| 精品乱码一区| 欧美天天影院| 国产成人精品电影久久久| 日本女优一区| 性感美女一区二区三区| 欧美视频中文字幕在线| 求av网址在线观看| 国产麻豆乱码精品一区二区三区| 美女网站久久| 中文字幕亚洲欧美日韩| 亚洲精品美女久久久| 综合欧美精品| 东京热加勒比无码少妇| 亚洲日本欧美天堂| 黄网在线免费| 国产精品久久久久久久免费大片| 狂野欧美一区| 久青草免费视频| www.欧美三级电影.com| 噜噜噜狠狠夜夜躁精品仙踪林| 一本一道久久a久久综合蜜桃| 午夜精品久久久久久久久久久 | 香蕉大人久久国产成人av|