基础环境信息
名称 | 详细信息 |
---|---|
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 可以正常运行。
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 XESQL*Plus: Release 21.0.0.0.0 - Production on Fri Apr 11 14:05:13 2025
Version 21.3.0.0.0Copyright © 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.0SQL> 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.0SQL*Plus: Release 21.0.0.0.0 - Production on Fri Apr 11 14:05:13 2025
Version 21.3.0.0.0Copyright © 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.0SQL> 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时区,会导致数据库时间异常
- 这是一个定时任务,每天定时凌晨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
) ;