DM7 使用dminit工具建立資料庫
1 功能簡介
dminit是DM資料庫初始化工具。在安裝DM的過程中,使用者可以選擇是否建立初始資料庫。如果當時沒有建立,那麼在安裝完成之後,可以利用建立資料庫工具dminit來建立。
系統管理員可以利用dminit工具提供的各種引數,設定資料庫存放路徑、段頁大小、是否對大小寫敏感、以及是否使用UNICODE等,建立出滿足使用者需要的資料庫。該工具位於安裝目錄的/bin目錄下。
2 使用dminit
dminit工具需要從命令列啟動。找到dminit所在安裝目錄/bin,輸入dminit和引數後回車。引數在下一節詳細介紹。
語法如下:
dminit KEYWORD=value { KEYWORD=value }
KEYWORD:dminit引數關鍵字。多個引數之間排列順序無影響,引數之間使用空格間隔。value:引數取值。
dminit如果沒有帶引數,系統會引導使用者進行設定。引數、等號和值之間不能有空格,例如PAGE_SIZE=16。HELP引數的後面不用新增“=”號。
例如,初始化一個資料庫,放在/home/test/dmdbms目錄下,資料頁PAGE_SIZE大小為16K。
./dminit PATH=/home/test/dmdbms PAGE_SIZE=16
如果建立成功,則螢幕顯示如下:
initdb V7.1.5.22-Build(2015.11.17-62910trunc) db version: 0x70009 create dm database success. 2015-12-21 15:46:27
此時在/home/test/dmdbms目錄下會出現一個DAMENG資料夾,內容包含初始資料庫DAMENG的相關檔案和DM資料庫啟動所必須的配置檔案dm.ini。
3 檢視dminit引數
dminit使用較為靈活,引數較多。使用者可使用“dminit HELP”快速檢視各引數。
[dmdba@ora19c bin]$ ./dminit help initdb V7.1.6.46-Build(2018.02.08-89107)ENT db version: 0x7000a file dm.key not found, use default license! License will expire on 2020-06-05 Format: ./dminit KEYWORD=value Example: ./dminit PATH=/public/dmdb/dmData PAGE_SIZE=16 Keyword Explanation(default value) -------------------------------------------------------------------------------- INI_FILE dm.ini path PATH database path CTL_PATH control file path LOG_PATH log file path EXTENT_SIZE extent size of data file(16), optional value: 16,32, unit: PAGE PAGE_SIZE page size(8), optional value: 4,8,16,32, unit: K LOG_SIZE log file size(256), unit: M, range: 64M ~ 2G CASE_SENSITIVE whether case is sensitive(Y), optional value: Y/N or 1/0 CHARSET/UNICODE_FLAG CHARSET(0), optional value:0[GB18030],1[UTF-8],2[EUC-KR] LENGTH_IN_CHAR whether LENGTH for VARCHAR is in characters(N), optional value: Y/N, 1/0 SYSDBA_PWD set SYSDBA password(SYSDBA), password length must between 9 and 48 SYSAUDITOR_PWD set SYSAUDITOR password(SYSAUDITOR), password length must between 9 and 48 DB_NAME database name(DAMENG) INSTANCE_NAME instance name(DMSERVER) PORT_NUM listener port(5236) TIME_ZONE set time zone(+08:00) PAGE_CHECK page check mode(0), optional value: 0/1/2 EXTERNAL_CIPHER_NAME set default encrypt/decrypt algorithm EXTERNAL_HASH_NAME set default hash algorithm EXTERNAL_CRYPTO_NAME set crypto name to encrypt svr key RLOG_ENC_FLAG whether encrypt redo log(N), optional value: Y/N, 1/0 USBKEY_PIN set usbkey pin ENCRYPT_NAME set algorithm for encrypt the whole database BLANK_PAD_MODE set blank padding mode(0), optional value:0/1 SYSTEM_MIRROR_PATH mirror path of system data file MAIN_MIRROR_PATH mirror path of main file ROLL_MIRROR_PATH mirror path of roll file MAL_FLAG MAL_INI flag(0) in dm.ini ARCH_FLAG ARCH_INI(0) flag in dm.ini MPP_FLAG MPP_INI(0) flag in dm.ini CONTROL control file path! AUTO_OVERWRITE whether overwrite all files with the same name(0) 0: no 1: part 2: all USE_NEW_HASH whether use new hash algorithm for string. (default 1) DCP_MODE whether is DM CLUSTER PROXY mode(default 0) DCP_PORT_NUM in DCP mode, set dcp_port_num ELOG_PATH set the path of log file recording the contents during initialization HELP print help information
4 dminit初始化資料庫
CONTROL引數是dminit工具的高階功能,用於初始化資料庫時指定初始化配置檔案。初始化配置檔案是一個儲存了各資料檔案路徑和大小設定、所有dminit工具的命令列引數設定等資訊的文字,名稱由使用者自己選取,例如:dminit.ini 、abc.txt、dminit.ctl等。
dminit工具使用CONTROL引數,就不能再指定其他引數,CONTROL引數只能單獨使用。
DM既支援初始化單機資料庫,又支援初始化RAC叢集的資料庫。操作非常簡單,只要在使用dminit工具建立資料庫的時候,使用CONTROL引數指定初始化配置檔案即可。
例如:初始化配置檔案為dminit.ini。
./dminit CONTROL=/home/data/dminit.ini
初始化配置檔案(本章統一命名為dminit.ini)內容如何書寫,單機和RAC環境下略有不同,下面分別詳細介紹。
4.1 初始化單機資料庫
DM支援初始化資料庫到一個普通機器上或是一個共享儲存上。本節以檔案系統為例,初始化單機資料庫。涉及路徑和檔案大小的引數配置。
例如,在檔案系統上建立資料庫。引數path、main、system、roll、ctl_path、log01、log02都指定了檔案系統,單機配置檔案(命名dminit.ini)書寫如下:
[dmdba@ora19c dm7]$ cat dminit.ini [jy] --例項名使用control配置檔案指定例項不能使用instance_name引數 db_name = jy path =/dm7/data main = /dm7/data/jy/main.dbf main_size = 256 system = /dm7/data/jy//system.dbf system_size = 256 roll = /dm7/data/jy//roll.dbf roll_size = 256 ctl_path = /dm7/data/jy/dm.ctl log_path = /dm7/data/jy/log01.log log_path = /dm7/data/jy/log02.log log_size = 128 auto_overwrite = 2 初始化資料庫 [dmdba@ora19c bin]$ ./dminit control=/dm7/dminit.ini initdb V7.1.6.46-Build(2018.02.08-89107)ENT db version: 0x7000a file dm.key not found, use default license! License will expire on 2020-06-05 log file path: /dm7/data/jy/log01.log log file path: /dm7/data/jy/log02.log write to dir [/dm7/data/jy]. create dm database success. 2020-05-22 22:36:10 註冊資料庫服務 [root@ora19c root]# ./dm_service_installer.sh -t dmserver -p jy -i /dm7/data/jy/dm.ini -m open ln -s '/usr/lib/systemd/system/DmServicejy.service' '/etc/systemd/system/multi-user.target.wants/DmServicejy.service' Finished to create the service (DmServicejy) [root@ora19c root]# systemctl start DmServicejy [root@ora19c root]# ps -ef | grep dmserver dmdba 31843 1 21 01:29 ? 00:00:05 /dm7/bin/dmserver /dm7/data/jy/dm.ini -noconsole root 31901 3225 0 01:30 pts/2 00:00:00 grep --color=auto dmserver 連線資料庫 [dmdba@ora19c ~]$ disql SYSDBA/SYSDBA@10.13.13.140:5236 Server[10.13.13.140:5236]:mode is normal, state is open login used time: 10.975(ms) disql V7.1.6.46-Build(2018.02.08-89107)ENT Connected to: DM 7.1.6.46 SQL> select * from v$version; LINEID BANNER ---------- ------------------------------------------------------------- 1 DM Database Server x64 V7.1.6.46-Build(2018.02.08-89107)ENT 2 DB Version: 0x7000a used time: 3.827(ms). Execute id is 807.
4.2初始化RAC叢集的資料庫
DM RAC是一個單資料庫、多例項的叢集系統,資料庫部署在共享儲存上,供所有節點訪問,具有高可用性、高效能、低成本等特性。DM支援在RAC環境下建立資料庫。RAC的初始化庫配置檔案dminit.ini中涉及到的引數,是在單機dminit.ini基礎上,增加了RAC節點資訊。同時,把單機dminit.ini中node_instance引數去掉,log_size,log_path二個引數下放到每個RAC節點裡。
準備dminit.ini 配置檔案
在2個節點的/dm/dmdbms/data目錄下建立 dminit.ini 配置檔案,新增如下內容。 在2個節點都建立。
[dmdba@dmrac1 data]$ vi dminit.ini db_name = rac system_path = +DMDATA/data system = +DMDATA/data/rac/system.dbf system_size = 128 roll = +DMDATA/data/rac/roll.dbf roll_size = 128 main = +DMDATA/data/rac/main.dbf main_size = 128 ctl_path = +DMDATA/data/rac/dm.ctl ctl_size = 8 log_size = 256 dcr_path = /dev/raw/raw1 #dcr 磁碟路徑,目前不支援 asm,只能是裸裝置 dcr_seqno = 0 auto_overwrite = 1 [RAC0] #inst_name 跟 dmdcr_cfg.ini 中 DB 型別 group 中 DCR_EP_NAME 對應 config_path = /dm7/data/rac0_config port_num = 5236 mal_host = 10.10.10.161 mal_port = 9340 log_path = +DMLOG/log/rac0_log01.log log_path = +DMLOG/log/rac0_log02.log [RAC1] #inst_name 跟 dmdcr_cfg.ini 中 DB 型別 group 中 DCR_EP_NAME 對應 config_path = /dm7/data/rac1_config port_num = 5236 mal_host = 10.10.10.162 mal_port = 9341 log_path = +DMLOG/log/rac1_log01.log log_path = +DMLOG/log/rac1_log02.log [dmdba@dmrac2 data]$ vi dminit.ini db_name = rac system_path = +DMDATA/data system = +DMDATA/data/rac/system.dbf system_size = 128 roll = +DMDATA/data/rac/roll.dbf roll_size = 128 main = +DMDATA/data/rac/main.dbf main_size = 128 ctl_path = +DMDATA/data/rac/dm.ctl ctl_size = 8 log_size = 256 dcr_path = /dev/raw/raw1 #dcr 磁碟路徑,目前不支援 asm,只能是裸裝置 dcr_seqno = 0 auto_overwrite = 1 [RAC0] #inst_name 跟 dmdcr_cfg.ini 中 DB 型別 group 中 DCR_EP_NAME 對應 config_path = /dm7/data/rac0_config port_num = 5236 mal_host = 10.10.10.161 mal_port = 9340 log_path = +DMLOG/log/rac0_log01.log log_path = +DMLOG/log/rac0_log02.log [RAC1] #inst_name 跟 dmdcr_cfg.ini 中 DB 型別 group 中 DCR_EP_NAME 對應 config_path = /dm7/data/rac1_config port_num = 5236 mal_host = 10.10.10.162 mal_port = 9341 log_path = +DMLOG/log/rac1_log01.log log_path = +DMLOG/log/rac1_log02.log
使用dminit初始化資料庫
在任意節點啟動 dminit 工具初始化資料庫。dminit 執行完成後,會在 config_path 目錄(/dm7/data/rac0_config 和/dm7/data/rac1_config)下生成配置檔案 dm.ini 和 dmmal.ini。
[dmdba@dmrac1 data]$ dminit control=/dm7/data/dminit.ini initdb V7.1.6.46-Build(2018.02.08-89107)ENT db version: 0x7000a file dm.key not found, use default license! License will expire on 2020-05-08 log file path: +DMLOG/log/rac0_log01.log log file path: +DMLOG/log/rac0_log02.log log file path: +DMLOG/log/rac1_log01.log log file path: +DMLOG/log/rac1_log02.log write to dir [+DMDATA/data/rac]. create dm database success. 2020-04-24 16:39:03
將節點一的配置檔案複製到節點二:
[dmdba@dmrac1 data]$ scp -r rac1_config 10.13.13.162:`pwd` The authenticity of host '10.13.13.162 (10.13.13.162)' can't be established. RSA key fingerprint is 89:fc:3e:e3:2d:27:94:07:0e:6b:fc:c5:e8:89:44:1f. Are you sure you want to continue connecting (yes/no)? yes Warning: Permanently added '10.13.13.162' (RSA) to the list of known hosts. dmdba@10.13.13.162's password: sqllog.ini 100% 479 0.5KB/s 00:00 dm.ini 100% 40KB 39.8KB/s 00:00 dmmal.ini 100% 204 0.2KB/s 00:00 [dmdba@dmrac1 data]$
啟動資料庫伺服器
1、在2個節點分別註冊DM 資料庫服務:
節點一:
[root@dmrac1 init.d]# /dm7/script/root/dm_service_installer.sh -t dmserver -i /dm7/data/rac0_config/dm.ini -d /dm7/data/dmdcr.ini -p rac1 Move the service script file(/dm7/bin/DmServicerac1 to /etc/rc.d/init.d/DmServicerac1) Finished to create the service (DmServicerac1) 節點二: [root@dmrac2 ~]# /dm7/script/root/dm_service_installer.sh -t dmserver -i /dm7/data/rac1_config/dm.ini -d /dm7/data/dmdcr.ini -p rac2 Move the service script file(/dm7/bin/DmServicerac2 to /etc/rc.d/init.d/DmServicerac2) Finished to create the service (DmServicerac2)
2、啟動資料庫
[root@dmrac1 init.d]# service DmServicerac1 start Starting DmServicerac1: [ OK ] [root@dmrac2 ~]# service DmServicerac2 start Starting DmServicerac2: [ OK ]
手工啟動命令如下,手工啟動後視窗不能關閉,所以
./dmserver /dm7/data/rac0_config/dm.ini dcr_ini=/dm7/data/dmdcr.ini ./dmserver /dm7/data/rac1_config/dm.ini dcr_ini=/dm7/data/dmdcr.ini
連線資料庫驗證
1 配置服務名檔案
[dmdba@dmrac1 ~]$ vi /etc/dm_svc.conf TIME_ZONE=(480) rac=(10.13.13.161:5236,10.13.13.162:5236) SWITCH_TIME=(10000) SWITCH_INTERVAL=(10) TIME_ZONE=(480) LANGUAGE=(en) [dmdba@dmrac2 ~]$ vi /etc/dm_svc.conf TIME_ZONE=(480) rac=(10.13.13.161:5236,10.13.13.162:5236) SWITCH_TIME=(10000) SWITCH_INTERVAL=(10) TIME_ZONE=(480) LANGUAGE=(en)
2連線RAC叢集
[dmdba@dmrac1 ~]$ disql SYSDBA/SYSDBA@rac Server[10.13.13.161:5236]:mode is normal, state is open login used time: 10.365(ms) disql V7.1.6.46-Build(2018.02.08-89107)ENT Connected to: DM 7.1.6.46 SQL> select instance_name from v$instance; LINEID INSTANCE_NAME ---------- ------------- 1 RAC0 used time: 18.248(ms). Execute id is 807. SQL> select * from v$rac_ep_info; LINEID EP_NAME EP_SEQNO EP_GUID EP_TIMESTAMP EP_MODE EP_STATUS ---------- ------- ----------- -------------------- -------------------- ------- --------- 1 RAC0 0 2067076818 2067077298 MASTER OK 2 RAC1 1 2067098084 2067098537 SLAVE OK used time: 2.741(ms). Execute id is 808.
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31545819/viewspace-2693787/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- DM7使用dmrestore工具還原資料庫REST資料庫
- DM7使用dmrestore工具利用不同資料庫的歸檔恢復資料庫REST資料庫
- DM7使用離線工具DMRMAN執行資料庫備份資料庫
- DM7使用DMRMAN執行RAC資料庫恢復資料庫
- DM7修改資料庫引數資料庫
- DM7 RAC資料庫恢復成單機資料庫資料庫
- 2 Day DBA-使用DBCA建立和管理資料庫—使用DBCA建立資料庫資料庫
- 使用RMAN建立Duplicate資料庫資料庫
- 建立資料庫時使用schema資料庫
- 使用rman建立standby資料庫資料庫
- DM7使用DMRMAN執行資料庫還原和恢復資料庫
- DM7資料複製之資料庫級複製資料庫
- DM7使用DMRMAN恢復資料庫到指定時間點/LSN資料庫
- 使用命令列建立資料庫命令列資料庫
- 使用RMAN建立物理Standby資料庫資料庫
- 達夢DM7 資料庫之資料守護DG搭建資料庫
- 安裝mongodb,建立資料庫、使用者、建立表、匯出匯入資料庫MongoDB資料庫
- 建立資料庫資料庫
- 建立MySQL資料庫備份的好工具:XtraBackupMySql資料庫
- 使用RMAN建立資料庫備份庫(筆記)資料庫筆記
- 2.3.1 有關使用DBCA建立資料庫資料庫
- 2.4.1 使用 CREATE DATABASE 子句建立資料庫Database資料庫
- AIX下使用dbca建立oracle資料庫AIOracle資料庫
- 資料庫及使用者的建立資料庫
- 關係型資料庫:使用正規化建立資料庫(轉)資料庫
- DM7使用DMRMAN對資料庫執行指定對映檔案還原資料庫
- MySQL 建立資料庫 建立表MySql資料庫
- 2.4 使用 CREATE DATABASE 語句建立資料庫Database資料庫
- 4.2.11 使用 SRVCTL 建立資料庫服務資料庫
- MacOS使用Docker建立MySQL主從資料庫MacDockerMySql資料庫
- MacOS使用Docker建立MySQL主主資料庫MacDockerMySql資料庫
- oracle資料庫使用者建立步驟Oracle資料庫
- 2 Day DBA-使用DBCA建立資料庫資料庫
- 使用RMAN進行快速Dataguard資料庫建立資料庫
- Oralce 10g 使用DBCA建立資料庫資料庫
- 建立資料庫表資料庫
- Mysql建立資料庫MySql資料庫
- 建立資料庫命令資料庫