设为首页 加入收藏 网站搜索 繁體中文 中国建站网 — 站长资源平台

Oracle安全全程接触(完整版)二

来源本站整理 作者:佚名 时间:2006-8-1 21:12:36 该文得分0

  (2)SQL*PLUS编程用户的规范
  
  ·存储结构的规范
  
  考虑到用SQL*PLUS编程可实现各行各业、各公司、各部门多种多样的应用需求,我们的SQL*PLUS编程用户也应该朝这个方向规范:不同种类的应用必须有不同的用户;不同种类的应用必须有不同的存储位置,包括物理文件、缺省表空间、临时表空间的创建和规划:当准备编写某一较大规模(从ORACLE数据量和面向用户量考虑)应用程序时,首先应该创建一个逻辑的存储位置-表空间,同时定义物理文件的存放路径和所占硬盘的大小。
  
  ①、物理文件缺省的存放路径在/oracle_home/dbs下,在命令行下用UNIX指令df -k 可查看硬盘资源分区的使用情况。如果oracle_home使用率达90‰以上,而且有一个或多个较为空闲的硬盘资源分区可以利用,我们最好把物理文件缺省的存放路径改到较为空闲的硬盘资源分区路径下。在此路径下我们可以这样规划资源物理文件的存储:
  
  xxx表空间
  
  xxx行业/ xxx公司/ xxx 部门/ xxx 服务.dbf
  
  DEMO表空间
  
  default_datafile_home1/col /elec/sys4/demo1.dbf
  
  default_datafile_home1/col /elec/sys4/demo2.dbf
  
  公司系统四部摹拟演示系统物理文件
  
  HUMAN表空间
  
  default_datafile_home1/col/elec/human/human.dbf
  
  公司人事部人事管理系统物理文件
  
  BOOK表空间
  
  default_datafile_home1/col/elec/book/book.dbf
  
  公司资料室图书管理系统物理文件
  
  QUESTION表空间
  
  default_datafile_home1/col/elec/client/question.dbf
  
  公司客户服务部问题库系统物理文件
  
  PC表空间
  
  default_datafile_home1/col/chaoxun/client/pc.dbf
  
  公司PC机售后服务系统物理文件
  
  ……表空间
  
  default_datafile_home2/……………………………
  
  等等
  
  说明:其中default_datafile_home1指oracle_home/dbs;
  
  default_datafile_home2指较为空闲的硬盘资源分区路径。
  
  ②、物理文件的大小根据应用系统的数据量、数据对象、程序包的多少来定。一般用于摹拟演示的小系统,表空间初始的物理文件为2M即能满足要求,如果信息量满,还可以增加物理文件,扩充表空间(每次扩充大小也可暂定为2M);一般实际运行的应用系统可适当增加表空间初始的物理文件大小,但也不要一次分配太大(因为不易回收空间,却易扩充空间),这也需要根据具体情况具体分析:信息量大、需长时间保存的应用在条件允许情况下,表空间可以大到几百M甚至上G;信息量小、短期经常刷新的应用,表空间可以控制在2M以下。
  
  ③、表空间的名称应该采用同系统应用相似的英文字符或字符缩写,表空间所对应的一个或多个物理文件名也应有相关性。不同用户所处的缺省表空间不同,存储的信息就不能互相访问。这比把所有用户信息都储存在系统表空间,安全性大大提高了。如果用ORACLE WEB SERVER管理端口创建的用户,其缺省和临时表空间一定是系统表空间,DBA切记要改变用户的缺省表空间。临时表空间存放临时数据段,处理一些排序、合并等中间操作,根据实际应用的需求可以把它们放在专门创建的表空间里;如果系统表空间大,也可以把它们放在系统表空间。用户创建的数据索引最好和数据文件分开存放在不同表空间,以减少数据争用和提高响应速度。
  
  ·密码和用户名的规范
  
  有相当数量的ORACLE用户名和密码一致,这是个很不安全的因素。我们建议ORACLE用户名和密码一定不要一样,密码最好在五,六位字符以上。不同用户间不应该使用相同的密码。用户名的定义可根据实际应用的英文名来设,而依据编程人员的姓名定义的用户名实际上不规范,可在日后的工作中结合上述有关存储结构规范的说明逐步改进。
  
  (3)特殊要求用户的规范
  
  在ORACLE数据库使用过程中,还会遇到一些有特殊要求的用户:非编程人员需要对某个表有查询、增加、删除、修改的权利。DBA应创建一个这样的用户,先确定用户名和密码,再规定相关应用所在缺省表空间(包含某个表)和临时表空间,最后TABLE属主给其授权:赋予CONNECT角色SELECT、INSERT、DELETE、UPDATE ON THE TABLE的对象级权限,这可根据实际需求自由取舍。
  
  举例:●给新用户授于对象级权限(命令行方式):
  
  假设新用户NEW2需要有查询、删除、修改DCD用户的表EMP。
  
  %svrmgrl
  
  SVRMGR>connect internal; 以系统管理员登录
  
  SVRMGR>create user new2 identified by new2345 default tablespace app;
  
  SVRMGR>connect dcd/dcdpwd; 以dcd用户登录
  
  SVRMGR>grant connect to new2;
  
  SVRMGR>grant select on emp to new2;
  
  SVRMGR>grant delete on emp to new2;
  
  SVRMGR>grant update on emp to new2;
  
  说了这么多关于用户的问题,那么接下来我们就详细得说一下关于密码文件的使用以及维护--在Oracle数据库系统中,用户如果要以特权用户身份(INTERNAL/SYSDBA/SYSOPER)登录Oracle数据库可以有两种身份验证的方法:即使用与操作系统集成的身份验证或使用Oracle数据库的密码文件进行身份验证。因此,管理好密码文件,对于控制授权用户从远端或本机登录Oracle数据库系统,执行数据库管理工作,具有重要的意义。
  
  Oracle数据库的密码文件存放有超级用户INTERNAL/SYS的口令及其他特权用户的用户名/口令,它一般存放在ORACLE_HOME\DATABASE目录下。
  
  ·密码文件的创建:
  
  在使用Oracle Instance Manager创建一数据库实例的时侯,在ORACLE_HOME\DATABASE目录下还自动创建了一个与之对应的密码文件,文件名为PWDSID.ORA,其中SID代表相应的Oracle数据库系统标识符。此密码文件是进行初始数据库管理工作的基础。在此之后,管理员也可以根据需要,使用工具ORAPWD.EXE手工创建密码文件,命令格式如下:
  
  C:\ >ORAPWD FILE=< FILENAME > PASSWORD =< PASSWORD > ENTRIES=< MAX_USERS >
  
  各命令参数的含义为:
  
  FILENAME:密码文件名;
  
  PASSWORD:设置INTERNAL/SYS帐号的口令;
  
  MAX_USERS:密码文件中可以存放的最大用户数,对应于允许以SYSDBA/SYSOPER权限登录数据库的最大用户数。由于在以后的维护中,若用户数超

[1] [2]  下一页

相关文章
广告赞助
网友评论

共有 0 位网友发表了评论,平均得分: 0 查看完整内容

用户名:

分 值:100分 85分 70分 55分 40分 25分 10分 0分

内 容:

(注“”为必填内容。) 验证码: 验证码,看不清楚?请点击刷新验证码