[分享]linux架设BT Tracker服务器小记
原链接:www.taoer.com
?
目前开源的Bt tracker项目有:
官方Tracker为?www.bittorrent.com/?使用python语言
xbtt.sf.net?的c++ tracker
sourceforge.net/cvs/?group_id=94951
windows下的tracker?www.bitcomet.com/tracker/index-zh.htm
这个似乎不是开源的说?不用管他,反正也不用windows做服务器。
另外介绍一个论坛:http://www.isohunt.com/forum/
我使用的是 c++ 的xbt tracker
下面我就以这个为例来把我的架设过程描述下。
首先下载BT tracker
在xbt的主页和?sourceforge.net/cvs/?group_id=94951?都有说明使用CVS方式下载源代码
cvs -z3 -d:pserver:anonymous@cvs.sourceforge.net:/cvsroot/xbtt co xbt/misc xbt/XBT\ Tracker
这样你可以下载xbt tracker 和与之相关的源代码
cvs -z3 -d:pserver:anonymous@cvs.sourceforge.net:/cvsroot/xbtt co xbt
这样你可以下载xbt所有的源代码,其中有用的是misc和XBT Tracker目录
执行后,你会得到一个xbt名字的目录,还犹豫什么,cd呗
进入XBT Tracker目录
新建一个名字为 xbt_tracker.conf 的文件
文件格式如下:
数据库名 主机地址 mysql用户名 mysql密码 表名前缀
然后用mysql命令行工具进入你的mysql数据库
/usr/local/mysql/bin/mysql -hlocalhost -uroot -p -P3306 -S/tmp/mysql.3306.sock #根据你不同的mysql配置这里也会不同
#最简单的: mysql -uroot -p
然后 create database tracker; #这里的tracker替换成你的配置文件的数据库名
use tracker;
\. xbt_tracker.sql;
exit;
好了,数据库方便搞完了,接下来要搞tracker了
chmod 0755 make.sh
./make.sh
如果出现了下面的错误:
In file included from ../misc/sql/database.h:13,
from server.h:8,
from connection.cpp:6:
../misc/sql/sql_result.h:16:25: mysql/mysql.h: No such file or directory
In file included from ../misc/sql/database.h:13,
from server.h:8,
from connection.cpp:6:
请执行一下这步操作
cd ../misc
ln -s /usr/local/mysql/include/mysql/ mysql
cd ../XBT\ Tracker/
./make.sh
不出以外的话,就执行成功了
然后在当前目录下你会发现多出一个 xbt_tracker的文件
没错,运行这个文件
./xbt_tracker
如果出现了这个错误:
./xbt_tracker: error while loading shared libraries: libmysqlclient.so.12: cannot open shared object file: No such file or directory
这样来做
cd /usr/lib/
ln -s /usr/local/mysql/lib/mysql/libmysqlclient.so.12 libmysqlclient.so.12
cd -
./xbt_tracker
ok运行成功了
注意上面的ln命令要根据你的mysql的配置的路径自行做相应的修改
再次进入你的mysql
use tracker;
SELECT * FROM xbt_tracker;
如果显示为空;
执行下面的sql语句
INSERT INTO xbt_config (name,value) VALUES ('announce_interval', '1800'); INSERT INTO xbt_config (name,value) VALUES ('anonymous_connect', '1'); INSERT INTO xbt_config (name,value) VALUES ('anonymous_announce', '1'); INSERT INTO xbt_config (name,value) VALUES ('anonymous_scrape', '1'); INSERT INTO xbt_config (name,value) VALUES ('auto_register', '1'); INSERT INTO xbt_config (name,value) VALUES ('clean_up_interval', '60'); INSERT INTO xbt_config (name,value) VALUES ('daemon', '1'); INSERT INTO xbt_config (name,value) VALUES ('debug', '0'); INSERT INTO xbt_config (name,value) VALUES ('gzip_announce', '1'); INSERT INTO xbt_config (name,value) VALUES ('gzip_debug', '1'); INSERT INTO xbt_config (name,value) VALUES ('gzip_scrape', '1'); INSERT INTO xbt_config (name,value) VALUES ('listen_check', '0'); INSERT INTO xbt_config (name,value) VALUES ('listen_ipa', '*'); INSERT INTO xbt_config (name,value) VALUES ('listen_port', '2710'); INSERT INTO xbt_config (name,value) VALUES ('log_access', '0'); INSERT INTO xbt_config (name,value) VALUES ('log_announce', '0'); INSERT INTO xbt_config (name,value) VALUES ('log_scrape', '0'); INSERT INTO xbt_config (name,value) VALUES ('pid_file', 'xbt_config.pid'); INSERT INTO xbt_config (name,value) VALUES ('read_config_interval', '300'); INSERT INTO xbt_config (name,value) VALUES ('read_db_interval', '60'); INSERT INTO xbt_config (name,value) VALUES ('redirect_url', ''); INSERT INTO xbt_config (name,value) VALUES ('scrape_interval', '0'); INSERT INTO xbt_config (name,value) VALUES ('table_announce_log', 'xbt_announce_log'); INSERT INTO xbt_config (name,value) VALUES ('table_files', 'xbt_files'); INSERT INTO xbt_config (name,value) VALUES ('table_files_updates', 'xbt_files_updates'); INSERT INTO xbt_config (name,value) VALUES ('table_files_users', 'xbt_files_users'); INSERT INTO xbt_config (name,value) VALUES ('table_ipas', 'xbt_ipas'); INSERT INTO xbt_config (name,value) VALUES ('table_scrape_log', 'xbt_scrape_log'); INSERT INTO xbt_config (name,value) VALUES ('table_users', 'xbt_users'); INSERT INTO xbt_config (name,value) VALUES ('update_files_method', '1'); INSERT INTO xbt_config (name,value) VALUES ('write_db_interval', '60');
–部分参数说明
auto_register
如果自动注册打开,tracker将会追踪任何的torrent,如果关闭,则只追踪 xbt_files 表里面的
insert into xbt_files (info_hash, ctime) values (’<INFO_HASH>‘, null); // insert
update xbt_files set flags = 1 where info_hash = ‘<INFO_HASH>‘; // delete
anonymous_announce
如果anonymous_announce打开,tracker会提供给任何用户服务,如果关闭,tracker只提供给存在于xbt_users中的用户
torrent_pass 字段在xbt_users表中内容是32位长度的字符
announce URL内容看起来像这样的:torrent_pass: /<TORRENT_PASS>/announce
执行后,tracker的配置也就完成了
我不确定重新加载配置用不用重启服务
killall -TERM xbt_tracker
./xbt_tracker
启动后,会在当前的目录产生一个名为xbt_tracker.pid的文件,当服务器停止后,这个文件也会随之消失
通过这个文件,写一个脚本
#!/bin/bash
xbt_tracker_path=”/usr/local/xbt/XBT Tracker”
file_name=”xbt_tracker.pid”
if [ ! -f “$xbt_tracker_path/$file_name” ]; then
echo “Not found pid file $xbt_tracker_path/$file_name”;
echo “Starting xbt tracker server …”;
“$xbt_tracker_path/xbt_tracker”;
fi;
放到crontab表里面来定期执行这个脚本
在tracker down掉的情况下就可以自动的启动了
over this.