[置顶] OGG同构(ORACLE-ORACLE)、异构(ORACLE-MYSQL)同步配置及错误解析

发布时间:2014-10-22 13:26:11编辑:www.fx114.net 分享查询网我要评论
本篇文章主要介绍了"[置顶] OGG同构(ORACLE-ORACLE)、异构(ORACLE-MYSQL)同步配置及错误解析",主要涉及到[置顶] OGG同构(ORACLE-ORACLE)、异构(ORACLE-MYSQL)同步配置及错误解析方面的内容,对于[置顶] OGG同构(ORACLE-ORACLE)、异构(ORACLE-MYSQL)同步配置及错误解析感兴趣的同学可以参考一下。

环境:11.2.0.3(已安装数据库实例)+OEL5.7 192.168.1.55 zlm sid:zlm11g 192.168.1.60 zlm2 sid:zlm11g 一、安装软件,配置环境,创建相关用户 1.1 下载介质并安装OGG软件 从官方网址下载最新版OGG FOR ORACLE 11g ON LINUX X86-64软件: http://www.oracle.com/technetwork/middleware/goldengate/downloads/index.html?ssSourceSiteId=ocomen Oracle GoldenGate V11.2.1.0.1 for Oracle 11g on Linux x86-64 (86 MB)  介质名称:ogg112101_fbo_ggs_Linux_x64_ora11g_64bit.zip 1.2 把OGG软件包复制到源端oracle主目录,创建安装目录gg11后2次解压到gg11 [[email protected] ~]$ ls ogg112101_fbo_ggs_Linux_x64_ora11g_64bit.zip [[email protected] ~]$ cd $OACLE_BASE [[email protected] oracle]$ mkdir gg11 [[email protected] oracle]$ cd gg11 [[email protected] gg11]$ unzip /home/oracle/ogg112101_fbo_ggs_Linux_x64_ora11g_64bit.zip  [[email protected] gg11]$ ll total 223764 -rw-rw-r-- 1 oracle oinstall 228556800 Apr 23  2012 fbo_ggs_Linux_x64_ora11g_64bit.tar -rwxrwxrwx 1 oracle oinstall    220546 May  2  2012 OGG_WinUnix_Rel_Notes_11.2.1.0.1.pdf -rwxrwxrwx 1 oracle oinstall     93696 May  2  2012 Oracle GoldenGate 11.2.1.0.1 README.doc -rwxrwxrwx 1 oracle oinstall     24390 May  2  2012 Oracle GoldenGate 11.2.1.0.1 README.txt [[email protected] gg11]$ tar xvof fbo_ggs_Linux_x64_ora11g_64bit.tar  1.3 修改环境变量文件.bash_profile,加入OGG的环境变量 export GGHOME=$ORACLE_BASE/gg11 export PATH=$ORACLE_BASE/gg11:$ORACLE_HOME/bin:/usr/bin/:$PATH [[email protected] gg11]$ . ~/.bash_profile [[email protected] gg11]$ ggsci ggsci: error while loading shared libraries: libnnz11.so: cannot open shared object file: No such file or directory 由于没有设置LD_LIBRARY_PATH环境变量,所以无法执行ggsci,添加export LD_LIBLARY_PATH=$ORACLE_BASE/gg11:$ORACLE_HOME/lib:$ORACLE_HOME/bin 到环境变量.bash_profile并source,或者创建一个link文件: [[email protected] gg11]$ ln -s /u01/app/oracle/product/11.2.0/db_1/lib/libnnz11.so - /u01/app/oracle/product/11.2.0/db_1/lib/libnnz10.so  1.4 创建OGG专用目录subdirs GGSCI (zlm) 1> create subdirs Creating subdirectories under current directory /u01/app/oracle/gg11 Parameter files                /u01/app/oracle/gg11/dirprm: already exists Report files                   /u01/app/oracle/gg11/dirrpt: created Checkpoint files               /u01/app/oracle/gg11/dirchk: created Process status files           /u01/app/oracle/gg11/dirpcs: created SQL script files               /u01/app/oracle/gg11/dirsql: created Database definitions files     /u01/app/oracle/gg11/dirdef: created Extract data files             /u01/app/oracle/gg11/dirdat: created Temporary files                /u01/app/oracle/gg11/dirtmp: created Stdout files                   /u01/app/oracle/gg11/dirout: created 1.5 开启归档模式、强制日志、附加日志 查看v$database看这3个参数是否已开启,使用OGG必须是开启状态 SQL> select LOG_MODE, SUPPLEMENTAL_LOG_DATA_MIN,FORCE_LOGGING from v$database; LOG_MODE     SUPPLEME FOR ------------ -------- --- ARCHIVELOG   YES      YES 各参数开启方法: --archivelog SQL> shutdown immediate SQL> startup mount SQL> alter database archivelog; SQL> alter database open; --force logging SQL> alter database force logging; --supplemental log data SQL> alter database add supplemental log data; 1.6 关闭数据库的recyclebin(10gDDL必须,11gDDL可选) SQL> alter system set recyclebin=off scope=spfile; --同步DDL要求关闭10g中的回收站特性 1.7 创建复制用户ogg并授予权限 SQL> create user ogg identified by ogg default tablespace users temporary tablespace temp; SQL> grant connect,resource,unlimited tablespace to ogg; 1.8 创建测试用户sender并授予权限 SQL> create user sender identified by sender default tablespace users temporary tablespace temp; SQL> grant connect,resource,unlimited tablespace to sender; 1.9 配置复制的DDL支持(必须SYSDBA登录执行) SQL> grant execute on utl_file to ogg; SQL> @$GGHOME/marker_setup.sql; --建立一个DDL标记表 SQL> @$GGHOME/ddl_setup.sql; --INITIALSETUP选项运行ddl_setup.sql 将在数据库中创建捕获DDL语句的Trigger等必要组件(注意,执行时必须断开GGSCI连接,否则报错) SQL> @$GGHOME/role_setup.sql; --建立GGS_GGSUSER_ROLE角色 SQL> grant GGS_GGSUSER_ROLE to ogg; --授予给extract group参数中定义的userid用户 SQL> @$GGHOME/ddl_enable.sql; --enable ddl捕获触发器 注意:下面2个SQL脚本只是为了提高DDL复制性能,不是必须的 SQL> @?/rdbms/admin/dbmspool --创建DBMS_SHARED_POOL包 SQL> @ddl_pin --通过dbms_shared_pool.keep存储过程将DDLReplication相关的对象keep在共享池中,以保证这些对象不要reload,提升性能 1.10 目标端重复配置以上1.1-1.9全部内容,至此,ORACLE-ORACLE环境搭建完毕 二、用EXPDP/IMPDP初始化测试数据(仅限ORACLE-ORACLE) 2.1 创建EXPDP/IMPDP使用的directory及其对应的本地目录 SQL> set lin 200 pages 999 SQL> col owner for a5 SQL> col directory_name for a25 SQL> col directory_path for a75 SQL> select * from dba_directories; OWNER DIRECTORY_NAME            DIRECTORY_PATH ----- ------------------------- ---------------------------------------------------------------------- SYS   GGS_DDL_TRACE             /u01/app/oracle/diag/rdbms/zlm11g/zlm11g/trace SYS   SUBDIR                    /u01/app/oracle/product/11.2.0/db_1/demo/schema/order_entry//2002/Sep SYS   SS_OE_XMLDIR              /u01/app/oracle/product/11.2.0/db_1/demo/schema/order_entry/ SYS   BACKUP                    /u01/backup SYS   LOG_FILE_DIR              /u01/app/oracle/product/11.2.0/db_1/demo/schema/log/ SYS   MEDIA_DIR                 /u01/app/oracle/product/11.2.0/db_1/demo/schema/product_media/ SYS   XMLDIR                    /u01/app/oracle/product/11.2.0/db_1/rdbms/xml SYS   DATA_FILE_DIR             /u01/app/oracle/product/11.2.0/db_1/demo/schema/sales_history/ SYS   DATA_PUMP_DIR             /u01/app/oracle/admin/zlm11g/dpdump/ SYS   ORACLE_OCM_CONFIG_DIR     /u01/app/oracle/product/11.2.0/db_1/ccr/state SQL> create directory expdump as '/u01/expdp'; SQL> select * from dba_directories; OWNER DIRECTORY_NAME            DIRECTORY_PATH ----- ------------------------- ---------------------------------------------------------------------- SYS   GGS_DDL_TRACE             /u01/app/oracle/diag/rdbms/zlm11g/zlm11g/trace SYS   EXPDUMP                   /u01/expdp SYS   SUBDIR                    /u01/app/oracle/product/11.2.0/db_1/demo/schema/order_entry//2002/Sep SYS   SS_OE_XMLDIR              /u01/app/oracle/product/11.2.0/db_1/demo/schema/order_entry/ SYS   BACKUP                    /u01/backup SYS   LOG_FILE_DIR              /u01/app/oracle/product/11.2.0/db_1/demo/schema/log/ SYS   MEDIA_DIR                 /u01/app/oracle/product/11.2.0/db_1/demo/schema/product_media/ SYS   XMLDIR                    /u01/app/oracle/product/11.2.0/db_1/rdbms/xml SYS   DATA_FILE_DIR             /u01/app/oracle/product/11.2.0/db_1/demo/schema/sales_history/ SYS   DATA_PUMP_DIR             /u01/app/oracle/admin/zlm11g/dpdump/ SYS   ORACLE_OCM_CONFIG_DIR     /u01/app/oracle/product/11.2.0/db_1/ccr/state [[email protected] gg11]$ cd /u01/ [[email protected] u01]$ ls app  backup [[email protected] u01]$ mkdir /u01/expdp [[email protected] u01]$ ll total 16 drwxr-xr-x 4 oracle oinstall 4096 Jul 13 03:12 app drwxrwxr-x 2 oracle oinstall 4096 Jul 21 20:26 backup drwxr-xr-x 2 oracle oinstall 4096 Aug 28 22:11 expdp 2.2 登录sender用户并创建测试表test SQL> conn sender/sender Connected. SQL> begin   2  for i in 1..3 loop   3  insert into test values(i);   4  end loop;   5  end;   6  / PL/SQL procedure successfully completed. SQL> select * from test1;         ID ----------          1          2          3 2.3 赋予sender读写directory的权限,执行expdp导出测试表test SQL> grant read,write on directory expdump to sender; SQL> ! [[email protected] ~]$ expdp sender/sender directory=expdump dumpfile=test.dmp logfile=test.log tables=test [[email protected] ~]$ cd /u01/expdp [[email protected] expdp]$ ls test.dmp  test.log 2.4 在目标端创建directory及相应的本地路径,复制dump文件到目标端 SQL> create directory impdump as ‘/u01/impdp’; --target [[email protected] gg11]$ mkdir /u01/impdp [[email protected] gg11]$ ls /u01 app  backup  impdp --source [[email protected] expdp]$ scp test.* zlm2:/u01/impdp [email protected]'s password:  test.dmp                                                                  100%   92KB  92.0KB/s   00:00  test.log                                                                  100% 1011     1.0KB/s   00:00  2.5 目标端赋予recerver用户权限,执行impdp导入测试表test SQL> grant read,write on directory impdump to sender; SQL> ! [[email protected] ~]$ impdp sender/sender directory=impdump dumpfile=test.dmp tables=test 注意:expdp/impdp必须是在同一个schema下的object,否则不能执行成功,logfile可以无 SQL> conn sender/sender Connected. SQL> select * from test;         ID ----------          1          2          3 此时完成test表的初始化同步,注意:如果非ORACLE-ORACLE方式同步,则只能使用OGG推荐的方式,即配置initial extract来初始化数据,具体可以参考我之前的一篇blog: OGG配置DML单向复制一例及错误分析 http://blog.csdn.net/aaron8219/article/details/10275431  三、不使用PUMP抽取进程的DML同步参数配置(ORACLE-ORACLE) 3.1 单向复制 3.1.1 创建并配置manager [[email protected] gg11]$ ./ggsci GGSCI (zlm) 1> info all GGSCI (zlm) 2> edit params mgr PORT 7809 ggate (zlm) 3> start manager Manager started. 3.1.2 配置源端抽取组ext1 GGSCI (zlm) 1> add extract ext1, tranlog, begin now GGSCI (zlm) 2> add rmttrail ./dirdat/rt, extract ext1 GGSCI (zlm) 3> edit params ext1 extract ext1 userid ogg, password ogg rmthost zlm2, mgrport 7809 rmttrail ./dirdat/rt ddl include mapped objname sender.*; table sender.*; GGSCI (zlm) 4> info all 3.1.3 配置目标端同步组 3.1.3.1 在目标端添加checkpoint表 [[email protected] gg11]$ ./ggsci GGSCI (zlm2) 1> edit params ./GLOBAL GGSCHEMA ogg CHECKPOINTTABLE ogg.ckpt GGSCI (zlm2) 2> dblogin userid ogg password ogg GGSCI (zlm2) 3> add checkpointtable ogg.ckpt 3.1.3.2 创建同步组rep1 GGSCI (zlm2) 4> add replicat rep1, exttrail ./dirdat/rt, checkpointtable ogg.ckpt GGSCI (zlm2) 5> edit params rep1 replicat rep1 ASSUMETARGETDEFS userid ogg,password ogg reperror default,discard discardfile ./dirrpt/rep1.dsc, append, megabytes 5 DDL map sender.*, target sender.*; 3.1.4 源端开启抽取组ext1,目标端开启同步组rep1 --source GGSCI (zlm) 1> start mgr GGSCI (zlm) 2> start extract ext1 GGSCI (zlm) 3> info all --target GGSCI (zlm2) 1> start mgr GGSCI (zlm2) 2> start replicat rep1 GGSCI (zlm2) 3> info all 3.1.5 测试DML同步 3.1.5.1 insert --source SQL> select * from test   2  /         ID ----------          1          2          3 SQL> insert into test values(4); 1 row created. SQL> commit; Commit complete. --target SQL> select * from test;         ID ----------          1          2          3          4 注意:可以顺利同步,但是查看ext1和rep1的run time messages,都报了如下的错误: WARNING OGG-00869  No unique key is defined for table 'TEST'. All viable columns will b e used to represent the key, but may not guarantee uniqueness.  KEYCOLS may be used to define the key. Using the following key columns for source table SENDER.TEST: ID. 该表没有主键,使用KEYCOLS代替,查询官方说明如下: OGG-00869: {0} Cause: The specified database error occurred, but can be ignored. Action: Contact Oracle Support only if a problem persists. 由于这只是个警告,况且对实际的应用也没什么影响,是可以忽略掉的。 3.1.5.2 update (略)... 3.1.5.3 delete (略)... 3.1.6 测试DDL同步(可选) 测试DDL需要之前做过1.8步骤的全部配置(绿色部分),并在相应参数中添加过相应DDL需要使用的参数(绿色部分) 3.1.6.1 create table --source SQL> create table test2 as select * from test; Table created. --target SQL> select * from test2;         ID ----------          1          2          3 5 rows selected. 3.1.6.2 alter table --source SQL> alter table test2 add (name varchar(10)); Table altered. --target SQL> desc test2;  Name                                      Null?    Type  ----------------------------------------- -------- ----------------------------  ID                                                 NUMBER  NAME                                               VARCHAR2(10) 3.1.6.3 tuncate table --source SQL> truncate table test2; Table truncated. --target SQL> select * from test2; no rows selected 3.1.6.4 drop table --source SQL> drop table test2; Table dropped. --target SQL> desc test2 ERROR: ORA-04043: object test2 does not exist 至此,不设置本地trail和pump抽取进程的DML,DDL都可以顺利复制到目标端 3.2 双向复制 双向复制,其实就是再配置一条目标端到源端的复制通道,分别在源端和目的端各配置一个extract和replicat进程就可以了 3.2.1 配置源端抽取组ext1 GGSCI (zlm2) 1> add extract ext1, tranlog, begin now GGSCI (zlm2) 2> add rmttrail ./dirdat/rt, extract ext1 GGSCI (zlm2) 3> edit params ext1 extract ext1 userid ogg, password ogg rmthost zlm1, mgrport 7809 --注意主机名要修改一下,别的参数和之前的一致就可以了 rmttrail ./dirdat/rt ddl include mapped objname sender.*; table sender.*; GGSCI (zlm2) 4> info all 3.2.2 配置目标端同步组 3.2.2.1 在目标端添加checkpoint表 [[email protected] gg11]$ ./ggsci GGSCI (zlm) 1> edit params ./GLOBAL GGSCHEMA ogg --DDL同步必须指定,DML同步不需要 CHECKPOINTTABLE ogg.ckpt GGSCI (zlm) 2> dblogin userid ogg password ogg GGSCI (zlm) 3> add checkpointtable ogg.ckpt 3.2.2.2 创建同步组rep1 GGSCI (zlm) 4> add replicat rep1, exttrail ./dirdat/rt, checkpointtable ogg.ckpt GGSCI (zlm) 5> edit params rep1 replicat rep1 ASSUMETARGETDEFS userid ogg,password ogg reperror default,discard discardfile ./dirrpt/rep1.dsc, append, megabytes 5 DDL map sender.*, target sender.*; 3.2.3 源端(原目标端)开启抽取组ext1,目标端(原源端)开启同步组rep1 --source GGSCI (zlm2) 1> start mgr GGSCI (zlm2) 2> start extract ext1 GGSCI (zlm2) 3> info all --target GGSCI (zlm) 1> start mgr GGSCI (zlm) 2> start replicat rep1 GGSCI (zlm) 3> info all 具体测试内容和之前配置的单向复制一样,步骤略,DML,DDL都顺利复制到目标端,和之前一样,第一次同步的时候会比较慢,之后就快了,可能是第一次同步需要创建文件的缘故。另外,这里要特别注意,此时因为配置了双向复制,当两边各自的ext1和rep1进程都是running状态,如果此时源端和目标端对同一个表进行DML操作,如insert一条记录,那么这条记录会不断地在两端来回复制,永不停歇,如下所示: SQL> insert into test values(6); 1 row created. SQL> select *from test;         ID ----------          1          2          3          4          5          6          6          6          6          6 这条插入id=6的数据就会不断地插入test表,要解决这个问题,就需要在两端的任意一个extract进程ext1里添加一条TRANLOGOPTIONS EXCLUDEUSER ogg就可以了 四、使用PUMP抽取进程的单向复制(ORACLE-ORACLE) 4.1 添加本地trail路径,修改源端extract抽取组ext1参数 GGSCI (zlm) 1> add extract ext1,tranlog, begin now GGSCI (zlm) 2> add exttrail ./dirdat/lt,extract ext1 GGSCI (zlm) 3> edit params ext1 extract ext1 userid ogg, password ogg --rmthost zlm2, mgrport 7809 --rmttrail ./dirdat/rt exttrail ./dirdat/lt ddl include mapped objname sender.*; table sender.*; 注释掉2行和远程连接有关的参数,再添加一行本地trail路径即可 4.2 添加pump抽取组epp1 GGSCI (zlm) 1> add extract epp1,exttrailsource ./dirdat/lt GGSCI (zlm) 2> add rmttrail ./dirdata/rt,extract epp1 GGSCI (zlm) 3> edit params epp1 extract epp1 userid ogg,password ogg rmthost zlm2, mgrport 7809 rmttrail ./dirdat/rt ddl include mapped objname sender.*; table sender.*; 相当于把原来配置在ext1里的远程配置参数搬过来了,因为现在是通过pump与远端连接, replicat复制组rep1参数不用修改,直接使用就可以 4.2 DML和DDL测试(参考3.1.5和3.1.6的步骤,方法一致) (略)… 注意:测试同步的时候要多开启一个pump进程,即源端运行ext1,epp1 五、异构数据库之间的单向复制(ORACLE-MYSQL) 5.1下载并安装介质 OGG FOR MYSQL: 官网链接:https://edelivery.oracle.com/EPD/Download/get_form 介质名称:Oracle GoldenGate V11.1.1.1.1 for MySQL 5.x on Linux x86-64  MYSQL DATABASE: 官网链接:https://edelivery.oracle.com/EPD/Search/handle_go 介质名称:MySQL Database 5.6.13 RPM for Oracle Linux / RHEL 5 x86 (64bit)  5.1.1目标端安装OGG软件并配置环境 因为MYSQL默认是以root用户登录并使用的,所以只要配置root的环境变量就可以了 在root用户的.bash_profile文件中添加以下内容: export GGHOME=/ggmysql export PATH=$PATH:$GGHOME 拷贝OGG FOR MYSQL介质到/rpm目录下并解压缩,然后再一次解压缩到/ggmysql [[email protected] ~]# cd /rpm [[email protected] rpm]# ls V27808-01.zip [[email protected] rpm]# unzip V27808-01.zip  Archive:  V27808-01.zip   inflating: ggs_Linux_x64_MySQL_64bit.tar     inflating: OGG_WinUnix_Rel_Notes_11.1.1.1.1.pdf     inflating: Oracle_GoldenGate_11.1.1.1_README.txt  [[email protected] rpm]# ls ggs_Linux_x64_MySQL_64bit.tar         Oracle_GoldenGate_11.1.1.1_README.txt OGG_WinUnix_Rel_Notes_11.1.1.1.1.pdf  V27808-01.zip [[email protected] rpm]# mkdir /ggmysql [[email protected] rpm]# cd /ggmysql [[email protected] ggmysql]# tar -xvf /rpm/ggs_Linux_x86_MySQL_32bit.tar  (略)... 进入OGG界面,添加OGG目录 [[email protected] ggmysql]# ./ggsci GGSCI (zlm2) 1> create subdirs 5.1.2 目标端安装配置MYSQL数据库软件 把从官网下载的MYSQL数据库软件也拷贝到/rpm下并解压 [[email protected] rpm]# ls [[email protected] rpm]# ls ggs_Linux_x64_MySQL_64bit.tar          V27808-01.zip OGG_WinUnix_Rel_Notes_11.1.1.1.1.pdf   V39097-01.zip Oracle_GoldenGate_11.1.1.1_README.txt [[email protected] rpm]# unzip V39097-01.zip  Archive:  V39097-01.zip  extracting: MySQL-shared-compat-advanced-5.6.13-1.rhel5.x86_64.rpm    extracting: MySQL-devel-advanced-5.6.13-1.rhel5.x86_64.rpm    extracting: MySQL-embedded-advanced-5.6.13-1.rhel5.x86_64.rpm    extracting: MySQL-shared-advanced-5.6.13-1.rhel5.x86_64.rpm    extracting: MySQL-server-advanced-5.6.13-1.rhel5.x86_64.rpm    extracting: MySQL-test-advanced-5.6.13-1.rhel5.x86_64.rpm    extracting: MySQL-client-advanced-5.6.13-1.rhel5.x86_64.rpm    extracting: README.txt  MYSQL数据库软件是一个rpm包,直接以root执行rpm命令进行安装 如果提示libaio.so.1依赖包没有安装的错误,就要先安装依赖包libaio 配置本地yum并执行:yum install libaio,或者直接用rpm包安装 [[email protected] rpm]# rpm -ivh MySQL-server-advanced-5.6.13-1.rhel5.x86_64.rpm  Preparing...                ########################################### [100%]    1:MySQL-server-advanced  ########################################### [100%] 2013-08-30 22:46:21 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details). 2013-08-30 22:46:21 5633 [Note] InnoDB: The InnoDB memory heap is disabled 2013-08-30 22:46:21 5633 [Note] InnoDB: Mutexes and rw_locks use GCC atomic builtins 2013-08-30 22:46:21 5633 [Note] InnoDB: Compressed tables use zlib 1.2.3 2013-08-30 22:46:21 5633 [Note] InnoDB: Using Linux native AIO 2013-08-30 22:46:21 5633 [Note] InnoDB: Not using CPU crc32 instructions /usr/sbin/mysqld: Can't create/write to file '/tmp/ibgnuRhJ' (Errcode: 13 - Permission denied) 2013-08-30 22:46:21 7fa1cc42c6f0  InnoDB: Error: unable to create temporary file; errno: 13 2013-08-30 22:46:21 5633 [ERROR] Plugin 'InnoDB' init function returned error. 2013-08-30 22:46:21 5633 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed. 2013-08-30 22:46:21 5633 [ERROR] Unknown/unsupported storage engine: InnoDB 2013-08-30 22:46:21 5633 [ERROR] Aborting 2013-08-30 22:46:21 5633 [Note] Binlog end 2013-08-30 22:46:21 5633 [Note] /usr/sbin/mysqld: Shutdown complete 显示完以上信息后就停住了,跳回了root的shell界面,查看了上面提示的内容, 出现几个报错,第一次装MYSQL,不太明白是什么意思,网上查了一下说是需要配置my.cnf参数,直接在my.cnf里的mysqld下加一行explicit_defaults_for_timestamp  http://bbs.csdn.net/topics/390369836?page=1#post-393710642 但是我觉得应该不是这个问题,现在软件肯定是还没有装好,查看了一下,相关的目录和配置文件都没有创建,可能是官网这个最新版server-advanced-5.6.13包兼容性有点问题,网上查了一下,也说最好别下官网最新版的MYSQL数据库安装包 于是去MYSQL官网下载MySQL Community Server最新版 官方链接:http://dev.mysql.com/downloads/mirror.php?id=414018 介质名称:MySQL-server-5.6.13-1.rhel5.x86_64.rpm 官方链接:http://dev.mysql.com/downloads/mirror.php?id=413959 介质名称:MySQL-client-5.6.13-1.rhel5.x86_64.rpm 把新下载的RPM拷贝到/rpm目录下,重新安装MYSQL,但是此时又发现一个问题 [[email protected] rpm]# rpm -ivh MySQL-server-5.6.13-1.rhel5.x86_64.rpm  Preparing...                ########################################### [100%]         file /usr/bin/innochecksum from install of MySQL-server-5.6.13-1.rhel5.x86_64 conflicts with file from package MySQL-server-advanced-5.6.13-1.rhel5.x86_64         file /usr/bin/my_print_defaults from install of MySQL-server-5.6.13-1.rhel5.x86_64 conflicts with file from package MySQL-server-advanced-5.6.13-1.rhel5.x86_64 (略)... 由于之前的server-advacned包没有完全正确安装,现在再安装这个包提示和之前的包有冲突,无法继续安装,于是想到先卸载一下之前安装的包: [[email protected] rpm]# rpm -ev MySQL-server-advanced-5.6.13-1.rhel5.x86_64.rpm  error: package MySQL-server-advanced-5.6.13-1.rhel5.x86_64.rpm is not installed 提示之前的server-advanced包并没有安装,也无法卸载,现在不知道如何清除之前rpm的安装残留信息,所以换了一台之前装的Oracle ASM单实例数据库的主机,进行安装: SQL-server-5.6.13-1.rhel5.x86_64.rpm  Preparing...                ########################################### [100%]    1:MySQL-server           ########################################### [100%] 2013-08-31 13:16:17 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details). 2013-08-31 13:16:17 4462 [Note] InnoDB: The InnoDB memory heap is disabled 2013-08-31 13:16:17 4462 [Note] InnoDB: Mutexes and rw_locks use GCC atomic builtins 2013-08-31 13:16:17 4462 [Note] InnoDB: Compressed tables use zlib 1.2.3 2013-08-31 13:16:17 4462 [Note] InnoDB: Using Linux native AIO 2013-08-31 13:16:17 4462 [Note] InnoDB: Not using CPU crc32 instructions 2013-08-31 13:16:17 4462 [Note] InnoDB: Initializing buffer pool, size = 128.0M 2013-08-31 13:16:17 4462 [Note] InnoDB: Completed initialization of buffer pool 2013-08-31 13:16:17 4462 [Note] InnoDB: The first specified data file ./ibdata1 did not exist: a new database to be created! 2013-08-31 13:16:17 4462 [Note] InnoDB: Setting file ./ibdata1 size to 12 MB 2013-08-31 13:16:17 4462 [Note] InnoDB: Database physically writes the file full: wait... 2013-08-31 13:16:18 4462 [Note] InnoDB: Setting log file ./ib_logfile101 size to 48 MB 2013-08-31 13:16:20 4462 [Note] InnoDB: Setting log file ./ib_logfile1 size to 48 MB 2013-08-31 13:16:21 4462 [Note] InnoDB: Renaming log file ./ib_logfile101 to ./ib_logfile0 2013-08-31 13:16:21 4462 [Warning] InnoDB: New log files created, LSN=45781 2013-08-31 13:16:21 4462 [Note] InnoDB: Doublewrite buffer not found: creating new 2013-08-31 13:16:21 4462 [Note] InnoDB: Doublewrite buffer created 2013-08-31 13:16:21 4462 [Note] InnoDB: 128 rollback segment(s) are active. 2013-08-31 13:16:21 4462 [Warning] InnoDB: Creating foreign key constraint system tables. 2013-08-31 13:16:21 4462 [Note] InnoDB: Foreign key constraint system tables created 2013-08-31 13:16:21 4462 [Note] InnoDB: Creating tablespace and datafile system tables. 2013-08-31 13:16:21 4462 [Note] InnoDB: Tablespace and datafile system tables created. 2013-08-31 13:16:21 4462 [Note] InnoDB: Waiting for purge to start 2013-08-31 13:16:21 4462 [Note] InnoDB: 5.6.13 started; log sequence number 0 A random root password has been set. You will find it in '/root/.mysql_secret'. 2013-08-31 13:16:22 4462 [Note] Binlog end 2013-08-31 13:16:22 4462 [Note] InnoDB: FTS optimize thread exiting. 2013-08-31 13:16:22 4462 [Note] InnoDB: Starting shutdown... 2013-08-31 13:16:23 4462 [Note] InnoDB: Shutdown completed; log sequence number 1625977 2013-08-31 13:16:23 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details). 2013-08-31 13:16:23 4486 [Note] InnoDB: The InnoDB memory heap is disabled 2013-08-31 13:16:23 4486 [Note] InnoDB: Mutexes and rw_locks use GCC atomic builtins 2013-08-31 13:16:23 4486 [Note] InnoDB: Compressed tables use zlib 1.2.3 2013-08-31 13:16:23 4486 [Note] InnoDB: Using Linux native AIO 2013-08-31 13:16:23 4486 [Note] InnoDB: Not using CPU crc32 instructions 2013-08-31 13:16:23 4486 [Note] InnoDB: Initializing buffer pool, size = 128.0M 2013-08-31 13:16:23 4486 [Note] InnoDB: Completed initialization of buffer pool 2013-08-31 13:16:23 4486 [Note] InnoDB: Highest supported file format is Barracuda. 2013-08-31 13:16:23 4486 [Note] InnoDB: 128 rollback segment(s) are active. 2013-08-31 13:16:23 4486 [Note] InnoDB: Waiting for purge to start 2013-08-31 13:16:23 4486 [Note] InnoDB: 5.6.13 started; log sequence number 1625977 2013-08-31 13:16:24 4486 [Note] Binlog end 2013-08-31 13:16:24 4486 [Note] InnoDB: FTS optimize thread exiting. 2013-08-31 13:16:24 4486 [Note] InnoDB: Starting shutdown... 2013-08-31 13:16:25 4486 [Note] InnoDB: Shutdown completed; log sequence number 1625987 A RANDOM PASSWORD HAS BEEN SET FOR THE MySQL root USER ! You will find that password in '/root/.mysql_secret'. You must change that password on your first connect, no other statement but 'SET PASSWORD' will be accepted. See the manual for the semantics of the 'password expired' flag. Also, the account for the anonymous user has been removed. In addition, you can run:   /usr/bin/mysql_secure_installation which will also give you the option of removing the test database. This is strongly recommended for production servers. See the manual for more instructions. Please report any problems with the /usr/bin/mysqlbug script! The latest information about MySQL is available on the web at   http://www.mysql.com Support MySQL by buying support/licenses at http://shop.mysql.com New default config file was created as /usr/my.cnf and will be used by default by the server when you start it. You may edit this file to change server settings [[email protected] rpm]# [[email protected] ~]# rpm -qa|grep -i mysql MySQL-server-5.6.13-1.rhel5 这次安装很顺利地就完成了,之前安装失败的主机和这台ASM单实例主机用的是OEL5.7的系统,所以排除了系统问题,肯定是之前的软件兼容性问题,继续安装client软件 [[email protected] rpm]# rpm -ivh MySQL-client-5.6.13-1.rhel5.x86_64.rpm  Preparing...                ########################################### [100%]    1:MySQL-client           ########################################### [100%] 至此,MYSQL顺利安装完毕! 5.1.3 启动MYSQL [[email protected] rpm]# mysql ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2) 报错了,可以使用下面的命令启动: service mysql start或/etc/init.d/mysql start或/etc/rc.d/init.d/mysql start [[email protected] rpm]# service mysql start Starting MySQL......                                       [  OK  ] [[email protected] rpm]#  5.1.4 登录MYSQL [[email protected] rpm]# mysql ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO) [[email protected] rpm]# 该错误提示不用密码是无法访问的,注意此时用mysql -u root -p的方式也是无法登录的,因为此时没有正确的root密码,必须先强制修改root密码,解决方法如下: [[email protected] rpm]# /etc/init.d/mysql stop Shutting down MySQL..                                      [  OK  ] [[email protected] rpm]# /usr/bin/mysqld_safe --skip-grant-tables 130831 14:32:39 mysqld_safe Logging to '/var/lib/mysql/dg1.err'. 130831 14:32:39 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql 另外再开一个SSH后执行: [[email protected] ~]# mysql Welcome to the MySQL monitor.  Commands end with ; or \g. Your MySQL connection id is 1 Server version: 5.6.13 MySQL Community Server (GPL) Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> use mysql Reading table information for completion of table and column names You can turn off this feature to get a quicker startup with -A Database changed mysql> update user set password=password("123456") where user="root"; Query OK, 4 rows affected (0.01 sec) Rows matched: 4  Changed: 4  Warnings: 0 mysql> flush privileges; Query OK, 0 rows affected (0.00 sec) mysql> exit Bye 直接关闭新开的SSH,或者执行pkill -KILL -t pts/0 可将pts为0的**用户(之前运行mysqld_safe的用户窗口)强制踢出 然后在原来的SSH,执行Ctrl+Z退出skip-grant-tables模式 [1]+  Stopped                 /usr/bin/mysqld_safe --skip-grant-tables [[email protected] rpm]#  正常启动 MySQL:/etc/init.d/mysql start   (service mysqld start) 此时再使用密码方式登录: [[email protected] rpm]# mysql -u root -p Enter password:  Welcome to the MySQL monitor.  Commands end with ; or \g. Your MySQL connection id is 5 Server version: 5.6.13 Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql>  之后有人提醒我,MYSQL安装完以后默认密码为空,也就是说,如果不进行强制修改密码方式,直接执行#mysql -u root -p也是可以进入系统的,当提示输入密码时直接回车就可以,这个我还没有验证过,如果是真的话,那我就绕圈子了,呵呵 如果已经登陆进系统,想修改某用户的密码,可以执行如下命令: [[email protected] ~]# /usr/bin/mysqladmin -u root password 123456 5.1.5 操作数据库 mysql> show databases; ERROR 1820 (HY000): You must SET PASSWORD before executing this statement 之前已经用安全模式给MYSQL重新修改了密码,也用密码登陆了,但是仍然提示需要密码 查阅官方文档:http://dev.mysql.com/doc/refman/5.6/en/alter-user.html 原来还要重新执行一个操作,再设置一下密码: mysql> set password=password('123456'); Query OK, 0 rows affected (0.03 sec) mysql> show databases; +--------------------+ | Database           | +--------------------+ | information_schema | | mysql              | | performance_schema | | test               | +--------------------+ 4 rows in set (0.00 sec) mysql> use test Database changed mysql> show tables; Empty set (0.00 sec) 5.1.6 设置开机自启动(可选) 可以在/etc/rc.local文件中添加以下MYSQL自启动命令: /etc/init.d/mysql start 另外也可以使用chkconfig命令配置自启动: # chkconfig --list | grep mysql # chkconfig --add mysql  设置完重启系统后,使用netstat-nat命令可以看到MYSQL的3306端口 #netstat-nat|grep 3306 5.1.7 MYSQL几个重要目录说明 (1)数据库目录    /var/lib/mysql/ (2)配置文件    /usr/share/mysql(mysql.server命令及配置文件) (3)相关命令    /usr/bin(mysqladmin mysqldump等命令) (4)启动脚本    /etc/rc.d/init.d/(启动脚本文件mysql的目录)          若想查看MySQL安装到哪个目录,可使用“whereis mysql”命令查看 官方说明: Table 2.9. MySQL Installation Layout for Linux RPM Packages Directory Contents of Directory /usr/bin Client programs and scripts /usr/sbin The mysqld server /var/lib/mysql Log files, databases /usr/share/info Manual in Info format /usr/share/man Unix manual pages /usr/include/mysql Include (header) files /usr/lib/mysql Libraries /usr/share/mysql Miscellaneous support files, including error messages, character set files, sample configuration files, SQL for database installation /usr/share/sql-bench Benchmarks 5.2 源端创建defgen文件并配置 异构数据库之间同步数据必须利用结构转换文件 GGSCI (zlm) 1> edit params defgen defsfile ./dirdef/oratomy.def,purge userid ogg, password ogg table sender.*; [[email protected] gg11] $ ./defgen paramfile ./dirprm/defgen.prm 执行前必须先启动oracle数据库,否则会报: ERROR   OGG-00664  OCI Error beginning session (status = 1034-ORA-01034: ORACLE not available ORA-27101: shared memory realm does not exist Linux-x86_64 Error: 2: No such file or directory). ERROR   OGG-01668  PROCESS ABENDING. 再执行一次也会报错: ERROR   OGG-00037  DEFSFILE file ./dirdef/oratomy.def already exists. ERROR   OGG-01668  PROCESS ABENDING. 此时应该先删除原先的那个def文件,再执行一次,直到出现: Definitions generated for 2 tables in ./dirdef/oratomy.def 这里这条命令的作用就是生成oratomy.def这个异构数据库转换文件 将生成的该文件拷贝到目标端相同位置: [[email protected] ~]# scp /u01/app/oracle/gg11/dirdef/oratomy.def dg1:/ggmysql/dirdef The authenticity of host 'dg1 (192.168.1.99)' can't be established. RSA key fingerprint is e4:1f:12:e6:63:13:3a:2a:ad:52:e3:4a:68:b6:33:e0. Are you sure you want to continue connecting (yes/no)? yes Warning: Permanently added 'dg1,192.168.1.99' (RSA) to the list of known hosts. [email protected]'s password:  oratomy.def                                   100% 1079     1.1KB/s   00:00     [[email protected] ~]#  5.3 一致性抽取源端数据到目标端 由于是异构数据库之间复制数据,初始化不能采用rman、dexpdp/impdp、传输表空间等oracle的方式来完成,这里选用Goldengate推荐的的初始化方式完成  5.3.1 源端增加用户对象的trandata日志 GGSCI (zlm) 1> dblogin userid ogg,password ogg GGSCI (zlm) 2> add trandata sender.* 5.3.2 源端配置初始化抽取组eini GGSCI (zlm) 1> add extract eini,sourceistable GGSCI (zlm) 2> edit params eini extract eini userid ogg,password ogg rmthost dg1,mgrport 7809 rmttask replicat,group rini table sender.*; 5.3.3 目标端配置复制组rini GGSCI (dg1) 1> add replicat rini,specialrun GGSCI (dg1) 2> edit params rini replicat rini sourcedb test userid root,password 123456 sourcedefs ./dirdef/oratomy.def discardfile ./dirrpt/rini.dsc,append,megabytes 5  map sender.*, target test.*; 5.3.4 运行源端manager和extract抽取组进程 GGSCI (zlm) 1> start mgr GGSCI (zlm) 2> start eini 5.3.5 运行目标端manager进程 GGSCI (zlm2) 1> start mgr 注意:当使用OGG推荐方式初始化数据时,目标端replicat复制组进程会自动运行,不用手动启动,就可以完成一次性抽取 当启动进程后,源端ggserr.log里提示有错误: 2013-08-31 17:43:13  WARNING OGG-01194  Oracle GoldenGate Capture for Oracle, eini.prm:  EXTRACT task RINI abended : Problem at line 27.  Expecting file, table, or record definition. 2013-08-31 17:43:13  ERROR   OGG-01203  Oracle GoldenGate Capture for Oracle, eini.prm:  EXTRACT abending. 2013-08-31 17:43:13  ERROR   OGG-01668  Oracle GoldenGate Capture for Oracle, eini.prm:  PROCESS ABENDING. 目标端的ggserr.log里也有同样的提示: 2013-08-31 17:43:12  INFO    OGG-00995  Oracle GoldenGate Delivery for MySQL, rini.prm:  REPLICAT RINI starting. 2013-08-31 17:43:12  ERROR   OGG-00303  Oracle GoldenGate Delivery for MySQL, rini.prm:  Problem at line 27.  Expecting file, table, or record definition. 2013-08-31 17:43:17  ERROR   OGG-01668  Oracle GoldenGate Delivery for MySQL, rini.prm:  PROCESS ABENDING 从该提示看来,应该是def文件的问题,但是之前已经创建并复制到目标库了,应该没有什么问题啊,查看了MOS上的文章才知道,原来这是由于目标端的OGG软件版本比源端版本低的缘故: Replicat abend with ERROR OGG-00303 Problem at line xx. Expecting file, table, or record definition. (Doc ID 1455370.1)   In OGG 11.2, there is a new parameter NOEXTATTR. This is used in DEFGEN. When the OGG version in a target site  is lower than the source site, defgen needs to use parameter NOEXTATTR to generate a sourcedef file which target site can read . If using a  sourcedef file generated without NOEXTATTR, a replicat will abend with error 00303.   So there are two ways to get around the issue:   1. Use a defgen paramfile with NOEXTATTR option, or 2. Generate definition file with the same OGG version as the OGG target site version.