transmission-daemon 安装配置及若干问题

发布于: 2014年04月20日

本文基于下列操作环境:

硬件:raspberry pi 树莓派

操作系统:RASPBIAN — Debian Wheezy

假设系统ip: 192.168.1.100

1. 安装transmission-daemon

sudo apt-get install transmission-daemon

2. 基本配置:

启动控制文件:/etc/init.d/transmission-daemon

transmission-daemon配置文件位于/etc/transmission-daemon/settings.json (权限所有者:trnasmission-daemon)

默认配置文件夹目录: /var/lib/transmission-daemon/info (权限所有者:trnasmission-daemon)

文件夹 /var/lib/transmission-daemon/info 中含 setting.json 指向 /etc/transmission-daemon/settings.json

默认下载目录: /var/lib/transmission-daemon/downloads(权限所有者:trnasmission-daemon)

/etc/transmission/settings.json主要配置说明:

“cache-size-mb”: 4,     #内存缓存大小
“dht-enabled”: true,     #开启dht
“download-dir”: “/your/own/download/path”,  #请指定下载地址
“download-limit”: 100,                     #下载限速kb,所有限速相关的建议网页上自己设定
“incomplete-dir”: “/your/own/incomplete/path”,    #请指定地址
“incomplete-dir-enabled”: false,      #如果指定了,可以改为true开启
“rpc-enabled”: true,                  #开启网页控制
“rpc-username”: “simon”,      #远程控制用户
“rpc-password”: “{f51cf44878098657b404152b3b532f8c04854514rIbqCA.F”,  #加密的远程控制密码,你可以填写不加密的密码,启动后软件会自行加密
“rpc-port”: 9091,   #远程访问端口
“rpc-url”: “/transmission/”,
“rpc-whitelist”: “192.168.1.*”,  #默认127.0.0.1 只允许本机访问,一般路由器远程访问就设置成这样即可

保存, 启动transmission-daemon. 这里有陷阱,相见下方的常见问题。

sudo /etc/init.d/transmission-daemon start

或者

sudo service transmission-daemon start

远程控制,假设树莓派主机ip 192.168.1.100,则以 http://192.168.1.100:9091/ 访问,输入settings.json 设定的用户/密码。

基本设置完成,enjoy!

好吧,Linux下的东西不折腾几下是不会enjoy的。下面是常见问题:

1. 配置文件陷阱1

默认启动脚本相当于

sudo -u transmission-daemon transmission-daemon –config-dir /var/lib/transmission-daemon/info

具体,请自行 ps aux | grep transmission-daemon 确认。但是实际的配置文件却在/etc/transmission-daemon/settings.json。是的,这点我上面讲过,因为: /var/lib/transmission-daemon/info/setting.json -> /etc/transmission-daemon/settings.json

2. 配置文件陷阱2:

默认安装了transmission-daemon后,会自动启动。然后你去配置setting.json文件夹,然后重启( /etc/init.d/transmission-daemon restart ),然后你会发现根本不是你改的那个样子,然后你再改配置文件发现配置文件变成默认样子了,然后你寻找原因,然后你找不到原因,然后你抓狂。

因为在远程访问网页上可以修改一些配置,transmission-daemon在stop的时候会将修改的内容写入settings.json,所以不要再启动状态下修改settings.json, 请先/etc/init.d/transmission-daemon stop

3. 如何修改transmission-daemon运行用户

transmission-daemon运行的默认用户是transmission-daemon,如果要共享出来,给共享用户读写权限,会深深陷入Linux用户权限的旋涡。最简单的方式,就是以常用用户运行(树莓派为例用户pi)。

修改运行用户简单,/etc/init.d/transmission-daemon/ 修改

注释USER=debian-transmission这一行,增加 USER=pi 这一行。

修改你的下载文件夹:

sudo chown pi:pi -R /your/own/download/path

如果完成这两步,启动transmission-daemon,则会出现

a. 原来正在下载的东东不见了

b.添加新的种子,下载是报错:Error: Unable to save resume file: No such file or directory

resume文件夹在/var/lib/transmission-daemon/info/resume ,transmission-daemon用户权限,所以:

sudo chown pi:pi -R /var/lib/transmission-daemon/

其实,还要这样:

sudo chown pi:pi -R /etc/transmission-daemon/settings.json

不然无法保存网页上修改的配置。

OK, enjoy then.

EC2 vsftpd 建立ftp服务器的连接异常解决

发布于: 2014年04月15日

Amazon 云计算EC2 的几个基本概念说明:

1. EC2 有两个IP,  内部IP: 例如:172.xxx.xxx.xxx,   外部IP:例如:68.xxx.xxx.xxx

ifconfig 只能看到内部IP, 也就是说默认网卡分配了一个内部IP。而外部IP实际上是NAT端口到服务器。

2. EC2 控制台->NETWORK & SECURITY->Security Group 可以设定了ec2的防火墙,选择哪些端口打开。实际上是设定了那些NAT的端口。

假设我们以比较严格的方式设定Security Group, 仅开放使用到的端口。如使用ssh, ftp, web, 等,仅打开22,21,80端口。以vsftpd服务器为例,设定ftp服务器通常会碰到的问题。

vsftpd.conf 相关设定:

listen=YES         #打开监听
listen_port=21 #监听21端口
pasv_enable=YES  #启动被动模式
ftp登录会碰到下面的错误提示:

227 Entering Passive Mode (172,xxx,xxx,xxx,56).
ftp: connect: timout!

上面红色字体表明ftp服务器返回了一个172开头的内部IP
如果把pasv_enable=YES改为pasv_enable=NO,来关闭被动模式。登录ftp时回返回以下错误:

500 Illegal PORT command.

如果vsftpd.conf 绑定 ip 68.xxx.xxx.xxx呢?

listen_address=68.xxx.xxx.xxx
你可以预计到根本无法连接了,因为 主机并没有绑定68.xxx.xxx.xxx 这个IP的物理设备。
解决方案如下:
listen_port=21
pasv_enable=YES
pasv_max_port=21100   #可自行变更
pasv_min_port=21000  #可自行变更
port_enable=YES
pasv_address=68.xxx.xxx.xxx
在ec2 Security Group开放21和21000~21100 端口,即可解决。

php 递归创建目录

发布于: 2014年02月10日

比如在home目录下递归创建不存在的a/b/c/d/目录:/home/simon/a/b/c/d

$dir=”/home/simon/a/b/c/d/”;
mkdir($dir,0700,true);

请忽略mkdir函数0700,这个是写入权限设定。Windows下无效。

mkdir第三个字符默认false, 设定为true可以递归创建目录。

rsync 同步目录问题经验小结

发布于: 2014年02月08日

实例一:

$rsync -avz –progress –delete /home/dest/ 192.168.1.104::test
上命令会把 /home/dest/ 与test根目录文件同步,将test目录下的所有文件结构与/home/dest/目录一致

实例二:

$rsync -avz –progress /home/dest/ 192.168.1.104::test
无–delete参数
上命令会把 /home/dest/ 与test根目录文件同步,但仅作增量备份,不删除任何test目录下的文件。

实例三:

$rsync -avz –progress –delete /home/dest 192.168.1.104::test
上命令会把 /home/dest 与test目录下dest子目录文件同步,将test/dest子目录下的所有文件结构与/home/dest/目录一致,删除test/dest子目录下任何不同的文件,但与test根目录下其他文件无关。

实例四:

$rsync -avz –progress /home/dest 192.168.1.104::test
上命令会把 /home/dest 与test目录下dest子目录文件同步,不删除任何test目录及子目录下的文件。

EXT4-fs: Unrecognized mount option “uid=500” or missing value

发布于: 2013年10月29日

首先,我声明这是我无知造成的乌龙事件。事情是这样的。

CentOS下,新硬盘,新分区,ext4。

mount -t ext4 -o uid=500,gid=500 /dev/sdb1 /media/sdb1

上面命令试图把分区给uid=500的常规用户读写。

报错:

mount: wrong fs type, bad option, bad superblock on /dev/sdb1,

missing codepage or helper program, or other error

In some cases usefl info is found in syslog – try

dmesg | tail or so

好吧:#dmesg | tail

发现错误:

EXT4-fs: Unrecognized mount option “uid=500” or missing value

原因:

uid, gid, umask, dmask等参数是给ntfs, vfat等文件系统用的。给ext4 文件系统制定uid相当于执行了chown,而这一切并不必要。因为只要chown一次,下次mount该分区并不会改变之前chown的结果。

心理暗示的力量

发布于: 2013年10月28日

相信大部分人都喝过啤酒。如果你记得第一次喝啤酒的感觉,我想大家都会记得它的味道:苦!缘何后来,如果你爱喝啤酒的话,都会忘记它的苦味?但炎热的夏天,又热又渴,你一定是奔着啤酒的凉爽味道去打开一瓶啤酒的吧。当然铺天盖地的啤酒广告,也必定没有一次一次的告诉你“我的啤酒是苦的”。即使以味苦闻名天下的黑啤,也说自己麦香浓郁。

–这一切都是心理暗示的力量

但我们持续不断的被这些信息轰炸,潜意识里面,大家都忘记了啤酒的苦味。虽然这个味道一直客观存在,但是大脑选择忽略味觉系统传过来的这一信息。

在陪伴着我的小公主逐渐长大的过程中,我在渐渐学习心理暗示的力量。

每个人不免生病,打针吃药是难以避免。为何有些小朋友在打针时哭得惊天动地,有些没有?我观察发现,害怕打针的小朋友在离护士站几十米远的时候就开始动容,越靠近动静越大。伴随着家长不停的劝说:怕什么,一点都不疼,我们宝贝很勇敢,一点都不疼,一点都不疼….

不疼你妹啊~~~~其实家长在不停地暗示孩子,打针很疼,打针很疼,很疼,很疼…… 在这种情况下,孩子不拼死挣扎才有鬼。

所以,我和夫人在带我们的小公主打针的时候,严格禁止说“疼”这个字。即使问,我也会说“宝贝,有没有很痒?会不会很舒服?护士姐姐好看吗?”

同理,吃药的时候,你要是说:“宝贝,吃药了,一点都不苦…”  那就惨了,整个房间的悲剧上演。

而我们的公主已经被训练到吃中药都应付自如。

心理暗示的力量如此强大。是积极?还是消极?则完全看运用者的技巧。如果不主动抵抗消极的心理暗示,者常常会被悄悄地到消极的一面。比如今天你干了很多的事情,正常的情况下,会让你在晚饭后懒散地躺在沙发上,根本不想动。做家务?门都没有!男吊丝们,请问这个时候,如果有人找你去打个篮球,踢个足球,是不是又是一条好汉?

So…. 只要你保证了正常的睡眠时间。累,只是一种选择。

心理暗示,make the choice of your own.

浙ICP备18056264号-1