TDB文件介绍
samba在运行时,Samba 存储许多信息,从本地密码到希望从中收到信息的一系列客户端。这类数据其中一些是暂时的,在 Samba 重启时可能会被丢弃,但是另一些却是永久的,不会被丢弃。这类数据可能是很大的,也可能是不经常访问只是在内存中保留,或者在重启时保持存在。要满足这些要求,Samba 团队创建了 Trivial Database。它实际上是一个键值存储,这意味着数据通过惟一键的方式存储和检索,且没有像在关系数据库中那样的表联接。键值存储 — 尤其是 TDB — 被设计成将数据存储到磁盘并将其取回的一种快速方式。
查看samba下tdb文件,只列出/var/lib/samba下面的,还有很多其他目录存在samba tdb文件。
[root@node1 samba]# cd /var/lib/samba/
[root@node1 samba]# ll
total 2236
-rw——- 1 root root 421888 Apr 23 15:10 account_policy.tdb
drwxr-xr-x 1 root root 0 Nov 28 00:21 drivers
-rw-r–r– 1 root root 425984 Apr 23 15:10 gencache.tdb
-rw——- 1 root root 696 Apr 23 15:10 group_mapping.tdb
drwxr-xr-x 1 root root 456 Apr 23 15:10 lock
drwxr-xr-x 1 root root 0 Apr 23 15:10 printing
drwx—— 1 root root 86 Apr 23 17:21 private
-rw——- 1 root root 528384 Apr 23 15:10 registry.tdb
-rw——- 1 root root 421888 Apr 23 15:10 share_info.tdb
-rw-r–r– 1 root root 483328 Apr 23 17:43 smbprofile.tdb
drwxr-x— 1 root wbpriv 0 Nov 28 00:21 winbindd_privileged
至于这些tdb文件如何查看数据,以及修改备份,下面介绍samba自带的几个tdb工具。
**tdbtool工具介绍**
tdbtool工具可以在命令行上接受命令,也可以打开交互式控制台类似shell一样。要在命令行上完成任务,请运行 tdbtool
example.tdb command options,其中 example.tdb 是文件名,command
是命令,针对命令的选项位于最后。要使用 tdb shell,只需单独运行 tdbtool
或在命令行上传递文件的名称。个人建议使用交互式控制台方式。以下是tdbtool参数介绍
tdbtool:
create dbname : create a database
open dbname : open an existing database
transaction_start : start a transaction
transaction_commit : commit a transaction
transaction_cancel : cancel a transaction
erase : erase the database
dump : dump the database as strings
keys : dump the database keys as strings
hexkeys : dump the database keys as hex values
info : print summary info about the database
insert key data : insert a record
move key file : move a record to a destination tdb
storehex key data : store a record (replace), key/value in hex format
store key data : store a record (replace)
show key : show a record by key
delete key : delete a record by key
list : print the database hash table and freelist
free : print the database freelist
freelist_size : print the number of records in the freelist
check : check the integrity of an opened database
repack : repack the database
speed : perform speed tests on the database
! command : execute system command
1 | first : print the first record
n | next : print the next record
q | quit : terminate
\n : repeat ‘next’ command
下面分别介绍:
1、创建数据库
[root@node1 tdbtest]# tdbtool
tdb> create hello
[root@node1 tdbtest]# ll
total 4
-rw——- 1 root root 696 Apr 23 15:53 hello
2、打开数据库
tdb> open hello
3、插入数据
tdb> insert name zhangsan
4、查询数据
tdb> show name
key 4 bytes
name
data 8 bytes
[000] 7A 68 61 6E 67 73 61 6E zhangsan
5、查看所有数据
tdb> dump
key 5 bytes
name1
data 4 bytes
[000] 6C 69 73 69 lisi
key 4 bytes
name
data 8 bytes
[000] 7A 68 61 6E 67 73 61 6E zhangsan
总共2条KEY/VALUES键值对,既2条数据信息。
6、列出key值
tdb> keys
key 5 bytes: name1
key 4 bytes: name
7、修改values值
tdb> store name zhang
Storing key:
key 4 bytes
name
data 5 bytes
[000] 7A 68 61 6E 67 zhang
将name值由zhangsan 修改为zhang,查看修改结果
tdb> dump
key 5 bytes
name1
data 4 bytes
[000] 77 61 6E 67 77 75 lisi
key 4 bytes
name
data 5 bytes
[000] 7A 68 61 6E 67 zhang
8、删除某个key值
tdb> delete name
tdb> dump
key 5 bytes
name1
data 4 bytes
[000] 6C 69 73 69 lisi
将key值为name的删掉后,查看只剩下name1记录。
9、检查数据完整性
tdb> check
Database integrity is OK and has 2 records.
10、复制数据到另外的数据库(后者数据库必须存在)
tdb> move name2 hello1
key 5 bytes
name2
data 6 bytes
[000] 77 61 6E 67 77 75 wangwu
record moved
查看hello1记录
tdb> open hello1
tdb> dump
key 5 bytes
name2
data 6 bytes
[000] 77 61 6E 67 77 75 wangwu
11、执行系统命令
tdb> ! pwd
/root/tdbtest
tdb> ! date
Mon Apr 23 16:36:18 CST 2018
12、支持事务处理
开启事务
tdb> transaction_start
tdb> insert name3 test
tdb> show name3
key 5 bytes
name3
data 4 bytes
[000] 74 65 73 74 test
取消事务
tdb> transaction_cancel
tdb> show name3
fetch failed
提交事务
tdb> transaction_start
tdb> insert name3 test
tdb> transaction_commit
tdb> show name3
key 5 bytes
name3
data 4 bytes
[000] 74 65 73 74 test
**tdbdump 工具介绍**
tdbdump是用来查看tdb文件中的所有键值对数据的工具
已hello为例, 查看所有数据
[root@node1 tdbtest]# tdbdump hello
{
key(5) = “name1”
data(4) = “lisi”
}
{
key(5) = “name2”
data(6) = “wangwu”
}
{
key(5) = “name3”
data(4) = “test”
}
每个键值对数据key data 数字为字节数
**tdbbackup 工具介绍**
tdbbackup工具为tdb数据库文件的备份工具。
– 备份hello数据库
[root@node1 tdbtest]# tdbbackup hello
[root@node1 tdbtest]# ll
total 828
-rw——- 1 root root 831488 Apr 23 16:42 hello
-rw——- 1 root root 8192 Apr 23 16:38 hello1
-rw——- 1 root root 8192 Apr 23 17:25 hello.bak
hello.bak就是备份文件。这里发现两者文件大小不一样,通过md5对比。因为是不同的文件,文件MD5值肯定是不一样的,但是文件内容是完全一样的。
查看文件md5
[root@node1 tdbtest]# md5sum hello
8c55e7dabbeab30e3cd96e96b59fb052 hello
[root@node1 tdbtest]# md5sum hello.bak
c20b4f9b01f5715bbec8f950cf394f51 hello.bak
查看文件内容md5
[root@node1 tdbtest]# tdbdump hello | md5sum
88be32a888d3cd63132e09a0de8d69de –
[root@node1 tdbtest]# tdbdump hello.bak | md5sum
88be32a888d3cd63132e09a0de8d69de –
– 恢复hello数据
模拟删除数据
[root@node1 tdbtest]# ll
total 828
-rw——- 1 root root 831488 Apr 23 16:42 hello
-rw——- 1 root root 8192 Apr 23 16:38 hello1
-rw——- 1 root root 8192 Apr 23 17:25 hello.bak
[root@node1 tdbtest]# >hello
[root@node1 tdbtest]# ll
total 16
-rw——- 1 root root 0 Apr 23 17:33 hello
-rw——- 1 root root 8192 Apr 23 16:38 hello1
-rw——- 1 root root 8192 Apr 23 17:25 hello.bak
[root@node1 tdbtest]# tdbbackup -v hello
restoring hello
[root@node1 tdbtest]# ll
total 24
-rw——- 1 root root 8192 Apr 23 17:33 hello
-rw——- 1 root root 8192 Apr 23 16:38 hello1
-rw——- 1 root root 8192 Apr 23 17:25 hello.bak
看到文件大小一致了,现在对比md5值
[root@node1 tdbtest]# md5sum hello
c20b4f9b01f5715bbec8f950cf394f51 hello
[root@node1 tdbtest]# md5sum hello.bak
c20b4f9b01f5715bbec8f950cf394f51 hello.bak
[root@node1 tdbtest]# tdbdump hello |md5sum
88be32a888d3cd63132e09a0de8d69de –
[root@node1 tdbtest]# tdbdump hello.bak |md5sum
88be32a888d3cd63132e09a0de8d69de –
看到MD5值与之前备份之前一致了。查看数据
[root@node1 tdbtest]# tdbdump hello
{
key(5) = “name1”
data(4) = “lisi”
}
{
key(5) = “name2”
data(6) = “wangwu”
}
{
key(5) = “name3”
data(4) = “test”
}
TDB文件介绍的更多相关文章
- Linux core 文件介绍
Linux core 文件介绍 http://www.cnblogs.com/dongzhiquan/archive/2012/01/20/2328355.html 1. core文件的简单介绍在一个 ...
- linux设备驱动程序该添加哪些头文件以及驱动常用头文件介绍(转)
原文链接:http://blog.chinaunix.net/uid-22609852-id-3506475.html 驱动常用头文件介绍 #include <linux/***.h> 是 ...
- Android下HelloWorld项目的R.java文件介绍
R.java文件介绍 HelloWorld工程中的R.java文件 package com.android.hellworld; public final class R { public s ...
- APK扩展文件介绍、功能及用法
APK扩展文件介绍 Android Market (Google Play Store)中每一个APK文件的最大限制是50MB.假设您的程序中包括大量的数据文件,曾经您仅仅能把这些数据文件放到自己的s ...
- NSIS文字及字符串函数与头文件介绍
原文 NSIS文字及字符串函数与头文件介绍 文字函数,顾名思义就是处理字符串的函数.使用这些字符串函数前,必须先包含头文件WordFunc.nsh.该头文件目前包含如下一些函数:WordFind.Wo ...
- opensslBIO系列之2---BIO结构和BIO相关文件介绍
BIO结构和BIO相关文件介绍 (作者:DragonKing Mail:wzhah@263.net 公布于:http://gdwzh.126.com openssl专业论坛) ...
- 微信小程序-01-项目组成文件介绍(入门篇)
自古开篇先说两句,写这些笔记不是学习用的,主要是后续分享一些遇到的坑,碰到过什么样的问题,怎么去解决,如果你不是一个很耐心无看文章的人,建议去 网易云课堂找一些课程,跟着别人的脚步或许会更有动力,我的 ...
- IOS-项目中常见文件介绍
一.项目文件结构示意图 二.文件介绍 1.products文件夹:主要用于mac电脑开发的可执行文件,ios开发用不到这个文件 2.frameworks文件夹主要用来放依赖的框架 3.test文件夹是 ...
- Linux文件介绍
Linux文件介绍 Linux 文件属性 可以通过命令ll+文件名,查看文件的具体属性 例如:ll syz.gz 1736706 -rw-r--r--. 1 root root 28 Oct 27 1 ...
随机推荐
- Spring Security认证提供程序
1.简介 本教程将介绍如何在Spring Security中设置身份验证提供程序,与使用简单UserDetailsService的标准方案相比,提供了额外的灵活性. 2. The Authentica ...
- ue4 官网IK流程记录
基本流程 角色蓝图构造 角色蓝图 角色蓝图中新建的函数IK Foot Trace AnimGraph事件 这里注意下Make Vector时把z方向的偏移量设置到了X上 猜测原因是效应器的x方向跟世界 ...
- [UE4]C++设置AnimInstance的相关问题
注意:ue4 4.17调用LoadObject<UAnimBlueprintGeneratedClass>直接崩 http://aigo.iteye.com/blog/2285001 UA ...
- 51nod1101(dp)
题目链接:https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1101 题意:中文题诶- 思路:dp 我们用dp[i][j]存 ...
- MySQL下载与安装配置
一.Windows 上安装 MySQL Windows 上安装 MySQL 相对简单,最新版本下载地址: 官网:https://dev.mysql.com/downloads/mysql/ 下载步骤: ...
- pgbouncer的安装和配置
tar -zxvf libevent-2.0.21-stable.tar.gzcd libevent-2.0.21-stable/mkdir /home/pg10/libevent./configur ...
- java 多线程下载文件并实时计算下载百分比(断点续传)
多线程下载文件 多线程同时下载文件即:在同一时间内通过多个线程对同一个请求地址发起多个请求,将需要下载的数据分割成多个部分,同时下载,每个线程只负责下载其中的一部分,最后将每一个线程下载的部分组装起来 ...
- js函数—隐形参数this
前言 this是函数中的隐形参数,它绑定的值取决于函数的调用位置. this的定义 <你不知道的js>中是这样说的:是函数体内的隐式参数,this就是记录函数调用上下文的一个属性.可以在函 ...
- oracle merge 目标表以及源表存在重复列的问题(转)
SQL> select * from t_source; ...
- G.Longest Palindrome Substring
链接:https://ac.nowcoder.com/acm/contest/908/G 题意: A palindrome is a symmetrical string, that is, a st ...