热备份:
不停数据库,一定范围内(内存写满后,用户操作挂起),不影响用户使用。
数据库开着,时刻变化,因此热备份通过以下手段保持一致性:
1、开启归档
2、备份前,通知数据库,把文件锁定,在备份未完成前,不操作这个数据文件(不写脏块)

备份数据文件:
SQL> conn / as sysdba
SQL> alter database begin backup; #数据库所有的数据文件SCN就会固定,DBW进程不会写脏块,即使内存不够用,会让用户等待。如果备份需要几个小时,日志很快就会写满。日志很快就会切换,不归档日志,就会造成数据丢失。所以要开归档,并锁定数据文件,在备份复制。
SQL> @check
SQL> !cp -v /data/oracle/oradata/orcl/*.dbf /u02/hotbak #复制数据文件
SQL>alter database end backup; #备份完了,及时告诉数据库,数据文件不再锁定,这样DBW进程就可以写脏块,清理内存空间了。

备份控制文件;
控制文件在使用时,是一直在变化的,记录最新的SCN。
热备时,因为控制文件有两个,会先锁定一个进行备份,有专用的命令,不能直接复制;
# chown -R oracle:oinstall /u02
# ls -l
drwxr-xr-x. 4 oracle oinstall 32 Nov 15 21:31 u02
# cd /u02/hotbak
SQL> alter database backup controlfile to '/u02/hotbak/control.bak'; # 用二进制方式备份,如源文件9.3M,备份后也是9.3M
Database altered.
SQL>
还有一种方式
SQL> alter database backup controlfile to trace as '/u02/hotbak/control.trace'; # 用文本方式备份,cat查看会发现里面是一些脚本,当控制文件丢失,会用这些脚本把控制文件创建出来,源文件9.3M,备份后可能就只有 6.1K。
Database altered.
SQL>

备份日志:
SQL> alter system switch logfile;
System altered.
SQL>
一般不备份,而是执行日志切换,一旦日志切换,就会自动以归档的方式备份日子。

可编写热备份脚本:
# su - oracle
# vi hotbak.sh
# cat hotbak.sh
sqlplus / as sysdba << eof
alter database begin backup;
!cp -v /data/oracle/oradata/orcl/*.dbf /u02/hotbak
alter database end backup;
alter database backup controlfile to '/u02/hotback/control.bak' reuser;
alter database backup controlfile to trace as '/u02/hotbak/control.trace' reuser;
alter system switch logfile;
alter system switch logfile;
alter system switch logfile;
alter system switch logfile;
exit
eof
$chmod u+x hotbak.sh #u代表所有者,x代表执行权限。 + 表示增加权限,chmod u+x file.sh 就表示对file.sh文件的所有者增加可执行权限.
$./hotbak.sh
备注:
备份控制文件,两个命令都可以,不放心可以两个命令都执行,用二进制方式和文本方式备份,恢复时,想用哪个就用哪个。 加resuer是覆盖的意思,如果不加,如果目录下有相同名称的文件,会提示报错,不能备份。
备份日志文件,有几组日志文件,就执行N+1次,此处有3组,所以就执行4次。

oracle 命令4 热备份的更多相关文章

  1. Oracle命令:授权-收回权限-角色

    Oracle命令:授权-收回权限-角色 oracle grant 不论授予何种权限,每条授权(grant)语句总是由三部分组成: 1) 接受者部分是准备获得权限的一个或多个用户的列表. 2)关键字权限 ...

  2. Oracle命令行中显示:ORA-04076: 无效的 NEW 或 OLD 说明

    Oracle命令行进行操作时可能出现"ORA-04076: 无效的 NEW 或 OLD 说明" 需要在条件语句中JOB前面添加“old.”即可(因为是在when条件里面,所以不用“ ...

  3. 给oracle命令的参数赋值

    ''' <summary>    '''   给oracle命令的参数赋值    ''' </summary>    ''' <param name="cmd& ...

  4. Oracle命令类别

    Oracle命令类别: 数据操纵语言:DML: select; insert; delete; update; merge. 数据定义语言:DDL: create; alter; drop; trun ...

  5. Linux下登录Oracle命令行时删除键^H解决方法

    Linux下登录Oracle命令行时删除键^H解决方法 在linux服务器下登录oracle的控制台,如果输入错误,想用删除键删除时却不能删除,输出的是^H的字符. 方法 用如下的命令可以使删除键生效 ...

  6. oracle命令

    oracle创建表空间: 1.如果在PL/SQL 等工具里打开的话,直接修改下面的代码中[斜体加粗部分]执行 2.确保路径存在,比如[D:\oracle\oradata\Oracle9i\]也就是你要 ...

  7. oracle命令识记

    连接数据库 sqlplus /nolog; conn / as sysdba; set ORACLE_SID=实例名; 查看表结构命令 select table_name from user_tabl ...

  8. oracle 命令创建用户 、授权、数据库导入、导出

    最近在使用oracle,经常要导入导出数据,命令很简单,却经常忘记,所以记下来.. drop user yfplss cascade;--登录system用户删除已存在的用户名,该用户下的所有东西都被 ...

  9. oracle命令大全

    内容包括三大项:    1.oracle基本操作语句 2.SQLServer基本操作语句 3.各种数据库连接方法 ******************************************* ...

  10. oracle命令1

    基础查询  查询当前用户 show user; 查询当前用户下的表 select * from tab; 清屏 host cls: clear; --查询所有的员工信息 select * from e ...

随机推荐

  1. 讯飞离线语音合成新版(Aikit)-android sdk合成 demo(Java版本)

    前言:科大讯飞的新版离线语音合成,由于官网demo是kt语言开发的,咱也看不懂kt,搜遍了全网也没看到一个java版的新版离线语音demo,现记录下,留给有缘人参考!!!!!毕竟咱在这上面遇到了不少的 ...

  2. 聊天室(二)__ unipush 推送实现详细教程

    一.推送作用 推送作用我就不废话了,能做推送的都知道作用,直接上干货. 二.unipush 快速开通   Dcloud 开发者实名认证注册账号,绑定对应的 app 信息. uni-push产品有2个入 ...

  3. 2023-07-16:讲一讲Kafka与RocketMQ中零拷贝技术的运用?

    2023-07-16:讲一讲Kafka与RocketMQ中零拷贝技术的运用? 答案2023-07-16: 什么是零拷贝? 零拷贝(英语: Zero-copy) 技术是指计算机执行操作时,CPU不需要先 ...

  4. Stable Diffusion修复老照片-图生图

    修复老照片的意义就不多说了,相信大家都明白,这里直接开讲方法. 1.原理 这个方法需要一个真实模型,以便让修复的照片看起来比较真实,我这里选择:realisticVisionV20,大家有更好的给我推 ...

  5. 开源BaaS平台Supabase介绍

    Supabase 介绍 Supabase 是一个开源的 Firebase 替代品,以BaaS的形式向各种应用程序提供了一系列的后端功能,可以帮助开发者更快地构建产品. 对于想快速实现一个产品而言,如果 ...

  6. Python爬虫实战之提高CSDN访问量

    python爬虫之建立代理池(一)_CodingInCV的博客-CSDN博客 python爬虫之建立代理池(二)_CodingInCV的博客-CSDN博客 前面2篇分别介绍了从2个免费代理网站爬取免费 ...

  7. 数据结构之B树

    1 引言 B-tree,B即Balanced,是自平衡的多叉搜索树,用于组织和存储大量数据,以及数据库和文件系统等需要高效查找和插入操作的应用中. 为什么是"大量数据"?当主存不足 ...

  8. Jenkins服务开机自启动

    最近因为护网行动,每天都要对服务器进行开.关机操作.为了省事儿,对Jenkins服务进行开机自动启动服务改造.实现如下: 1. 通过chkconfig --list命令列出系统中已安装的服务及其启动状 ...

  9. MySQL——后码锁(Next-Key Block)

    众所周知,Mysql的事务隔离级别分为4个,分别是READ-UNCOMMITED,READ-COMMITED,REPEATABLE-READ,SERIALIZABLE,在常规数据库概论中,前三种事务隔 ...

  10. 一个.NET 7 + DDD + CQRS +React+Vite的实战项目

    项目简介 基于SignalR实现聊天通信,支持横向扩展,可支撑上万用户同时在线聊天 后端架构 后端技术栈采用 .NET 7 PostgreSQL (业务数据库) Redis(用于存放热点数据,和支持S ...