arm平台搭建vsftpd服务
2014-12-24 11:59
381 查看
编译vsftpd程序
1. 获得源码包:vsftpd-2.1.2.tar.gz
2. 解压,进入源码目录:
tar xzvf vsftpd-2.1.2.tar.gz
cd vsftpd-2.1.2
3. 修改Makefile,指定交叉编译器:
CC = arm-linux-gcc 或者make -e CC =arm-linux-gcc
4. make
编译时会出现错误,跟libcap.so有关
修改vsf_findlibs.sh:
45-53行注释掉:
ftp:root@pwd//172.18.129.237/
gcc -c access.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c features.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c readwrite.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c opts.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c ssl.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c sslslave.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c ptracesandbox.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c ftppolicy.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c sysutil.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c sysdeputil.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -o vsftpd main.o utility.o prelogin.o ftpcmdio.o postlogin.o privsock.o tunables.o ftpdataio.o secbuf.o ls.o postprivparent.o logging.o str.o netstr.o sysstr.o strlist.o banner.o filestr.o parseconf.o secutil.o ascii.o oneprocess.o twoprocess.o privops.o standalone.o hash.o tcpwrap.o ipaddrparse.o access.o features.o readwrite.o opts.o ssl.o sslslave.o ptracesandbox.o ftppolicy.o sysutil.o sysdeputil.o -Wl,-s `./vsf_findlibs.sh`
sysdeputil.o: In function `vsf_sysdep_check_auth':
sysdeputil.c:(.text+0xf1): undefined reference to `crypt'
sysdeputil.c:(.text+0x122): undefined reference to `crypt'
解决方法:
打开Makefile
vim Makefile
LIBS = `./vsf_findlibs.sh`
末尾增加 -lcrypt 变成
LIBS = `./vsf_findlibs.sh` -lcrypt
vsftpd编译错误:tcpwrap.c:16:20: error: tcpd.h: No such file or directory
vsftpd: not configured for standalone, must be started from inetd
因为xinetd已经启动了vsftpd,而你的vsftpd设置成了stardalone模式
如果要用inetd启动,那用如下方面启动:
首先copy你的安装文件里的vsftpd.xinetd到/etc/xinetd.d/下
cp vsftpd.xinetd /etc/xinetd.d/vsftpd
/etc/rc.d/init.d/xinetd restart
用inetd模式启动
如果你想用standalone启动,必须做如下更改
编辑/etc/xinetd.d/vsftpd文件,把disable=no改成YES
编辑/etc/vsftpd.conf文件在顶部加listen=YES
停止xinetd服务,
#service xinetd stop ,
再启动vsftpd:
/usr/local/sbin/vsftpd &
个人经验: 只需要在/etc/vsftpd.conf文件的顶部加listen=YES
500 OOPS: vsftpd: cannot locate user specified in 'ftp_username':ftp
远程主机关闭连接。
原来,由于进行了安全设置,将ftp等匿名用户进行了删除处理,所以在读取vsftp.conf配置文件时,发生了错误,我们需要修改一下参数
[root@localhost ~]# vi /etc/vsftpd/vsftpd.conf
找到:
anonymous_enable=YES
修改为:
anonymous_enable=NO
重新启动vsftpd使配置生效
如果需要匿名登录,查看ftp用户是否存在,是否创建ftp用户家目录以及其子目录,在上述条件都满足的情况下,仍然报上述错误,可以选择修改源码中报上述错误的地方,直接跳过
目录权限问题:
ftp登录目录一般设置为755,其子目录设置为777
1. 获得源码包:vsftpd-2.1.2.tar.gz
2. 解压,进入源码目录:
tar xzvf vsftpd-2.1.2.tar.gz
cd vsftpd-2.1.2
3. 修改Makefile,指定交叉编译器:
CC = arm-linux-gcc 或者make -e CC =arm-linux-gcc
4. make
编译时会出现错误,跟libcap.so有关
修改vsf_findlibs.sh:
45-53行注释掉:
ftp:root@pwd//172.18.129.237/
安装vsftpd 报告错误 undefined reference to `crypt'
gcc -c access.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyincgcc -c features.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c readwrite.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c opts.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c ssl.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c sslslave.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c ptracesandbox.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c ftppolicy.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c sysutil.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -c sysdeputil.c -lcrypt -O2 -Wall -W -Wshadow -idirafter dummyinc
gcc -o vsftpd main.o utility.o prelogin.o ftpcmdio.o postlogin.o privsock.o tunables.o ftpdataio.o secbuf.o ls.o postprivparent.o logging.o str.o netstr.o sysstr.o strlist.o banner.o filestr.o parseconf.o secutil.o ascii.o oneprocess.o twoprocess.o privops.o standalone.o hash.o tcpwrap.o ipaddrparse.o access.o features.o readwrite.o opts.o ssl.o sslslave.o ptracesandbox.o ftppolicy.o sysutil.o sysdeputil.o -Wl,-s `./vsf_findlibs.sh`
sysdeputil.o: In function `vsf_sysdep_check_auth':
sysdeputil.c:(.text+0xf1): undefined reference to `crypt'
sysdeputil.c:(.text+0x122): undefined reference to `crypt'
解决方法:
打开Makefile
vim Makefile
LIBS = `./vsf_findlibs.sh`
末尾增加 -lcrypt 变成
LIBS = `./vsf_findlibs.sh` -lcrypt
vsftpd编译错误:tcpwrap.c:16:20: error: tcpd.h: No such file or directory
原来在CentOS 5.x 上没有报过这个错误,但是在CentOS 6.4上编译时却出错了,编译失败, 提示是:tcpwrap.c:16:20: error: tcpd.h: No such file or directory 解决方法: yum install tcp_wrappers yum install tcp_wrappers-devel 另外,如果#undef VSF_BUILD_TCPWRAPPERS 禁用tcpwrap再编译,就可能不报这个错误了 |
因为xinetd已经启动了vsftpd,而你的vsftpd设置成了stardalone模式
如果要用inetd启动,那用如下方面启动:
首先copy你的安装文件里的vsftpd.xinetd到/etc/xinetd.d/下
cp vsftpd.xinetd /etc/xinetd.d/vsftpd
/etc/rc.d/init.d/xinetd restart
用inetd模式启动
如果你想用standalone启动,必须做如下更改
编辑/etc/xinetd.d/vsftpd文件,把disable=no改成YES
编辑/etc/vsftpd.conf文件在顶部加listen=YES
停止xinetd服务,
#service xinetd stop ,
再启动vsftpd:
/usr/local/sbin/vsftpd &
个人经验: 只需要在/etc/vsftpd.conf文件的顶部加listen=YES
500 OOPS: vsftpd: cannot locate user specified in 'ftp_username':ftp
远程主机关闭连接。
原来,由于进行了安全设置,将ftp等匿名用户进行了删除处理,所以在读取vsftp.conf配置文件时,发生了错误,我们需要修改一下参数
[root@localhost ~]# vi /etc/vsftpd/vsftpd.conf
找到:
anonymous_enable=YES
修改为:
anonymous_enable=NO
重新启动vsftpd使配置生效
如果需要匿名登录,查看ftp用户是否存在,是否创建ftp用户家目录以及其子目录,在上述条件都满足的情况下,仍然报上述错误,可以选择修改源码中报上述错误的地方,直接跳过
目录权限问题:
ftp登录目录一般设置为755,其子目录设置为777
相关文章推荐
- arm平台搭建vsftpd服务
- arm平台搭建vsftpd服务
- .Net平台如何基于wsdl文件搭建虚拟WebService服务器进行跨平台服务调试?
- Linux系列-Red Hat5平台下的DHCP服务搭建
- Linux系列-Red Hat5平台下Sendmail邮件服务搭建
- Linux系列-Red Hat5平台下的Postfix邮件服务搭建(二)
- Linux系列-Red Hat5平台下的Postfix邮件服务搭建(二)
- 利用mysql搭建vsftpd虚拟用户登录服务
- Linux系列-Red Hat5平台下的LAMP网站服务搭建(三)
- Linux系列-Red Hat5平台下的FTP服务搭建
- Linux系列-Red Hat5平台下的Samba服务搭建
- Linux系列-Red Hat5平台下的LAMP网站服务搭建(二)
- Linux系列-Red Hat5平台下的FTP服务搭建
- Linux系列-Red Hat5平台下的LAMP网站服务搭建(三)
- Linux系列-Red Hat5平台下的LAMP网站服务搭建(二) 推荐
- Linux系列-Red Hat5平台下的DHCP服务搭建
- (原创)使用开源免费软件teamspeak搭建内网语音服务平台(无用户数限制)
- Linux系列-Red Hat5平台下的LAMP网站服务搭建(一)
- Linux系列-Red Hat5平台下的DNS服务搭建
- Linux系列-Red Hat5平台下的Postfix邮件服务搭建(一