阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Oracle 12c创建可插拔数据库(PDB)及用户

199次阅读
没有评论

共计 2016 个字符,预计需要花费 6 分钟才能阅读完成。

由于 Oracle 12c 使用了 CDB-PDB 架构,类似于 docker,在 container-db 内可以加载多个 pluggable-db,因此安装后需要额外配置才能使用。

一、修改 listener.ora , tnsnames.ora
###listener.ora###
LISTENER =
(DESCRIPTION =
  (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
  (CONNECT_DATA = (SERVICE_NAME = orcl))
)
#sid list 列举 cdb 和所有 pdb 的数据库名,所有 sid 与 oracle 环境变量保持一致 #
SID_LIST_LISTENER =
(SID_LIST =
  (SID_DESC =
    (GLOBAL_DBNAME = orcl) #cdb db_name
    (SID_NAME = orcl)
  )
  (SID_DESC =
    (GLOBAL_DBNAME = pdborcl) #pdb db_name
    (SID_NAME = orcl)
  )
)
###listener.ora###

##tnsnames.ora###
#cdb
orcl =
(DESCRIPTION =
  (ADDRESS_LIST =
    (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521)) )
  (CONNECT_DATA =
    (SERVICE_NAME = orcl) #cdb 的 db_name
  )
)
#pdb
pdborcl =
(DESCRIPTION =
  (ADDRESS_LIST =
    (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
  )
  (CONNECT_DATA =
    (SERVICE_NAME = pdborcl) #pdb 的 db_name
  )
)
##tnsnames.ora###
在客户端连接时使用“service_name+domain_name”连接。如果出现 ora-01017,很有可能是

二、创建 pdb
cdb 相当于操作系统,调用并管理各个 pdb。pdb 相当于真正提供业务需求的数据库实例。oracle 12c 安装后只创建了 cdb,需要自己生成相应的 pdb。
1、创建 pdb
在 sqlplus 下:

create pluggable database pdborcl
admin user pdbadmin identified by pdbadmin
role=(resource)
file_name_convert=(‘PDB$SEED’s directory’ , ‘PDBOrcl’s directory’);

2、同步文件
select pdb_name,status from cdb_pdbs
若 pdb 状态为 need sync,则需要:

alter sesseion set container=pdborcl
shutdown immediate 或者 alter pluggable database pdborcl close immediate ;
alter pluggable database pdborcl open restricted ;
exec dbms_pdb.sync_pdb ; #调用 dbms_pdb 进行 pdb

3、新增用户
create user scott account unlock identified by tiger ;
grant resource to scott ;

按照上述方法创建用户,如果出现 ora-01017,很有可能是 1、没有指定连接的 service_name 到具体 pdb,或者 oracle 对密码大小写敏感。前者检查 listener.ora 中 sid_list 是否已经列出该 pdb,并检查连接字符串是否在 tnsnames.ora 指定。后者如果无法修改前端程序,可以使用
alter system set SEC_CASE_SENSITIVE_LOGON = false ;

强制关闭 oracle 的大小写检查进行确认。

三、常用命令
show pdbs:查看当前数据库 container 中包含有多少个 pdb。如果 session 在某个 pdb 中,可以查看当前的 pdb。
alter session set container=PDBNAME
切换当前会话到某个 pdb 中。切换后才可使用当前 pdb 的私有用户进行操作
startup/shutdown immediate
关闭当前会话所在的 cdb/pdb
alter pluggable database PDBNAME open ;
打开指定 pdb

alter pluggable database PDBNAME close immediate ;

关闭指定 pdb

更多 Oracle 相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-02/140824.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计2016字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中