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

Yashan DB 文件管理

一、文件类型介绍

本章主要介绍了YashanDB生命周期中涉及的文件类型,包括以下几类:

1. 密码文件:用于存放系统用户的密码信息。

2. 参数文件:记录数据库的配置信息,用于实例启动时的初始化。

3. 控制文件:存储数据库运行所需的元数据信息,如数据文件和Redo日志文件的位置等。

4. Redo日志文件:记录数据库的所有历史变更,用于数据恢复。

5. 归档文件:Redo日志归档后的备份文件,用于数据恢复或主备库同步。

6. 数据文件:存储数据库的实际数据,包括系统数据、用户数据等。

7. 运行日志:记录数据库运行过程中的日志信息。

8. 告警日志:记录数据库的告警信息,用于问题排查。

这些文件在数据库的启动、运行和维护过程中起着关键作用。


---

二、密码文件
 

1. 作用

• 密码文件以加密方式存放系统用户的密码(如`sys`用户)。

• 在用户登录时,密码文件用于校验用户身份。


2. 位置

• 密码文件名为`yasdb.pwd`,为文本文件,不可直接编辑。

• 文件路径由`PASSWORD_FILE`参数控制,默认路径为`$YASDB_DATA/instance/yasdb.pwd`。


3. 修改方式

• 不建议直接编辑密码文件,可以通过`yaspwd`工具或`yasboot`工具修改密码。


4. 命令格式


 

 yaspwd file=<fname> password=<password> input_file=<input-fname> 'sys={y | password}'


 

示例:


   

$ yaspwd file=yasdb.pwd password=yasdb_123


 

提示:只有当`yasdb.pwd`文件不存在时,才能生成新的密码文件。


---

三、参数文件
 

1. 作用

• 参数文件记录数据库的配置信息,实例在启动阶段会读取参数文件,并根据其中的参数设置来配置数据库。


2. 内容

• 参数文件定义了数据库实例的内存组件大小、监听端口、字符集、数据块大小等配置信息。


3. 位置

• 参数文件名为`yasdb.ini`,为文本文件,存放在`$YASDB_DATA/config`路径下。

• 虽然可以直接编辑,但不建议直接修改,推荐使用SQL命令修改参数。


4. 修改参数配置

• 示例:修改`data_buffer_size`参数


     

ALTER SYSTEM SET data_buffer_size=2G SCOPE=spfile;
SHOW PARAMETER data_buffer_size;


 

---

四、控制文件
 

1. 作用及重要性

• 控制文件包含数据库运行所需的关键信息,如数据文件、Redo日志文件、表空间信息等。

• YashanDB默认会创建3份冗余控制文件,以提高安全性。

• 如果控制文件损坏,数据库将无法启动。


2. 内容

• 数据库名称

• 数据文件名字及位置

• Redo日志文件名字及位置

• 表空间信息

• 归档日志信息等


3. 查看方式

• 通过参数`CONTROL_FILES`:查看控制文件的路径。

• 通过视图`V$CONTROLFILE`:查看控制文件的详细信息。


---

五、Redo日志文件
 

1. 作用

• Redo日志记录数据库的所有历史变更。

• 在事务提交前,只需将Redo日志持久化即可,数据文件的持久化可以延迟。

• 系统崩溃时,Redo日志可用于恢复数据到最新状态。


2. 查看方式

• 通过视图`V$LOGFILE`查看Redo日志的信息,包括ID、路径、块大小、已用大小、序列号与状态等。

• 示例:


     

SELECT id, name, block_size, block_size * block_count / 1024 / 1024 AS size_mb, status FROM v$logfile;


 

3. 维护操作

• 添加Redo日志:


     

ALTER DATABASE ADD LOGFILE ('redo6' SIZE 128M, 'redo7' SIZE 128M);


 


• 删除Redo日志:只有状态为`INACTIVE`或`NEW`的Redo日志可以删除。


     

ALTER DATABASE DROP LOGFILE '/home/yashan/yasdb_data/db-1-1/dbfiles/redo6';


 


• 切换Redo日志:在需要对当前Redo日志进行维护时,切换日志组并执行checkpoint。


   

ALTER SYSTEM SWITCH LOGFILE;
ALTER SYSTEM CHECKPOINT;


 

---

六、归档文件
 

1. 作用

• 归档日志是Redo日志完成归档后的备份文件,为二进制文件。

• 归档日志可用于数据恢复,也可在主备库中的备库上应用,还原主库的数据。


