在网络协议的学习过程中,我们应该了解到TFTP是用来下载远程文件的最简单网络协议,它基于UDP协议而实现.那么tftp server安装配置如何进行呢?
首先我们需要了解,嵌入式linux的tftp开发环境包括两个方面:
一是嵌入式linux宿主机的tftp-server支持,
二是嵌入式linux目标机的tftp-client支持;因为u-boot本身内置支持tftp-client,所以嵌入式目标机就不用配置了.
tftp server安装配置1>安装
#mount -o loop /mnt/CD //挂载光盘
#rpm -ivh tftp-0.42-3.1.i386.rpm //安装tftp-client
#rpm -ivh tftp-server-0.42-3.1.i386.rpm //安装tftp-server
#umount /mnt/CD //卸载光盘
-------------------------------------------------------------
#yum install --downloadonly tftp*
文件被下载到/var/cache/yum/i386/6/base/packages/
#cd /var/cache/yum/i386/6/base/packages/
#yum localinstall tftp*.rpm
-------------------------------------------------------------
TFTP是用来下载远程文件的最简单网络协议,它其于UDP协议而实现
1.安装两个软件
tftp-0.39-2.i386.rpm
tftp-server-0.39-2.i386.rpm
#yum install tftp
#yum install tftp-server
2.修改启动配置文件
不管使用的是哪一种super-server,inetd或者xinetd,默认情况下TFTP服务是禁用的,所以要修改文件来开启服务。修改文件/etc/xinetd.d/tftp,主要是设置TFTP服务器的根目录,开启服务。
修改后的配置文件如下:
service tftp
{
disable = no
socket_type = dgram
protocol = udp
wait = yes
user = root
server = /usr/sbin/in.tftpd
server_args = -s /tftpboot -c #指定tftp服务器的目录,-c为指定为可以创建文件
per_source = 11
cps = 100 2
flags = IPv4
}
3.创建tftp根目录,关闭防火墙,启动tftp-server
#mkdir /tftpboot
#chmod -R 777 /tftpboot
#/etc/init.d/iptables stop //关闭防火墙
#service xinetd restart //重启 xinetd 服务重启xinetd服务,因为TFTP服务受控与xinetd, xinetd是管服务的服务,它是不开端口的。
验证一下TFTP是否起来了:
# netstat -nlp
出现下面的信息代表已经启动了
udp 0 0 0.0.0.0:69 0.0.0.0:*
4.tftp的使用
#tftp 192.168.2.105 登陆到tftp server
>get filename 从tftp server根目录获取文件
>put filename 上传文件到tftp server根目录
>q 离开
安装过程中出现的问题及原因
问题一
tftp> get
Transfer timed out.
原因:
tftpd服务没有启动
解决:
#service xinetd status 先查看tftp运行状态,如果是没开启服务,再执行如下语句
#service xinetd start
问题二
tftp> put
Error code 0: Permission denied
原因:
运行命令,查看系统日志
#tail /var/log/messages
发现有如下一段文字:
Mar 24 19:05:26 localhost setroubleshoot: SELinux is preventing /usr/sbin/in.tftpd (tftpd_t) "write" to tftpboot (tftpdir_t). For complete SELinux messages. run sealert -l 40a5a6bf-8ded-4bfa-ab6e-fa669a25fc6c
知道这是是由SELinux造成的,在FC3和FC3以后的FC版本中SELinux默认的都是开启的,现关掉它。
解决:
修改文件 /etc/sysconfig/selinux,设定其中的SELINUX=disabled,然后重启电脑即可。或者执行命令 system-config-securitylevel 打开 “安全级别配置”对话框,将SELinux(S)选项中 “强制” 改为“允许”。
问题三
tftp> put
Error code 1: File not found
原因:
指定的文件不存在;
解决:
/etc/xinetd.d/tftp中的server_args指定的目录中没有该文件,将要下载的文件拷贝到该目录即可,或server_args不是默认的/tftpboot,而是自己设定,但是在后面没有指定-c选项,补上即可。
问题四
tftp> get test.log
Error code 2: Only absolute filenames allowed
原因:
在/etc/xinetd.d/tftpd中设置的server_args为/etc/default/tftpd-hpa
cat /etc/default/tftpd-hpa
#Defaults for tftpd-hpa
RUN_DAEMON="no"
OPTIONS="-s /home/tftpd -c -p -U 077 -u tftpd"
设置的时候只要将server_args=改为你自己设定的服务器文件夹就行了
tftp与ftp的区别。
I.传输协议不一样:FTP是基于TCP, TFTP是基于UDP;
II.端口号不一样:FTP是用21/20,TFTP是69;
III.速度和安全方面:FTP在速度方面没有TFTP快但是FTP安全好。
配置
#mkdir /tftpboot;chmod -R 777 /tftpboot
配置文件是:/etc/xinetd.d/tftp
内容如下:
service tftp
{
disable = no
socket_type = dgram
protocol = udp
wait = yes
user = root
server = /usr/sbin/in.tftpd
server_args = -s /tftpboot
per_source = 11
cps = 100 2
flags = IPv4
}
修改后保存退出,重启服务
#service xinetd restart
server_args = -s /tftpboot
是tftp服务器运行时的参数。-s /tftpboot表示服务器默认的目录是 /tftpboot,当执行put a.txt时,文件会被放到服务器的/tftpboot/a.txt,省去敲put a.txt /tftpboot/的麻烦.
到此tftp server安装配置就全部完成了。
如果想上传原来目录中没有的文件,需要修改tftp服务器的配置文件并重起服务,如下操作所示:
打开/etc/xinetd.d/tftp文件,在server_args增加-c参数,-c为可以创建文件;如下所示:
service tftp
{
disable = no
socket_type = dgram
protocol = udp
wait = yes
user = root
server = /usr/sbin/in.tftpd
server_args = -s /tftpboot -c
per_source = 11
cps = 100 2
flags = IPv4
}
保存退出,重启tftp服务:
#service xinetd restart
现在就可以上传新文件了。
如果提示
Error code 0: Permission denied
用下面的命令禁用selinux:
#setenforce 0