百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

星际魔盒系列之局域网文件共享篇samba、nfs、tftp

nanshan 2025-04-24 05:59 13 浏览 0 评论

本未打算写该篇,文件共享是个很简单的功能,也有很多web应用也集成了该功能,但是还有一些小伙伴不了解,工具嘛,要灵活掌握为已所用,所以又拎出来单独再讲一下.

文件共享的方法有很多,如ftp、samba、nfs、tftp....这里介绍下比较常见的

一、samba文件共享服务器

Samba是在Linux和UNIX系统上实现SMB协议的一个免费软件,由服务器及客户端程序构成。常用于linux与windows之间的共享。

A.安装samba

apt install -y samba

B.配置samba

cat >>/etc/samba/smb.conf << EOF

[NAS2]

comment = NAS2

path = /mnt/hdd1/

writable = yes

EOF

C.创建用户密码

smbpasswd -a root

输入你的共享访问密码

D.重启SMB服务,完成配置

service smbd restart

E.windows电脑访问共享

开始--运行 输入 \\samba服务器IP 输入samba用户名及密码即可访问

F.移动终端访问samba服务

IOS与android系统可以安装应用 es文件浏览器

在ES文件浏览器设置---网络---局域网,新建

服务器 填写玩客云IP地址

用户名 填写设置的共享账户名

密码 填写共享访问密码

G、WIN10共享访问错误解决办法:

错误提示:你不能访问此共享文件夹,因为你组织的安全策略阻止未经身份验证的来宾访问,这些策略可帮助保护你的电脑免受网络上不安全设备或者恶意设备的威胁

开始--运行--gpedit.msc--计算机配置--管理模板--网络--Lanman工作站

双击右窗口内“启用不安全的来宾登录” --改为“已启用” 确定即可解决!

详细samba安装说明见

玩客云系列7之debian安装samba共享文件服务器

二、NFS文件共享服务

全称Network File Service,常用于linux系统间的文件共享,NFS客户端可以像访问本地文件一样访问远端NFS服务器上的文件。

A.安装

服务器端nfs-kernel-server 客户端nfs-common

apt install -y nfs-kernel-server nfs-common

B.配置

服务器共享目录配置

cat >>/etc/exports << EOF
#允许单机访问/mnt/hdd1/nfs目录,且授于读写权限
/mnt/hdd1/nfs 192.168.2.230(rw,sync,no_subtree_check)
#允许局域网访问/mnt/hdd1/nfs目录,且授于读写等权限
/mnt/hdd1/nfs 192.168.2.0/255.255.255.0(rw,sync,no_subtree_check)
/mnt/hdd1/nfs 192.168.2.0/24(rw,sync,no_subtree_check)
EOF

常用命令

exportfs [-adfhioruvs] [host:/path]

exportfs -v #查看所有共享目录

exportfs -rv #使配置生效

exportfs -au #取消所有共享目录

C.重启NFS服务

service nfs-kernel-server restart

D.客户机挂载

mount ip:/mnt/hdd1/nfs /nfs /本地挂载点

E.常见参数

ro:共享目录只读;
rw:共享目录可读可写
sync:同步,将数据同步写入内存缓冲区与磁盘中,效率低,但可以保证数据的一致性;
async:异步,将数据先保存在内存缓冲区中,必要时才写入磁盘,效率高,但有丢失数据的风险;
wdelay(默认):如果有多个客户端要对同一个共享目录进行写操作,则将这些操作集中执行。对有很多小的IO写操作时,使用该选项可以有效地提高效率;
no_wdelay:如果有多个客户端要对同一个共享目录进行写操作则立即写入。当设置了async选项时,no_wdelay选项无效,应与sync配合使用;
root_squash(默认):将来访的root用户映射为匿名用户或用户组;
no_root_squash:来访的root用户保持root帐号权限;
all_squash:所有访问用户都映射为匿名用户或用户组;
no_all_squash(默认):访问用户先与本机用户匹配,匹配失败后再映射为匿名用户或用户组;
anonuid=<UID>:指定匿名访问用户的本地用户UID,默认为nfsnobody(65534);
anongid=<GID>:指定匿名访问用户的本地用户组GID,默认为nfsnobody(65534);
secure(默认):限制客户端只能从小于1024的tcp/ip端口连接服务器;
insecure:允许客户端从大于1024的tcp/ip端口连接服务器;
subtree_check :若输出目录是一个子目录,则nfs服务器将检查其父目录的权限;
no_subtree_check(默认) :即使输出目录是一个子目录,nfs服务器也不检查其父目录的权限,这样可以提高效率;
hide:共享一个目录时,不共享该目录的子目录;
no_hide:共享子目录;

F.卸载nfs软件包

apt autoremove -y nfs-kernel-server nfs-common

apt autopurge -y nfs-kernel-server nfs-common

三、TFTP文件共享

全称Trivial File Transfer Protocol,用途广泛,常用于嵌入式系统从服务器上下载文件升级。

A.安装

服务器端tftpd-hpa 客户端tftp-hpa

apt install -y tftp-hpa tftpd-hpa

B.创建TFTP共享目录及配置

mkdir -p /mnt/hdd1/tftp #创建用于TFTP共享的服务器目录

chmod -Rf 777 /mnt/hdd1/tftp #授权读写执行权限

