linux配置nfs步骤

linux配置nfs步骤,第1张

NFS的配置过程很简单。在服务器端中编辑 /etc/exports 文件,添加如下内容: /home/nfs-share 1921681122 (rw,sync)
第一项是要共享的目录,后者为共享的配置参数一般为: (rw,sync,no_root_squash,no_all_squash,no_subtree_check)
然后开启NFS和portmap服务:
/etc/initd/nfs start //用service nfs start也可以 /etc/initd/portmap start //用service portmap stasrt也可以
在centos65中portmap已经改为rpcbind 在客户端,用mount –t nfs 192168123:/home/nfs-share /home/remote_file挂载服务器端的共享目录到本地的/home/remote-file挂载点,然后我们就可以在客户端上应用到远程主机上的/home/nfs-share目录了。想要系统在开机时自动挂载,修改/etc/fstab文件,把NFS服务器的共享目录添加进去就可以了,这个不用多说。

如何知道远程主机上的共享目录情况呢?使用showmount命令,这个命令需要root权限。它有三个选项(记住这三个选项代表的含义: showmount –a IP 显示指定NFS服务器的客户端以及服务器端在客户端的挂载点 showmount –d IP 显示指定NFS服务器在客户端的挂载点 showmount –e IP 显示指定NFS服务器上的共享目录列表(或者叫输出列表) 我们输入命令showmount –a 1921681123:

客户端中出现的mount clntudp_create: RPC: Program not registered错误是怎么回事?噢,我刚才重启了一下服务器端,重启后NFS服务没有开启。 我们开启服务器端的NFS服务,再从客户端上查看一下NFS服务器的情况:

Showmount –a显示出NFS服务器1921681123的共享目录被客户端192168122挂载到/home中;

在showmount -e IP,出现clnt_create: RPC: Port mapper failure - Timed out报错
解决方案:
被访问的NFS服务器上的防火墙没有添加规则,向iptables里面添加以下查看的所有端口即可(目前解决的方法,当然你也可以关闭防火墙,不过这样是比较不安全的,如果你的nfs作用不大,建议你另选别的应用来替代吧!毕竟开那么多的端口,比较不安全呀!)

通过#rpcinfo -p 1010209148
[root@rh01 /]# rpcinfo -p 1010209148program vers proto port service100000 4 tcp 111 portmapper100000 3 tcp 111 portmapper100000 2 tcp 111 portmapper100000 4 udp 111 portmapper100000 3 udp 111 portmapper100000 2 udp 111 portmapper100024 1 udp 52943 status100024 1 tcp 37706 status100011 1 udp 875 rquotad100011 2 udp 875 rquotad100011 1 tcp 875 rquotad100011 2 tcp 875 rquotad100003 2 tcp 2049 nfs100003 3 tcp 2049 nfs100003 4 tcp 2049 nfs100227 2 tcp 2049 nfs_acl100227 3 tcp 2049 nfs_acl100003 2 udp 2049 nfs100003 3 udp 2049 nfs100003 4 udp 2049 nfs100227 2 udp 2049 nfs_acl100227 3 udp 2049 nfs_acl100021 1 udp 37438 nlockmgr100021 3 udp 37438 nlockmgr100021 4 udp 37438 nlockmgr100021 1 tcp 46331 nlockmgr100021 3 tcp 46331 nlockmgr100021 4 tcp 46331 nlockmgr100005 1 udp 57177 mountd100005 1 tcp 43147 mountd100005 2 udp 49154 mountd100005 2 tcp 54810 mountd100005 3 udp 55707 mountd100005 3 tcp 58309 mountd
[root@rh01 /]#

刚才在重启NFS服务的时候,细心的话可以注意到,我们在输入命令/etc/initd/nfs start开启nfs服务时,系统还自作主张地开启了NFS quotas等其它3个服务。

怎么回事?我们只输入了一条启动NFS服务的命令,它怎么额外的启动了3个服务?后面的启动portmap服务又是怎么回事? 我们首先要了解一点:NFS文件系统要提供服务单靠本身的NFS服务是不够的,还需要调用其它服务,这个其它服务就是RPC(remote procedure call,远程过程调用)服务和portmap服务。由于NFS服务本身不提供文件传输功能,我们要远程使用NFS文件系统就需要RPC服务的支持;而portmap服务用来为RPC服务进行动态端口分配和映射,所以portmap服务也是NFS服务所必须的。

我们查看一下服务的启动情况:

所遇错误:
/etc/initd/nfs-kernel-server: 没有那个文件或目录
解决方案:
没有配置、安装NFS
Linux 下配置NFS服务
1、安装

2、配置

3、客户端

所遇问题:centos65
portmap: 未被识别的服务
解决方案:
由于在6系列里面,portmap已经改名了 ,6系列需要使用 service rpcbind start启动[root@unix-big-bang ~]# service portmap start
portmap: 未被识别的服务
[root@unix-big-bang ~]# service rpcbind status
rpcbind (pid 1312) is running
[root@unix-big-bang ~]#

好文共赏:
linux nfs文件共享

◆一、概念
NFS是网络文件系统(Network File System)的简称,是分布式计算机系统的一个组成部分,可实现在异构网络上共享和装配远程文件系统。
NFS由SUN公司开发,目前已成为文件服务的一种标准(RFC1904,RFC1813)。其最大的功能就是可以通过网络,让不同 *** 作系统 的计算机可以共享数据,所以也可以看作是一个文件服务器。NFS是除了SAMBA之外Windows与Linux及Unix与Linux之间通信的方法。

理想条件下的NFS 网络拓扑结构

1、设置Linux系统之间的文件共享(Linux与Windows中间文件共享采用SAMBA服务);
2、NFS只是一种文件系统,本身没有传输功能,是基于RPC协议实现的,才能达到两个Linux系统之间的文件目录共享;
3、NFS为C/S 架构 ;
◆二、服务器配置
1、配置文件
主要配置文件为:/etc/exports
格式为: 共享目录 可mount主机IP(参数1,参数2,……)
如:/var/nfs 17220 (rw,sync,no_rootl_squash)
说明:必须注意nfs/目录的访问权限,必须设置成777权限;父目录/var权限无要求,普通的755即可;
2、启动相关服务
然后依次启动相关服务:portmap,nfslock,nfs
service portmap start
service nfslock start
service nfs start
关闭顺序相反。
3、检查共享目录
随后可以采用showmount –e查看一下,看看共享的目录情况:
[root@ns var]# showmount -e
Export list for nsosserver:
/var/nfs 17220
OK,到此为止,NFS服务器搭建完毕;
◆三、客户端配置
1、确保portmap运行
客户端必须确保RPC协议相应的portmap正常运行,否则mount将失败;
2、挂载/var/nfs目录(本地挂载点为/mnt/nfs)
mount -t nfs 172206516:/var/nfs /mnt/nfs
成功mount以后,即可同本地目录一样随意 *** 作;
◆四、其它相关命令
1、当修改了/etc/exports文件后,可以不用重新启动nfs服务,直接采用exports –rv 即可重新导出共享目录;
该命令格式如下:
exportfs [-aruv]
-a :全部mount或者unmount /etc/exports中的内容
-r :重新mount /etc/exports中分享出来的目录
-u :umount 目录
-v :在 export 的时候,将详细的信息输出到屏幕上。
具体例子:
[root@ns var]# showmount -e
Export list for nsosserver:
/var/nfs 17220
[root@ns var]# exportfs –au #全部卸载
[root@ns var]# showmount -e
Export list for nsosserver:
[root@ns var]# exportfs –rv #全部重新 export 一次
exporting 17220 :/var/nfs
[root@ns var]#
2、showmout命令对于NFS的 *** 作和查错有很大的帮助,所以我们先来看一下showmount的用法
showmout
-a :这个参数是一般在NFS SERVER上使用,是用来显示已经mount上本机nfs目录的cline机器。
-e :显示指定的NFS SERVER上export出来的目录。
例如:
[root@localhost ~]# showmount -e 1722016139
Export list for 1722016139 :/root/share 1722016137
[root@ns var]# showmount -a
All mount points on localhostlocaldomain: :/root/share,17220 :/root/share,1722016 :/root/share,1722016139:/nfsshare,1722016139:/root/share1722016137: 1722016137:,17220 1722016137:,1722016 1722016137:/root/share1722016139: 1722016139:,17220 1722016139:,1722016 1722016139:,17220161391722016139:DEFAULT
◆五、常见问题解答
1、提示:mount to NFS server '1722067203' failed: server is down
解决方案:可能是NFS服务器的防火墙有问题;
2、提示:mount: RPC: Timed out
解决方案:由于RPC协议没运行;启动portmap服务;
也有可能是防火墙问题;Server/Client均有可能。

NFS(Network File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间共享资源。在NFS的应用中,本地NFS的客户端应用可以透明地读写位于远端NFS服务器上的文件,就像访问本地文件一样。

NFS体系至少有两个主要部分:

一台NFS服务器和若干台客户机。

客户机通过TCP/IP网络远程访问存放在NFS服务器上的数据。

在NFS服务器正式启用前,需要根据实际环境和需求,配置一些NFS参数。

扩展资料:

NFS是基于UDP/IP协议的应用,其实现主要是采用远程过程调用RPC机制,RPC提供了一组与机器、 *** 作系统以及低层传送协议无关的存取远程文件的 *** 作。

RPC采用了XDR的支持。XDR是一种与机器无关的数据描述编码的协议,他以独立与任意机器体系结构的格式对网上传送的数据进行编码和解码,支持在异构系统之间数据的传送。

参考资料来源:百度百科-网络文件系统

参考资料来源:百度百科-NFS

一、获取内核源码

二、解压内核源码

首先以root帐号登录,然后进入/usr/src子目录。如果用户在安装Linux时,安装了内核的源代码,则会发现一个linux-xyz的子目录。该目录下存放着内核xyz的源代码。此外,还会发现一个指向该目录的链接linux。删除该连接,然后将新内核的源文件拷贝到/usr/src目录中,并解压:

#tarzxvfLinux-2314targz

文件释放成功后,在/usr/src目录下会生成一个linux子目录。其中包含了内核2314的全部源代码。将/usr/include/asm、/usr/inlude/linux、/usr/include/scsi链接到/usr/src/linux/include目录下的对应目录中。

#cd/usr/include

#rm-Rfasmlinux

#ln-s/usr/src/linux/include/asm-i386asm

#ln-s/usr/src/linux/include/linuxlinux

#ln-s/usr/src/linux/include/scsiscsi

删除源代码目录中残留的o文件和其它从属文件。

#cd/usr/src/linux

#makemrproper

三增量补丁

有时不需要完全重新安装,只需打增量补丁,类似升级,在内核源码树根目录运行:

patch-p1</patch-xyz

四内核源码树目录:

arch:包含和硬件体系结构相关的代码,每种平台占一个相应的目录。和32位PC相关的代码存放在i386目录下,其中比较重要的包括kernel(内核核心部分)、mm(内存管理)、math-emu(浮点单元仿真)、lib(硬件相关工具函数)、boot(引导程序)、pci(PCI总线)和power(CPU相关状态)。

block:部分块设备驱动程序。

crypto:常用加密和散列算法(如AES、SHA等),还有一些压缩和CRC校验算法。

Documentation:关于内核各部分的通用解释和注释。

drivers:设备驱动程序,每个不同的驱动占用一个子目录。

fs:各种支持的文件系统,如ext、fat、ntfs等。

include:头文件。其中,和系统相关的头文件被放置在linux子目录下。

init:内核初始化代码(注意不是系统引导代码)。

ipc:进程间通信的代码。

kernel:内核的最核心部分,包括进程调度、定时器等,和平台相关的一部分代码放在arch//kernel目录下。

lib:库文件代码。

mm:内存管理代码,和平台相关的一部分代码放在arch//mm目录下。

net:网络相关代码,实现了各种常见的网络协议。

scripts:用于配置内核文件的脚本文件。

security:主要是一个SELinux的模块。

sound:常用音频设备的驱动程序等。

usr:实现了一个cpio。

在i386体系下,系统引导将从arch/i386/kernel/heads开始执行,并进而转移到init/mainc中的main()函数初始化内核。

五配置内核

#cd/usr/src/linux

内核配置方法有三种:

(1)命令行:makeconfig

(2)菜单模式的配置界面:makemenuconfig

(3)Xwindow:makexconfig

Linux的内核配置程序提供了一系列配置选项。对于每一个配置选项,用户可以回答\"y\"、\"m\"或\"n\"。其中\"y\"表示将相应特性的支持或设备驱动程序编译进内核;\"m\"表示将相应特性的支持或设备驱动程序编译成可加载模块,在需要时,可由系统或用户自行加入到内核中去;\"n\"表示内核不提供相应特性或驱动程序的支持。由于内核的配置选项非常多,本文只介绍一些比较重要的选项。

1、Codematurityleveloptions(代码成熟度选项)

Promptfordevelopmentand/orincompletecode/drivers(CONFIG_EXPERIMENTAL)[N/y/]如果用户想要使用还处于测试阶段的代码或驱动,可以选择“y”。如果想编译出一个稳定的内核,则要选择“n”。

2、Processortypeandfeatures(处理器类型和特色)

(1)、Processorfamily(386,486/Cx486,586/K5/5x86/6x86,Pentium/K6/TSC,PPro/6x86MX)[PPro/6x86MX]选择处理器类型,缺省为Ppro/6x86MX。

(2)、MaximumPhysicalMemory(1GB,2GB)[1GB]内核支持的最大内存数,缺省为1G。

(3)、Mathemulation(CONFIG_MATH_EMULATION)[N/y/]协处理器仿真,缺省为不仿真。

(4)、MTRR(MemoryTypeRangeRegister)support(CONFIG_MTRR)[N/y/]

选择该选项,系统将生成/proc/mtrr文件对MTRR进行管理,供Xserver使用。

(5)、Symmetricmulti-processingsupport(CONFIG_SMP)[Y/n/]选择“y”,内核将支持对称多处理器。

3、Loadablemodulesupport(可加载模块支持)

(1)、Enableloadablemodulesupport(CONFIG_MODULES)[Y/n/]选择“y”,内核将支持加载模块。

(2)、Kernelmoduleloader(CONFIG_KMOD)[N/y/]选择“y”,内核将自动加载那些可加载模块,否则需要用户手工加载。

4、Generalsetup(一般设置)

(1)、Networkingsupport(CONFIG_NET)[Y/n/]该选项设置是否在内核中提供网络支持。

(2)、PCIsupport(CONFIG_PCI)[Y/n/]该选项设置是否在内核中提供PCI支持。

(3)、PCIaccessmode(BIOS,Direct,Any)[Any]该选项设置Linux探测PCI设备的方式。选择“BIOS”,Linux将使用BIOS;选择“Direct”,Linux将不通过BIOS;选择“Any”,Linux将直接探测PCI设备,如果失败,再使用BIOS。

(4)Parallelportsupport(CONFIG_PARPORT)[N/y/m/]选择“y”,内核将支持平行口。

5、PlugandPlayconfiguration(即插即用设备支持)

(1)、PlugandPlaysupport(CONFIG_PNP)[Y/m/n/]选择“y”,内核将自动配置即插即用设备。

(2)、ISAPlugandPlaysupport(CONFIG_ISAPNP)[Y/m/n/]选择“y”,内核将自动配置基于ISA总线的即插即用设备。

6、Blockdevices(块设备)

(1)、NormalPCfloppydisksupport(CONFIG_BLK_DEV_FD)[Y/m/n/]选择“y”,内核将提供对软盘的支持。

(2)、EnhancedIDE/MFM/RLLdisk/cdrom/tape/floppysupport(CONFIG_BLK_DEV_IDE)[Y/m/n/]选择“y”,内核将提供对增强IDE硬盘、CDROM和磁带机的支持。

7、Networkingoptions(网络选项)

(1)、Packetsocket(CONFIG_PACKET)[Y/m/n/]选择“y”,一些应用程序将使用Packet协议直接同网络设备通讯,而不通过内核中的其它中介协议。

(2)、Networkfirewalls(CONFIG_FIREWALL)[N/y/]选择“y”,内核将支持防火墙。

(3)、TCP/IPnetworking(CONFIG_INET)[Y/n/]选择“y”,内核将支持TCP/IP协议。

(4)TheIPXprotocol(CONFIG_IPX)[N/y/m/]选择“y”,内核将支持IPX协议。

(5)、AppletalkDDP(CONFIG_ATALK)[N/y/m/]选择“y”,内核将支持AppletalkDDP协议。

8、SCSIsupport(SCSI支持)

如果用户要使用SCSI设备,可配置相应选项。

9、Networkdevicesupport(网络设备支持)

Networkdevicesupport(CONFIG_NETDEVICES)[Y/n/]选择“y”,内核将提供对网络驱动程序的支持。

10、Ethernet(10or100Mbit)(10M或100M以太网)

在该项设置中,系统提供了许多网卡驱动程序,用户只要选择自己的网卡驱动就可以了。此外,用户还可以根据需要,在内核中加入对FDDI、PPP、SLIP和无线LAN(WirelessLAN)的支持。

11、Characterdevices(字符设备)

(1)、Virtualterminal(CONFIG_VT)[Y/n/]选择“y”,内核将支持虚拟终端。

(2)、Supportforconsoleonvirtualterminal(CONFIG_VT_CONSOLE)[Y/n/]

选择“y”,内核可将一个虚拟终端用作系统控制台。

(3)、Standard/generic(dumb)serialsupport(CONFIG_SERIAL)[Y/m/n/]

选择“y”,内核将支持串行口。

(4)、Supportforconsoleonserialport(CONFIG_SERIAL_CONSOLE)[N/y/]

选择“y”,内核可将一个串行口用作系统控制台。

12、Mice(鼠标)

PS/2mouse(aka\"auxiliarydevice\")support(CONFIG_PSMOUSE)[Y/n/]如果用户使用的是PS/2鼠标,则该选项应该选择“y”。

13、Filesystems(文件系统)

(1)、Quotasupport(CONFIG_QUOTA)[N/y/]选择“y”,内核将支持磁盘限额。

(2)、Kernelautomountersupport(CONFIG_AUTOFS_FS)[Y/m/n/]选择“y”,内核将提供对automounter的支持,使系统在启动时自动mount远程文件系统。

(3)、DOSFATfssupport(CONFIG_FAT_FS)[N/y/m/]选择“y”,内核将支持DOSFAT文件系统。

(4)、ISO9660CDROMfilesystemsupport(CONFIG_ISO9660_FS)[Y/m/n/]

选择“y”,内核将支持ISO9660CDROM文件系统。

(5)、NTFSfilesystemsupport(readonly)(CONFIG_NTFS_FS)[N/y/m/]

选择“y”,用户就可以以只读方式访问NTFS文件系统。

(6)、/procfilesystemsupport(CONFIG_PROC_FS)[Y/n/]/proc是存放Linux系统运行状态的虚拟文件系统,该项必须选择“y”。

(7)、Secondextendedfssupport(CONFIG_EXT2_FS)[Y/m/n/]EXT2是Linux的标准文件系统,该项也必须选择“y”。

14、NetworkFileSystems(网络文件系统)

(1)、NFSfilesystemsupport(CONFIG_NFS_FS)[Y/m/n/]选择“y”,内核将支持NFS文件系统。

(2)、SMBfilesystemsupport(tomountWfWsharesetc)(CONFIG_SMB_FS)

选择“y”,内核将支持SMB文件系统。

(3)、NCPfilesystemsupport(tomountNetWarevolumes)(CONFIG_NCP_FS)

选择“y”,内核将支持NCP文件系统。

15、PartitionTypes(分区类型)

该选项支持一些不太常用的分区类型,用户如果需要,在相应的选项上选择“y”即可。

16、Consoledrivers(控制台驱动)

VGAtextconsole(CONFIG_VGA_CONSOLE)[Y/n/]选择“y”,用户就可以在标准的VGA显示方式下使用Linux了。

17、Sound(声音)

Soundcardsupport(CONFIG_SOUND)[N/y/m/]选择“y”,内核就可提供对声卡的支持。

18、Kernelhacking(内核监视)

MagicSysRqkey(CONFIG_MAGIC_SYSRQ)[N/y/]选择“y”,用户就可以对系统进行部分控制。一般情况下选择“n”。

六、编译内核

(一)、建立编译时所需的从属文件

#cd/usr/src/linux

#makedep

(二)、清除内核编译的目标文件

#makeclean

(三)、编译内核

#makezImage

内核编译成功后,会在/usr/src/linux/arch/i386/boot目录中生成一个新内核的映像文件zImage。如果编译的内核很大的话,系统会提示你使用makebzImage命令来编译。这时,编译程序就会生成一个名叫bzImage的内核映像文件。

(四)、编译可加载模块

如果用户在配置内核时设置了可加载模块,则需要对这些模块进行编译,以便将来使用insmod命令进行加载。

#makemodules

#makemodelus_install

编译成功后,系统会在/lib/modules目录下生成一个2314子目录,里面存放着新内核的所有可加载模块。

七、启动新内核

(一)、将新内核和Systemmap文件拷贝到/boot目录下

#cp/usr/src/linux/arch/i386/boot/bzImage/boot/vmlinuz-2314

#cp/usr/src/linux/Systemmap/boot/Systemmap-2314

#cd/boot

#rm-fSystemmap

#ln-sSystemmap-2314Systemmap

(二)、配置/etc/liloconf文件。在该文件中加入下面几行:

default=linux-2314

image=/boot/vmlinuz-2314

label=linux-2314

root=/dev/hda1

read-only

(三)、使新配置生效

#/sbin/lilo

(四)、重新启动系统

#/sbin/reboot

新内核如果不能正常启动,用户可以在LILO:提示符下启动旧内核。然后查出故障原因,重新编译新内核即可。

1、登录NFS客户端,开始菜单->运行,输入cmd进入命令行;
2、输入netsh int ipv4 set sub int “网卡名称” netsh int ipv6 set sub int “网卡名称”其中网卡名称要换成自己计算机的网卡名称;
3、输入netsh int ipv4 add route prefix=10000/8 interface=”网卡名称”其中网卡名称要换成自己计算机的网卡名称;
4、按“确定”,重启计算机,内核参数修改完毕。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/10560014.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-09
下一篇 2023-05-09

发表评论

登录后才能评论

评论列表(0条)

保存