淘宝TFS分布式文件系统亲测(2)

2.配置dataserver
配置为 ds.conf 和 ads.conf
cat  ds.conf

[public]

#日志文件的size,default 1GB
log_size=1073741824

#保留日志文件的个数,default 64
log_num = 64

#日志文件的级别, default debug
log_level=debug

#工作队列size, default 10240
task_max_queue_size = 10240

#监听端口, 1024 ~ 65535
port = 9998

#工作目录
work_dir=/root/tfs_bin/

#网络设备
dev_name= eth0

#工作线程池 default 4
thread_count = 4

#本机IP地址(vip)
ip_addr = 192.168.0.13

[dataserver]

#!NameServer vip地址
ip_addr = 192.168.0.10

#!nameserver IP地址列表(master, salve的ip地址,只能以'|'分隔)
ip_addr_list = 192.168.0.10|192.168.0.2

#!NameServer 监听的端口, 1024 ~ 55535
port = 8888

#备集群NameServer的vip地址, 可以不用配置
#slave_nsip = 192.168.0.2

#备集群NameServer监听端口, 可以不用配置
#slave_nsport = 9999

#dataserver 与 nameserver心跳间隔时间, 单位(秒), default: 2
heart_interval = 2

check_interval = 2

#datafile失效时间, 单位(秒), default: 90
#expire_datafile_time = 90

#拷贝一个Block超时时间, 单位(秒), default: 180
#expire_clonedblock_time = 180

#压缩一个Block超时时间, 单位(秒), default: 600
#expire_compactblock_time = 600

#复制Block线程池的大小, default: 2
replicate_threadcount = 2

#是否写同步日志, defalut: 1
#write_sync_flag = 1

#block 最大size
block_max_size = 7549747

#定时dump统计信息的间隔时间, 单位(秒), default: 60
dump_visit_stat_interval = 60

#io操作的阀值, 超过此值时, 会警告
#max_io_warning_time = 0

#备件类型, 1: tfs, 2: nfs
backup_type = 1

#备件路径
backup_path = /data/tfs

#最大datafile值, default: 50
#max_data_file_nums = 50

#crc error的最大个数
#max_crc_error_nums = 4

#eio error的最大个数
#max_eio_error_nums_ = 6

#超时block检测时间, 单位(秒)
#expire_checkblock_time = 86000

#cpu使用率
#max_cpu_usage = 60

#dump 统计信息的间隔时间, 单位(微秒)
#dump_stat_info_interval = 60000000

#mount路径
mount_name = /data/tfs

#mount 时磁盘的大小, 单位(KB)
mount_maxsize = 4194304    //最大的挂载空间,如果你的/data/tfs1有1T,而这里是设置了4G ,那只有4G的块可用空间,剩下的全部浪费。

#文件系统类型: 0: no initialize, 1: ext4, 2: ext3 posix fallocate, 3: ext3 ftruncate
base_filesystem_type = 1

#超级块存存储的保留位置,default: 0
superblock_reserve = 0

#平均文件的大小, 单位(字节)
avg_file_size = 40960

#主块的大小, 单位(字节)
mainblock_size = 83886080    //每个数据存储块的大小

#扩展块的大小, 单位(字节)
extblock_size = 419430

#主块与扩展的比例
block_ratio = 0.5

#hash桶的比例
hash_slot_ratio = 0.5

ds_thread_count = 4

#访问控制ip mask, 可选
#access_control_ipmask = 192.168.0.1

#访问控制文件路径, 可选
#access_control_file = /home/xxxxx/xxxxxx/tfs/control.file



cat ads.conf

[public]

#日志文件的size,default 1GB
log_size=1073741824

#保留日志文件的个数,default 64
log_num = 64

#日志文件的级别, default debug
log_level=debug

#工作队列size, default 10240
task_max_queue_size = 10240

#监听端口, 1024 ~ 65535
port = 9998

#工作目录
work_dir=/root/tfs_bin/

#网络设备
dev_name= eth0

#工作线程池 default 4
thread_count = 4

#本机IP地址(vip)
ip_addr = 192.168.0.13

[dataserver]

#!NameServer vip地址
ip_addr = 192.168.0.10

#!nameserver IP地址列表(master, salve的ip地址,只能以'|'分隔)
ip_addr_list = 192.168.0.10|192.168.0.2

#!NameServer 监听的端口, 1024 ~ 55535
port = 8888

