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.rhkb.cn/news/32120.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【鸿蒙开发】MongoDB入门

https://www.mongodb.com/try/download/community 下载MongoDB: var mongoose require("mongoose");// localhost 域名&#xff0c;代表本机 // 127.0.0.1 ip , 代码本机 mongoose.connect("mongodb://localhost:27017/jiaju").then(() > {console.l…

Linux中的TCP编程接口基本使用

TCP编程接口基本使用 本篇介绍 在UDP编程接口基本使用已经介绍过UDP编程相关的接口&#xff0c;本篇开始介绍TCP编程相关的接口。有了UDP编程的基础&#xff0c;理解TCP相关的接口会更加容易&#xff0c;下面将按照两个方向使用TCP编程接口&#xff1a; 基本使用TCP编程接口…

wireshark 如何关闭混杂模式 wireshark操作

Fiddler和Wireshark都是进行抓包的工具&#xff1a;所谓抓包就是将网络传输发送与接收的数据包进行截获、重发、编辑、转存等操作&#xff0c;也用来检查网络安全。抓包也经常被用来进行数据截取等。黑客常常会用抓包软件获取你非加密的上网数据&#xff0c;然后通过分析&#…

IDEA2024又一坑:连接Docker服务连不上,提示:Cannot run program “docker“: CreateProcess error=2

为新电脑安装了IDEA2024版&#xff0c;因为局域网中安装有Docker,所以这台电脑上没有安装&#xff0c;当运行时发现死活连不上Docker报&#xff1a;Cannot run program “docker“: CreateProcess error2 分析&#xff1a; Docker服务有问题 其它电脑都能连&#xff0c;排除 网…

文件包含漏洞第一关

一、什么是文件包含漏洞 1.文件包含漏洞概述 和SQL注入等攻击方式一样&#xff0c;文件包含漏洞也是一种注入型漏洞&#xff0c;其本质就是输入一段用户能够控制的脚本或者代码&#xff0c;并让服务端执行。 什么叫包含呢&#xff1f;以PHP为例&#xff0c;我们常常把可重复使…

网络安全事件响应--应急响应(windows)

应用系统日志 Windows主要有以下三类日志记录系统事件&#xff1a;应用程序日志、系统日志和安全日志。 系统和应用程序日志存储着故障排除信息&#xff0c;对于系统管理员更为有用。安全日志记录着事件审计信息&#xff0c;包括用户验证&#xff08;登录、远程访问等&#x…

C++蓝桥杯基础篇(九)

片头 嗨&#xff01;小伙伴们&#xff0c;大家好~ 今天我们将学习蓝桥杯基础篇&#xff08;十&#xff09;&#xff0c;学习函数相关知识&#xff0c;准备好了吗&#xff1f;咱们开始咯&#xff01; 一、函数基础 一个典型的函数定义包括以下部分&#xff1a;返回类型、函数名…

JVM内存结构笔记01-运行时数据区域

文章目录 前言运行时数据区域1.程序计数器定义特点总结 2.虚拟机栈2.1 定义局部变量表 ★操作数栈动态链接方法返回地址(方法出口) 2.2 栈内存溢出演示栈内存溢出 java.lang.StackOverflowError 2.3问题辨析1. 垃圾回收是否涉及栈内存&#xff1f;2. 栈内存分配越大越好吗&…

01-简单几步!在Windows上用llama.cpp运行DeepSeek-R1模型

1.llama.cpp介绍 Llama.cpp 是一个开源的、轻量级的项目&#xff0c;旨在实现 Meta 推出的开源大语言模型 Llama 的推理&#xff08;inference&#xff09;。Llama 是 Meta 在 2023 年开源的一个 70B 参数的高质量大语言模型&#xff0c;而 llama.cpp 是一个用 C 实现的轻量化…

对开源VLA sota π0的微调——如何基于各种开源数据集、以及你自己的私有数据集微调π0(含我司的微调实践)

前言 25年2.4日&#xff0c;几个月前推出π0的公司Physical Intelligence (π)宣布正式开源π0及π0-FAST&#xff0c;如之前所介绍的&#xff0c;他们对用超过 10,000 小时的机器人数据进行了预训练 该GitHub代码仓库「 π0及π0-FAST的GitHub地址&#xff1a;github.com/Ph…

