I am writing this blog to test one of the Oracle-provided docker images for database 23ai.
I found it very easy to set up a quick database environment to do some tests. You don’t need any virtual machine, Vagrant, or anything else to set this up.
The Oracle Database 23ai Free server Container image contains a pre-built database running on Oracle Linux 8, so the startup time is very fast.
This image contains a default database in a multitenant configuration with one pluggable database.
data:image/s3,"s3://crabby-images/38d96/38d96a88723dc3d214716c15a291de021086d38b" alt="docker docker"
Pre-requisite: You should have docker installed on your system.
Here is the link for the Oracle registry where you can find docker images.
data:image/s3,"s3://crabby-images/85f6d/85f6dea18f9eccaae6ee3ac769ed91bd9e4486e2" alt="docker2 docker2"
data:image/s3,"s3://crabby-images/91dfb/91dfb77d803f1788a946e90952df74e3ffeaf011" alt=""
You can use the below command to pull the image and then run it.
docker pull container-registry.oracle.com/database/free:latest
Or I used the direct Docker run command and provided variables in the command.
docker run -d --name myoradb1 -p 1521:1521 -p 5500:5500 -e ORACLE_PWD=Welcome1 -e ORACLE_CHARACTERSET=AL32UTF8 -v ${PWD}/opt/oracle/oradata:/opt/oracle/oradata container-registry.oracle.com/database/free:latest
This command will pull the image and run it.
data:image/s3,"s3://crabby-images/39a04/39a04d02b75f99a5ef014f75e8db4fd4dae80046" alt="docker3 docker3"
In the above command
container name = myoradb1
Port mapping = 1521:1521
Port mapping = 5500:5500
Set env. variable = ORACLE_CHARACTERSET=AL32UTF8
Set volume = ${PWD}/opt/oracle/oradata:/opt/oracle/oradata
Container Registry = container-registry.oracle.com/database/free:latest
Once this is done, you can see the image using the below command.
data:image/s3,"s3://crabby-images/28bca/28bca2d2c7b1ccc7c0f643a79a0d8ae7ccb3902b" alt="docker4 docker4"
I used Docker Desktop on my Windows machine, so we can also see the image on the Docker Desktop.
data:image/s3,"s3://crabby-images/f89c0/f89c0ed834642776acc41defa6f1cf5bbccba5e6" alt="docker5 docker5"
Now let me start the container in interactive mode to log into the Database.
data:image/s3,"s3://crabby-images/5e27c/5e27c9a89e28697625be99f1db10aa558aaa8429" alt="docker6 docker6"
Connect as you see in my above docker command I used port mapping so that we can connect this DB
From any external tool like SQL Developer, toad, etc. from a laptop
data:image/s3,"s3://crabby-images/29731/29731e778363c85848506e31eecec3ce90d13d64" alt="docker7 docker7"