一起学习网 一起学习网

如何在Linux系统中创建SPFILE文件 (linux创建spfile)

SPFILE文件是Oracle数据库参数文件的一种类型,一个数据库只能有一个SPFILE文件,包含了数据库实例的所有参数设置,而且这些参数只能由DBA进行修改。在Oracle 9i及以上版本中,SPFILE替代了早期版本中的PFILE。

在Linux系统下,创建SPFILE文件需要在数据库实例启动的情况下进行,以及使用SQL语句或命令来完成。下面将详细介绍的步骤。

步骤一:启动Oracle数据库实例

在Linux系统下,启动Oracle数据库实例需要使用Oracle用户身份登录,打开终端,输入以下命令:

$ sqlplus /nolog

SQL*Plus: Release 11.2.0.1.0 Production on Tue May 12 16:12:56 2023

Copyright (c) 1982, 2023, Oracle. All rights reserved.

SQL> connect / as sysdba

Connected.

SQL>

登录成功后,输入以下命令启动Oracle数据库实例:

SQL> startup

ORACLE instance started.

Total System Global Area 1468006400 bytes

Fixed Size 2291040 bytes

Variable Size 872421424 bytes

Database Buffers 503316480 bytes

Redo Buffers 11980800 bytes

Database mounted.

Database opened.

执行此命令后,Oracle数据库实例将启动,同时会在数据库的初始化参数中读取SPFILE文件。如果数据库没有设置SPFILE文件,则会读取PFILE文件(在Linux系统中该文件位于$ORACLE_HOME/dbs目录下)。

步骤二:创建SPFILE文件

在数据库实例启动后,即可开始创建SPFILE文件了。在终端中输入以下命令:

SQL> create spfile from pfile;

这个命令将会从$ORACLE_HOME/dbs目录下的PFILE文件中创建SPFILE文件。

SPFILE文件的默认名称为SPFILE.ORA,其中为实例的名称。如果需要指定自定义的SPFILE文件,则必须使用以下命令:

SQL> create spfile=” from pfile;

其中可以是任何你想要创建的文件路径。

创建SPFILE文件后,可以使用以下命令来验证SPFILE文件是否已经成功创建:

SQL> show parameter spfile;

这个命令将会显示SPFILE文件在数据库实例中的路径和文件名。

步骤三:修改SPFILE文件参数

在SPFILE文件创建成功后,可以使用以下命令来修改SPFILE文件中的参数:

SQL> alter system set = scope=spfile;

其中是需要修改的参数名称,是新的参数值。这个命令将会修改SPFILE文件中的参数。当数据库实例重新启动时,它将加载SPFILE文件来应用修改后的参数。

另外,也可以使用以下命令来查看SPFILE文件中的参数:

SQL> show parameter ;

这个命令将会显示SPFILE文件中的参数及其当前值。

相关问题拓展阅读:

  • 如何修改linux中oracle数据库的更大连接数
  • 个人经验总结:Oracle10g手工创建数据库
  • dataguard 可以在linux不同版本实现吗

如何修改linux中oracle数据库的更大连接数

oracle的配置文件里面添加max_connection=20230;

有权限的用户登陆,姿咐如SYstem等

alter system set process=XXXX scope=spfile ;

然后重枣樱新启动凳册丛数据库

个人经验总结:Oracle10g手工创建数据库

