docker实战部署并配置oracle21(官方镜像)

基础环境信息

名称详细信息
linux环境CentOS Linux release 7.9.2009 (Core)
内核版本3.10.0-1160.el7.x86_64
docker环境26.1.4

1.linux

在这里插入图片描述

2.docker

在这里插入图片描述

一、环境准备

1. 安装 Docker 环境

首先,确保你的系统已经安装了 Docker 环境。可参考:Centos7实战docker安装配置。安装完成后,确保 Docker 可以正常运行。
查看docker信息

2.拉取官方镜像

1.如图所示为oracle官网的数据库镜像地址
在这里插入图片描述
2.根据大版本选择自己所需要的镜像,如作者选择的为express版本。进入之后页面拉到底,选择具体的版本号,作者选择的为21.3.0.0。此处需要注意,部分镜像的获取需要有特定权限,如企业版本(enterprise)
在这里插入图片描述
其中

docker pull container-registry.oracle.com/database/express:21.3.0-xe

即为在docker中可以拉取镜像的命令,

3.在docker中执行此命令,拉取官方镜像,等待执行完成,完成后会得到一个11.4G大小的镜像文件
4.对应镜像提供了详细的配置参数以及相关参数配置方法,具体可参考官网,不同版本可使用的参数不同,完整的参数解释可参考下一章节中的4.参数解释
在这里插入图片描述

3.查看镜像

docker images

在这里插入图片描述

4.重命名镜像

docker tag [原镜像名称]:[原镜像标签] [新镜像名称]:[新镜像标签] 

通过重命名镜像名称,设置成自己所需要的镜像名。
container-registry.oracle.com/database/express:为原镜像名称。
oracle21:为自定义镜像名称。
21.3.0-xe:为标签信息。

docker tag container-registry.oracle.com/database/express:21.3.0-xe oracle21:21.3.0-xe

在这里插入图片描述

修改完成之后会有2个相同镜像ID的问题,是因为同一个镜像有2个不同的名称,可以通过删除其他未使用的镜像名称,保留自己需要的镜像。

5.删除镜像

docker rmi [镜像名称]:[标签]

在这里插入图片描述

二、oracle安装

1.创建数据存放文件夹

用于存放oracle数据文件

mkdir -p /home/data/oracle/oradata

2.文件授权

为了确保oracle数据有权限写入文件,此处需要对文件进行授权

chmod 777 /home/data/oracle/oradata

3.启动容器

docker run -d \
--name oracle21 \
-p 1521:1521 -p 5500:5500 \
-e ORACLE_PWD=123456 \
-e ORACLE_CHARACTERSET=AL32UTF8 \
-v /home/data/oracle/oradata:/opt/oracle/oradata \
oracle21:21.3.0-xe

容器正常创建后会返回容器ID
在这里插入图片描述

4.参数解释

  • docker run: 这是 Docker 命令的一部分,用于在容器中运行一个镜像。
  • -d: 这个选项告诉 Docker 在后台运行容器,即“detached”模式。
  • -p 1521:1521 -p 5500:5500: 这两个选项指定了端口映射。它们将容器内部的端口 1521 映射到主机的端口 1521,以及将容器内部的端口 5500 映射到主机的端口 5500。Oracle 数据库通常使用 1521 端口进行连接,而 5500 端口用于 Oracle Enterprise Manager Express。前一个为主机的端口,后一个为容器内部端口。
  • -e:这些选项用于设置容器中 Oracle 数据库的一些环境变量
    • -e ORACLE_SID=ORCLCDB:设置 Oracle 的系统标识符(SID),这里设置为ORCLCDB。
    • -e ORACLE_PDB=ORCLPDB:设置 Oracle 的 Pluggable Database 名称,这里设置为 ORCLPDB1。
    • -e ORACLE_PWD=123456:设置 Oracle 的管理员密码,这里设置为 123456。此处设置的密码为:SYS, SYSTEM and PDBADMIN用户
    • -e ORACLE_EDITION=standard:设置 Oracle 的版本/版本类型,这里设置为标准版,若想使用分表操作则需要设置为企业版(enterprise)
    • -e ORACLE_CHARACTERSET=AL32UTF8:设置 Oracle 数据库的字符集,这里设置为 AL32UTF8,即 Unicode 字符集。
  • -v /home/data/oracle/oradata:/opt/oracle/oradata: 这个选项用于挂载主机文件系统的目录到容器中。在这个例子中,它将主机上的 /home/data/oracle/oradata 目录挂载到容器中的 /opt/oracle/oradata 目录。此处:/opt/oracle/oradata不可更改,这样做是为了将 Oracle 数据库的数据文件存储到主机文件系统中,以便数据持久化,即使容器被删除也不会丢失数据。如果是window则修改自己的window目录 C:\docker\volumes\oracle21.3.0.0\oradata:/opt/oracle/oradata
  • --privileged=true:赋予容器全部的特权,通常用于一些需要较高权限的操作。
  • --name oracle: 这个选项用于为容器指定一个名称,这里命名为 oracle。
  • oracle21:21.3.0-xe: 这是要运行的 Oracle镜像的名称及其标签

