一、文件权限

1.理解文件权限及其分配

2.掌握查看文件和目录的权限

3.掌握权限文字表示法和数值表示法

4.学会使用chmod命令设置权限

5.学会使用chown命令修改属主和组

linux文件能不能被执行完全看属性,与文件名一点关系都没有,在windows下能被执行的文件扩展名通常.com .exe .bat等,

而在linux下,只要权限中有x的话,就代表这个文件能被执行。

但是如果是其他软件的编译器去执行文件的时候是必须有相应的后缀名才能执行,如用javac去编译文件它只识别.java文件。

文件所有者、所在组和其它组

在linux中的每个用户必需属于一个组,不能独立于组外。在linux中每个文件有所有者、所在组、其它组的概念。

(1)所有者

一般为文件的创建者,谁创建了该文件,就是天然的成为该文件的所有者。

用[ls -ahl]命令可以看到文件的所有者

你也可以用[chown 用户名 文件名]来修改文件的所有者

(2)所在组

当某个用户创建了一个文件后,这个文件的所在组就是该用户所在的组。

用[ls -ahl]命令可以看到文件的所有组。

你可以通过[chgrp 组名 文件名]来修改文件所在的组

(3)其它组

除开文件的所有者和所在组的用户外,系统的其它用户都是文件的其它组。

(4)改变用户所在的组

在添加用户时,可以指定将该用户添加到哪个组中,同样的用root的管理权限可以改变某个用户所在的组:

usermod -g 组名 用户名

你可以用

usermod -d 目录名 用户名 改变该用户登陆的初始目录

如何在linux中添加组

需要用root用户来添加,普通用户无法进行用户和组的添加

添加组命令:groupadd 组名

查看linux中所有组的信息

命令:vi /etc/group

查看命令:cat /etc/group

组名:x:组ID号:

创建用户,并同时指定将该用户分配到指定组。

命令:useradd -g 组名 用户名

查看linux中所有用户信息

可编辑查看命令:vi /etc/passwd

查看命令:cat /etc/passwd

查看详细信息:ls -l  fileName(LInux标准)或者ll fileName

-rw-r--r--  分别表示对当前用户可读可写、对当前用户组只可读、对其他用户只可读。这是默认权限。

使用chmod命令设置权限

用数字表示可以同时处理三组权限,而使用字符则只能一个一个修改。chmod 777 fileName  可以将所有权限打开。

使用chown命令修改属主和组

chown root:root test/

SUID:

[xiangkejin@localhost tmp]$ ll /usr/bin/passwd
-rwsr-xr-x. 1 root root 27832 6月 10 2014 /usr/bin/passwd

passwd的拥有者是root,且拥有者权限里面本应是x的那一列显示的是s,这说明这个命令具有SUID权限

以普通用户执行这个命令时,当系统生成对应的进程后,这个进程就拥有了/usr/bin/passwd文件拥有者root的权限,只是借助,如果改成rwx普通用户就没法执行。

SGID:

新建用户:useradd user

创建一个组:groupadd share 

添加用户到组:

usermod -G share user
这样做会使你离开其他用户组,仅仅做为用户组 share 的成员。
应该加上 -a 选项:
usermod -a -G share user
-a 代表 append, 也就是将自己添加到用户组 share, 而不必离开原来到用户组。

更改文件目录的组:chgrp file  share/

现在账号user新建一个文件,新建文件的拥有者和用户组都会是user!重要的是其他用户都无法访问这个文件!现在我们的需求是让属于同一组中的用户都能访问修改这个文件。
所以我们需要给这个目录加入SGID权限,之后任意一个用户创建的文件,文件用户组都会是这个目录的用户组。

chmod 770  share/ 更改权限设置

SBIT:

drwxrwxrwt. 16 root root 4096 11月 22 19:52 tmp

当给一个目录设置了SBIT权限,当用户对目录拥有wx权限时,用户在该目录创建的文件或目录,只有自己与root才可以删除。

查看特殊权限的方法就是普通的ls命令:
 SUID会在所属用户权限本应是x的地方显示s
 SGID会在所属用户组权限本应是x的地方显示s
 SBIT在其它用户权限本应是x的地方显示t

 

二、Linux系统的查找

which查找文件、whereis查找指定文件、locate查找、find查找、find查找实例

which只能查找到可执行文件,并且只能在根据用户环境变量信息到指定路径下查找。

查看环境变量设置 env

vim  /root/.bash_profile修改环境变量

whereis是查找自己的数据库,数据是提前写到数据库中。帮助文档,配置文件这些。

