Samba 共享解决方案:微服务多机共享 `/app` 目录

Samba 共享解决方案:微服务多机共享 /app 目录

背景需求

  • 技术栈‌:Java SpringCloud + Nacos 微服务架构
  • 部署变更‌:从单机开发环境迁移至四台生产服务器
  • 核心问题 ‌:多服务器需同时读写 /app 目录
  • 选型原因‌:分布式存储改造时间不足,采用 Samba 作为临时共享方案

服务端配置(Ubuntu)

1. 安装 Samba 服务

bash 复制代码
sudo apt update && sudo apt install samba samba-common-bin -y

2. 配置共享目录

创建目录并设置权限
shell 复制代码
sudo mkdir -p /app/share  # 推荐使用系统级目录
sudo chmod -R 1777 /appa/share  # 开放读写权限
编辑 Samba 配置 (/etc/samba/smb.conf)
ini 复制代码
[SharedApp] 
comment = App Samba Share  # 描述
path = /app/share 
browseable = yes 
writable = yes  
read only = no 
guest ok = no  
force create mode = 0775 
force directory mode = 0775 
  • ‌参数说明‌:
  • SharedApp 是url后的名字对应
  • comment 描述
  • path 物理路径
  • browseable 是否可见
  • writable 可写
  • read only 是否 禁用
  • guest ok 是否禁止匿名访问
  • force create mode 文件默认权限
  • force directory mode 目录默认权限

3. 用户与权限管理

复制代码
# 创建系统用户
sudo adduser smbuser

# 设置Samba专用密码(与系统密码隔离)
sudo smbpasswd -a smbuser

# 修改目录属主
sudo chown -R smbuser:smbuser /app/share

4. 防火墙与服务重启

复制代码
sudo ufw allow samba  # 放行139/445端口
sudo systemctl restart smbd
sudo testparm  # 验证配置语法

客户端挂载(其他服务器)

1. 安装依赖工具

shell 复制代码
sudo apt install cifs-utils -y

2. 挂载共享目录

shell 复制代码
sudo mount -t cifs //smb服务器ip/SharedApp /app/share -o username=smbuser,password=emacs,vers=3.0

‌注意事项‌:

  • 生产环境建议使用密钥文件替代明文密码
  • 如需开机自动挂载,需将配置写入 /etc/fstab
  • 确保所有客户端服务器的 /app/share 目录存在

方案优缺点

优点 缺点
快速实现多机共享 单点故障风险
无需改造现有代码 网络延迟影响IO性能
权限管理灵活 不适合海量小文件场景

建议后续迁移至 MinIO 或 NFS 等分布式存储方案

相关推荐
唐僧洗头爱飘柔95274 小时前
【SpringCloud(2)】微服务注册中心:Eureka、Zookeeper;CAP分析;服务注册与服务发现;单机/集群部署Eureka;连接注册中心
spring cloud·微服务·zookeeper·eureka·服务发现·集群部署·服务注册
uesowys17 小时前
腾讯云微服务平台TSF
微服务·腾讯云
森林-17 小时前
Spring Cloud Netflix Ribbon:微服务的客户端负载均衡利器
spring cloud·微服务·ribbon·负载均衡
虫师c17 小时前
云原生微服务:Kubernetes+Istio 魔法学院实战指南
微服务·云原生·kubernetes·istio·服务网格
稚辉君.MCA_P8_Java19 小时前
Git 基础 - 查看提交历史
spring boot·git·微服务·云原生·kubernetes
森林-2 天前
Spring Cloud Netflix Eureka:从微服务基础到高可用集群实战
微服务·云原生·eureka·springcloud
月夕·花晨2 天前
Gateway-过滤器
java·分布式·spring·spring cloud·微服务·gateway·sentinel
罗亚方舟2 天前
微服务故障排查
微服务·云原生·架构
Tadas-Gao3 天前
微服务可观测性的“1-3-5”理想:从理论到实践的故障恢复体系
java·开发语言·微服务·云原生·架构·系统架构·可观测
Vahala0623-孔勇3 天前
微服务接口性能优化终极指南:从HTTP/2多路复用到gRPC选型,序列化性能一网打尽
http·微服务·性能优化