创建目录

  mkdir d:\oracle\product\ \database

  mkdir e:\oracle\admin\Ora g\bdump

  mkdir e:\oracle\admin\Ora g\cdump

  mkdir e:\oracle\admin\Ora g\create

  mkdir e:\oracle\admin\Ora g\pfile

  mkdir e:\oracle\admin\Ora g\udump

  mkdir e:\oracle\flash_recovery_area

  mkdir e:\oracle\oradata

  mkdir e:\oracle\oradata\Ora g

  

  

   生成windows服务 创建密码文件 在cmd命令下手数运行

  set ORACLE_SID=dbca 绿色部分设置oracle 实例名为 为ora g

  d:\oracle\product\ \DB_ \bin\oradim exe new sid ORA G startmode manual spfile d:\oracle\product\ \DB_ \bin\oradim exe edit sid ORA G startmode a spfile

   创建一个实例名为dbca 并且有手动启动方式改为自动启动

  

  d:\oracle\product\ \DB_ \bin\orapwd exe file=d:\oracle\product\ \db_ \PWDOra g ora password=sysPassword force=y

   用oracle自带的orapwd 为sys用户创建一个默认的密码为sysPassword

  

  

   执行创建数据库脚本

  D:\oracle\ora \bin\sqlplus /nolog @D:\oracle\admin\dbca\scripts\CreateDB sql

  D:\oracle\ora \bin\sqlplus /nolog @D:\oracle\admin\dbca\scripts\CreateDBFiles sql

  D:\oracle\ora \bin\sqlplus /nolog @D:\oracle\admin\dbca\scripts\CreateDBCatalog sql

  D:\oracle\ora \bin\sqlplus /nolog @D:\oracle\admin\dbca\scripts\postDBCreation sql

   黑体部分就是创建数据库纯培要调用的脚本

  

   之一 CreateDB sql

  connect SYS/change_on_install as SYSDBA 这是刚刚我们设置的密码以sysdba身份连接到数据库

  connect SYS/change_on_install as SYSDBA 这是刚刚我们设置的密码以sysdba身份连接到数据库

  set echo on

  spool D:\oracle\ora \assistants\dbca\logs\CreateDB log 写日志

  startup nomount pfile= D:\oracle\admin\dbca\scripts\init ora ; 调用参数文件 启动数据库到只装载实例阶段

  CREATE DATABASE dbca

  MAXINSTANCES

  MAXLOGHISTORY

  MAXLOGFILES

  MAXLOGMEMBERS

  MAXDATAFILES 控制文件记录的相关更大日志数 日志组 更大毕裤首数据文件数等限制

  DATAFILE D:\oracle\oradata\dbca\system dbf SIZE M REUSE AUTOEXTEND ON NEXT K MAXSIZE UNLIMITED

  EXTENT MANAGEMENT LOCAL

  DEFAULT TEMPORARY TABLESPACE TEMP TEMPFILE D:\oracle\oradata\dbca\temp dbf SIZE M REUSE AUTOEXTEND ON NEXT K MAXSIZE UNLIMITED

  UNDO TABLESPACE UNDOTBS DATAFILE D:\oracle\oradata\dbca\undotbs dbf SIZE M REUSE AUTOEXTEND ON NEXT K MAXSIZE UNLIMITED 创建系统 临时 回滚 表空间ITPUB个人空间!dJ l {!i W r f

  CHARACTER SET ZHS GBK

  NATIONAL CHARACTER SET AL UTF 字符集

  LOGFILE GROUP ( D:\oracle\oradata\dbca\redo log ) SIZE K

  GROUP ( D:\oracle\oradata\dbca\redo log ) SIZE K

  GROUP ( D:\oracle\oradata\dbca\redo log ) SIZE K; 创建日志文件租和成员

  spool off

  exit;

  

  

   第二 CreateDBFiles sql

  

  connect SYS/change_on_install as SYSDBA

  set echo on

  spool D:\oracle\ora \assistants\dbca\logs\CreateDBFiles log

  CREATE TABLESPACE INDX LOGGING DATAFILE D:\oracle\oradata\dbca\indx dbf SIZE M REUSE AUTOEXTEND ON NEXT K MAXSIZE UNLIMITED EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO ;

  CREATE TABLESPACE TOOLS LOGGING DATAFILE D:\oracle\oradata\dbca\tools dbf SIZE M REUSE AUTOEXTEND ON NEXT K MAXSIZE UNLIMITED EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO ;

  CREATE TABLESPACE USERS LOGGING DATAFILE D:\oracle\oradata\dbca\users dbf SIZE M REUSE AUTOEXTEND ON NEXT K MAXSIZE UNLIMITED EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO ; 创建相关用户要用到的表空间

  spool off

  

   第三:CreateDBCatalog sql

   创建system数据字典 存放到system表空间 相关表 视图等

  connect SYS/change_on_install as SYSDBA

  set echo on

  spool D:\oracle\ora \assistants\dbca\logs\CreateDBCatalog log

  @D:\oracle\ora \rdbms\admin\catalog sql;

  @D:\oracle\ora \rdbms\admin\catexp sql;

  @D:\oracle\ora \rdbms\admin\catblock sql;

  @D:\oracle\ora \rdbms\admin\catproc sql;

  @D:\oracle\ora \rdbms\admin\catoctk sql;

  @D:\oracle\ora \rdbms\admin\owminst plb;

  connect SYSTEM/manager

  @D:\oracle\ora \sqlplus\admin\pupbld sql;

  connect SYSTEM/manager

  set echo on

  spool D:\oracle\ora \assistants\dbca\logs\sqlPlusHelp log

  @D:\oracle\ora \sqlplus\admin\help\hlpbld sql helpus sql;

  spool off

  spool off

  exit;

  

   第四: postDBCreation sql

  

  connect SYS/change_on_install as SYSDBA

  set echo on

  spool D:\oracle\ora \assistants\dbca\logs\postDBCreation log

  @D:\oracle\ora \rdbms\admin\utlrp sql; 编译相关视图 包对象等

  shutdown ; 关闭数据库

  connect SYS/change_on_install as SYSDBA

  set echo on

  spool D:\oracle\ora \assistants\dbca\logs\postDBCreation log

  create spfile= D:\oracle\ora \database\spfiledbca ora FROM pfile= D:\oracle\admin\dbca\scripts\init ora ;

  

   创建服务器参数文件代替文件初始化参数文件 方便有时在不重启数据库的情况下可以使参数生效

  

  从上面可以看到spfile文件的存放位置

  startup ; 启动数据库 创建数据库完成 从上面可以看出 创建数据库有以下 个步骤

  

  Step : 创建相关trace目录文件夹

  

  Step :创建实例 密码 启动方式

  

  Step :创建初始化参数文件 init ora

  

  Step : 连接到实例

  

  Step : 启动实例到nomount状态

  

  Step :创建数据库

  

  Step :创建表空间

  

  Step : 运行脚本创建数据字典

  

  Step : 创建服务器参数文件(这步不是必须的 但oracle建议做这步) 好处会在以后的总结中列出

  

  下面也贴出linux下脚本 和windows下几乎差不多

  

  #!/bin/sh

  

  mkdir /oradata/ora i

  mkdir /oradata/ora i/controlfile

  mkdir /oradata/ora i/redofile

  mkdir /orasys/oracle/admin

  mkdir /orasys/oracle/admin/ora i

  mkdir /orasys/oracle/admin/ora i/bdump

  mkdir /orasys/oracle/admin/ora i/cdump

  mkdir /orasys/oracle/admin/ora i/create

  mkdir /orasys/oracle/admin/ora i/udump

  mkdir /orasys/oracle/admin/ora i/pfile

  

  

  cp init ora /orasys/oracle/product/ /dbs/

  

  export ORACLE_BASE=/orasys/oracle

  export ORACLE_HOME=$ORACLE_BASE/product/

  export ORACLE_SID=ora i

  export ORA_NLS =$ORACLE_HOME/omon/nls/admin/data

  LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib

  LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib

  export LD_LIBRARY_PATH

  export PATH=$PATH:$ORACLE_HOME/bin

  echo Add this entry in the oratab: ora i:/orasys/oracle/product/ :Y

  /orasys/oracle/product/ /bin/orapwd file=/orasys/oracle/product/ /dbs/orapwora i password=change_on_install

  /orasys/oracle/product/ /bin/sqlplus /nolog @/home/oracle/create_script/CreateDB sql

  /orasys/oracle/product/ /bin/sqlplus /nolog @/home/oracle/create_script/CreateDBFiles sql

  /orasys/oracle/product/ /bin/sqlplus /nolog @/home/oracle/create_script/CreateDBCatalog sql

lishixinzhi/Article/program/Oracle/202311/17648

dataguard 可以在linux不同版本实现吗

Linux 安装oracle10g 配置dataguard 介绍和步骤

DataGuard是甲骨文推出的一种高可用性数据库方案,在Oracle 8i之前被称为Standby Database。从Oracle 9i开始,正式更名为Data Guard。它是在主节点与备用节点间通过日志同步来保证数据的同步,可以实现数据库快速切换与灾难性恢复。Data Guard只是在软件上对数据库进行设置,并不需要额外购买任何组件。用卜姿户能够在对主数据库影响很小的情况下,实现主备数据改余库的同步。而主备机之间的数据差异只限于在线日志部分,因此被不少企业用作数据容灾解决方案。(以上是度娘解释,本人理解 dataguard设计之初为异地容灾,他的应急切换能提供很好的高可用,但同时对外服务还是只有一台pridb,所以性能未有所提高)此次配置型歼绝为dataguard物理备库更大性能模式。

1)linux操作系统安装并安装oracle10g软件

