Samba原理和配置
Samba原理和配置
个人原创,转载请注明,否则追究法律责任。
一,原理及安装
1,Samba是在Linux和UNIX系统上实现在局域网上共享文件一种通信协议,它为局域网内的不同计算机之间提供文件等资源的共享服务。
2,Samba访问控制机制:两重限制:操作系统本身的文件属性的限制和smb的访问列表的限制。


第二栏:多少档名连结到此节点(i-node) 文件的连接数
第三栏:文件(或目录)的拥有者
第四栏:文件的所属群组
第五栏:文件的容量大小(默认单位为bytes)
第六栏:最近的修改日期
3,Samba的安装及环境搭建(硬件,软件环境)
Samba运行由两个服务组成,为smb和nmb。
安装:
yum -y install samba
service smb start
chkconfig smb on
chkconfig --list |grep smb
SMB,监听139 TCP端口,SMB是Samba 的核心启动服务,主要负责建立 Linux Samba服务器与Samba客户机之间的对话,验证用户身份并提供对文件系统的访问,

NMB服务是负责解析用的,类似与DNS实现的功能,NMB可以把Linux系统共享的工作组名称与其IP对应起来,如果NMB服务没有启动,就只能通过IP来访问共享文件,监听137和138 UDP端口。

windows端可以关闭防火墙,排除影响
关闭selinux
防火墙设置:
规划:
开启tcp的长连接
开启ssh连接22端口
开启smb连接的139端口
开启ping功能的ICMP协议
查看端口:

[root@localhost ~]# service iptables status
[root@localhost ~]# service iptables start
iptables: Applying firewall rules: [ OK ]
[root@localhost ~]# iptables -L
将默认的INPUT链的规则设置成DORP
[root@localhost ~]# iptables -P INPUT DROP
[root@localhost ~]# iptables -L -n --line-number
将多余的INPUT链的规则删掉
[root@localhost ~]# iptables -D INPUT 3
[root@localhost ~]# iptables -D INPUT 3
[root@localhost ~]# iptables -D INPUT 3
[root@localhost ~]# iptables -L -n --line-number
添加22,139端口为允许端口
[root@localhost ~]# iptables -A INPUT -p tcp --dport 22 -j ACCEPT
[root@localhost ~]# iptables -A INPUT -p tcp --dport 139 -j ACCEPT
[root@localhost ~]# iptables -L -n --line-number

保存防火墙规则:
[root@localhost ~]# service iptables save
iptables: Saving firewall rules to /etc/sysconfig/iptables:[ OK ]
检验:
[root@localhost ~]# cat /etc/sysconfig/iptables
[root@localhost ~]# yum -y install httpd
[root@localhost ~]# service httpd start
Starting httpd: httpd: Could not reliably determine the server's fully qualified domain name, using localhost.localdomain for ServerName
[ OK ]
其他机器验证:
[root@shiyan tomcat1]# ping 192.168.115.81
[root@shiyan tomcat1]# ssh 192.168.115.81
[root@shiyan tomcat1]# nc -v -w 2 192.168.115.81 -z 139
-bash: nc: command not found
[root@shiyan tomcat1]# yum -y install nc
[root@shiyan tomcat1]# nc -v -w 2 192.168.115.81 -z 139
[root@shiyan tomcat1]# nc -v -w 2 192.168.115.81 -z 80
nc: connect to 192.168.115.81 port 80 (tcp) timed out: Operation now in progress
[root@shiyan tomcat1]# nc -v -w 2 192.168.115.81 -z 22
Connection to 192.168.115.81 22 port [tcp/ssh] succeeded!
[root@shiyan tomcat1]#

二,配置
1,规划:








