当前位置: 首页 > article >正文

AlmaLinux8.10安装samba实现与Windows文件共享

AlmaLinux8.10安装samba实现与Windows文件共享

步骤:

  1. 安装samba, 并启用 smb , nmb 服务

    • 切换阿里源(可选)
    sudo sed -e 's|^mirrorlist=|#mirrorlist=|g' \
      -e 's|^# baseurl=https://repo.almalinux.org|baseurl=https://mirrors.aliyun.com|g' \
      -i.bak \
      /etc/yum.repos.d/almalinux*.repo
    sudo dnf makecache  
    
    1. 安装 samba
    sudo dnf update
    sudo dnf install samba -y
    
    1. 启用启动 smb, nmb
    sudo systemctl enable smb nmb
    sudo systemctl start smb nmb
    

    在Ubuntu24.04下,smb和smbd通用, nmb和nmbd通用, CentOS,Alma,Rocky 只能用smb和nmb, Ubuntu18.04只能用nmbd和smbd

  2. 设置 /etc/samba/smb.conf

    sudo vi /etc/samba/smb.conf
    

    2.1 将 [global]workgrop 设为 workgroup

    [global]
    	workgroup = workgroup
       	security = user
    

    不替换, 保留为: workgroup = SAMBA 也能连通

    2.2. 设置共享目录, 这里设置了根目录, 在底部加入

    [root]
    path=/
    workgroup=workgroup
    public=yes
    writeable = yes
    available = yes
    browseable = yes
    guest ok = yes
        forceuser = root
        forcegroup = root
        create mask = 0775
        directory mask = 0775
    

    开头可以有空格或制表符,也可以没有, 等号之间可以有空格,也可以没有
    开头单 tab 版

    [RootFolder]
    	path = /
    	comment = 根文件夹
    	public = yes
    	read only = no
    	writable = yes
    	available = yes
    	browseable = yes
    	guest ok = yes
    	forceuser = root
    	forcegroup = root
    	create mask = 0777
    	directory mask = 0777
    
    [RootHomeFolder]
    	path = /root
    	comment = root用户文件夹
    	public = yes
    	read only = no
    	writable = yes
    	available = yes
    	browseable = yes
    	guest ok = yes
    	forceuser = root
    	forcegroup = root
    	create mask = 0777
    	directory mask = 0777
    
    

    开头四空格版

    ### 四空格版
    [RootFolder]
        path = /
        comment = 根文件夹
        public = yes
        read only = no
        writable = yes
        available = yes
        browseable = yes
        guest ok = yes
        forceuser = root
        forcegroup = root
        create mask = 0777
        directory mask = 0777
    
    [RootHomeFolder]
        path = /root
        comment = root用户文件夹
        public = yes
        read only = no
        writable = yes
        available = yes
        browseable = yes
        guest ok = yes
        forceuser = root
        forcegroup = root
        create mask = 0777
        directory mask = 0777
    
    
  3. 将系统用户添加到samba的用户,并单独设置samba的密码,独立于系统密码

    sudo smbpasswd -a root
    

    查看samba的用户

    sudo pdbedit -L
    
  4. 重启 smb, nmb 服务

    sudo systemctl restart smb nmb smb nmb
    
  5. 关闭禁用防火墙或者开启端口

    • 关闭禁用防火墙

      sudo systemctl stop firewalld ; sudo systemctl disable firewalld
      
    • 或者开启端口
      查看firewall默认的zone是不是public

      sudo firewall-cmd --get-default-zone
      
      • 开放445端口的tcp

        sudo firewall-cmd --zone=public --add-port=445/tcp --permanent
        sudo firewall-cmd --reload
        
      • 开放139端口的tcp

        sudo firewall-cmd --zone=public --add-port=139/tcp --permanent
        sudo firewall-cmd --reload
        
      • 开放138端口的udp

        sudo firewall-cmd --zone=public --add-port=138/udp --permanent
        sudo firewall-cmd --reload
        
      • 开放137端口udp

        sudo firewall-cmd --zone=public --add-port=137/udp --permanent
        sudo firewall-cmd --reload
        
      • 开放137,138的udp, 139,445的tcp

        sudo firewall-cmd --zone=public --add-port=137/udp --permanent
        sudo firewall-cmd --zone=public --add-port=138/udp --permanent
        sudo firewall-cmd --zone=public --add-port=139/tcp --permanent
        sudo firewall-cmd --zone=public --add-port=445/tcp --permanent
        sudo firewall-cmd --reload
        sudo systemctl restart firewalld
        
    • 查看开放的端口 firewall-cmd --list-ports

      sudo firewall-cmd --list-ports
      
      • 查看 public 的 zone 开放的端口 firewall-cmd --list-ports --zone=public
        sudo firewall-cmd --list-ports --zone=public
        
        如何查看firewall开放了哪些端口 笔记241129
  6. 在Windows登录
    在"文件资源管理器"输入 \\IPv4 或控制台输入 explorer \\IPv4

    如果用 IPv6
    Explorer文件资源管理器用 IPv6 访问局域网网络共享网上邻居 , 要将 ipv6 的地址格式进行转换:

    1. 将所有 :(冒号) 替换成 -(横杆,减号,负号)

    2. 在地址末尾加上 .ipv6-literal.net

      .ipv6-literal.net
      

      例如:

      fc00::102:2441:f
      对应转换为👇
      \\fc00--102-2441-f.ipv6-literal.net
      
  7. 第一次登录可能慢,甚至要多登录几次, 尝试重启AlmaLinux
    登录成功后发现不能访问/root文件夹和/home下的用户文件夹, 原因是SELinux在作怪,
    可以执行sudo setenforce 0,但重启会失效

    sudo setenforce 0  # 设置为Permissive模式 重启失效
    

    可用getenforce命令查看SELinux当前的执行模式。SELinux有三种执行模式:enforcing(强制模式)、permissive(宽容模式)和disabled(禁用模式)。

    sudo getenforce
    

    想要永久生效
    可修改编辑/etc/selinux/config文件,将SELINUX=enforcing更改为SELINUX=permissive , 或者 SELINUX=disabled, 重启生效
    用vi编辑器修改/etc/selinux/config

    sudo vi /etc/selinux/config
    

    用sed命令修改
    二选一

    • 设置 SELINUX=permissive
      ###  备份
      tempUri=/etc/selinux/config ;    sudo cp -a  $tempUri  $tempUri.$(date +%0y%0m%0d%0H%0M%0Sns%0N).bak
      ###  修改
      sudo sed -ie 's(^\s*SELINUX\s*=\s*enforcing$(SELINUX=permissive(g' /etc/selinux/config
      
    • 设置 SELINUX=disabled
      ###  备份
      tempUri=/etc/selinux/config ;    sudo cp -a  $tempUri  $tempUri.$(date +%0y%0m%0d%0H%0M%0Sns%0N).bak
      ###  修改
      sudo sed -ie 's!^\s*SELINUX\s*=\s*enforcing$!SELINUX=disabled!g' /etc/selinux/config
      

    查看/etc/selinux/config

    sudo cat /etc/selinux/config
    

    重启

    sudo systemctl reboot
    

    SELinux的 getenforce setenforce 配置文件/etc/selinux/config的 SELINUX和SELINUXTYPE