ps:主库安装数据库软件并建库,备库只需要安装oracle软件不需要建库

以下主库简称pridb备库stydb

linux安装oracle10g传送门:

本次环境:

pridb 172.25.56.149

stydb 172.25.56.150

2)pridb配置

1.查看是否开启归档模式(由于dataguard高性能需要运用到archivelog恢复stydb,所以必须开启)

archive log list

如果没有开启 需将数据库打至mount模式后开启

alter database archivelog;

alter database force logging;(开启强制归档,有时候由于语句not logging 可能未生成redolog)

生成standby controlfile

alter database create standby controlfile as ‘/u01/temp/standbycontrolfile.ctl’;

2.查询pridb如下文件位置

datafile (select name from v$datafile;)

redologfile (select member from v$logfile;)

controlfile (show parameter control_files)

spfile (show parameter spfile)

3.关闭主库shutdown immediate

4.把datafile standbycontrolfile redologfile spfile listener.ora tnsnames.ora passwdfile拷贝至备库相应位置(如果没有相应文件夹,新建同名文件夹)

scp/u01/oradata/WILLSON/ :/u01/oradata/

scp standbycontrolfile.ctl :/u01/oradata/

scp listener.ora tnsnames.ora :/u01/product/10.2.0/db_1/network/admin/