Redis网络模型

redis为什么快 1.主要原因是因为redis是基于内存操作的&#xff0c;比起直接操作磁盘速度快好几倍 2.基于内存的数据库瓶颈主要是在网络io这一块&#xff0c;redis网络模型采用io多路复用技术能够高效的处理并发连接。 3.redis使用单线程执行命令&#xff0c;可以避免上下文…

PyTorch系列教程:Tensor.view() 方法详解

这篇简明扼要的文章是关于PyTorch中的tensor.view()方法的介绍与应用&#xff0c;与reshape()方法的区别&#xff0c;同时给出示例进行详细解释。 Tensor基础 Tensor(张量)的视图是一个新的Tensor&#xff0c;它与原始Tensor共享相同的底层数据&#xff0c;但具有不同的形状或…

Python数据分析之数据可视化

Python 数据分析重点知识点 本系列不同其他的知识点讲解&#xff0c;力求通过例子让新同学学习用法&#xff0c;帮助老同学快速回忆知识点 可视化系列&#xff1a; Python基础数据分析工具数据处理与分析数据可视化机器学习基础 四、数据可视化 图表类型与选择 根据数据特…

swift -(5) 汇编分析结构体、类的内存布局

一、结构体 在 Swift 标准库中&#xff0c;绝大多数的公开类型都是结构体&#xff0c;而枚举和类只占很小一部分 比如Bool、 Int、 Double、 String、 Array、 Dictionary等常见类型都是结构体 ① struct Date { ② var year: Int ③ var month: Int ④ …

推荐一个比较好的开源的工作流引擎

由于DeepSeek等AI大模型的出现&#xff0c;工作流模式再次流行起来&#xff0c;低代码甚至零代码就可以实现应用开发&#xff0c;而且有DeepSeek这样的超级AI作为大脑&#xff0c;人人都可以开发自动化工作流。 比如搭建邮件助手工作流&#xff0c;可以自动润色各种邮件内容。…

CarPlanner:用于自动驾驶大规模强化学习的一致性自回归轨迹规划

25年2月来自浙大和菜鸟网络的论文“CarPlanner: Consistent Auto-regressive Trajectory Planning for Large-scale Reinforcement Learning in Autonomous Driving”。 轨迹规划对于自动驾驶至关重要&#xff0c;可确保在复杂环境中安全高效地导航。虽然最近基于学习的方法&a…

Fedora41安装MySQL8.4.4

Fedora41安装MySQL8.4.4 Fedora41用yum仓库安装MySQL8.4.4 笔记250310下载安装启动mysqld服务查看生成的初始密码 , 用初始密码登录登录后,必须修改初始密码才能执行其它操作可选设置降低密码强度要求, 使用简单密码降低 validate_password 组件对密码强度的要求 用SET GLOBAL命…

信息安全意识之安全组织架构图

一、信息安全技术概论1.网络在当今社会中的重要作用2.信息安全的内涵 网络出现前&#xff1a;主要面向数据的安全&#xff0c;对信息的机密性、完整性和可用性的保护&#xff0c;即CIA三元组 网络出现后&#xff0c;还涵盖了面向用户的安全&#xff0c;即鉴别&#xff0c;授权&…

安卓Android与iOS设备管理对比:企业选择指南

目录 一、管理方式差异 Android Enterprise方案包含三种典型模式&#xff1a; Apple MDM方案主要提供两种模式&#xff1a; 二、安全防护能力 Android系统特点&#xff1a; 三、应用管理方案 四、设备选择建议 五、典型场景推荐 需求场景 推荐方案 六、决策建议要点…

linunx ubuntu24.04.02装libfuse2导致无法开机进不了桌面解决办法

osu.appimage运行需要libfuse2 然后我就下了fuse,打了两把第二天无法开机 这样是不能开机的 这样是可以开机的 解决办法一&#xff1a;玩星火商店的osu&#xff0c;好了问题解决 解决办法二&#xff1a; 在这个页面 ctrl alt f2进入tty6 sudo apt install ubuntu-desktop 进…