建立不支持增量备份的全备份


做一个全备份,fileFull为不支持增量的全备份

$ ttbackup -type fileFull  -dir /tmp/backupdir sampledb_1122
ttbackup -type fileFull -dir 指定存放目录 要备份的表明

恢复到原数据库


$ ttrestore -dir /tmp/backupdir sampledb_1122
Restore started ...
Restore failed:
Error 12133: TT12133: Data store file already exists -- file "restore.c", lineno 1006, procedure "doRestore"
恢复时原数据库必须不存在
$ ttdestroy sampledb_1122
$ ttrestore -dir /tmp/backupdir sampledb_1122
Restore started ...
Restore complete
$ ttisql -v1 sampledb_1122
Command> select * from test;
< 1, 2016-04-05 05:35:53.000000 >

恢复到另一数据库

**必须用-fname指定文件前缀,否则以sampledb1_1122为前缀**
$ ttrestore -fname sampledb_1122 -dir /tmp/backupdir/ sampledb1_1122
Restore started ...
ttRestore: SQL Error: Failed to connect to data store
*** [TimesTen][TimesTen 11.2.2.6.2 ODBC Driver][TimesTen]TT6200: New value for permanent data partition size ignored since smaller than current value of 40 megabytes -- file "db.c", lineno 10239, procedure "sbDbConnect"
*** ODBC Error = 01000, TimesTen Error = 6200 *** [TimesTen][TimesTen 11.2.2.6.2 ODBC Driver]Invalid value (AL32UTF8) for DatabaseCharacterSet connection attribute -- value must be the same as the current data store value (US7ASCII)
*** ODBC Error = 08004, TimesTen Error = 6228 ttRestore: Failed connecting to data store after restore 虽然有很多警告,不过备份还是成功了,警告为:
- 恢复库的字符集不一致,忽略。因为字符集必须一致
- 恢复库的PermSize较备份库小,忽略. 如果较大则没有问题 $ ttisql -v1 sampledb1_1122 Warning 6226: Ignoring value requested for first connection attribute 'PermSize' -- value currently in use: 40, requested value: 32 Command> select * from test;
< 1, 2016-04-05 05:35:53.000000 >

备份中到底包含哪些内容

备份的内容包含三部分,最近一次的checkpoint文件,transaction log文件和.sta元数据文件
$ ls -l /tmp/backupdir
total 43880
-rw------- 1 oracle oracle 28834840 Apr 5 06:27 sampledb_1122.0.bac
-rw------- 1 oracle oracle 16039936 Apr 5 06:27 sampledb_1122.0.bac0
-rw------- 1 oracle oracle 720 Apr 5 06:27 sampledb_1122.sta
从元数据文件中可得到备份的DataStore的信息
$ strings sampledb_1122.sta
/home/oracle/TimesTen/tt1122/info/DemoDataStore/sampledb_1122
tt1122
然后可以与DataStore中的checkpoint和日志文件核对
$ ll /home/oracle/TimesTen/tt1122/info/DemoDataStore/sampledb_1122*
-rw-rw---- 1 oracle oracle 28834840 Apr 5 06:27 /home/oracle/TimesTen/tt1122/info/DemoDataStore/sampledb_1122.ds0
-rw-rw---- 1 oracle oracle 28834840 Apr 5 06:27 /home/oracle/TimesTen/tt1122/info/DemoDataStore/sampledb_1122.ds1
-rw-rw---- 1 oracle oracle 16039936 Apr 5 06:27 /home/oracle/TimesTen/tt1122/info/DemoDataStore/sampledb_1122.log0
-rw-rw---- 1 oracle oracle 67108864 Apr 5 06:21 /home/oracle/TimesTen/tt1122/info/DemoDataStore/sampledb_1122.res0
-rw-rw---- 1 oracle oracle 67108864 Apr 5 06:21 /home/oracle/TimesTen/tt1122/info/DemoDataStore/sampledb_1122.res1
-rw-rw---- 1 oracle oracle 67108864 Apr 5 06:21 /home/oracle/TimesTen/tt1122/info/DemoDataStore/sampledb_1122.res2

使用流式全备份和恢复

流式备份的特点是输出到stdout,因此可以定向到文件或磁带等,或在线压缩如: 
备份:ttbackup -type streamfull sampledb_1122|gzip > sampledb1122.ttb.gz 
恢复:gunzip -c sampledb1122.ttb.gz | ttrestore -i sampledb1122

$ ttbackup -type streamfull sampledb_1122 > sampledb_1122.ttb
Backup started ...
Backup complete
$ ll sampledb_1122.ttb
-rw-rw-r-- 1 oracle oracle 44842736 Apr 5 06:18 sampledb_1122.ttb
$ ttdestroy sampledb_1122
$ ttrestore -i sampledb_1122 < ./sampledb_1122.ttb
Restore started ...
Restore complete
$ ttisql -v1 sampledb_1122
Command> select * from test;
< 1, 2016-04-05 05:35:53.000000 >

