当前位置: 首页 > news >正文

Docker 安装 Oracle创建表空间并导入数据库

一、Docker 安装Oracle

1、检查docker 版本

2、docker 下载镜像

3、 docker启动容器

4、  进入容器内部

5、安装成功,使用客户端工具连接

二、创建数据库用户与表空间

1、查询数据库文件位置

2、创建表空间

3、创建用户

4、设置权限

三、导出数据库DMP

1、上传文件到指定目录

2、创建权限目录

3、执行oracle-expdp导出

四、导入oracle dmp文件

1、创建权限目录

2、导入oracle dmp文件


一、Docker 安装Oracle

1、检查docker 版本

docker version

2、docker 下载镜像

docker pull registry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g

3、 docker启动容器

docker run -d -p 30026:1521 -p 8081:8080 --name oracle_11g -e ORACLE_HOME=/home/oracle/app/oracle/product/11.2.0/dbhome_2 -e ORACLE_SID=helowin registry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g

4、  进入容器内部

docker exec -it oracle_11g bash

# 1. 切换至root用户(默认是oracle用户),密码为helowin
su root# 2. 创建软链接
ln -s $ORACLE_HOME/bin/sqlplus /usr/bin# 3.切换回oracle用户
su oracle# 4. 登录sql plus
sqlplus /nolog
conn /as sysdba
## 4.1 修改system用户密码为system
alter user system identified by system;
## 4.2 修改sys用户密码为system
alter user sys identified by system;
## 4.3 新增一个测试用户(用户名:test,密码:test123);
create user test identified by test123;
## 4.4 将dba权限给内部管理员账号和密码
grant connect,resource,dba to SYS_ORM;
## 4.5 修改密码策略规则为:密码永不过期
ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED;
## 4.6 修改数据库最大连接数;
alter system set processes=1000 scope=spfile;
## 4.7 最后重启数据库;
shutdown immediate;
startup;# 5.退出
exit

5、安装成功,使用客户端工具连接

二、创建数据库用户与表空间

1、查询数据库文件位置

 select t1.name,t2.name  from v$tablespace t1,v$datafile t2  where t1.ts# = t2.ts#;

2、创建表空间

用sysdba登陆,sqlplus /@sysware as sysdba /PLSQL使用SYSDBA 登录执行

CREATE TABLESPACE ORM
DATAFILE '/home/oracle/app/oracle/oradata/helowin/orm.dbf' size 800M  	   --存储地址 初始大小800Mautoextend on next 50M maxsize unlimited                   --每次扩展10M,无限制扩展EXTENT MANAGEMENT LOCAL autoallocate SEGMENT SPACE MANAGEMENT AUTO; 

3、创建用户

用sysdba登陆,sqlplus /@sysware as sysdba /PLSQL使用SYSDBA 登录执行

create user 用户名 identified by 密码 default tablespace 表空间名;  

create user ORM identified by ORM default tablespace ORM;  

4、设置权限

用sysdba登陆,sqlplus /@sysware as sysdba /PLSQL使用SYSDBA 登录执行

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 ORM;

三、导出数据库DMP

注意:导出需要记录用户名、表空间名,导入需要用到

1、上传文件到指定目录

docker cp  /home/imp e5w3hr4rrre3:/home/ormexp

2、创建权限目录

用sysdba登陆,
create directory 授权目录名 as '授权目录';   
grant read,write on directory 授权目录名 to 数据库用户名;

# 切换oracle用户:
su - oracle
# 管理员登录
sqlplus sys/system@orcl as sysdbacreate directory ormExp as '/home/ormexp';   
grant read,write on directory ormExp to ORM;

3、执行oracle-expdp导出

在cmd、用户窗口执行:

expdp 数据库用户名/数据库密码@sysware directory=授权目录名 dumpfile=数据文件名称.dmp

expdp ORM/ORM@orcl directory=ormExp dumpfile=data.dmp

四、导入oracle dmp文件

1、创建权限目录

用sysdba登陆,
create directory 授权目录名 as '授权目录';   
grant read,write on directory 授权目录名 to 数据库用户名;

# 切换oracle用户:
su - oracle
# 管理员登录
sqlplus sys/system@orcl as sysdbacreate directory ormimp as '/home/ormimp';   
grant read,write on directory ormimp to ORM;

2、导入oracle dmp文件

在cmd、用户窗口执行


impdp 数据库用户名/数据库密码 directory=授权目录名 remap_tablespace=导出数据库的表空间:表空间 dumpfile=数据文件名称.dmp remap_schema=导出数据库的用户名:数据库用户名 transform=OID:N

impdp ORM/ORM@orcl directory=impdata remap_tablespace=BLUESYS20240715:ORM dumpfile=BLUESYS.DMP remap_schema=BLUESYS:ORM transform=OID:N
impdp ORM/ORM directory=impdata remap_tablespace=BLUESYS20240715:ORM dumpfile=BLUESYS.DMP remap_schema=BLUESYS:ORM transform=OID:N


 

http://www.lryc.cn/news/500288.html

相关文章:

  • elementui table子级tree懒加载bug
  • AI与低代码技术融合:如何加速企业智能化应用开发?
  • 【C#】新建窗体文件,Form、UserControl
  • ansible学习笔记之02command模块与shell模块
  • 在Docker中部署禅道,亲测可用
  • C++(十二)
  • 【数学建模】线性规划问题及Matlab求解
  • 【JavaWeb后端学习笔记】Spring全局异常处理器
  • PT8M2102 触控型 8Bit MCU
  • 4. React 性能优化技巧:如何让你的应用更快
  • pytest中使用conftest做测试前置和参数化
  • Spring Boot 中使用 @Transactional 注解配置事务管理
  • MATLAB 建筑顶面面积计算(95)
  • Linux网络编程之---组播和广播
  • Apache Dolphinscheduler可视化 DAG 工作流任务调度系统
  • docker 部署共享文档ZFile
  • 面试题之JVM
  • 二叉树的深搜(不定期更新。。。。。)
  • WebLLM Chat:无服务器、私密的AI聊天体验
  • C#中的模拟服务器与客户端建立连接
  • 【深度学习】利用Java DL4J 构建和训练医疗影像分析模型
  • application.yml 和 bootstrap.yml
  • 使用uniapp开发小程序场景:在百度地图上调用接口返回的设备相关信息并展示
  • ubuntu22.04 使用可以用的镜像源获取你要的镜像
  • Flume——sink连接hdfs的参数配置(属性参数+时间参数)
  • python+docker实现分布式存储的demo
  • go-blueprint create exit status 1
  • 如何更改Git用户名 - 本地与全局设置指南
  • Node.js JWT认证教程
  • 【青牛科技】应用于音频信号处理系统的D258 是由两个独立的高增益运算放大器组成