您的位置 首页 东南亚服务器

如何实现文件双向传输搭建FTP服务器?(两个ftp服务器文件传输)

  实现文件双向传输 搭建FTP服务器

FTP(File Transfer Protocol),是文件传输协议的简称。用于Internet上的控制文件的双向传输。同时,它也是一个应用程序(Application)。用户可以通过它把自己的PC机与世界各地所有运行FTP协议的服务器相连,访问服务器上的大量程序和信息。
  

FTP协议

TCP/IP协议中,FTP标准命令TCP端口号为21,Port方式数据端口为20。FTP协议的任务是从一台计算机将文件传送到另一台计算机,它与这两台计算机所处的位置、联接的方式、甚至是是否使用相同的操作系统无关。假设两台计算机通过ftp协议对话,并且能访问Internet, 你可以用ftp命令来传输文件。
  每种操作系统使用上有某一些细微差别,但是每种协议基本的命令结构是相同的。

FTP的传输有两种方式:ASCII传输模式和二进制数据传输模式。

1.ASCII传输方式:假定用户正在拷贝的文件包含的简单ASCII码文本,如果在远程机器上运行的不是UNIX,当文件传输时ftp通常会自动地调整文件的内容以便于把文件解释成另外那台计算机存储文本文件的格式。
  

但是常常有这样的情况,用户正在传输的文件包含的不是文本文件,它们可能是程序,数据库,字处理文件或者压缩文件(尽管字处理文件包含的大部分是文本,其中也包含有指示页尺寸,字库等信息的非打印字符)。在拷贝任何非文本文件之前,用binary 命令告诉ftp逐字拷贝,不要对这些文件进行处理,这也是下面要讲的二进制传输。
  

2.二进制传输模式:在二进制传输中,保存文件的位序,以便原始和拷贝的是逐位一一对应的。即使目的地机器上包含位序列的文件是没意义的。例如,macintosh以二进制方式传送可执行文件到Windows系统,在对方系统上,此文件不能执行。

如果你在ASCII方式下传输二进制文件,即使不需要也仍会转译。
  这会使传输稍微变慢 ,也会损坏数据,使文件变得不能用。(在大多数计算机上,ASCII方式一般假设每一字符的第一有效位无意义,因为ASCII字符组合不使用它。如果你传输二进制文件,所有的位都是重要的。)如果你知道这两台机器是同样的,则二进制方式对文本文件和数据文件都是有效的。
  

FTP的工作方式

FTP支持两种模式,一种方式叫做Standard (也就是 PORT方式,主动方式),一种是 Passive (也就是PASV,被动方式)。 Standard模式 FTP的客户端发送 PORT 命令到FTP服务器。Passive模式FTP的客户端发送 PASV命令到 FTP Server。
  

下面介绍一个这两种方式的工作原理:

Port模式FTP 客户端首先和FTP服务器的TCP 21端口建立连接,通过这个通道发送命令,客户端需要接收数据的时候在这个通道上发送PORT命令。 PORT命令包含了客户端用什么端口接收数据。在传送数据的时候,服务器端通过自己的TCP 20端口连接至客户端的指定端口发送数据。
   FTP server必须和客户端建立一个新的连接用来传送数据。

Passive模式在建立控制通道的时候和Standard模式类似,但建立连接后发送的不是Port命令,而是Pasv命令。FTP服务器收到Pasv命令后,随机打开一个高端端口(端口号大于1024)并且通知客户端在这个端口上传送数据的请求,客户端连接FTP服务器此端口,然后FTP服务器将通过这个端口进行数据的传送,这个时候FTP server不再需要建立一个新的和客户端之间的连接。
  

很多防火墙在设置的时候都是不允许接受外部发起的连接的,所以许多位于防火墙后或内网的FTP服务器不支持PASV模式,因为客户端无法穿过防火墙打开FTP服务器的高端端口;而许多内网的客户端不能用PORT模式登陆FTP服务器,因为从服务器的TCP 20无法和内部网络的客户端建立一个新的连接,造成无法工作。
  

LINUX下如何搭建内部文件服务器?

  建议先将防火墙停用和selinux服务停用再做如下配置

NIS服务端配置步骤:

1。 rpm -qa |grep ^yp 查看系统是否把pybind-1。17。2-3 yp-tools-2。8-7这两个软件包装上了。

rpm -q portmap 查看系统是否把该包也装上了。
  (因为NIS与NFS一样需要portmap服务的支持)

2。安装ypserv软件包(第一张光盘)

rpm -ivh ypserv-2。13-5。i386。rpm

3。设置time 和 time-udp服务为启动状态

chkconfig time on

chkconfig time-udp on

service xinetd restart(启动依赖于xinetd的服务都要将它重新启动才会生效)

4。
  建立NIS域名nisdomainname nistest (这里使用nisdomainname命令建立的nistest域名是临时生效的,要想永久生效需要写入配置文件)

vi /etc/rc。d/rc。local 在最后添加一行 /bin/nisdomainname nistest 也可以使用这条命令将内容导入追加进去:echo \’/bin/nisdomainname nistest\’ >> /etc/rc。
  d/rc。local 这样与编辑rc。local是同样的效果。

同时还需要在/etc/sysconfig/network文件中写入一行 NISDOMAIN=nisdomain 的记录,可以使用VI编辑,也可以使用追加

echo \’NISDOMAIN=nistest\’ >> /etc/sysconfig/network

5。
  修改主配置文件 ypserv。conf

设置访问控制记录(第二重验证)

在# under MSDOG everbody is root and can access port > /etc/hosts

6。建立NIS的域名nisdomainname nistest (服务器上叫什么域名、客户机上也必须一样。
  ) echo \’/bin/nisdomainname nistest\’ >> /etc/rc。d/rc。local

echo \’NISDOMAIN=nistest\’ >> /etc/sysconfig/network

7。设置yp。conf配置文件echo \’domain nistest server NISserver\’ >> /etc/yp。
  conf

(其中nistest是NIS域名NISserver是NIS域名服务器的主机名)

8。设置nsswitch。conf文件 设置系统中信息的查询方式 在原来的files后都加上nis

passwd: files

shadow: files (原)

group: files

hosts: files dns

passwd: files nis

shadow: files nis (修改后)

group: files nis

hosts: files dns nis

9。
  启动ypbind服务程序

service portmap start

service ypbind start

chkconfig –level 35 ypbind on

10。使用NIS客户机测试与NIS服务器的连接

yptest (该命令会对NIS服务器的域名、主机、数据库及其内容进行自动测试并显示结果)

ypwhich(该命令可显示NIS服务器的主机名、使用-x命令选项会同时显示NIS服务器使用的数据库和映射的文件名称)

其他命令ypcat ypcat -x ypcat group等等

8。
  NIS客户端用户登陆

在客户端使用NIS服务器上的用户名登陆

用户登陆成功后可以使用yppasswd命令更改自己的密码。

NIS基本应用:

在NIS服务器中输出NFS共享目录

在/etc/exports文件中添加如下一行

/home 192。
  168。1。0/24(rw,async,no_root_squash)

(添加该行就是为了当用户登陆后不把他当作nfsnobody帐户看待)

修改完了后重启NFS服务service nfs restart

这个时候客户端可以使用mount命令将NIS服务器上的共享挂载到本地mount -t nfs 192。
  168。1。
  1:/home/user /mnt如果客户端想每次开机后自动挂载的话那就需要修改客户机中的/etc/fstab文件,添加如下一行

NISserv:/home/user/ /mnt nfs defaults 0 0

这样客户机每次开机之后都会自动挂载这个目录。

关于作者: 维拓主机

热门文章