2,操作
添加用户:
useradd -s /sbin/nologin jsadmin
useradd -s /sbin/nologin kfadmin
useradd -s /sbin/nologin -g jsadmin zhangsan
useradd -s /sbin/nologin -g jsadmin lisi
useradd -s /sbin/nologin -g kfadmin wangwu
useradd -s /sbin/nologin -g kfadmin zhaoliu
新建共享目录
mkdir /data
cd /data
mkdir jishubu ulian
chmod -R 777 /data
chown -R ulian:ulian ulian
chown -R jishubu:jishubu jishubu
ll
vim /etc/samba/smb.conf
samba配置:
[技术部]
comment = this directory is used for ulian group ---------------------------- 描述
path = /data/jishubu ----------------------------------------------------------- 对应的工作目录路径
public = no ------------------------------------------------------------------ 无口令账号不允许访问共享资源
admin users = ulian ------------------------------------------------------------ 管理员账号
valid users = @ulian ------------------------------------------------------------ 成员账号
writable = yes ----------------------------------------------------------------- 是否可写
create mask = 0770 ----------------------------------------------------------- 成员创建文件的权限
directory mask = 0770 --------------------------------------------------------- 成员创建目录的权限
service smb restart
smbpasswd -a zhang
smbpasswd -a san
smbpasswd -a li
smbpasswd -a si
改进:
chmod -R 1777 /data 同组用户可以修改,不能删除
vim /etc/samba/smb.conf ----- 用户登录后不显示自己的家目录文件夹
注释掉【home】
Samba原理和配置的更多相关文章
- 【CentOS】samba服务器安装与配置
参考资料: http://www.cnblogs.com/mchina/archive/2012/12/18/2816717.html 1.简介 2.安装 3.配置 1.简介 Samba是一个能让Li ...
- ubuntu samba服务器多用户配置【转】
转自:http://www.2cto.com/os/201204/127043.html ubuntu samba服务器多用户配置 在/home/下有多个用户目录A.B...,现通过samba共享 ...
- MySQL主从复制的原理及配置
[http://www.jb51.net/article/50053.htm] MySQL 数据库的高可用性架构: 集群,读写分离,主备.而后面两种都是通过复制来实现的.下面将简单 ...
- MySQL的复制原理及配置
MySQL 的数据库的高可用性的架构大概有以下几种:集群,读写分离,主备.而后面两种都是通过复制来实现的.下面将简单介绍复制的原理及配置,以及一些常见的问题. 一.复制的原理 MySQL 复制基于主服 ...
- ubuntu samba共享安装 配置
参考: http://www.360doc.com/content/11/0615/12/3989678_127081905.shtml 参考: http://xfshean.blog.163.com ...
- samba安装与配置
1.安装软件包rpm -q samba samba-common samba-client cifs-utilsyum -y install samba samba-common samba-clie ...
- CentOS下Samba服务器的配置
主要用途: 在两台计算机间共享文件.打印机 安装: yum install samba 启动服务: /etc/rc.d/init.d/smb start 添加用户 (必须是系统中真实存在的用户) s ...
- Mysql中主从复制的原理、配置过程以及实际案例
Mysql中主从复制的原理.配置过程以及实际案例1.什么是主从复制?原理:主从分离,什么意思呢?我们不妨画个图看看.如图1所示: 2.准备工作:预备两台服务器,我这里使用虚拟机安装了两个Centos6 ...
- 【samba】samba 用户权限配置(转)
首先要保证你的samba安装并配置好,关于安装和配置samba请参考此文章 http://blog.csdn.net/linglongwunv/archive/2010/01/19/5212875.a ...
随机推荐
- UESTC - 1057 秋实大哥与花 线段树
题意 秋实大哥是一个儒雅之人,昼听笙歌夜醉眠,若非月下即花前. 所以秋实大哥精心照料了很多花朵.现在所有的花朵排成了一行,每朵花有一个愉悦值. 秋实大哥每天要对着某一段连续的花朵歌唱,然后这些花朵的愉 ...
- 使用stringstream对象简化类型转换
< sstream>库定义了三种类:istringstream.ostringstream和stringstream,分别用来进行流的输入.输出和输入输出操作.另外,每个类都有一个对应的宽 ...
- nyoj358 取石子(五) 斐波那契博弈
我写代码找的规律:如果这个n是斐波那契数,那么它是P态,如2,3,5,8..... 找规律的代码: #include <cstdio> #include <cmath> #in ...
- Selenium里可以自行封装与get_attribute对应的set_attribute方法
我们在做UI自动化测试的过程中,某些情况会遇到,需要操作WebElement属性的情况. 假设现在我们需要获取一个元素的title属性,我们可以先找到这个元素,然后利用get_attribute方法获 ...
- CEPH RGW 设置 user default_placement为ssd-placement,优化100KB-200KB小文件性能,使用户创建的bucket对象放置到 SSD设备的Pool上。
sudo radosgw-admin metadata get user:tuanzi > user.md.json vi user.md.json #to add ssd-placement ...
- Jpa中设置OneToMany插入报异常解决办法
在Jpa中如果设置@OneToMany,但使用的时候,如果没有赋值,会报异常出现,这时只需要实例化一个空数组即可, 但类型一定要对应: 实例如下: newField.setxxxxxList(new ...
- PHPmysqli的 预处理执行查询语句
header( 'Content-Type:text/html;charset=utf-8 '); require 'prepareSrarment.php'; $mysqli=new mysqli( ...
- VxWorks镜像简介
VxWorks镜像可分为三类: 可加载型VxWorks镜像:存储在开发机上,运行在板上RAM中 基于ROM的VxWorks镜像:存储在板上ROM,运行在板上RAM中 ROM驻留的VxWor ...
- 图像处理------泛洪填充算法(Flood Fill Algorithm) 油漆桶功能
泛洪填充算法(Flood Fill Algorithm) 泛洪填充算法又称洪水填充算法是在很多图形绘制软件中常用的填充算法,最熟悉不过就是 windows paint的油漆桶功能.算法的原理很简单,就 ...
- Caused by: org.xml.sax.SAXParseException; lineNumber: 28; columnNumber: 81;
1.错误描述 严重: Exception sending context initialized event to listener instance of class org.springframe ...