增量备份和恢复

ttbulkcp结合ttschema进行逻辑备份和恢复

ttbulkcp可以将表中的数据导出成ASCII文件,反向亦可。 
但每次只能导出一个表,如果批量导需要自己写批处理文件,如下面示意:

$ ttisql -v1 -e "tables;exit" plsqldb|while read tab; do
> echo ttbulkcp $tab
> done;
ttbulkcp ORACLE.COUNTRIES
ttbulkcp ORACLE.DEPARTMENTS
ttbulkcp ORACLE.EMPLOYEES
ttbulkcp ORACLE.JOBS
ttbulkcp ORACLE.JOB_HISTORY
ttbulkcp ORACLE.LOCATIONS
ttbulkcp ORACLE.REGIONS
ttbulkcp ORACLE.T1
ttbulkcp ORACLE.TT_TEST

导出:

ttbulkcp -o 导出后的文件名  表的明=========>整张表导出
$ ttbulkcp -o plsqldb employees employees.dump107/107 rows copied
$ more employees.dump
##ttBulkCp:DATEMODE=TIMESTAMP
#
# ORACLE.EMPLOYEES, 11 columns, dumped Tue Apr 5 18:35:46 2016
# columns:
# 1. EMPLOYEE_ID NUMBER(6)
# 2. FIRST_NAME VARCHAR2(20 BYTE)
# 3. LAST_NAME VARCHAR2(25 BYTE)
# 4. EMAIL VARCHAR2(25 BYTE)
# 5. PHONE_NUMBER VARCHAR2(20 BYTE)
# 6. HIRE_DATE DATE
# 7. JOB_ID VARCHAR2(10 BYTE)
# 8. SALARY NUMBER(8,2)
# 9. COMMISSION_PCT NUMBER(2,2)
# 10. MANAGER_ID NUMBER(6)
# 11. DEPARTMENT_ID NUMBER(4)
# end
# 100,"Steven","King","SKING","515.123.4567",1987-06-17 00:00:00,"AD_PRES",24000,N
ULL,NULL,90
101,"Neena","Kochhar","NKOCHHAR","515.123.4568",1989-09-21 00:00:00,"AD_VP",1700
0,NULL,100,90

导入:

ttbulkcp -i 导出后的文件名  表的明=========>整张表导出(导入导出就是参数不一样,一个-i,一个-o)
$ ttbulkcp -i -connstr "dsn=sampledb_1122;uid=tthr" employees employees.dump
Enter password for 'tthr':
ttBulkCp: Error received while retrieving information about table employees -- Table not found. 由于目标库的表结构还不存在,这时我们可以用ttschema导出表定义 $ ttschema plsqldb oracle.employees > employees.sql
Warning: objects may not be printed in an order that can satisfy foreign key reference constraints or other dependencies
$ cat employees.sql
-- Database is in Oracle type mode
Warning: objects may not be printed in an order that can satisfy foreign key reference constraints or other dependencies
create table "ORACLE".EMPLOYEES (
EMPLOYEE_ID NUMBER(6) NOT NULL,
FIRST_NAME VARCHAR2(20 BYTE) INLINE,
LAST_NAME VARCHAR2(25 BYTE) INLINE NOT NULL,
EMAIL VARCHAR2(25 BYTE) INLINE NOT NULL UNIQUE,
PHONE_NUMBER VARCHAR2(20 BYTE) INLINE,
HIRE_DATE DATE NOT NULL,
JOB_ID VARCHAR2(10 BYTE) INLINE NOT NULL,
SALARY NUMBER(8,2),
COMMISSION_PCT NUMBER(2,2),
MANAGER_ID NUMBER(6),
DEPARTMENT_ID NUMBER(4),
primary key (EMPLOYEE_ID)
); create index "ORACLE".EMP_MANAGER_IX on "ORACLE".EMPLOYEES (MANAGER_ID); create index "ORACLE".EMP_NAME_IX on "ORACLE".EMPLOYEES
(LAST_NAME, FIRST_NAME); 不过我们看到ttschema导出的文件中包含了用户名,如果需要在另一个用户如tthr的schema下建表,则需要使用vi替换一下
(1,$ s/ORACLE/TTHR/g)
$ ttisql -connstr "dsn=sampledb_1122;uid=tthr;pwd=tthr" -f employees.sql
$ ttbulkcp -i -connstr "dsn=sampledb_1122;uid=tthr" employees employees.dump
Enter password for 'tthr': employees.dump:
107 rows inserted
107 rows total 借鉴:https://blog.csdn.net/stevensxiao/article/details/51067958

