1. 程式人生 > >tftp: server says: File not found解決辦法

tftp: server says: File not found解決辦法

在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/lqm/tftpboot -c

       disable                    =no

       per_source             =11

       cps                         =100 2

       flags                       =IPv4

}

說明:修改項server_args= -s     <path>    -c,其中<path>處可以改為你的tftp-server的根目錄,引數-s指定chroot,-c指定了可以建立檔案。

3. 建立tftp根目錄,啟動tftp-server。

#mkdir /home/lqm/tftpboot

#chmod o+w       /home/lqm/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.
原因:
tftpd服務沒有啟動

現象二
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=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=改為你自己設定的伺服器資料夾就行了