মূলত TriCore দ্বারা প্রকাশিত:জুন 6, 2017
Oracle® ডেটা পাম্প (expdp, impdp) ডাটাবেসের মধ্যে এবং জুড়ে ডেটাবেস অবজেক্ট রপ্তানি এবং আমদানি করার জন্য একটি ইউটিলিটি। যদিও বেশিরভাগ ডাটাবেস প্রশাসক ডেটা পাম্প সম্পর্কে সচেতন, OracleDatabase 12c-এ মাল্টিটেন্যান্ট আর্কিটেকচারের জন্য সমর্থন কীভাবে ডেটা পাম্প ডেটা রপ্তানি এবং আমদানি করে তার পরিবর্তনগুলি চালু করেছে৷
পরিচয়
এই দুই-অংশের ব্লগ সিরিজে Oracle Data PumpExport (expdp) প্রযুক্তির পরিবর্তনগুলি এবং আপনার ডাটাবেস আর্কিটেকচারের উপাদানগুলির রপ্তানি করতে কীভাবে এটি ব্যবহার করা যায় তা কভার করে৷
এই পোস্টের উদাহরণগুলি একটিকন্টেইনার ডাটাবেস এর পরিপ্রেক্ষিতে রপ্তানির উপর ফোকাস করে৷ (CDB), যা ওরাকল মেটাডেটা ধারণ করে এবং এক বা একাধিকপ্লাগেবল ডেটাবেস (PDBs), যা আপনার প্রকৃত তথ্য ধারণ করে।
পিডিবি এবং সিডিবি সম্পর্কে আরও তথ্যের জন্য, মাল্টিটেন্যান্ট আর্কিটেকচারের ভূমিকা দেখুন।
একটি সম্পূর্ণ ডাটাবেস এক্সপোর্ট নেওয়া
একটি সম্পূর্ণ ডাটাবেস রপ্তানি অগত্যা আপনি চান যে সমস্ত ডেটা অন্তর্ভুক্ত করে না। উদাহরণ স্বরূপ, আপনি ভাবতে পারেন যে আপনি যখন থেরুট কন্টেইনার বা CDB-এর সাথে সংযোগ করেন এবং ডাটাবেসের afullexport নেন, তখন রপ্তানি এর অন্তর্ভুক্ত সমস্ত PDB অন্তর্ভুক্ত করে। যাইহোক, এটি ক্ষেত্রে নয়। রুট কন্টেইনার থেকে সম্পূর্ণ রপ্তানি শুধুমাত্র সেই বস্তু রপ্তানি করে যা রুট কন্টেইনারের অন্তর্গত, PDB নয়।
উদাহরণস্বরূপ, PRODCDB
নামের একটি CDB বিবেচনা করুন যেটি চারটি PDB-এর সাথে যুক্ত। নিম্নলিখিত কমান্ডটি এই ডাটাবেস সম্পর্কে বিস্তারিত তথ্য তুলে ধরে:
sys@PRODCDB> select name,open_mode,con_id from v$pdbs;
নিম্নলিখিত কোড ব্লক টেবিলটি দেখায় যা এই কমান্ড তৈরি করে:
NAME OPEN_MODE CON_ID
------------------------------ ---------- ----------
PDB$SEED READ ONLY 2
PRODPDB1 READ WRITE 3
PRODPDB2 READ WRITE 4
PRODPDB3 READ WRITE 5
PRODPDB4 READ WRITE 6
আপনি যখন afullexport নেওয়ার চেষ্টা করেন, EXPDP শুধুমাত্র রুট কন্টেইনারের অন্তর্গত একটি বস্তুর রপ্তানি করে, এবং সমস্ত প্লাগযোগ্য ডাটাবেসের বস্তু নয়।
নিম্নলিখিত কমান্ডটি রপ্তানি করে:
[oracle@labserver ~]$ expdp directory=DPUMP dumpfile=exp_cdb_full_%U.dmp logfile=exp_cdb_full.log full=Y parallel=4
নিম্নলিখিত কোড ব্লক এই অপারেশন থেকে আউটপুট দেখায়:
Export: Release 12.1.0.1.0 - Production on Thu Mar 26 23:10:41 2015
Copyright (c) 1982, 2013, Oracle and/or its affiliates. All rights reserved.
Username: / as sysdba
Connected to: Oracle Database 12c Enterprise Edition Release 12.1.0.1.0 - 64bit Production
With the Partitioning, Automatic Storage Management, OLAP, Advanced Analytics
and Real Application Testing options
WARNING: Oracle Data Pump operations are not typically needed when connected to the root or seed of a container database. Below are the steps for exporting of full database.
Starting "SYS"."SYS_EXPORT_FULL_01": /******** AS SYSDBA directory=DPUMP dumpfile=exp_cdb_full_%U.dmp logfile=exp_cdb_full.log full=Y parallel=4
Estimate in progress using BLOCKS method...
Processing object type DATABASE_EXPORT/EARLY_OPTIONS/VIEWS_AS_TABLES/TABLE_DATA
Processing object type DATABASE_EXPORT/NORMAL_OPTIONS/TABLE_DATA
Processing object type DATABASE_EXPORT/NORMAL_OPTIONS/VIEWS_AS_TABLES/TABLE_DATA
Processing object type DATABASE_EXPORT/SCHEMA/TABLE/TABLE_DATA
Total estimation using BLOCKS method: 90.70 MB
Processing object type DATABASE_EXPORT/PRE_SYSTEM_IMPCALLOUT/MARKER
Processing object type DATABASE_EXPORT/PRE_INSTANCE_IMPCALLOUT/MARKER
Processing object type DATABASE_EXPORT/TABLESPACE
Processing object type DATABASE_EXPORT/PROFILE
Processing object type DATABASE_EXPORT/SYS_USER/USER
Processing object type DATABASE_EXPORT/SCHEMA/USER
. . exported "LBACSYS"."OLS$AUDIT_ACTIONS" 5.734 KB 8 rows
Processing object type DATABASE_EXPORT/ROLE
. . exported "LBACSYS"."OLS$DIP_EVENTS" 5.515 KB 2 rows
. . exported "LBACSYS"."OLS$INSTALLATIONS" 6.937 KB 2 rows
Processing object type DATABASE_EXPORT/RADM_FPTM
. . exported "LBACSYS"."OLS$PROPS" 6.210 KB 5 rows
. . exported "SYS"."DAM_CONFIG_PARAM$" 6.507 KB 14 rows
. . exported "SYS"."TSDP_PARAMETER$" 5.929 KB 1 rows
. . exported "SYS"."TSDP_POLICY$" 5.898 KB 1 rows
. . exported "SYS"."TSDP_SUBPOL$" 6.304 KB 1 rows
. . exported "SYSTEM"."REDO_DB" 23.42 KB 1 rows
. . exported "WMSYS"."WM$ENV_VARS$" 6.054 KB 5 rows
. . exported "WMSYS"."WM$EVENTS_INFO$" 5.789 KB 12 rows
. . exported "WMSYS"."WM$HINT_TABLE$" 9.429 KB 75 rows
. . exported "WMSYS"."WM$NEXTVER_TABLE$" 6.351 KB 1 rows
Processing object type DATABASE_EXPORT/GRANT/SYSTEM_GRANT/PROC_SYSTEM_GRANT
. . exported "WMSYS"."WM$VERSION_HIERARCHY_TABLE$" 5.960 KB 1 rows
Processing object type DATABASE_EXPORT/SCHEMA/GRANT/SYSTEM_GRANT
Processing object type DATABASE_EXPORT/SCHEMA/ROLE_GRANT
Processing object type DATABASE_EXPORT/SCHEMA/DEFAULT_ROLE
. . exported "WMSYS"."WM$WORKSPACES_TABLE$" 12.08 KB 1 rows
. . exported "WMSYS"."WM$WORKSPACE_PRIV_TABLE$" 6.539 KB 8 rows
. . exported "LBACSYS"."OLS$AUDIT" 0 KB 0 rows
. . exported "LBACSYS"."OLS$COMPARTMENTS" 0 KB 0 rows
. . exported "LBACSYS"."OLS$DIP_DEBUG" 0 KB 0 rows
. . exported "LBACSYS"."OLS$GROUPS" 0 KB 0 rows
. . exported "LBACSYS"."OLS$LAB" 0 KB 0 rows
. . exported "LBACSYS"."OLS$LEVELS" 0 KB 0 rows
. . exported "LBACSYS"."OLS$POL" 0 KB 0 rows
Processing object type DATABASE_EXPORT/SCHEMA/ON_USER_GRANT
. . exported "LBACSYS"."OLS$POLICY_ADMIN" 0 KB 0 rows
. . exported "LBACSYS"."OLS$POLS" 0 KB 0 rows
. . exported "LBACSYS"."OLS$POLT" 0 KB 0 rows
. . exported "LBACSYS"."OLS$PROFILE" 0 KB 0 rows
. . exported "LBACSYS"."OLS$PROFILES" 0 KB 0 rows
. . exported "LBACSYS"."OLS$PROG" 0 KB 0 rows
. . exported "LBACSYS"."OLS$SESSINFO" 0 KB 0 rows
. . exported "LBACSYS"."OLS$USER" 0 KB 0 rows
. . exported "LBACSYS"."OLS$USER_COMPARTMENTS" 0 KB 0 rows
. . exported "LBACSYS"."OLS$USER_GROUPS" 0 KB 0 rows
. . exported "LBACSYS"."OLS$USER_LEVELS" 0 KB 0 rows
. . exported "SYS"."AUD$" 0 KB 0 rows
. . exported "SYS"."DAM_CLEANUP_EVENTS$" 0 KB 0 rows
. . exported "SYS"."DAM_CLEANUP_JOBS$" 0 KB 0 rows
. . exported "SYS"."TSDP_ASSOCIATION$" 0 KB 0 rows
. . exported "SYS"."TSDP_CONDITION$" 0 KB 0 rows
. . exported "SYS"."TSDP_FEATURE_POLICY$" 0 KB 0 rows
. . exported "SYS"."TSDP_PROTECTION$" 0 KB 0 rows
. . exported "SYS"."TSDP_SENSITIVE_DATA$" 0 KB 0 rows
. . exported "SYS"."TSDP_SENSITIVE_TYPE$" 0 KB 0 rows
. . exported "SYS"."TSDP_SOURCE$" 0 KB 0 rows
. . exported "SYSTEM"."REDO_LOG" 0 KB 0 rows
. . exported "WMSYS"."WM$BATCH_COMPRESSIBLE_TABLES$" 0 KB 0 rows
. . exported "WMSYS"."WM$CONSTRAINTS_TABLE$" 0 KB 0 rows
. . exported "WMSYS"."WM$CONS_COLUMNS$" 0 KB 0 rows
. . exported "WMSYS"."WM$LOCKROWS_INFO$" 0 KB 0 rows
. . exported "WMSYS"."WM$MODIFIED_TABLES$" 0 KB 0 rows
. . exported "WMSYS"."WM$MP_GRAPH_WORKSPACES_TABLE$" 0 KB 0 rows
. . exported "WMSYS"."WM$MP_PARENT_WORKSPACES_TABLE$" 0 KB 0 rows
. . exported "WMSYS"."WM$NESTED_COLUMNS_TABLE$" 0 KB 0 rows
. . exported "WMSYS"."WM$REMOVED_WORKSPACES_TABLE$" 0 KB 0 rows
. . exported "WMSYS"."WM$RESOLVE_WORKSPACES_TABLE$" 0 KB 0 rows
. . exported "WMSYS"."WM$RIC_LOCKING_TABLE$" 0 KB 0 rows
. . exported "WMSYS"."WM$RIC_TABLE$" 0 KB 0 rows
. . exported "WMSYS"."WM$RIC_TRIGGERS_TABLE$" 0 KB 0 rows
. . exported "WMSYS"."WM$UDTRIG_DISPATCH_PROCS$" 0 KB 0 rows
. . exported "WMSYS"."WM$UDTRIG_INFO$" 0 KB 0 rows
. . exported "WMSYS"."WM$VERSION_TABLE$" 0 KB 0 rows
. . exported "WMSYS"."WM$VT_ERRORS_TABLE$" 0 KB 0 rows
. . exported "WMSYS"."WM$WORKSPACE_SAVEPOINTS_TABLE$" 0 KB 0 rows
Processing object type DATABASE_EXPORT/SCHEMA/TABLESPACE_QUOTA
Processing object type DATABASE_EXPORT/RESOURCE_COST
Processing object type DATABASE_EXPORT/TRUSTED_DB_LINK
Processing object type DATABASE_EXPORT/DIRECTORY/DIRECTORY
. . exported "SYS"."KU$\_USER_MAPPING_VIEW" 6.054 KB 36 rows
Processing object type DATABASE_EXPORT/SYSTEM_PROCOBJACT/PRE_SYSTEM_ACTIONS/PROCACT_SYSTEM
Processing object type DATABASE_EXPORT/SYSTEM_PROCOBJACT/PROCOBJ
Processing object type DATABASE_EXPORT/SYSTEM_PROCOBJACT/POST_SYSTEM_ACTIONS/PROCACT_SYSTEM
Processing object type DATABASE_EXPORT/SCHEMA/PROCACT_SCHEMA
. . exported "SYSTEM"."SCHEDULER_JOB_ARGS" 8.640 KB 4 rows
Processing object type DATABASE_EXPORT/EARLY_OPTIONS/VIEWS_AS_TABLES/TABLE
Processing object type DATABASE_EXPORT/EARLY_POST_INSTANCE_IMPCALLOUT/MARKER
. . exported "ORDDATA"."ORDDCM_DOCS" 252.9 KB 9 rows
Processing object type DATABASE_EXPORT/NORMAL_OPTIONS/TABLE
. . exported "SYSTEM"."SCHEDULER_PROGRAM_ARGS" 10.18 KB 22 rows
. . exported "SYS"."AUDTAB$TBS$FOR_EXPORT" 5.929 KB 2 rows
. . exported "SYS"."NACL$\_ACE_EXP" 9.906 KB 1 rows
. . exported "SYS"."NACL$\_HOST_EXP" 6.890 KB 1 rows
. . exported "WMSYS"."WM$EXP_MAP" 7.695 KB 3 rows
. . exported "SYS"."DBA_SENSITIVE_DATA" 0 KB 0 rows
. . exported "SYS"."DBA_TSDP_POLICY_PROTECTION" 0 KB 0 rows
. . exported "SYS"."FGA_LOG$FOR_EXPORT" 0 KB 0 rows
. . exported "SYS"."NACL$\_WALLET_EXP" 0 KB 0 rows
. . exported "C##ABBAS"."T" 72.67 MB 667728 rows
Processing object type DATABASE_EXPORT/NORMAL_OPTIONS/VIEWS_AS_TABLES/TABLE
Processing object type DATABASE_EXPORT/NORMAL_POST_INSTANCE_IMPCALLOU/MARKER
Processing object type DATABASE_EXPORT/SCHEMA/TABLE/TABLE
Processing object type DATABASE_EXPORT/SCHEMA/TABLE/STATISTICS/TABLE_STATISTICS
Processing object type DATABASE_EXPORT/STATISTICS/MARKER
Processing object type DATABASE_EXPORT/FINAL_POST_INSTANCE_IMPCALLOUT/MARKER
Processing object type DATABASE_EXPORT/SCHEMA/POST_SCHEMA/PROCOBJ
Processing object type DATABASE_EXPORT/SCHEMA/POST_SCHEMA/PROCACT_SCHEMA
Processing object type DATABASE_EXPORT/AUDIT_UNIFIED/AUDIT_POLICY_ENABLE
Processing object type DATABASE_EXPORT/AUDIT
Processing object type DATABASE_EXPORT/POST_SYSTEM_IMPCALLOUT/MARKER
Master table "SYS"."SYS_EXPORT_FULL_01" successfully loaded/unloaded
******************************************************************************
Dump file set for SYS.SYS_EXPORT_FULL_01 is:
/backup/exp/prodcdb/exp_cdb_full_01.dmp
/backup/exp/prodcdb/exp_cdb_full_02.dmp
/backup/exp/prodcdb/exp_cdb_full_03.dmp
Job "SYS"."SYS_EXPORT_FULL_01" successfully completed at Thu Mar 26 13:49:26 2015 elapsed 0 00:08:34
আউটপুট দেখায় যে শুধুমাত্র রুট কন্টেইনারের অন্তর্গত বস্তুগুলি full
দিয়ে রপ্তানি করা হয় বিকল্প দুর্ভাগ্যবশত, সমস্ত PDB এবং রুট কন্টেইনার একসাথে এক্সপোর্ট করার কোন উপায় নেই।
একটি CDB রপ্তানি করা
সিডিবি বা রুট ডাটাবেস রপ্তানি করা সাধারণত প্রয়োজন হয় না কারণ এটি প্রাথমিকভাবে পিডিবি হোস্ট করে। যাইহোক, যদি এই কাজটি সম্পাদন করা প্রয়োজন হয়, আপনি একটি নতুন CDB তৈরি করতে পারেন এবং বিদ্যমান পিডিবিগুলিকে প্লাগ করতে পারেন৷ এই ক্ষেত্রে, অ্যাডমিনিস্ট্রেটররা সাধারণত সাধারণ ব্যবহারকারী এবং ভূমিকাগুলির একটি এক্সপোর্ট নিতে সবচেয়ে বেশি আগ্রহী৷
উদাহরণস্বরূপ, কল্পনা করুন যে আপনার একটি CDB-তে নিম্নলিখিত সাধারণ ব্যবহারকারী রয়েছে:
sys@PRODCDB> select USERNAME, COMMON from dba_users where common='YES' and oracle_maintained='N';
USERNAME COM
--------------- ---
C##ABBAS YES
আপনি CDB-এর জন্য EXPDP শুরু করতে নিম্নলিখিত কমান্ডটি ব্যবহার করে একটি CDB-এর অন্তর্গত সাধারণ ব্যবহারকারী এবং ভূমিকাগুলির একটি রপ্তানি নিতে পারেন:
[oracle@labserver ~]$ expdp directory=DATA_PUMP_DIR dumpfile=common_usr_cdb.dmp logfile=common_usr_cdb.log schemas=C##ABBAS
নিম্নলিখিত কোড ব্লক এই কমান্ডের আউটপুট দেখায়:
Export: Release 12.1.0.1.0 - Production on Thu Mar 26 23:45:26 2015
Copyright (c) 1982, 2013, Oracle and/or its affiliates. All rights reserved.
Username: / as sysdba
Connected to: Oracle Database 12c Enterprise Edition Release 12.1.0.1.0 - 64bit Production
With the Partitioning, Automatic Storage Management, OLAP, Advanced Analytics
and Real Application Testing options
WARNING: Oracle Data Pump operations are not typically needed when connected to the root or seed of a container database.
Starting "SYS"."SYS_EXPORT_SCHEMA_01": /******** AS SYSDBA directory=DATA_PUMP_DIR dumpfile=common_usr_cdb.dmp logfile=common_usr_cdb.log schemas=C##ABBAS
Estimate in progress using BLOCKS method...
Processing object type SCHEMA_EXPORT/TABLE/TABLE_DATA
Total estimation using BLOCKS method: 88 MB
Processing object type SCHEMA_EXPORT/USER
Processing object type SCHEMA_EXPORT/SYSTEM_GRANT
Processing object type SCHEMA_EXPORT/ROLE_GRANT
Processing object type SCHEMA_EXPORT/DEFAULT_ROLE
Processing object type SCHEMA_EXPORT/PRE_SCHEMA/PROCACT_SCHEMA
Processing object type SCHEMA_EXPORT/TABLE/TABLE
Processing object type SCHEMA_EXPORT/TABLE/STATISTICS/TABLE_STATISTICS
Processing object type SCHEMA_EXPORT/STATISTICS/MARKER
. . exported "C##ABBAS"."T" 72.67 MB 667728 rows
Master table "SYS"."SYS_EXPORT_SCHEMA_01" successfully loaded/unloaded
******************************************************************************
Dump file set for SYS.SYS_EXPORT_SCHEMA_01 is:
/backup/exp/prodcdb/common_usr_cdb.dmp
Job "SYS"."SYS_EXPORT_SCHEMA_01" successfully completed at Thu Mar 26 14:16:53 2015 elapsed 0 00:01:16
আদর্শভাবে, আপনাকে রুট কন্টেইনারবজেক্টের রপ্তানি করতে হবে না যদি না আপনার কাছে সেই কন্টেইনারের সাধারণ ব্যবহারকারীদের সাথে সম্পর্কিত ডেটা থাকে।
উপসংহার
এই ব্লগ পোস্টে বর্ণিত ধাপগুলি অনুসরণ করলে আপনি ডেটাপাম্প 12c-এর নতুন বৈশিষ্ট্যগুলিকে আরও সহজে ডেটা রপ্তানি করতে ব্যবহার করতে পারবেন। Part2 পিডিবিতে ডেটা পাম্পের সীমাবদ্ধতা এবং এই ডেটাবেসগুলি কীভাবে রপ্তানি করতে হয় তা কভার করে৷
রেফারেন্স
নিম্নলিখিত নথিটি এই ব্লগ পোস্টের জন্য একটি রেফারেন্স হিসাবে ব্যবহৃত হয়েছিল:
- ওরাকল ডেটাবেস ইউটিলিটিগুলির জন্য এই রিলিজে পরিবর্তনগুলি
কোনো মন্তব্য করতে বা প্রশ্ন জিজ্ঞাসা করতে প্রতিক্রিয়া ট্যাবটি ব্যবহার করুন৷
৷