一气呵成

#!/bin/bash

sudo yum install samba -y

sudo sed -ri 's/workgroup\s*=.*$/workgroup=WORKGROUP/g' /etc/samba/smb.conf

echo '


[RootFolder]
	path = /
	comment = 根文件夹
	public = yes
	read only = no
	writable = yes
	available = yes
	browseable = yes
	guest ok = yes
	forceuser = root
	#forcegroup = root
	create mask = 0777
	directory mask = 0777

[RootHomeFolder]
	path = /root
	comment = root用户文件夹
	public = yes
	read only = no
	writable = yes
	available = yes
	browseable = yes
	guest ok = yes
	forceuser = root
	#forcegroup = root
	create mask = 0777
	directory mask = 0777


'  >>  /etc/samba/smb.conf

sudo systemctl enable --now smb nmb


sudo firewall-cmd --zone=public --add-port=445/tcp --permanent
sudo firewall-cmd --reload



sudo setenforce 0  # 设置为Permissive模式 重启失效
###  备份
tempUri=/etc/selinux/config ;    sudo cp -a  $tempUri  $tempUri.$(date +%0y%0m%0d%0H%0M%0Sns%0N).bak
###  修改
sudo sed -ie 's(^\s*SELINUX\s*=\s*enforcing$(SELINUX=permissive(g' /etc/selinux/config


sudo smbpasswd -a root



http://www.kler.cn/a/420958.html

相关文章:

  • 计算S=1!+2!+3!+…+N!的值:JAVA
  • 【NLP高频面题 - LLM架构篇】旋转位置编码RoPE相对正弦位置编码有哪些优势?
  • qt QGraphicsScale详解
  • 故障诊断 | Transformer-LSTM组合模型的故障诊断(Matlab)
  • 深入傅里叶级数与傅里叶变换:从基础到应用
  • 使用Python和OpenCV自动检测并去除图像中的字幕
  • 获取联通光猫的管理员密码
  • 【AI日记】24.12.03 kaggle 比赛 Titanic-6
  • SVN客户端及语言包免费下载 无需积分
  • 计算机网络八股整理(四)
  • 【SpringBoot】SpringBoot优雅停机机制
  • Springboot(五十)SpringBoot3集成sentinel并连接sentinel-dashboard
  • 【大数据学习 | 面经】Spark3.x对比2.x有哪些优点
  • 通过搭建安消一体化管理体系,高校实现应急中心数字化转型升级新动能
  • 树和二叉树(概念 结构)
  • 手机租赁系统开发全攻略 创新服务助力企业智能转型
  • 库存管理如何做到“先进先出”?
  • delphi 12 idhttpsever(S)+idhttp(C) 实现简单的JSON API服务
  • Navicat连接SQL Server
  • 初始Python篇(9)—— 函数
  • Creating Server TCP listening socket *:6379: bind: No error
  • Logistic Regression(逻辑回归)、Maximum Likelihood Estimatio(最大似然估计)
  • 经典图论之道路与航线
  • 【阿来来gis规划师工具箱说明书】b03要素信息写入字段
  • Scala的正则表达式
  • 便携微型充气泵方案开发设计