scp orapwWILLSON spfileWILLSON.ora :/u01/product/10.2.0/db_1/dbs/

scp -r WILLSON/ :/u01/admin/

5.配置pridb角色,配置归档日志地址,配置切换模式

alter system set log_archive_config=’DG_CONFIG=(pridb,stydb)’;

alter system set db_unique_name=’pridb’ scope=spfile;

shutdown immediate;

startup mount;

alter system set log_archive_dest_1=’LOCATION=/u01/oradata/archivelog VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=pridb’;

alter system set log_archive_dest_2=’SERVICE=stydb VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLES) DB_UNIQUE_NAME=stydb’;

alter system set log_archive_dest_state_1=’enable’;

alter system set log_archive_dest_state_2=’enable’;

alter system set FAL_CLIENT=’pridb’;

alter system set FAL_SERVER=’stydb’;

alter system set standby_archive_dest=’/u01/oradata/archivelog’;

alter system set standby_file_management=’auto’;

6.配置监听

$ more listener.ora

# listener.ora Network Configuration File: /u01/product/10.2.0/db_1/network/admin/listener.ora

# Generated by Oracle configuration tools.

SID_LIST_LISTENER =

(SID_LIST =

(SID_DESC =

(SID_NAME = PLSExtProc)

(ORACLE_HOME = /u01/product/10.2.0/db_1)

(PROGRAM = extproc)

)

(SID_DESC =

(SID_NAME = WILLSON)

(ORACLE_HOME = /u01/product/10.2.0/db_1)

)

)

LISTENER =

(DESCRIPTION_LIST =

(DESCRIPTION =

(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))

(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.149)(PORT = 1521))

)

)

$ moretnsnames.ora

# tnsnames.ora Network Configuration File: /u01/product/10.2.0/db_1/network/admin/tnsnames.ora

# Generated by Oracle configuration tools.

WILLSON =