5.查看容器启动日志

docker logs -f 容器名称

此处可以使用一下命令查看日志信息

docker logs -f oracle21

完整的启动日志如下:

Specify a password to be used for database accounts. Oracle recommends
that the password entered should be at least 8 characters in length,
contain at least 1 uppercase character, 1 lower case character and 1
digit [0-9]. Note that the same password will be used for SYS, SYSTEM
and PDBADMIN accounts: Confirm the password: Configuring Oracle
Listener. Listener configuration succeeded. Configuring Oracle
Database XE. Enter SYS user password:
***** Enter SYSTEM user password:
****** Enter PDBADMIN User Password:
********** Prepare for db operation 7% complete Copying database files 29% complete Creating and starting Oracle instance 30% complete 33%
complete 37% complete 40% complete 43% complete Completing Database
Creation 47% complete 50% complete Creating Pluggable Databases 54%
complete 71% complete Executing Post Configuration Actions 93%
complete Running Custom Scripts 100% complete Database creation
complete. For details check the logfiles at:
/opt/oracle/cfgtoollogs/dbca/XE. Database Information: Global Database
Name:XE System Identifier(SID):XE Look at the log file
“/opt/oracle/cfgtoollogs/dbca/XE/XE.log” for further details.

Connect to Oracle Database using one of the connect strings:
Pluggable database: 237e7e26b469/XEPDB1
Multitenant container database: 237e7e26b469 Use https://localhost:5500/em to access Oracle Enterprise Manager for
Oracle Database XE

SQL*Plus: Release 21.0.0.0.0 - Production on Fri Apr 11 14:05:13 2025
Version 21.3.0.0.0

Copyright © 1982, 2021, Oracle. All rights reserved.

Connected to: Oracle Database 21c Express Edition Release 21.0.0.0.0 -
Production Version 21.3.0.0.0

SQL> System altered.

SQL> System altered.

SQL> Pluggable database altered.

SQL> PL/SQL procedure successfully completed.

SQL> SQL> Session altered.

SQL> User created.

SQL> Grant succeeded.

SQL> Grant succeeded.

SQL> Grant succeeded.

SQL> User altered.

SQL> SQL> Disconnected from Oracle Database 21c Express Edition
Release 21.0.0.0.0 - Production Version 21.3.0.0.0

SQL*Plus: Release 21.0.0.0.0 - Production on Fri Apr 11 14:05:13 2025
Version 21.3.0.0.0

Copyright © 1982, 2021, Oracle. All rights reserved.

Connected to: Oracle Database 21c Express Edition Release 21.0.0.0.0 -
Production Version 21.3.0.0.0

SQL> PL/SQL procedure successfully completed.

