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 端口,即可解决。

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.

php-5.3.3 mssql support

发布于: 2013年10月15日

系统环境:

CentOS 6.4

软件仓库php5.3.3 带php-devel包

希望能够得到mssql.so 支持。

安装freetds:

http://www.freetds.org/ 下载最新稳定版本:freetds.stable.tgz 我得到的版本是0.91。下方的命令安装:

# tar zxvf freetds-current.tgz

# ./configure –prefix=/usr/local/freetds –with-tdsver=7.2 –enable-msdblib

# make

# make install

配置,我要求链接到SQL Server 2005:

修改/usr/local/freetds/etc/freetds.conf

[Server2005]
host = 192.168.1.100 #根据自己改

port = 1433

tds version = 7.2

client charset = UTF-8

tds version 选择参考:http://www.freetds.org/userguide/choosingtdsprotocol.htm

Server2005这个名字会在PHP 链接代码中用到。

mssql.so文件编译:

由于是软件仓库安装,并没有源代码。也没有php-mssql这样的软件包。所以编译mssql.so比较特殊,但也是可以。

下载php-5.3.3源码,老版本源码在这里下载:http://www.php.net/releases/

解压,进入目录:php-5.3.3/ext/mssql

#phpize

#./configure –with-php-config=/usr/bin/php-config –with-mssql=/usr/local/freetds

#make

#make install

make 的时候可能出现下面的错误:

/usr/include/php/main/spprintf.h:40: note: expected ‘char **’ but argument is of type ‘unsigned char **’

make: *** [php_mssql.lo] Error 1

修改 php-5.3.3/ext/mssql/php_mssql.h 24行增加一行:

#define PHP_MSSQL_API
此为bug,已经有人报告,见链接:https://bugs.php.net/bug.php?id=60267

编译成功后,会在/usr/lib/php/modules中出现mssql.so文件,64位的位于/usr/lib64/php/modules 中。在php.ini增加
extension=mssql.so

重启apache.
php链接mssql 代码:
mssql_pconnect('Server2005',username,passwd);

Good luck!

 

浙ICP备18056264号-1