The following example shows Oracle to MySQL replication. In this example, Oracle and MySQL are running on a single server.
Environment: Virtualbox using Pre-Built Developer VMs (for Oracle VM VirtualBox)
Template name: Database App Development VM
Oracle Linux 5 (32bit)
Oracle RDBMS 11gR2
MySQL Server 5.0.77
MySQL is not installed on the pre-built VM, but this can be installed with:
...
...
...
This section helps first timers to quickly setup MySQL environment so Dbvisit Replicate can be configured after that to establish proof of concept in testing environment.
If MySQL is not installed then it can be installed with the following command. This installs the MySQL database and the MySQL client.
No Format |
---|
|
yum install mysql mysql-server |
Start MySQL
Section |
---|
Column |
---|
|
|
Panel |
---|
The MySQL database software only needs to be installed on the target server. However to establish a mysql connect from the source server the mysql client software is needed. On the source server only install:
No Format |
---|
yum install mysql |
You can start MySQL using following command:
No Format |
---|
|
/etc/init.d/mysqld start |
Install Dbvisit Replicate using the 32bit RPM installation file (as root):
Section |
---|
Column |
---|
| Panel |
---|
| rpm -ivh dbvisit_replicate-2.0.02-1.i386.rpm Preparing... ########################################## [100%] 1:dbvisit_replicate ########################################### [100%] |
|
|
The following Oracle table is going to be replicated. This is a copy of the sys.dba_objects table but created in the SCOTT schema. Create this table in Oracle:
Section |
---|
Column |
---|
| Panel |
---|
| CREATE TABLE "SCOTT"."AVI_OBJECTS" ( "OWNER" VARCHAR2(30), "OBJECT_NAME" VARCHAR2(128), "SUBOBJECT_NAME" VARCHAR2(30), "OBJECT_ID" NUMBER, "DATA_OBJECT_ID" NUMBER, "OBJECT_TYPE" VARCHAR2(19), "CREATED" DATE, "LAST_DDL_TIME" DATE, "TIMESTAMP" VARCHAR2(19), "STATUS" VARCHAR2(7), "TEMPORARY" VARCHAR2(1), "GENERATED" VARCHAR2(1), "SECONDARY" VARCHAR2(1), "NAMESPACE" NUMBER, "EDITION_NAME" VARCHAR2(30) ) SEGMENT CREATION IMMEDIATE PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "USERS" |
|
|
Create this same table in MySQL. The syntax is slightly different to Oracle.
First user scott (or database) has to be created first in MySQL.
Use mysql command to connect to The MySQL server. This program is started by executing the command mysql at the shell prompt. You can connect using following command. You can find more information about MySQL and configuring authentication here
Unlike Oracle, MySQL has no schemas but only databases. Therefore we will create database first before creating table within the new database.
No Format |
---|
|
mysql> create database scott;
Query OK, 1 row affected (0.00 sec)
mysql> use scott;
Database changed |
Now the MySQL table can be created:
Section |
---|
Column |
---|
|
Panel |
---|
No Format |
---|
|
DROP TABLE IF EXISTS `avi_objects`;
SET @saved_cs_client = @@character_set_client;
SET character_set_client = utf8;
CREATE TABLE `avi_objects` (
`OWNER` varchar(30) default NULL,
`OBJECT_NAME` varchar(128) default NULL,
`SUBOBJECT_NAME` varchar(30) default NULL,
`OBJECT_ID` bigint(20) default NULL,
`DATA_OBJECT_ID` bigint(20) default NULL,
`OBJECT_TYPE` varchar(19) default NULL,
`CREATED` date default NULL,
`LAST_DDL_TIME` date default NULL,
`TIMESTAMP` varchar(19) default NULL,
`STATUS` varchar(7) default NULL,
`TEMPORARY` varchar(1) default NULL,
`GENERATED` varchar(1) default NULL,
`SECONDARY` varchar(1) default NULL,
`NAMESPACE` bigint(20) default NULL,
`EDITION_NAME` varchar(30) default NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1; |
Some handy MySQL tips:
1) To change the password for the MySQL root user:
No Format |
---|
mysql> UPDATE mysql.user SET Password = PASSWORD('root') WHERE User = 'newpasswd';
mysql> FLUSH PRIVILEGES; |
2) To allow a remote host to connect from a different server other than the local host on MySQL. This is needed when the following error message is received: "ERROR 1130 (HY000)": Host 'xxxxx' is not allowed to connect to this MySQL server
First determine the current privileges:
No Format |
---|
mysql> SELECT host FROM mysql.user WHERE User = 'root';
+-----------+
| host |
+-----------+
| 127.0.0.1 |
| localhost |
| target |
+-----------+ |
Now add privilege to connect from a server called "source":
No Format |
---|
GRANT ALL PRIVILEGES ON *.* TO 'root'@'source';
FLUSH PRIVILEGES; |
Note |
---|
Ensure you understand MySQL privileges fully on your production server before running this command as it may expose the database too much. Reduce the privileges as required. |
The new privileges look like:
No Format |
---|
mysql> SELECT host FROM mysql.user WHERE User = 'root';
+-----------+
| host |
+-----------+
| 127.0.0.1 |
| localhost |
| target |
| source |
+-----------+ |
3) To allow access for a specific remote user to connect to MySQL. This is needed when the following error message is received: ERROR 1045 (28000): Access denied for user 'root'@'source' (using password: YES)
No Format |
---|
mysql> GRANT ALL ON root.* TO 'root'@'source' IDENTIFIED BY 'root';
FLUSH PRIVILEGES; |
Note |
---|
Ensure you understand MySQL privileges fully on your production server before running this command as it may expose the database too much. Reduce the privileges as required. |