TFS使用文档-安装篇

TFS(Taobao FileSystem)是一个高可扩展、高可用、高性能、面向互联网服务的分布式文件系统,其设计目标是支持海量的非结构化数据的存储;TFS使用C++语言开发,需要运行在64bit Linux OS上,本文介绍如何在Linux环境编译安装TFS。

安装依赖的软件包

  • automake TFS基于automake工具构建

  • libtool automake需要使用libtool
  • realine 用于命令行编辑的库
  • libz-devel 用于数据压缩/解压缩
  • uuid-devel 用于生成全局唯一ID
  • tcmalloc google的内存管理库
    • 下载源码安装
    • apt-get install libgoogle-perftools-dev
    • yum install google-perftools.x86_64

安装tb-common-utils

TFS使用tb-common-utils软件包,tb-common-utils包含淘宝使用的基础系统库tbsys和网络库tbnet两个组件;安装tb-common-utils前需要设置环境变量TBLIB_ROOT,tbsys和tbnet将会被安装TBLIB_ROOT对应的路径(必须是绝对路径)下,TFS会在这个路径下查找tbsys、tbnet头文件和库。

设置TBLIB_ROOT环境变量

在~/.bash_profile文件中加入,export TBLIB_ROOT=path_to_tbutil , 然后执行source ~/.bash_profile

下载源码

# svn co -r 18 http://code.taobao.org/svn/tb-common-utils/trunk tb-common-utils
注意: 这里不要checkout最新版本,version18以后的修改导致部分接口不能前向兼容。

编译安装

# cd tb-common-utils
# sh build.sh

如果一切顺利,tb-common-utils已经安装成功到$TBLIB_ROOT路径下;如遇到问题请先阅读后面的编译FAQ

安装TFS

TFS开源用户大都只使用TFS的基本功能,所以这个版本我们默认只编译TFS的nameserver,dataserver,client和tool,以去除对mysql的依赖,需要使用到rcserver(全局资源管理服务),metaserver(TFS自定义文件名服务)的用户请自行编译安装这两个服务。

下载源码

# svn co http://code.taobao.org/svn/tfs/branches/dev_for_outer_users tfs

编译安装

# cd tfs
# sh build.sh init
# ./configure --prefix=path_to_tfs --with-release
# make
# make install
  • –prefix 指定tfs安装路径,默认会被安装到~/tfs_bin目录
  • –with-release 指定按release版本的参数进行编译,如果不指定这个参数,则会按开发版本比较严格的参数编译,包含-Werror参数,所有的警告都会被当错误,在高版本gcc下会导致项目编译不过,很多开源用户反馈的编译问题都跟这个有关,因为gcc高版本对代码的检查越来越严格,淘宝内部使用的gcc版本是gcc-4.1.2。

至此,TFS已经安装成功了,你可以开始部署TFS服务

编译FAQ

Q: 使用TFS一定需要64bit Liunx?
A: 是的,否则整个项目不能正常编译通过。

Q: 编译TFS过程中出现出现类似tbnet.h:39: fatal error: tbsys.h: No such file or directory的错误提示?
A: 需要先安装tb-common-utils软件包。

Q: 在安装tb-common-utils过程中,提示设置please set TBLIB_ROOT varialbe first!!?
A: 需要先设置TBLIB_ROOT环境变量,再编译安装tb-common-utils。

Q: 编译过程中出现类似警告:格式 ‘%lu’ 需要类型 ‘long unsigned int’,但实参 3 的类型为 ‘size_t’ ?
A: 你的机器使用的应该是32bit OS,如果你坚持要编译,可以自行修改代码或者直接忽略这些警告。

Q: 执行./configure时,提示configure: error: readline header files not found, --disable-readline or install gnu readline library?
A: 你需要安装readline库,或在configure时加上--disable-readline参数,不使用readline库。

Q: 执行./configure时,提示configure: error: tcmalloc link failed (--without-tcmalloc to disable)?
A: 你需要安装tcmalloc库, 或在configure时加上--without-tcmalloc参数,不使用tcmalloc库。

Q: 编译过程中出现大量的错误信息,类似于warnings being treated as error?
A: 请确认在./configure的时候是否加了--with-release参数。

Q: 编译过程中提示类似client_request_server.cpp:722:38: error: no matching function for call to ‘atomic_inc(volatile uint64_t*)’的错误信息?
A: 你的系统时32位的,请在64bit Linux编译安装TFS;因为32bit系统不支持对64bit整数的原子操作。

Q: 编译时遇到session_util.cpp:2:23: fatal error: uuid/uuid.h: No such file or directory?
A: 你需要先安装uuid库, 用于生成全局唯一ID, uuid库是e2fsprogs包工具的一部分;

Q: 编译时提示tfs_meta_helper.cpp:15:18: fatal error: zlib.h: No such file or directory?
A: 你需要先安装zlib,用于压缩/解压缩。

有问题或建议请直接留言,或微博@淘宝TFS。

时间: 2024-10-31 22:22:08

TFS使用文档-安装篇的相关文章

TFS使用文档-部署篇

