NFS(Network File System)是网络文件系统,是linux系统中常用的分布式文件共享方案,适用于多服务器环境下的数据共享与协同工作,本文将详细阐述NFS的配置过程,结合实际操作步骤、最佳实践及真实案例,帮助读者掌握NFS配置与优化技巧。
NFS基础与配置目标
NFS通过TCP/IP协议实现文件系统的网络共享,允许客户端挂载服务器端的目录,如同本地文件系统,其核心配置包括服务器端的共享目录定义、客户端的挂载设置及权限管理,配置目标是在保证数据安全的前提下,实现多客户端对共享文件的快速读写访问,适用于数据库镜像、应用服务器数据共享等场景。
环境准备与基础配置
操作系统要求
NFS主要应用于Linux系统,常见发行版包括CentOS 7+/8、Ubuntu 18.04+/20.04+等,本文以CentOS 8为例说明,Ubuntu配置逻辑类似。
安装NFS服务(服务器端)
在CentOS 8中,通过yum包管理器安装NFS相关组件:
# 更新软件源sudo dnf update -y# 安装NFS服务、客户端及工具sudo dnf install nfs-utils rpcbind -y# 安装防火墙管理工具(可选,用于配置防火墙规则)sudo dnf install firewalld -y
启动与启用服务
安装完成后,启动NFS服务并设置为开机自启:
# 启动NFS服务sudo systemctl start nfs-server# 启动RPC绑定服务(NFS依赖RPC)sudo systemctl start rpcbind# 开机自启sudo systemctl enable nfs-serversudo systemctl enable rpcbind
服务器端配置
服务器端的配置核心是定义共享目录及访问权限,通过
/etc/exports
文件完成。
创建共享目录
在服务器上创建用于共享的目录(如
/export/share
),并设置初始权限:
# 创建目录sudo mkdir -p /export/share# 设置目录权限(仅示例,实际需根据业务调整)sudo chmod 755 /export/sharesudo chown nobody:nobody /export/share
配置共享文件(核心步骤)
编辑
/etc/exports
文件,定义共享目录的访问规则,文件格式为:
共享目录路径 客户端列表(选项)
示例配置(允许所有客户端读写该目录):
# 编辑文件sudo nano /etc/exports示例/export/share *(rw,sync,no_subtree_check)
设置防火墙规则(CentOS 8)
启用防火墙并允许NFS相关端口(2049)及RPC端口(111):
# 开启防火墙sudo systemctl start firewalldsudo systemctl enable firewalld# 添加NFS端口sudo firewall-cmd --add-service=nfs --permanentsudo firewall-cmd --add-service=rpc-bind --permanentsudo firewall-cmd --add-service=mountd --permanentsudo firewall-cmd --reload
重启服务
完成配置后重启NFS服务以应用更改:
sudo systemctl restart nfs-server
客户端配置
客户端需安装NFS工具并挂载服务器端的共享目录。
安装客户端工具
在客户端(如Ubuntu服务器)安装:
sudo apt updatesudo apt install nfs-common -y
挂载共享目录
使用命令将服务器端共享目录挂载到客户端本地目录(如
/mnt/nfs_share
):
# 基础挂载sudo mount -t nfs server_ip:/export/share /mnt/nfs_share# 设置自动挂载(开机启动)echo "server_ip:/export/share /mnt/nfs_share nfs defaults 0 0" | sudo tee -a /etc/fstab
验证挂载
检查挂载状态及文件内容:
# 查看挂载点df -h /mnt/nfs_share# 测试文件操作sudo touch /mnt/nfs_share/test_filesudo ls /mnt/nfs_share
酷番云 客户案例:分布式存储场景下的NFS配置实践
案例背景 :某大型电商企业采用酷番云分布式存储服务,需将商品图片目录共享给多台应用服务器(如商品详情页、订单系统),通过NFS实现跨服务器数据同步,提升图片访问效率。
场景配置
配置过程
效果
通过NFS共享,商品图片目录被多台应用服务器实时访问,避免了传统文件共享方式(如Samba)的性能瓶颈,图片加载速度提升约30%,同时降低了服务器间数据同步成本。
性能优化与最佳实践
调整挂载选项
在客户端挂载时添加性能优化参数:
sudo mount -t nfs server_ip:/export/share /mnt/nfs_share -o hard,rsize=65536,wrsize=65536
使用软连接优化
在客户端挂载点创建软连接,避免重复挂载:
sudo ln -s /mnt/nfs_share /var/www/html/images
安全增强
常见问题与解决方案
问题1:客户端无法挂载,提示“connection timed out”
原因 :网络连接问题或服务器防火墙未开放NFS端口。 解决 :
问题2:性能慢,文件读写延迟高
原因 :挂载选项设置不当或服务器资源不足。 解决 :
深度问答
问题1:如何优化NFS在多客户端并发环境下的性能?
解答 :
问题2:NFS与SMB/CIFS相比,在文件共享方面有什么优势?
解答 :
通过以上步骤,可完成NFS从环境准备到配置优化的全过程,结合实际案例与最佳实践,有效解决多服务器环境下的文件共享需求。
404页面该怎么做?
# Some examples:
#ErrorDocument 500 The server made a boo boo.
#ErrorDocument 404 / 不是Error。html
#ErrorDocument 404 /cgi-bin/missing_
#ErrorDocument 402新建一个文件。注意是文件,而不是。这两个还是有点差距的
将建好的文件和文件上传到网站的根目录下面
谁有侠盗飞车最高版本的,能给我个地址吗,我现在很想要,要能玩的,谢谢,我给高分~~~
[br][br][color=#][b]-=-=-=-=- 以下内容由 [i]xali[/i] 在 [i]2006年01月08日 11:25am[/i] 时添加 -=-=-=-=-[/b][/color]这次发贴我是精心准备的,望吧主能够加精,谢谢! 1.侠盗猎车-罪恶都市完全版 因为下载的人太多,大家进入后选个合适的下载地址:下载地址1在河南,可容纳300人;下载地址2在上海,是我新买的,可容纳100人。 注意:两台服务器均是网通线路,南方用户速度上可能要慢些 下载地址:说明]下载下来的是WinRAR的压缩包,有252MB,解压缩并且完全安装后有1.27GB,所以你不必担心没有声音或者缺少东西什么的。 如果你没有解压缩的软件,去这里侠盗猎车-罪恶都市 作弊码激活器 下载地址:说明]可以设置F1,F2等键一键激活作弊码,非常方便。 设置完后打开软件的激活状态:Enable 3.侠盗猎车-罪恶都市 多项属性修改器 下载地址:说明]无限金钱,无限子弹,无限装甲,冻结时间等等 4.侠盗猎车-罪恶都市 全攻略 阅读地址:说明]这个嘛……大家看名字就知道了 5.侠盗猎车-罪恶都市 作弊码 阅读地址:说明]这个也没什么好解释的 6.侠盗猎车-罪恶都市 100%暴机存档 下载及说明地址:说明]200甲,200血,3保镖,太爽了阿~ 怎么安装里面都写着 因为有两台服务器,空间足够,所以我这里还有一些经典的PC游戏,感兴趣的可以来看看游戏更新最后:做人要厚道,看贴一定要回,下完再顶也可以!
docker commit和docker file的区别
制作镜像的方式主要有两种:通过docker commit 制作镜像通过docker build 制作镜像这两种方式都是通过改进已有的镜像来达到自己的目的。
制作基础镜像,会在另外一篇文章“从零开始制作基础镜像”中介绍。
docker commitdocker commit 是往版本控制系统里提交一次变更。
使用这种方式制作镜像,本质上是运行一个基础镜像,然后在基础镜像上进行软件安装和修改。
最后再将改动提交到版本系统中。
选择基础镜像基础镜像的选择要结合自己的需求。
可以选择已有的应用镜像来改造,也可以选择Ubuntu,Debian,OpenSuse这类基础系统镜像我们以ubuntu为例子来说明步骤1:运行ubuntu 镜像docker run -i -t ubuntu /bin/bash步骤2:安装软件并修改软件配置, 比如:安装apache2apt-get -yqq updateapt-get -y install apache2安装完成后,对apache2进行配置和修改步骤3:退出docker并保存镜像使用“exit”命令退出容器运行docker comit 命令, 进行保存docker commit ae46 own-apache2docker commit 命令参数说明命令格式docker commit [OPTIONS] container [REPOSITORY[:TAG]]OPTIONS:-a, --author=提交的镜像作者-c, --change=[]Apply Dockerfile instruction to the created image, 没用过-m, --message= 提交时的说明文字-p, --pause=true在commit时,将container 暂停CONTAINER:可以使用container 的名字或者IDREPOSITORY指定镜像仓库,上述例子中,指定的是本地存储可以指定远程镜像仓库,如docker hub。
也可自建仓库来存放imageTAG:镜像TAGdocker build使用docker build创建镜像需要编写Dockerfile.步骤:编写自己的Dcokerfile运行docker build 命令打包镜像仍然以apache打包为例子。
以下是Dockerfile的例子FROM ubuntu:latestMAINTAINER sky#Add 163 mirror for aptADD /etc/apt/ /root/ DEBIAN_frontend noninteractive# PackagesRUN rm -rf /var/lib/apt/listsRUN apt-get update -q --fix-missingRUN apt-get -y upgrade#ubuntu wwwRUN apt-get install -y apache2 curl libapache2-mod-php5 php5-curl php5-gd php5-mysql rsync mysql-client -qqRUN apt-get autocleanRUN rm -rf /var/lib/apt/lists/*# Setup environmnt for apaches init scriptENV APACHE_CONFDIR /etc/apache2ENV APACHE_ENVVARS $APACHE_CONFDIR/envvarsENV APACHE_RUN_USER www-dataENV APACHE_RUN_GROUP www-dataENV APACHE_RUN_DIR /var/run/apache2ENV APACHE_PID_FILE $APACHE_RUN_DIR/ APACHE_LOCK_DIR /var/lock/apache2ENV APACHE_LOG_DIR /var/log/apache2ENV LANG CRUN mkdir -p $APACHE_RUN_DIR $APACHE_LOCK_DIR $APACHE_LOG_DIRRUN find $APACHE_CONFDIR -type f -exec sed -ri \s!^(\s*CustomLog)\s+\S+!\1 /proc/self/fd/1!g; \s!^(\s*ErrorLog)\s+\S+!\1 /proc/self/fd/2!g; \ {} ;EXPOSE 80CMD [apache2, -DFOREGROUND]编辑完成后,在与Dockerfile同一目录下运行docker build 命令docker build -t apache-img .如果没有命令出错,docker build会持续运行直到镜像创建完成而创建的过程本质上是运行一个镜像,然后在镜像中按序执行在Dockerfile中的命令,直到执行结束。
如果中间有命令执行失败,镜像创建会停止。
这时就需要看log,并修改Dockerfile,然后再次执行docker build注:两种镜像创建方式的对比:docker commitdocker build难度相对容易,适合新手和对Linux不熟悉的用户相对难,要求有一定的linux和脚本基础知识文档化文档化在通过其他文件来实现Dockerfile本身就是比较好的文档,可读和可理解性比较强。
也可配合其他文档带来详细说明升级,维护后续升级和维护麻烦,需要再次运行镜像并对内部软件进行升级或者安装新软件增加特性后续升级和维护会相对简单,可以直接在dockerfile中更改并增加新特性具体选择哪种方式来制作镜像需要结合实际情况来选择Dockerfile 关键字详解FROMFROM用来指定基础包。
在上面的例子中,基础包用的是ubuntu。
MAINTAINER镜像作者信息,或者维护人员信息ADD将文件拷贝到Container内文件系统对应的路径格式 ADD














发表评论