SQL> Disconnected from Oracle Database 21c Express Edition Release
21.0.0.0.0 - Production Version 21.3.0.0.0 The Oracle base remains unchanged with value /opt/oracle The Oracle base remains unchanged
with value /opt/oracle
######################### DATABASE IS READY TO USE!
######################### The following output is now a tail of the alert.log: XEPDB1(3):Completed: ALTER DATABASE DEFAULT TABLESPACE
“USERS” 2025-04-11T14:05:12.033406+00:00 ALTER PLUGGABLE DATABASE
XEPDB1 SAVE STATE Completed: ALTER PLUGGABLE DATABASE XEPDB1 SAVE
STATE 2025-04-11T14:05:13.180049+00:00 ALTER SYSTEM SET
control_files=‘/opt/oracle/oradata/XE/control01.ctl’ SCOPE=SPFILE;
2025-04-11T14:05:13.294964+00:00 ALTER SYSTEM SET local_listener=‘’
SCOPE=BOTH; ALTER PLUGGABLE DATABASE XEPDB1 SAVE STATE Completed:
ALTER PLUGGABLE DATABASE XEPDB1 SAVE STATE

如果输出:DATABASE IS READY TO USE!,则表示oracle启动成功。可以通过客户端登录。
注意本地机器的防火墙对端口的开放

6.查看的容器

  • 查看运行中的容器
    docker ps
    

在这里插入图片描述

  • 查看所有的容器

    docker ps -a
    

在这里插入图片描述

三、配置 Oracle 环境变量

1.进入容器内部

创建并启动容器后,你可以进入容器内部进行配置

docker exec -it 容器名称 /bin/bash

此命令会让你进入 Oracle 容器的 Bash 环境。

docker exec -it oracle21 /bin/bash

在这里插入图片描述
后续所有的配置均在容器内部,请勿退出容器,否则配置无法生效

2.配置SID

1.查看现有SID的开启状态

cat /etc/oratab

此处表示,现有的SID名称为XE,开启状态为Y(已启用),若此处为N,则需要先修改为Y,以下为修改SID的过程
在这里插入图片描述

2.登录oracle

sqlplus / as sysdba

在这里插入图片描述

3.关闭数据库

修改前需要先关闭数据库

#关闭数据库
shutdown immediate;
exit;

4.修改SID开启状态

vim /etc/oratab

将XE:/opt/oracle/product/21c/dbhomeXE:N 修改为XE:/opt/oracle/product/21c/dbhomeXE:Y

此处可能会提示vim不是有效的命令,需要先装vim,参考centos安装vim命令即可

5.重新登录数据库并开启数据库

#登录数据库
sqlplus / as sysdba

#开启数据库
startup

6.安装vim

yum install vim

若提示无权限,则需要先切换root账户

在这里插入图片描述

2.修改账号密码

1.登录数据库

sqlplus / as sysdba

2.修改指定账号密码

#将system账号的密码修改为itcast
alter user system identified by itcast;

#刷新
ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED;
#退出
exit

在这里插入图片描述

3.登录数据库

通过数据库工具,配置链接参数进行登录
在这里插入图片描述

4.时区配置

默认时区非东8时区,会导致数据库时间异常

1231231231231231213123

  • 这是一个定时任务,每天定时凌晨2点执行。但是日志记录的时间与真实时间不一致,相差8个小时。
  • 这就会导致定时任务中如果涉及到系统时间的情况,那么其生成、处理的数据时间都将是错误的系统时间

1.检查容器系统时间

在容器的Bash 环境下检查容器系统时间是否异常

date -R

在这里插入图片描述

进入容器后,采用替换时区文件的方法。进入/usr/share/zoneinfo/Asia目录下,查看是否有需要的时区文件。
如果有,可以直接执行cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime命令,替换系统时区文件,再执行date -R查看时间是否正常。
如果没有,而且对应的文件夹也没有的话,需要先创建对应的文件夹,mkdir -p/usr/share/zoneinfo/Asia。创建好后,使用exit命令先退出回到宿主机,从宿主机中进入/usr/share/zoneinfo/Asia目录下找到对应的时区文件。 执行docker cp/usr/share/zoneinfo/Asia/Shanghai 容器ID或容器名:/usr/share/zoneinfo/Asia 命令,将宿主机中的时区文件拷贝得到docker容器中。再以root权限进入容器替换系统时区文件

bash-4.2# cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime  #修改容器的系统时区文件
bash-4.2# date -R   #检查时间是否正常
Sat, 12 Apr 2025 15:57:57 +0800

