{"id":128,"date":"2020-10-31T17:42:37","date_gmt":"2020-10-31T17:42:37","guid":{"rendered":"https:\/\/adrianotanaka.com.br\/?p=128"},"modified":"2020-10-31T17:45:06","modified_gmt":"2020-10-31T17:45:06","slug":"migrando-um-oracle-autonomous-database-adw-para-outro-banco","status":"publish","type":"post","link":"https:\/\/adrianotanaka.com.br\/index.php\/2020\/10\/31\/migrando-um-oracle-autonomous-database-adw-para-outro-banco\/","title":{"rendered":"Migrando um Oracle Autonomous Database (ADW) para outro banco"},"content":{"rendered":"\n<p>Geralmente quando falamos em Autonomous Database, estamos falando de levar um banco local para a n\u00favem Oracle, mas nesse caso o procedimento vai ser o inverso, vamos retirar um banco do ADW e coloca-lo em um banco local, o banco de origem (ADW) estava na vers\u00e3o 18c e iremos migrar para a vers\u00e3o 19.9.0 local.<\/p>\n\n\n\n<p>De acordo com a <a rel=\"noreferrer noopener\" href=\"https:\/\/docs.oracle.com\/en\/cloud\/paas\/autonomous-data-warehouse-cloud\/user\/export-data-other-database.html#GUID-529CD03E-7983-423B-A5FD-34D8B36831EC\" target=\"_blank\">documenta\u00e7\u00e3o da Oracle<\/a>, existem algumas formas de se realizar a extra\u00e7\u00e3o dos dados, e todas envolvem de alguma forma o Object Storage:<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\"><p>To export data from your\u00a0Autonomous Data Warehouse database\u00a0to other Oracle databases, use one of the following methods:<\/p><\/blockquote>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\"><p>Use Oracle Data Pump to export the data from your\u00a0Autonomous Data Warehouse database\u00a0to a directory on your database, and then move the data from the directory to your cloud object store.<\/p><p>Use Oracle Data Pump to export the data to your cloud object store directly. This method is only supported with\u00a0Oracle Cloud Infrastructure\u00a0Object Storage and\u00a0Oracle Cloud Infrastructure Object Storage Classic.<\/p><p>Use the procedure\u00a0<code>DBMS_CLOUD.EXPORT_DATA<\/code>\u00a0This method is only supported with\u00a0Oracle Cloud Infrastructure\u00a0Object Storage and\u00a0Oracle Cloud Infrastructure Object Storage Classic.<\/p><\/blockquote>\n\n\n\n<p>Como eu n\u00e3o queria &#8220;perder&#8221; tempo tendo que gerar o arquivo no Object Storage, depois baixa-lo para a minha m\u00e1quina e s\u00f3 ent\u00e3o restaurar o dump, eu usei um par\u00e2metro interessante que \u00e9 o uso do database link no expdp para gerar o arquivo em minha m\u00e1quina, os passos executados foram os seguintes:<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Configurar a conex\u00e3o:<\/h2>\n\n\n\n<p>Ap\u00f3s o banco local instalado, baixe a wallet do seu ADW e coloque ele no servidor, al\u00e9m disso precisamos ajustar o arquivo sqlnet.ora apontando para onde ele deve buscar a wallet, no meu caso ficou assim:<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"shell\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">[oracle@srv-db admin]$ cat sqlnet.ora\nWALLET_LOCATION = (SOURCE = (METHOD = file) (METHOD_DATA = (DIRECTORY=\"\/home\/oracle\/wallet_ADW\")))\nSSL_SERVER_DN_MATCH=yes\n[oracle@srv-db admin]$<\/pre>\n\n\n\n<p>E no nosso tnsnames podemos usar o de exemplo que j\u00e1 vem no arquivo baixado do ADW:<\/p>\n\n\n\n<p><\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"shell\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">db01_high =\n(description= (retry_count=20)(retry_delay=3)(address=(protocol=tcps)(port=1522) (host=xxxxxxx.oraclecloud.com))\n(connect_data=\n(service_name=xxxxxxx.adwc.oraclecloud.com))(security=(ssl_server_cert_dn=\"CN=xxxxxxx.oraclecloud.com\")))<\/pre>\n\n\n\n<p>A dica aqui \u00e9 usar a conex\u00e3o no servi\u00e7o HIGH pois iremos utilizar parallel para o nosso export.<\/p>\n\n\n\n<p><\/p>\n\n\n\n<p>Teste a sua conex\u00e3o com um tnsping:<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"shell\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">[oracle@srv-db admin]$ tnsping db01_high\nTNS Ping Utility for Linux: Version 19.0.0.0.0 - Production on 31-OCT-2020 16:35:04&lt;br>Copyright (c) 1997, 2020, Oracle. All rights reserved\nUsed parameter files:\n\/oracle\/app\/oracle\/product\/19.0.0\/dbhome_1\/network\/admin\/sqlnet.ora\nUsed TNSNAMES adapter to resolve the alias\nAttempting to contact (description= (retry_count=20)(retry_delay=3)(address=(protocol=tcps)(port=1522) (host=xxxxxxx.oraclecloud.com)) (connect_data= (service_name=xxxxxxxxxx.adwc.oraclecloud.com)) (security=(ssl_server_cert_dn=CN=xxxxxxxx.oraclecloud.com)))\nOK (520 msec)\n[oracle@srv-db admin]$<\/pre>\n\n\n\n<h2 class=\"wp-block-heading\">Criando o database link<\/h2>\n\n\n\n<p>No seu banco local, crie um database link usando a string de conex\u00e3o que acabamos de criar:<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"sql\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">create database link\nadw_origem\nconnect to\nadmin\nidentified by\n\"SENHA_ADW\"\nusing 'db01_high';<\/pre>\n\n\n\n<h2 class=\"wp-block-heading\">Realizando o export<\/h2>\n\n\n\n<p>No nosso export usamos  o par\u00e2metro network_link que vai se conectar no database link que criamos e realizar o export para um diret\u00f3rio na m\u00e1quina de destino, dessa forma j\u00e1 vamos gerando e baixando o dump(o que pode nos economizar um tempo), vale lembrar que para usar o parallel voc\u00ea precisa estar usando uma edi\u00e7\u00e3o Enterprise.<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"shell\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">expdp system\/senha network_link=adw_origem directory=expdp_adw dumpfile=expdp_adw_30102020_%u.dmp logfile=EXPDP_ADW.log full=y parallel=6<\/pre>\n\n\n\n<h2 class=\"wp-block-heading\">Realizando o import <\/h2>\n\n\n\n<p>Ap\u00f3s o export ter terminado(no meu caso levou aproximadamente 2h e gerou 104G de dump), podemos realizar o import mas sem antes precisarmos fazer algumas valida\u00e7\u00f5es:<\/p>\n\n\n\n<h5 class=\"wp-block-heading\">Criar tablespaces:<\/h5>\n\n\n\n<p>Com esse select voc\u00ea pode ver quais tablespaces s\u00e3o necess\u00e1rias no seu ambiente, no meu caso apesar de existirem diversas outras, eu s\u00f3 precisava da DATA:<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"sql\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">SELECT \nOWNER,\nTABLESPACE_NAME\nFROM DBA_SEGMENTS\nGROUP BY OWNER,TABLESPACE_NAME;<\/pre>\n\n\n\n<figure class=\"wp-block-image size-large\"><img loading=\"lazy\" decoding=\"async\" width=\"300\" height=\"204\" src=\"https:\/\/adrianotanaka.com.br\/wp-content\/uploads\/2020\/10\/image.png\" alt=\"\" class=\"wp-image-135\"\/><\/figure>\n\n\n\n<h5 class=\"wp-block-heading\">Conferir timezone<\/h5>\n\n\n\n<p>No primeiro import que tentei fazer, havia apenas instalado a vers\u00e3o 19c local sem aplicar nenhum patch e peguei o seguinte problema:<\/p>\n\n\n\n<p><\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"shell\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">Connected to: Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production\nORA-39002: invalid operation\nORA-39405: Oracle Data Pump does not support importing from a source database with TSTZ version 33 into a target database with TSTZ version 32.<\/pre>\n\n\n\n<p>Conforme documentado <a rel=\"noreferrer noopener\" href=\"https:\/\/oracle-base.com\/blog\/2020\/02\/19\/data-pump-between-database-versions-its-not-just-about-the-version-parameter\/\" target=\"_blank\">aqui<\/a> pelo mestre Tim Hall, al\u00e9m de termos vers\u00f5es de banco compat\u00edveis, tamb\u00e9m precisamos que o Timezone da origem e destino sejam compat\u00edveis, aproveitei para atualizar meu banco e grid para a vers\u00e3o 19.9 (lan\u00e7ada a alguns dias) e quando fui aplicar o patch ele n\u00e3o estava dispon\u00edvel para essa vers\u00e3o, dessa forma copiei os arquivos .dat da vers\u00e3o 19.8 de forma manual para seus respectivos diret\u00f3rios e segui o post do Tim Hall.<\/p>\n\n\n\n<h5 class=\"wp-block-heading\">Compress<\/h5>\n\n\n\n<p>No ADW uma de suas principais vantagens \u00e9 estar rodando em cima de um Exadata e utilizar de suas funcionalidades para entregar a parte inteligente, um outro erro que peguei durante meu import foi o seguinte:<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">ORA-39083: Object type TABLE:\"XXXX\".\"XXXX\" failed to create with error:\nORA-64307: Exadata Hybrid Columnar Compression is not supported for tablespaces on this storage type<\/pre>\n\n\n\n<p>Que pode ser resolvido na origem retirando a compress\u00e3o do objeto  ou durante o import, criando a tabela manualmente sem a compress\u00e3o e depois importando os dados ou ent\u00e3o como estamos em uma vers\u00e3o mais nova(superior a 12.1) podemos usar o par\u00e2metro transform=table_compression_clause:none que fala para o impdp respeitar a compress\u00e3o que est\u00e1 definida na nossa tablespace (que no meu caso n\u00e3o possui nenhuma compress\u00e3o ativa).<\/p>\n\n\n\n<h5 class=\"wp-block-heading\">Tamanho do campo varchar2<\/h5>\n\n\n\n<p>Outro problema que encontrei foi que no ADW ele j\u00e1 vem com o par\u00e2metro MAX_STRING_EXTENDED\u00a0configurado EXTENDED<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">ORA-39083: Object type TABLE:\"xxxx\".\"xxxx\" failed to create with error:\nORA-00910: specified length too long for its datatype<\/pre>\n\n\n\n<p>Para isso basta fazer o seguinte, por sua conta e risco, leia a documenta\u00e7\u00e3o da Oracle para entender melhor o que essa altera\u00e7\u00e3o acarreta.<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">SHUTDOWN IMMEDIATE;\nSTARTUP UPGRADE;\nalter system set MAX_STRING_SIZE=EXTENDED;\n@?\/rdbms\/admin\/utl32k.sql\nSHUTDOWN IMMEDIATE;\nSTARTUP;\u00a0<\/pre>\n\n\n\n<h5 class=\"wp-block-heading\">Impdp<\/h5>\n\n\n\n<p>Ap\u00f3s esse ajuste, o seu import j\u00e1 pode ser realizado com os par\u00e2metros que voc\u00ea precisar:<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">impdp system directory=expdp_adw dumpfile=expdp_adw_30102020_%u.dmp logfile=impdp_adw.log transform=table_compression_clause:none PARALLEL=6 full=y<\/pre>\n","protected":false},"excerpt":{"rendered":"<p>Geralmente quando falamos em Autonomous Database, estamos falando de levar um banco local para a n\u00favem Oracle, mas nesse caso o procedimento vai ser o inverso, vamos retirar um banco do ADW e coloca-lo em um banco local, o banco de origem (ADW) estava na vers\u00e3o 18c e iremos migrar para a vers\u00e3o 19.9.0 local. [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":140,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0,"material-hide-sections":[],"footnotes":""},"categories":[1],"tags":[],"class_list":["post-128","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-uncategorized"],"_links":{"self":[{"href":"https:\/\/adrianotanaka.com.br\/index.php\/wp-json\/wp\/v2\/posts\/128","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/adrianotanaka.com.br\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/adrianotanaka.com.br\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/adrianotanaka.com.br\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/adrianotanaka.com.br\/index.php\/wp-json\/wp\/v2\/comments?post=128"}],"version-history":[{"count":14,"href":"https:\/\/adrianotanaka.com.br\/index.php\/wp-json\/wp\/v2\/posts\/128\/revisions"}],"predecessor-version":[{"id":144,"href":"https:\/\/adrianotanaka.com.br\/index.php\/wp-json\/wp\/v2\/posts\/128\/revisions\/144"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/adrianotanaka.com.br\/index.php\/wp-json\/wp\/v2\/media\/140"}],"wp:attachment":[{"href":"https:\/\/adrianotanaka.com.br\/index.php\/wp-json\/wp\/v2\/media?parent=128"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/adrianotanaka.com.br\/index.php\/wp-json\/wp\/v2\/categories?post=128"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/adrianotanaka.com.br\/index.php\/wp-json\/wp\/v2\/tags?post=128"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}