locate查找:模糊查找,找到所有相关信息。

find查找:查找较慢,查找硬盘。

按时间查找:

#-atime  #-mtime   #-ctime   #-amin   #-mmin   #-cmin

所以这里atime,mtime,ctime就是分别对应的“最近一次访问时间”“最近一次内容修改时间”“最近一次属性修改时间”,这里的atime的单位指的是“天”,amin的单位是分钟

如果跟的是具体数字 find / -atime 10  表示在第十天被访问的文件(/表示从根目录开始查找),表示区间加上+-

#find  /tmp  –atime  +5           //表示查找在五天前访问过的文件

#find  /tmp  -atime  -5            //表示查找在五天内访问过的文件

根据文件名查找

#  -name       //根据文件名查找(精确查找)

#  -iname       //根据文件名查找,但是不区分大小写

根据文件类型来查找文件:

-type            f     // 普通文件

d     //目录文件

l     //链接文件

b     //块设备文件

c     //字符设备文件

p     //管道文件

s     //socket文件

文件大小查找:

find / -size +1000k  查找大于1M的文件

通配符匹配文件名:

find / -name '*pass*'   只要包含pass关键字

查找特殊权限的文件:

-perm

#find  /tmp  -perm  755           //查找在/tmp目录下权限是755的文件

#find  /tmp  -perm  +222          //表示只要有一类用户(属主,属组,其他)的匹配写权限就行

#find  /tmp  -perm  -222          //表示必须所有类别用户都满足有写权限

三、文本编辑器

普通模式:这种模式下键盘上的字符都代表着特殊操作

跳至指定的行

「ctrl」+「g」列出光标所在行的行号。

「#G」:例如,「15G」,表示移动光标至文章的第15行行首。

 回撤上一次操作

「u」:如果您误执行一个命令,可以马上按下「u」,回到上一个操作。按多次"u"可以执行多次回复

[ctrl+r]:对使用u命令撤销的操作进行恢复

 复制

「yw」:将光标所在之处到字尾的字符复制到缓冲区中。

「#yw」:复制#个字到缓冲区

「yy」:复制光标所在行到缓冲区。

「#yy」:例如,「6yy」表示拷贝从光标所在的该行"往下数"6行文字。

「p」:将缓冲区内的字符贴到光标所在位置。注意:所有与"y"有关的复制命令都必须与"p"配合才能完成复制与粘贴功能。

删除

「x」:每按一次,删除光标所在位置的"后面"一个字符。

「#x」:例如,「6x」表示删除光标所在位置的"后面"6个字符。

「X」:大写的X,每按一次,删除光标所在位置的"前面"一个字符。

「#X」:例如,「20X」表示删除光标所在位置的"前面"20个字符。

「dd」:删除光标所在行。

「#dd」:从光标所在行开始删除#行

插入模式:在普通模式按i键进入插入模式,按Esc退出到普通模式

命令模式:在普通模式按:键进入插入模式,按Esc退出到普通模式 

     q!强制退出

     wq保存退出

列出行号

「set nu」:输入「set nu」后,会在文件中的每一行前面列出行号

跳到文件中的某一行

「#」:「#」号表示一个数字,在冒号后输入一个数字,再按回车键就会跳到该行了,如输入数字15,再回车,就会跳到文章的第15行。

查找:

方法如下:

1、命令模式下输入“/字符串”,例如“/Section 3”。

2、如果查找下一个,按“n”即可。

要自当前光标位置向上搜索,请使用以下命令:

/pattern Enter

其中,pattern表示要搜索的特定字符序列。

要自当前光标位置向下搜索,请使用以下命令:

?pattern Enter

vi支持同时打开多个文件:

vi file1 file2 file3

