CentOS下tftp 安装配置使用

TFTP一般用于向目标板下载镜像文件TFTP是用来下载远程文件的最简单网络协议,它其于UDP协议而实现。嵌入 式linux的tftp开发环境包括两个方面:一是linux服务器端的tftp-server支持,二是嵌入式目标系统的tftp-client支持。 因为u-boot本身内置支持tftp-client,所以嵌入式目标系统端就不用配置了。下面就详细介绍一下linux服务器端tftp-server 的配置。



安装:
执行下面的命令能够看到服务是否已经启动,若已经启动则不用安装,否则需要安装下面的步骤安装tftp-server服务器。
#netstat -a|grep tftp
udp       0       0   *:tftp            *:*

我的系统是CentOS,所以执行一下命令进行安装:
#yum install tftp tftp-server //其它系统做相应改动



配置:
在linux下,不管使用的是哪一种super-server,inetd或者xinetd,默认情况下TFTP服务是禁用的,所以要修改文件来开启服务。
根据(1)的安装方法,可以修改文件/etc/xinetd.d/tftp。主要是设置TFTP服务器的根目录,开启服务。修改后的文件如下:

service tftp
{     socket_type            =dgram
      protocol               =udp
      wait                   =yes
      user                   =root
      server                 =/usr/sbin/in.tftpd
      server_args            =-s  /home/xt/tftpboot -c
      disable                =no
      per_source             =11
      cps                    =100 2
      flags                  =IPv4
}

修改项说明:

默认 disable                =yes 修改为 disable                =no

server_args=-s <path> -c,其中<path>处可以改为你的tftp-server的根目录参数-s指定chroot-c指定了可以创建文件




创建tftp根目录,启动tftp-server
 #mkdir  /home/xt/tftpboot
 #chmod o+w       /home/xt/tftpboot
 #service xinetd restart
停止 xinetd:                                              [确定]
启动 xinetd:                                                           [确定]
这样,tftp-server就启动了。你可以登陆本机测试以下,命令如下:
 #tftp     <your-ip-address>
 #tftp>get <download file>
 #tftp>put <upload file>
 #tftp>q



安装过程中出现的问题及原因

现象一:

tftp> get test.log

Transfer timed out.
原因:

1.tftpd服务没有启动

2.需要把selinux禁用掉 具体方法如下:

#vim /etc/selinux/config      //如果没有selinux/config这个文件,则创建。


# This file controls the state of SELinux on the system.
# SELINUX= can take one of these three values:
#       enforcing - SELinux security policy is enforced.
#       permissive - SELinux prints warnings instead of enforcing.
#       disabled - SELinux is fully disabled.
SELINUX=enforcing
# SELINUXTYPE= type of policy in use. Possible values are:
#       targeted - Only targeted network daemons are protected.
#       strict - Full SELinux protection.
SELINUXTYPE=targeted


把上面的SELINUX=enforcing 改为:SELINUX=disable  禁用SeLinux
然后reboot重启PC



现象二:

tftp> put test2

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=enabled改为 SELINUX=disabled
然后重启电脑即可

或者执行命令 system-config-securitylevel 打开 “安全级别配置”对话框,将SELinux(S)选项中 “强制” 改为“允许”。



现象三:

tftp> put ex070416.log

Error code 1: File not found
原因:

指定的文件不存在;或tftpd启动参数中没有指定-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=改为你自己设定的服务器文件夹就行了




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值