TimesTen数据库的备份和恢复的更多相关文章

  1. SQL数据库的备份和恢复

    SQL数据库的备份和恢复 一.SQL数据库的备份: 1.依次打开 开始菜单 → 程序 → Microsoft SQL Server 2008 → SQL Server Management Studi ...

  2. mysql数据库的备份和恢复

    Mysql数据库的备份和恢复 1.备份单个数据库 mysql数据库自带了一个很好用的备份命令,就是mysqldump,它的基本使用如下: 语法:mysqldump –u <用户名> -p ...

  3. 一、MySQL中的索引 二、MySQL中的函数 三、MySQL数据库的备份和恢复 四、数据库设计和优化(重点)

    一.MySQL中的索引###<1>索引的概念 索引就是一种数据结构(高效获取数据),在mysql中以文件的方式存在.存储建立了索引列的地址或者指向. 文件 :(以某种数据 结构存放) 存放 ...

  4. Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁

    Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁 一丶安装 pip install PyMySQL 二丶pymysql连接数据库 ### 语法: ...

  5. postgresql 数据库的备份和恢复 (pg_dump 和 pg_restore)

    pg_dump 用来备份数据库: pg_restore 用来恢复数据库: 备份出来的文件可以用 XZ (linux 自带的压缩工具压缩). XZ压缩最新压缩率之王 xz这个压缩可能很多都很陌生,不过您 ...

  6. Linux系统下MySQL数据库的备份和恢复

    当我们MySQL数据库保存重要数据的时候,备份工作极为重要.本文介绍如何使用mysqldump备份和恢复数据,使用该方法,可以将数据库中的数据备份成一个文本文件,也可将备份好的数据库迁移到另一台的服务 ...

  7. Db2数据库的备份和恢复

    DB2数据库备份与恢复 1.    备份 1.1离线备份(必须在数据库所在PC机进行操作) STEP 1 连接到要备份的数据库 C:\Documents and Settings\Administra ...

  8. MongoDB数据库的备份和恢复

    MongoDB数据库备份方式: 1.整库备份 2.单表备份 1.整库备份 备份整个数据库: mongodump -h 127.0.0.1:27000 -d park --authenticationD ...

  9. MySQL 数据库的备份和恢复

    1.DOS命令 mysqldump /*DOS命令生成文本文件*/ mysqldump -u username -h host -ppassword dbname [tbanme1,tbname2,. ...

随机推荐

  1. es集群数据库~运维相关

    一 数据同步方案  1 ES-JDBC  不能实现删除同步操作.MYSQL如果删除,ES不会删除  2 logstash-input-jdbc  能实现insert update,但是仍然不能实现删除 ...

  2. Tableau 之一 连接数据源

    导入数据源 与各类数据源建立连接关系,是使用tableau探索分析数据的第一步,本节内容包括: 数据源类型 连接数据源 数据源类型 打开tableau,可以在左侧窗口看到连接选项,目前tableau可 ...

  3. 为什么要使用`QuerySet.iterator()`

    用django的custom command功能,写了一个脚本,目的是修正生成环境的数据,tqdm告诉我运行时长预估是2小时. 一个小时后,正在吃午饭的我,接到了很多微信推送.客户告诉我服务不可用,同 ...

  4. STM32F0使用LL库实现PWM输出

    在本次项目中,限于空间要求我们选用了STM32F030F4作为控制芯片.这款MCU不但封装紧凑,而且自带的Flash空间也非常有限,所以我们选择了LL库实现.本文我们将说明如何通过LL库实现PWM信号 ...

  5. 第十三章:UNDO段

    一.UNDO UNDO 段是用于存储还原数据的特殊段,在发生实例故障的时候,UNDO 段用来对数 据进行恢复.本章内容包括介绍 UNDO 段的工作原理,并进行自动和手工的 UNDO 段的管理 1.1 ...

  6. PCB开钢网不容忽视的问题

    作为PCB工程师,或许你已经出过很多次的钢网文件,但却不一定了解出钢网有哪些要求. 1.首先我们来看下钢网的实物图,就是一块薄薄的钢板,钢网上有很多焊盘孔.把钢网盖在PCB板上后,这些焊盘孔就会和PC ...

  7. python3 集合(set)

    一.定义:集合是一个无序不重复元素序列 语法: #---------------两种写法-------------------------# parame = {value1,value2,value ...

  8. The type javax.servlet.http.HttpServletResponse cannot be resolved. It is indirectly referenced from required .class files

    The type javax.servlet.http.HttpServletResponse cannot be resolved. It is indirectly referenced from ...

  9. vue-router路由模式

    什么是单页应用? 单页Web应用(single page web application,SPA),就是只有一张Web页面的应用,是加载单个HTML 页面并在用户与应用程序交互时动态更新该页面的Web ...

  10. Liunx系统下的进程与线程

    1.    进程.线程的概念 a.    进程是操作系统进行资源分配的单位. b.    线程(Thread)是程序中独立的指令流,是CPU调度和分派的基本单位. c.     多进程是指同时运行多种 ...