2. 归档模式查看

• 默认安装下,数据库为归档模式。

• 可以通过`V$DATABASE`视图中的`log_mode`字段查看当前归档模式配置。

• 示例:


     

SELECT database_name, log_mode, open_mode FROM v$database;


 


• 字段值为`ARCHIVELOG`表示归档模式,`NOARCHIVELOG`表示非归档模式。

• 为了能将数据库还原到任意时间点以及主备库的搭建,建议生产环境配置为归档模式。


3. 归档模式切换

• 查看归档路径:

SHOW PARAMETER archive_local_dest;


• 修改归档路径:

• 归档路径只允许静态修改,需要重启生效。

• 确保路径存在,且操作系统用户`yashan`有读写权限。

ALTER SYSTEM SET archive_local_dest='/home/yashan/arch' scope=spfile;

• 关闭数据库实例:

SHUTDOWN IMMEDIATE;

• 调整到归档模式:

• 从非归档模式调整到归档模式:

ALTER DATABASE ARCHIVELOG;

• 从归档模式调整到非归档模式:

ALTER DATABASE NOARCHIVELOG;

• 注意:从归档模式调整到非归档模式时,需要设置`replication_addr`为空。

 ALTER SYSTEM SET replication_addr='' SCOPE=spfile;

• 开启数据库到OPEN状态:

ALTER DATABASE OPEN;

• 查看当前归档模式:

SELECT database_name, log_mode, open_mode FROM v$database;

---

七、数据文件
 

1. 分类

• 系统数据文件:存放数据库系统内部生成的数据(如SYSTEM和SYSAUX表空间)。

• UNDO数据文件:存放回滚段的数据,用于事务回滚。

• TEMP数据文件:用于临时表的段分配,存储临时数据。

• SWAP数据文件:当虚拟内存不足时,将虚拟内存交换到SWAP表空间释放内存。

• 用户数据文件:存放实际的生产数据,包括内置表空间`USERS`的数据文件以及用户自定义表空间的文件。


2. 属性

• 大小:

• 数据块默认大小为8KB,单个普通数据文件最大为512GB。

• 数据块为16KB和32KB时,单个数据文件的最大大小相应成倍增大。

• 状态:

• 数据文件的状态有`ONLINE`和`OFFLINE`,`OFFLINE`状态下的数据文件不能被访问。

• 自动扩展性:

• 自动扩展性有`ON`和`OFF`两种模式,`ON`表示允许数据文件空间自动扩展,`OFF`表示不允许自动扩展。


3. 查看方式

• 通过视图`V$DATAFILE`查看数据文件的信息。

• 示例:

SELECT name, bytes, status, auto_extend FROM v$datafile;

---

八、小结

1. 本章回顾了YashanDB生命周期中涉及的文件类型,包括密码文件、参数文件、控制文件、Redo日志文件、归档文件和数据文件。

2. 分别介绍了各文件的作用、查看方式和维护操作。


http://www.kler.cn/a/582219.html

相关文章:

  • 《深度剖析架构蒸馏与逻辑蒸馏:探寻知识迁移的差异化路径》
  • 【音视频】ffmpeg命令提取像素格式
  • 20250212:linux系统DNS解析卡顿5秒的bug
  • 在 Spring Boot 2.7.x 中引入 Kafka-0.9 的实践
  • vscode 好用插件
  • MySQL-储存引擎
  • 深度解析:如何在 Vue 3 中安全访问子组件实例
  • 使用STM32CubeMX配置定时器中断实现LED每秒闪烁一次(STM32G070CBT6)
  • windows上传uniapp打包的ipa文件到app store构建版本
  • Selenium 中 ActionChains 支持的鼠标和键盘操作设置及最佳实践
  • 密码学系列 - 利用CPU指令加速
  • 高效自动化测试:打造Python+Requests+Pytest+Allure+YAML的接口测试框架
  • 鸿蒙NEXT开发-自定义相机拍照
  • 小程序 wxml 语法 —— 42 条件渲染
  • JavaScript 模块 vs C# 类:封装逻辑的两种哲学
  • 【社交+陪玩服务】全场景陪玩系统源码 小程序+H5双端 社群互动+即时点单+搭建教程
  • Linux 进程信息查看
  • 【每日学点HarmonyOS Next知识】防止重复点击、对话框收拾拦截、自定义键盘焦点、页面层级、自定义对话框创建
  • 【二分算法】-- x的平⽅根(easy)
  • MySQL(第3周)-database命令