| 
                         TFTP 即 简单文本传输协议(Trivial File Transfer Protocol),允许用户通过 UDP  协议在系统之间传输文件。默认情况下,协议使用的是 UDP 的 69 号端口。TFTP 协议广泛用于无盘设备的远程启动。因此,在你的本地网络建立一个 TFTP  服务器,这样你就可以对 安装好的 Fedora 和其他无盘设备做一些操作,这将非常有趣。 
TFTP 仅仅能够从远端系统读取数据或者向远端系统写入数据,而没有列出远端服务器上文件的能力。它也没提供用户身份验证。由于安全隐患和缺乏高级功能,TFTP  通常仅用于局域网内部(LAN)。 
  
安装 TFTP 服务器 
首先你要做的事就是安装 TFTP 客户端和 TFTP 服务器: 
- dnf install tftp-server tftp -y 
 
  
上述的这条命令会在 /usr/lib/systemd/system 目录下为 systemd 创建 tftp.service 和 tftp.socket  文件。 
- /usr/lib/systemd/system/tftp.service 
 - /usr/lib/systemd/system/tftp.socket 
 
  
接下来,将这两个文件复制到 /etc/systemd/system 目录下,并重新命名。 
- cp /usr/lib/systemd/system/tftp.service /etc/systemd/system/tftp-server.service 
 - cp /usr/lib/systemd/system/tftp.socket /etc/systemd/system/tftp-server.socket 
 
  
修改文件 
当你把这些文件复制和重命名后,你就可以去添加一些额外的参数,下面是 tftp-server.service 刚开始的样子: 
- [Unit] 
 - Description=Tftp Server 
 - Requires=tftp.socket 
 - Documentation=man:in.tftpd 
 - [Service] 
 - ExecStart=/usr/sbin/in.tftpd -s /var/lib/tftpboot 
 - StandardInput=socket 
 - [Install] 
 - Also=tftp.socket 
 
  
在 [Unit] 部分添加如下内容: 
- Requires=tftp-server.socket 
 
  
修改 [ExecStart] 行: 
- ExecStart=/usr/sbin/in.tftpd -c -p -s /var/lib/tftpboot 
 
  
下面是这些选项的意思: 
    - -c 选项允许创建新的文件
 
    - -p 选项用于指明在正常系统提供的权限检查之上没有其他额外的权限检查
 
    - -s 建议使用该选项以确保安全性以及与某些引导 ROM 的兼容性,这些引导 ROM 在其请求中不容易包含目录名。
 
 
默认的上传和下载位置位于 /var/lib/tftpboot。 
下一步,修改 [Install] 部分的内容 
- [Install] 
 - WantedBy=multi-user.target 
 - Also=tftp-server.socket 
 
  
不要忘记保存你的修改。 
下面是 /etc/systemd/system/tftp-server.service 文件的完整内容: 
- [Unit] 
 - Description=Tftp Server 
 - Requires=tftp-server.socket 
 - Documentation=man:in.tftpd 
 - [Service] 
 - ExecStart=/usr/sbin/in.tftpd -c -p -s /var/lib/tftpboot 
 - StandardInput=socket 
 - [Install] 
 - WantedBy=multi-user.target 
 - Also=tftp-server.socket 
 
  
启动 TFTP 服务器 
重新启动 systemd 守护进程: 
- systemctl daemon-reload 
 
  
启动服务器: 
- systemctl enable --now tftp-server 
 
  
要更改 TFTP 服务器允许上传和下载的权限,请使用此命令。注意 TFTP 是一种固有的不安全协议,因此不建议你在与其他人共享的网络上这样做。 
- chmod 777 /var/lib/tftpboot 
 
  
配置防火墙让 TFTP 能够使用: 
- firewall-cmd --add-service=tftp --perm 
 - firewall-cmd --reload 
 
  
客户端配置 
安装 TFTP 客户端 
- yum install tftp -y 
 
  
运行 tftp 命令连接服务器。下面是一个启用详细信息选项的例子: 
- [client@thinclient:~ ]$ tftp 192.168.1.164 
 - tftp> verbose 
 - Verbose mode on. 
 - tftp> get server.logs 
 - getting from 192.168.1.164:server.logs to server.logs [netascii] 
 - Received 7 bytes in 0.0 seconds [inf bits/sec] 
 - tftp> quit 
 - [client@thinclient:~ ]$ 
 
  
记住,因为 TFTP 没有列出服务器上文件的能力,因此,在你使用 get 命令之前需要知道文件的具体名称。                         (编辑:滁州站长网) 
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! 
                     |