Linux(三)__文件权限、系统的查找、文本编辑器的更多相关文章

  1. Linux常用命令--文件(夹)查找之find命令

    Linux系统用得越久,就会发现这真的是一个很优秀的系统,各种方便各种实用各种高效率. 晚饭前写一下find命令的笔记. 其实这篇笔记,也是看到一篇外文博客,写得不错,自己拿来练一练,然后才顺便写篇笔 ...

  2. Linux命令:修改文件权限命令chmod、chgrp、chown详解

    Linux系统中的每个文件和目录都有访问许可权限,用它来确定谁可以通过何种方式对文件和目录进行访问和操作. 文件或目录的访问权 限分为只读,只写和可执行三种.以文件为例,只读权限表示只允许读其内容,而 ...

  3. linux中的文件权限chmod

    linux中的文件权限chmod ​ 还是GPU集群那点事儿,集群之间磁盘互相挂载,普通用户也可以操作/cu02_nfs./cu04_nfs文件夹,这就牵扯到权限的问题,去google发现所谓的777 ...

  4. Linux用户及文件权限管理

    Linux用户及文件权限管理

  5. Linux下日志文件监控系统Logwatch的使用记录

    Linux下日志文件监控系统Logwatch的使用记录 原文:http://www.cnblogs.com/kevingrace/p/6519504.html 在维护Linux服务器时,经常需要查看系 ...

  6. Linux系统 vi/vim文本编辑器

    Linux系统 vi/vim文本编辑器 (一)Vim/Vi简介 (二)Vim/Vi工作模式 (三)Vim/Vi基本使用 (四)Vim/Vi应用技巧 (一)Vim/Vi简介 Vim/Vi是一个功能强大的 ...

  7. 关于linux下的文件权限

    在ls指令加 -l 参数能看到文件权限 就像这样: drwxrwxr-x 2 asml users 4096 Jul 24 02:45 desktop 第一个d表示这是个目录,若为"-&qu ...

  8. Linux编程 17 文件权限(权限设置chmod,改变文件属主属组关系chown,chgrp)

    一. 概述 如果创建了一个目录或文件,有时会需要改变它的安全性设置,在linux系统上有一些工具可以完成这任务,包括使用chmod命令改变已有默认权限,分别能对属主,属组,其它用户的权限的控制分别以读 ...

  9. linux用户、文件权限相关命令

    root 现代操作系统一般属于多用户的操作系统,也就是说,同一台机器可以为多个用户建立账户,一般这些用户都是为普通用户,这些普通用户能同时登录这台计算机,计算机对这些用户分配一定的资源. 普通用户在所 ...

随机推荐

  1. SQL语句全

    创建数据库 创建之前判断该数据库是否存在 if exists (select * from sysdatabases where name='databaseName') drop database ...

  2. MVC与WebForm的区别

    在初步了解MVC后,发现很多人对于MVC和三层架构开发概念上会有很大的混淆,所以把这两天的学习笔记整理一下,分享给自己的同学们.同时也做一个小Demo,让没有接触过MVC开发的同学,能对MVC有一个简 ...

  3. JMeter--一、安装JMeter

    Apache JMeter是Apache组织开发的基于Java的接口和性能测试工具. 作用: 1.能够对HTTP和FTP服务器进行压力和性能测试, 也可以对任何数据库进行同样的测试(通过JDBC). ...

  4. 导入镜像文件,分区启动liunx

    1:更改虚拟机配置 2:导入系统镜像 3:启动虚拟机,选择第一个选项回车 4:这里问你是否检查镜像,我们的镜像肯定没问题不需要检查,点击Skip 5:语言选择,按提示默认下一步 6:主机名也默认 7: ...

  5. 让IE系列支持HTML5的html5shiv.js和respond.min.js

    HTML5越来越成为主流,被广大搜索引擎所使用,但IE对HTML5的支持却常被人唾弃. 解决方案有两种: 1.为网站创建多套模板,通过程序对User-Agent的判断给不同的浏览器用户显示不同的页面, ...

  6. MongoDB 分片管理

    在MongoDB(版本 3.2.9)中,分片集群(sharded cluster)是一种水平扩展数据库系统性能的方法,能够将数据集分布式存储在不同的分片(shard)上,每个分片只保存数据集的一部分, ...

  7. Index的填充属性:FillFactor 和 PAD_INDEX

    在Create Index时,必须考虑属性FillFactor 和 PAD_INDEX的设置,这两个属性只在create index 或 rebuild index时起作用,表示Index page( ...

  8. Android 内存管理 &Memory Leak & OOM 分析

    转载博客:http://blog.csdn.net/vshuang/article/details/39647167 1.Android 进程管理&内存 Android主要应用在嵌入式设备当中 ...

  9. 窥探Swift之需要注意的基本运算符和高级运算符

    之前更新了一段时间有关Swift语言的博客,连续更新了有6.7篇的样子.期间间更新了一些iOS开发中SQLite.CollectionViewController以及ReactiveCocoa的一些东 ...

  10. iOS开发之窥探UICollectionViewController(三) --使用UICollectionView自定义瀑布流

    上篇博客的实例是自带的UICollectionViewDelegateFlowLayout布局基础上来做的Demo, 详情请看<iOS开发之窥探UICollectionViewControlle ...