(DESCRIPTION =

(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.149)(PORT = 1521))

(CONNECT_DATA =

(SERVER = DEDICATED)

(SERVICE_NAME = WILLSON)

)

)

pridb =

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.149)(PORT = 1521))

)

(CONNECT_DATA =

(SERVER = DEDICATED)

(SERVICE_NAME = WILLSON)

)

)

stydb =

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.150)(PORT = 1521))

)

(CONNECT_DATA =

(SERVER = DEDICATED)

(SERVICE_NAME = WILLSON)

)

)

EXTPROC_CONNECTION_DATA =

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))

)

(CONNECT_DATA =

(SID = PLSExtProc)

(PRESENTATION = RO)

)

)

3)stydb配置

1.启动备库至mount状态(如果失败查看初始化参数文件和控制文件是否更新)

startup mount;

2.配置备库参数

alter system set log_archive_config=’DG_CONFIG=(pridb,stydb)’;

alter system set db_unique_name=’stydb’scope=spfile;

shutdown immediate

startup mount

alter system set log_archive_dest_1=’LOCATION=/u01/oradata/archivelog VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=stydb’;

alter system set log_archive_dest_2=’SERVICE=pridb VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLES) DB_UNIQUE_NAME=pridb’;

alter system set log_archive_dest_state_1=’enable’;

alter system set log_archive_dest_state_2=’enable’;

alter system set FAL_CLIENT=’stydb’;

alter system set FAL_SERVER=’pridb’;

alter system set standby_archive_dest=’/u01/oradata/archivelog’;

alter system set standby_file_management=’auto’;

alter database force logging;

shutdown immediate

3.配置监听

$ morelistener.ora

# listener.ora Network Configuration File: /u01/product/10.2.0/db_1/network/admin/listener.ora

# Generated by Oracle configuration tools.

SID_LIST_LISTENER =

(SID_LIST =

(SID_DESC =

(SID_NAME = PLSExtProc)

(ORACLE_HOME = /u01/product/10.2.0/db_1)

(PROGRAM = extproc)

)

(SID_DESC =

(SID_NAME = WILLSON)

(ORACLE_HOME = /u01/product/10.2.0/db_1)

)

)

LISTENER =

(DESCRIPTION_LIST =

(DESCRIPTION =

(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))

(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.150)(PORT = 1521))

)

)

$ more tnsnames.ora

# tnsnames.ora Network Configuration File: /u01/product/10.2.0/db_1/network/admin/tnsnames.ora

# Generated by Oracle configuration tools.

WILLSON =

(DESCRIPTION =

(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.150)(PORT = 1521))

(CONNECT_DATA =

(SERVER = DEDICATED)

(SERVICE_NAME = WILLSON)

)

)

pridb =

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.149)(PORT = 1521))

)

(CONNECT_DATA =

(SERVER = DEDICATED)

(SERVICE_NAME = WILLSON)

)

)

stydb =

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.150)(PORT = 1521))

)

(CONNECT_DATA =

(SERVER = DEDICATED)

(SERVICE_NAME = WILLSON)

)

)

EXTPROC_CONNECTION_DATA =

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))

)

(CONNECT_DATA =

(SID = PLSExtProc)

(PRESENTATION = RO)

)

)

4)测试配置

pridb:

alter database open;

select open_mode,database_role from v$database;

OPEN_MODE DATABASE_ROLE

READ WRITE PRIMARY

stydb

startup;

alter database recover managed standby database disconnect;

select open_mode,database_role from v$database;

OPEN_MODE DATABASE_ROLE

MOUNTEDPHYSICAL STANDBY

同步测试:

pridb:

select sequence#,applied from v$archived_log;

stydb:

select sequence#,applied from v$archived_log;

就此oracle dataguard for linux 配置完成了,dataguard切换测试另有传送门:

linux创建spfile的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux创建spfile,如何在Linux系统中创建SPFILE文件,如何修改linux中oracle数据库的更大连接数,个人经验总结:Oracle10g手工创建数据库,dataguard 可以在linux不同版本实现吗的信息别忘了在本站进行查找喔。