bash-4.2# mkdir -p/usr/share/zoneinfo/Asia  #如果没有对应的时区文件夹,就创建
bash-4.2# exit
exit
[root@localhost ~]# docker cp/usr/share/zoneinfo/Asia/Shanghai oracle21:/usr/share/zoneinfo/Asia  #将宿主机的时区文件copy到容器对应的时区文件夹中
[root@localhost ~]# docker exec -it -u root test /bin/bash  #再次进入容器
bash-4.2# cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime   #修改容器的系统时区文件
bash-4.2# date -R   #检查时间是否正常
Sat, 12 Apr 2025 15:57:57 +0800

若提示无权限,则通过su root先切换到root用户

2.检查时区

-- 查询数据库时区
select dbtimezone from dual;

-- 查询数据库时间
select to_char(sysdate, 'yyyy-mm-dd hh24:mi:ss') from dual;

第一句是检查数据库的时区。如果是+08:00一般都是正确的东8时区。
第二句是检查系统时间,根据查询出来的结果时间与实际时间对比,如果是一致的就是对的,不用再看下面的了。
在这里插入图片描述

3.修改数据库时区

1.修改时区为正确的东8时区。

alter database set time_zone = '+8:00';

在这里插入图片描述
2.重启数据库让配置生效

##关闭数据库
shutdown immediate;

##启动数据库
startup

在这里插入图片描述
完成上面的步骤 Oracle数据库的时间问题也就解决了,可以在进入数据库,查询系统时间检查一下。

四、创建并配置用户

在 Oracle 多租户架构中(从 Oracle 12c 开始),用户分为

  • 普通用户(Common User)
    1.用户的名称必须以 C## 开头,在CDB中创建
    2.适用于管理员用户,用户管理CDB下的多个PDB

  • 本地用户(Local User)
    1.用户的名称无需以 C## 开头,在PDB中创建
    2.更适合应用开发和租户管理
    3.我们平时开发时用的多是本地用户

数据库刚被安装后,并没有本地用户,我们需要通过system用户登录Oracle之后,创建本地用户。

1.进入docker内部并且登录oracle

# 进入 Oracle 容器的 Bash 环境,oracle21 为容器名称
docker exec -it oracle21 /bin/bash

#登录数据库
sqlplus / as sysdba

2、切换session为PDB

  • 在包含 CDB(容器数据库)和 PDB(可插拔数据库)的环境中,显示会话所连接的容器的名称。
  • 容器可以是根容器(CDB R O O T )、种子数据库( P D B ROOT)、种子数据库(PDB ROOT)、种子数据库(PDBSEED)或某个具体的 PDB。
    1.查看数据库中所有的PDB
##方式1
SELECT PDB_ID, PDB_NAME, STATUS FROM DBA_PDBS;

##方式1
SELECT NAME FROM V$PDBS;

在这里插入图片描述
在这里插入图片描述

2.查看当前容器

SHOW CON_NAME;

在这里插入图片描述
3.切换当前用户的session为PDB

-- 切换session到根容器
SQL> ALTER SESSION SET CONTAINER = CDB$ROOT;

Session altered.

-- 切换session到PDB
SQL> ALTER SESSION SET CONTAINER = XEPDB1;

Session altered.

-- 查看当前容器名称
SQL> SHOW CON_NAME;

CON_NAME
------------------------------
XEPDB1
SQL>

3、创建用户

create user 用户名 identified by 密码;

create user test_user identified by test_user123;

在这里插入图片描述

4.账户授权

grant connect,resource,create type,create view,recovery_catalog_owner to 用户名;
注意:禁止使用:imp_full_database权限

grant connect,resource,create type,create view,recovery_catalog_owner to test_user;

在这里插入图片描述

5.账户登录

此处需要注意的是,必须使用指定容器名进行登录,否则登录不成功
在这里插入图片描述

6.创建表并查看

CREATE TABLE TEST_USER.PERSON_TABLE (
    id NUMBER PRIMARY KEY,
    name VARCHAR2(50),
    age NUMBER,
    email VARCHAR2(100),
    created_date DATE
) ;

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值