在成功安装TFS之后,在你的安装目录(默认为~/tfs_bin),包含几个子目录bin.conf.include.lib.logs.script等. bin:包含tfs所有的可执行程序文件,如nameserver(NS).dataserver(DS).tfstool. conf:包含tfs的配置文件,如NS的配置文件ns.conf,DS的配置文件ds.conf. include:包含TFS客户端库相关的头文件,应用程序使用TFS需要包含这些头文件. lib: 包含TFS客户端的静/动态库,应用程

四.OC基础--1.文档安装和方法重载,2.self和super&static,3.继承和派生,4.实例变量修饰符 ,5.私有变量&私有方法,6.description方法

四.OC基础--1.文档安装和方法重载, 1. 在线安装 xcode-> 系统偏好设置->DownLoads->Doucument->下载 2. 离线安装 百度xcode文档 3. 方法重载: 是指在一个类中定义多个同名的方法 在OC中没有重载 2.self和super&static, self和super: 1. self理解: 谁调用当前方法, self就代表谁. 比如: 在对象方法中,self代表的是对象, 因为只有对象才可以调用对象方法 在类方法中, self代表的

[译文]Casperjs1.1.0参考文档-安装

安装 Casperjs能被安装在mac osx,windows 和大多数linux版本 依赖项 PhantomJS1.82及以上 Python2.6及以上 1.1版本的新特性 试验性的:在1.1-beta1版本,slimerjs 0.8及以上版本可以在 gecko(firefox)内核上运行你的测试.(仅需要在执行语句命令行中增加–engine=slimerjs这个参数) Mac osx下安装 略 Npm安装 略 从git安装 略 从一个档案安装 你可以从此处下载源代码: 最近的开发版: htt

Xcode文档安装

1.Xcode文档在线安装 打开Xcode,首选项 点击DownLoads下载文档 2.Xcode文档离线安装 找到备份的文档 com.apple.adc.documentation.AppleiOS8.0.iOSLibrary.docset 找到DocSets目录 /Applications/Xcode.app/Contents/Developer/Documentation/DocSets 拷贝文件到该目录 退出重新打开Xcode 如果还不行,/Users/你的用户名/Library/Dev

Mongoose学习参考文档——基础篇

Mongoose学习参考文档 前言:本学习参考文档仅供参考,如有问题,师请雅正 一.快速通道 1.1 名词解释 Schema : 一种以文件形式存储的数据库模型骨架,不具备数据库的操作能力 Model : 由Schema发布生成的模型,具有抽象属性和行为的数据库操作对 Entity : 由Model创建的实体,他的操作也会影响数据库 注意: 1.本学习文档采用严格命名方式来区别不同对象,例如: var PersonSchema; //Person的文本属性 var PersonModel; //

关于SqlServer2012本地帮助文档安装失败问题

由于本人在前一段时间安装了SqlServer2012,安装后没有自带本地帮助文档,因为新的数据库版本微软捆绑了一个本地帮助文档查看器软件,所以在这个软件里面选择联机安装的时候,总是下载不成功,原因你们懂的,服务器不在中国,速度奇慢无比,最终在网上找了好久才找到该解决问题 1 打开下面的链接下载 http://www.microsoft.com/zh-cn/download/details.aspx?id=347 用于受防火墙和代理限制的环境的 Microsoft SQL Server 2012

【SQL】SQL2012离线帮助文档安装不上的处理手记

注:解决方法在最后,心急的童鞋可以直接往下滚动. 我SQL实例装的是2008 R2版,由于该版自带的SSMS(Microsoft SQL Server Management Studio 管理工具)存在一些操蛋问题,例如: - 文本编辑器中对矩形文本块(alt+鼠标左键选取)的操作支持不好,例如不能多行批量键入,块粘贴之类 - 复制结果集时,cell中的回车换行会变为两个空格,不能准确得到cell的值,这点尤为操蛋 于是我安装了独立版的SSMS 2014(https://www.microsof

vim中文帮助文档安装

下载对应版本的中文帮助文档,例如:vim8.0下载vimcdoc-2.1.0.tar.gz $ wget http://nchc.dl.sourceforge.net/sourceforge/vimcdoc/vimcdoc-2.1.0.tar.gz 解压vimcdoc-2.1.0.tar.gz $ tar -zxvf vimcdoc-2.1.0.tar.gz 解压后其中有个doc文件夹, 将其中的内容全部复制到home/.vim/doc(如果目录不存在,手动新建), 或者vim安装目录下的doc

Vs2012帮助文档安装介绍

Vs2012的帮助文档:Microsoft Help Viewer.exe,vs2010对应的是1.0,vs2012对应的是2.0,版本号以此类推 与早期的chm格式的msdn帮助文档不同在于: 1. 默认不能单独运行帮助文档 2.需要一个xxxx.msha 的清单文件,以及相应的xxx.cab包 3.帮助文档支持多国语言 1.下载vs2012帮助文档(简体中文帮助文档不包含win32API以及驱动开发相关文档,如果需要win32API及 驱动开发相关文档还需要下载英文帮助文档) 简体中文帮助文