#备集群NameServer的vip地址, 可以不用配置
#slave_nsip = 192.168.0.2

#备集群NameServer监听端口, 可以不用配置
#slave_nsport = 9999

#dataserver 与 nameserver心跳间隔时间, 单位(秒), default: 2
heart_interval = 2

check_interval = 2

#datafile失效时间, 单位(秒), default: 90
#expire_datafile_time = 90

#拷贝一个Block超时时间, 单位(秒), default: 180
#expire_clonedblock_time = 180

#压缩一个Block超时时间, 单位(秒), default: 600
#expire_compactblock_time = 600

#复制Block线程池的大小, default: 2
replicate_threadcount = 2

#是否写同步日志, defalut: 1
#write_sync_flag = 1

#block 最大size
block_max_size = 7549747

#定时dump统计信息的间隔时间, 单位(秒), default: 60
dump_visit_stat_interval = 60

#io操作的阀值, 超过此值时, 会警告
#max_io_warning_time = 0

#备件类型, 1: tfs, 2: nfs
backup_type = 1

#备件路径
backup_path = /data/tfs

#最大datafile值, default: 50
#max_data_file_nums = 50

#crc error的最大个数
#max_crc_error_nums = 4

#eio error的最大个数
#max_eio_error_nums_ = 6

#超时block检测时间, 单位(秒)
#expire_checkblock_time = 86000

#cpu使用率
#max_cpu_usage = 60

#dump 统计信息的间隔时间, 单位(微秒)
#dump_stat_info_interval = 60000000

#mount路径
mount_name = /data/tfs

#mount 时磁盘的大小, 单位(KB)
mount_maxsize = 4194304

#文件系统类型: 0: no initialize, 1: ext4, 2: ext3 posix fallocate, 3: ext3 ftruncate
base_filesystem_type = 1

#超级块存存储的保留位置,default: 0
superblock_reserve = 0

#平均文件的大小, 单位(字节)
avg_file_size = 40960

#主块的大小, 单位(字节)
mainblock_size = 83886080

#扩展块的大小, 单位(字节)
extblock_size = 419430

#主块与扩展的比例
block_ratio = 0.5

#hash桶的比例
hash_slot_ratio = 0.5

ds_thread_count = 4

#访问控制ip mask, 可选
#access_control_ipmask = 192.168.0.1

#访问控制文件路径, 可选
#access_control_file = /home/xxxxx/xxxxxx/tfs/control.file
[root@loctfs conf]# vi ads.conf

[public]

#日志文件的size,default 1GB
log_size=1073741824

#保留日志文件的个数,default 64
log_num = 64

#日志文件的级别, default debug
log_level=debug

#工作队列size,default 10240
task_max_queue_size = 10240

#监听端口, 1024 ~ 65535
port = 12000

#工作目录
work_dir=/root/tfs_bin/

#网络设备
dev_name= eth0

#工作线程池size, default 4
thread_count = 4

#本机ip地址
ip_addr = 192.168.0.11

[adminserver]

#检测的间隔时间, 单位(秒), default: 5
check_interval = 5

#失败的次数的阀值, default: 5
check_count = 5

#死亡个数的阀值
warn_dead_count = 3

#kill server之前等待时间
ds_fkill_waittime = 15

#dataserver启动命令脚本
ds_script = /root/tfs_bin/bin/dataserver -f /root/tfs_bin/conf/ds.conf -d

#监控的dataserver列表
ds_index_list = 1,2,3

[nameserver]

#!NameServer的vip
ip_addr = 192.168.0.10

#!NameServer监听的端口
port = 8888

[dataserver]

#!DataServer监听的端口
port = 9999

#!DataServer lock file路径
lock_file = /root/tfs_bin/logs/dataserver

#!DataServer 加载点路径
mount_name = /data/tfs


到这里配置文件就结束了,好好理解上的一些注释。

启动dataserver
首先需要格式化一个分区为ext4文件系统,并挂载到/data/tfs1至/data/tfs(i),其中i为磁盘号。注意上面的 mount_name = /data/tfs  没有加(i) 
假设你是用虚拟机,添加一个硬盘hda,然后执行:
fdisk /dev/sdb
n   //具体看fdisk用法
e   //具体看fdisk用法
 //具体看fdisk用法
mkfs.ext4 /dev/sdb1 mount /dev/sdb /data/tfs1/

 

淘宝TFS分布式文件系统亲测

 

 这样就挂载上去了

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/f6692bab673fa67b105a8073a1051791.html