`

TFS(Taobao File System)配置dataServer、分区、挂载数据盘

 
阅读更多

目前的情况,tfs安装在/usr/local/tfs/
在 /usr/local/tfs/conf/目录,共有三个文件需要配置:ns.conf、ads.conf和ds.conf
各个文件功能
ns.conf用于配置nameserver,
ds.conf用于配置dataserver,
ads.conf为可选配置文件,用于配置nameserver和dataserver地址信息,可用于快速启动ns和ds。
rc.conf为可选配置文件,用于配置rcserver相关信息,主要适用于集群多,应用多的用户,可实现应用资源和集群资源的管理。
meta.conf为可选配置文件,用于配置metaserver相关信息,主要用于自定义文件名功能。
rs.conf为可选配置文件,用于配置rootserver相关信息,主要用于自定义文件名功能。

 

 

 

 

ds.conf 中注意修改的项目
-----------------------------------------------------
public->log_level=debug #日志文件的级别
public->port = 9998  #监听端口
public->work_dir=/usr/local/tfs #工作目录
public->dev_name= eth0 #网络设备
public->ip_addr = 192.168.119.217 #本机IP地址(vip)

dataserver->ip_addr = 192.168.119.145 #NameServer配置HA时请设置为vip,没配置HA时请设置为主ns的ip
dataserver->ip_addr_list = 192.168.119.145|192.168.119.147 #!nameserver IP地址列表(master, salve的ip地址,只能以'|'分隔)
dataserver->port = 8108 #!NameServer 监听的端口, 1024 ~ 55535
dataserver->mount_name =  /data/tfs #mount路径
dataserver->mount_maxsize = 141000000  #mount 时磁盘的大小, 单位(KB),TFS将使用这么多的空间134G
dataserver->block_max_size = 67108864 #block 最大size
dataserver->mainblock_size = 67108864 #每个数据存储块的大小

dataserver->extblock_size = 8388608  #扩展块的大小, 单位(字节)

 

 

 

ds.conf 内容 (其中有中文,要保存为UTF-8,不带标签)
-----------------------------------------------------

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

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

#日志文件的级别, default info,线上使用建议设为info,调试设为debug
#dubug级日志量会很大
log_level=debug

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

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

#work directoy
#工作目录
work_dir=/usr/local/tfs

#device name
#网络设备
dev_name= eth0

#work thread count default 4
#工作线程池 default 4
thread_count = 4

#ip addr
#本机IP地址(vip)
ip_addr = 192.168.119.217

[dataserver]

#NameServer ip addr(vip)
#!NameServer vip地址
#NameServer配置HA时请设置为vip,没配置HA时请设置为主ns的ip
ip_addr = 192.168.119.145

#!nameserver IP地址列表(master, salve的ip地址,只能以'|'分隔)
#如果没有salve,第二个ip随便写一个
ip_addr_list = 192.168.119.145|192.168.119.147

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

#备集群NameServer的vip地址, 没有搭建主副集群的可以不用配置此项
#slave_nsip = 192.168.0.2:8108

#无效配置,直接加到slave_nsip项即可
#slave_nsport = 8108

#heart interval time(seconds)
#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),不要大过文件系统实际剩余空间
#最大的挂载空间,如果你的/data/tfs1有1T,而设置了4G ,那只有4G的块可用空间,剩下的被浪费。
#120G  ,原来分134G,存储区预分配时报错了
mount_maxsize = 125829120

#文件系统类型: 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 = 7549747

#扩展块的大小, 单位(字节)
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

 

 

 

 

 

 

 

 

 

 

 

 

 

挂数据盘,一台服务器,可以挂载多块数据盘。

----------查看硬盘------------
fdisk -l  发现本台服务器上有5块146G的磁盘,第一块是系统盘。其它4块可以做数据盘
Disk /dev/sda: 146.6 GB
Disk /dev/sdb: 146.6 GB
Disk /dev/sdc: 146.6 GB
Disk /dev/sdd: 146.6 GB
Disk /dev/sde: 146.6 GB

----------umount---------
分区,格式化之前,如果已挂载,要先反挂载
umount /dev/sdb1
umount /dev/sdc1
umount /dev/sdd1
umount /dev/sde1

----------分区---------------
对数据盘进行分区,一块盘分一个区就行。
执行“fdisk /dev/sdb”命令,对数据盘进行分区;
根据提示,依次输入“n”,“p”“1”,两次回车,“wq”,分区就开始了,很快就会完成。

fdisk /dev/sdb
fdisk /dev/sdc
fdisk /dev/sdd
fdisk /dev/sde

-----------格式化----------
mkfs.ext4 /dev/sdb1
mkfs.ext4 /dev/sdc1
mkfs.ext4 /dev/sdd1
mkfs.ext4 /dev/sde1

-----------挂载--------------
建好目录,第一块磁盘就挂载在第一个目录上。目录数据取决于你磁盘的数量。
mkdir /data/tfs1
mkdir /data/tfs2
mkdir /data/tfs3
mkdir /data/tfs4

mount /dev/sdb1 /data/tfs1
mount /dev/sdc1 /data/tfs2
mount /dev/sdd1 /data/tfs3
mount /dev/sde1 /data/tfs4

-----------加入启动时自动挂载----------------
设置开机自动挂载

[root@loctfs scripts]# vi /etc/fstab
加入以下信息
/dev/sdb1                /data/tfs1              ext4    defaults        1 2
/dev/sdc1                /data/tfs2              ext4    defaults        1 2
/dev/sdd1                /data/tfs3              ext4    defaults        1 2
/dev/sde1                /data/tfs4              ext4    defaults        1 2


--------------重启系统-----------------------------
查看mount情况



------------存储区预分配------------------------------------
注意:挂载目录是/data/tfs1至/data/tfs(i),其中i为磁盘号。
而ds.conf配置文件中的配置  mount_name =  /data/tfs  没有加(i)

 执行scripts下的stfs format n (n为挂载点的序号,具体用法见stfs的Usage)。例如stfs format 2,4-6 则会对/data/tfs2,
/data/tfs4,/data/tfs5,/data/tfs6,进行预分配。运行完后会在生成/data/tfs2, /data/tfs4,/data/tfs5,/data/tfs6下预先创建主块,扩展块及相应的统计信息。
[root@locname conf]#  cd /usr/local/tfs/scripts
[root@locname scripts]# ./stfs format 1-4    //分配第1,2,3,4个存储区

 

 

 

------------运行data server------------
有两种方法:
    1)通过adminserver来启动dataserver(推荐): 执行scripts下的./tfs admin_ds
    2)直接启动dataserver,执行scripts下的./tfs start_ds 2,4-6, 则会启动dataserver2,dataserver4,dataserver5,dataserver6

目前我们没有配置adminserver的ads.conf, 我们使用方法2来启动。

cd /usr/local/tfs/scripts

./tfs start_ds 1-4

 

 

 

我们一台服务器上启动了4个进程

 

停止: ./tfs stop_ds 1-4

  • 大小: 45.1 KB
  • 大小: 104.9 KB
  • 大小: 8.5 KB
  • 大小: 12.7 KB
  • 大小: 42.7 KB
分享到:
评论
2 楼 bukebuhao 2018-08-29  
已解决,打开文件太多。ulimit -n 上次临时生效后再次ssh无效导致的
1 楼 bukebuhao 2018-08-29  
ds重启后启动不了。报错信息如下,请大神帮助
[2018-08-29 13:51:57] ERROR load_block_file (blockfile_manager.cpp:861) [139840572004160] init physical block fail. fatal error! pos: 510, file: /tfs2
[2018-08-29 13:51:57] ERROR init_block_files (data_management.cpp:57) [139840572004160] blockfile manager boot fail! ret: -24
[2018-08-29 13:51:57] ERROR initialize (dataservice.cpp:324) [139840572004160] dataservice::start, init block files fail! ret: -24
[2018-08-29 13:51:57] ERROR run (base_service.cpp:205) [139840572004160] /usr/local/tfs/bin/dataserver initialize user data failed, must be exit
[2018-08-29 13:51:57] ERROR start (base_main.cpp:194) [139840572004160] /usr/local/tfs/bin/dataserver initialze failed, exit

相关推荐

    淘宝分布式文件服务器taobao file system tfs配置文件

    淘宝分布式文件服务器taobao file system tfs配置文件 为线上正在使用的生产配置 具体配置项可视自己服务微调,配置项含义参考tfs.taobao.org的文档说明.有无备份集群不影响TFS的运行,若没有,则去掉备份集群的配置

    TFS(Taobao File System)功能说明以及使用

    **TFS(Taobao File System)**是一款专为淘宝网设计的分布式文件系统,其核心目标是处理大规模的非结构化数据。该系统通过在普通的Linux服务器集群上构建,实现了高可扩展性、高可用性和高性能的特点。TFS特别适用...

    Taobao File System

    TFS(Taobao !FileSystem)是一个高可扩展、高可用、高性能、面向互联网服务的分布式文件系统,主要针对海量的非结构化数据,它构筑在普通的Linux机器集群上,可为外部提供高可靠和高并发的存储访问。TFS为淘宝提供...

    TFS(Taobao FileSystem)介绍

    - NameServer根据DataServer的容量和负载情况动态调整数据分布,确保新加入的DataServer能够有效地利用起来。 - 在集群负载较轻时,NameServer会自动执行Block均衡操作,将数据均匀地分布到各个DataServer上。 - ...

    TFS(Team Foundation Server)配置使用和迁移

    **TFS(Team Foundation Server)配置使用和迁移详解** Team Foundation Server (TFS) 是微软提供的一款企业级的版本控制系统,集成了项目管理、代码版本控制、自动化测试、持续集成和发布等功能,广泛应用于软件开发...

    TFS(Team Foundation Server)配置使用和迁移.docx

    TFS配置使用和迁移 TFS(Team Foundation Server)是一种集成的开发环境,提供了源代码管理、工作项跟踪、项目管理、版本控制、自动化构建和测试等功能。下面将详细介绍TFS的配置使用和迁移。 一、TFS安装 TFS...

    IDEA配置TFS操作手册-20190507.docx

    在本手册中,我们将详细介绍如何在 IntelliJ IDEA 中配置 TFS(Team Foundation Server),并上传代码到 TFS 服务器。同时,我们也会介绍如何从 TFS 服务器下载代码。 一、TFS 配置及上传代码 1.1 配置 TFS 服务器...

    VS2008 TFS安装及配置顺序

    VS2008 TFS 安装及配置顺序 有详细说明VS2008 TFS 安装及配置顺序 有详细说明VS2008 TFS 安装及配置顺序 有详细说明

    淘宝TFS介绍

    每个 Block 中的实际数据都存储在 DataServer 上,而一台 DataServer 服务器一般会有多个独立 DataServer 进程存在,每个进程负责管理一个挂载点,这个挂载点一般是一个独立磁盘上的文件目录,以降低单个磁盘损坏...

    TFS2012安装部署详细步骤

    SQL Server 2008 R2 SP1是TFS2012的数据库管理系统,负责存储TFS2012的数据。需要安装SQL Server 2008 R2 SP1以便TFS2012的正常运行。 SharePoint Products SharePoint Products是TFS2012的 SharePoint 集成组件,...

    TFS2008配置文档

    - Data Tier:数据库服务器,存储TFS的所有数据。 - Build Tier:用于执行自动化构建的服务器。 2. **安装与配置** - 安装前准备:确认硬件和软件需求,如操作系统版本、内存、磁盘空间等。 - 安装TFS:通过...

    TFS安装及用户配置手册

    本文档提供了 Team Foundation Server 2010 的安装和用户配置指南,旨在帮助用户快速搭建 TFS 服务器并完成用户设置。本手册涵盖了硬件环境配置、操作系统安装、系统用户设置、IIS 安装和 SQL Server 2008 安装等...

    tfsserver2017.0.1.rar

    8. **安装与升级**:“tfsserver2017.0.1.exe”执行文件的运行会引导用户完成TFS服务器的安装或升级过程,包括配置数据库、服务、权限设置等步骤。 9. **安全性与权限**:TFS提供角色基础的访问控制,可设置不同...

    开发工具在TFS2010环境下的配置

    【开发工具在TFS2010环境下的配置】 Team Foundation Server 2010 (TFS2010) 是微软提供的一款强大的版本控制系统,它集成了项目管理、源代码控制、缺陷跟踪、构建管理和持续集成等功能。为了在TFS2010环境下进行...

    TFS安装配置

    Team Foundation Server (TFS) 是微软提供的一款强大的版本控制系统,用于软件开发中的源代码管理、工作项跟踪、持续集成和报告等功能。在本文中,我们将深入探讨如何进行TFS的安装配置,包括优化配置和实现TFS的...

    tfs2010安全安装配置(windows2003)

    TFS:Team Foundation Server 2010中文版 说明:Windows Server 2003 系统 安装IIS6.0 Windows Server 2008 系统 安装IIS7.0 SharePoint只支持Server系统。 Team Foundation Server 2010 需要的Sql Server 2008 或更...

    tfs-client-java

    1. **分布式文件系统**:TFS(Taobao File System)是一种大规模、高性能的分布式文件系统,旨在解决大数据量存储和处理的问题。它通过将数据分散存储在多台服务器上,实现了高可用性和高吞吐量,是大数据处理的重要...

    tfs.tar.gz

    此外,也可以使用支持NFS(Network File System)的Windows客户端来挂载Linux服务器的TFS。 1. **安装SMB服务**:在Linux服务器上配置Samba服务,允许Windows通过SMB协议访问TFS文件系统。 2. **配置Samba**:编辑...

    阿里巴巴开源的分布式文件系统 TFS.zip

    淘宝在这一领域做了有效的探索和实践,Taobao File System(TFS)作为淘宝内部使用的分布式文件系统,针对海量小文件的随机读写访问性能做了特殊优化,承载着淘宝主站所有图片、商品描述等数据存储。 文章首先概括了...

    linux下挂载ntfs硬盘

    在linux系统下使安装tfs-3g软件,识别和挂载ntfs分区格式的硬盘

Global site tag (gtag.js) - Google Analytics