修改/etc/default/tftpd-hpa配置文件中TFTP_DIRECTORY="/srv/tftp"为你的TFTP共享目录

C.重启服务

service tftpd-hpa restart

D.使用

例:连接到远程TFTP服务器192.168.2.11上下载123.txt ,上传456.txt

tftp 192.168.2.11

get 123.txt

put 456.txt

E.常见参数

connect:连接到远程tftp服务器
mode:文件传输模式
put:上传文件
get:下载文件
quit:退出
verbose:显示详细的处理信息
tarce:显示包路径
status:显示当前状态信息
binary:二进制传输模式
ascii:ascii传送模式
rexmt:设置包传输的超时时间
timeout:设置重传的超时时间
help:帮助信息
?:帮助信息

D.卸载tftp服务器软件包

apt autoremove -y tftp-hpa tftpd-hpa

apt autopurge -y tftp-hpa tftpd-hpa

至此,常见的linux下文件共享方法就结束了,欢迎小伙伴们交流!

相关推荐

0722-6.2.0-如何在RedHat7.2使用rpm安装CDH(无CM)

文档编写目的在前面的文档中,介绍了在有CM和无CM两种情况下使用rpm方式安装CDH5.10.0,本文档将介绍如何在无CM的情况下使用rpm方式安装CDH6.2.0,与之前安装C5进行对比。环境介绍:...

ARM64 平台基于 openEuler + iSula 环境部署 Kubernetes

为什么要在arm64平台上部署Kubernetes,而且还是鲲鹏920的架构。说来话长。。。此处省略5000字。介绍下系统信息;o架构:鲲鹏920(Kunpeng920)oOS:ope...

生产环境starrocks 3.1存算一体集群部署

集群规划FE:节点主要负责元数据管理、客户端连接管理、查询计划和查询调度。>3节点。BE:节点负责数据存储和SQL执行。>3节点。CN:无存储功能能的BE。环境准备CPU检查JDK...

在CentOS上添加swap虚拟内存并设置优先级

现如今很多云服务器都会自己配置好虚拟内存,当然也有很多没有配置虚拟内存的,虚拟内存可以让我们的低配服务器使用更多的内存,可以减少很多硬件成本,比如我们运行很多服务的时候,内存常常会满,当配置了虚拟内存...

国产深度(deepin)操作系统优化指南

1.升级内核随着deepin版本的更新,会自动升级系统内核,但是我们依旧可以通过命令行手动升级内核,以获取更好的性能和更多的硬件支持。具体操作:-添加PPAs使用以下命令添加PPAs:```...

postgresql-15.4 多节点主从(读写分离)

1、下载软件[root@TX-CN-PostgreSQL01-252software]#wgethttps://ftp.postgresql.org/pub/source/v15.4/postg...

Docker 容器 Java 服务内存与 GC 优化实施方案

一、设置Docker容器内存限制(生产环境建议)1.查看宿主机可用内存bashfree-h#示例输出(假设宿主机剩余16GB可用内存)#Mem:64G...

虚拟内存设置、解决linux内存不够问题

虚拟内存设置(解决linux内存不够情况)背景介绍  Memory指机器物理内存,读写速度低于CPU一个量级,但是高于磁盘不止一个量级。所以,程序和数据如果在内存的话,会有非常快的读写速度。但是,内存...

Elasticsearch性能调优(5):服务器配置选择

在选择elasticsearch服务器时,要尽可能地选择与当前业务量相匹配的服务器。如果服务器配置太低,则意味着需要更多的节点来满足需求,一个集群的节点太多时会增加集群管理的成本。如果服务器配置太高,...

Es如何落地

一、配置准备节点类型CPU内存硬盘网络机器数操作系统data节点16C64G2000G本地SSD所有es同一可用区3(ecs)Centos7master节点2C8G200G云SSD所有es同一可用区...

针对Linux内存管理知识学习总结

现在的服务器大部分都是运行在Linux上面的,所以,作为一个程序员有必要简单地了解一下系统是如何运行的。对于内存部分需要知道:地址映射内存管理的方式缺页异常先来看一些基本的知识,在进程看来,内存分为内...

MySQL进阶之性能优化

概述MySQL的性能优化,包括了服务器硬件优化、操作系统的优化、MySQL数据库配置优化、数据库表设计的优化、SQL语句优化等5个方面的优化。在进行优化之前,需要先掌握性能分析的思路和方法,找出问题,...

Linux Cgroups(Control Groups)原理

LinuxCgroups(ControlGroups)是内核提供的资源分配、限制和监控机制,通过层级化进程分组实现资源的精细化控制。以下从核心原理、操作示例和版本演进三方面详细分析:一、核心原理与...

linux 常用性能优化参数及理解

1.优化内核相关参数配置文件/etc/sysctl.conf配置方法直接将参数添加进文件每条一行.sysctl-a可以查看默认配置sysctl-p执行并检测是否有错误例如设置错了参数:[roo...

如何在 Linux 中使用 Sysctl 命令?

sysctl是一个用于配置和查询Linux内核参数的命令行工具。它通过与/proc/sys虚拟文件系统交互,允许用户在运行时动态修改内核参数。这些参数控制着系统的各种行为,包括网络设置、文件...

取消回复欢迎 发表评论: