linux学习笔记(2)

ps进程扫描
echo打印输出
####1.管理输入输出####
watch -n 1 cat file   时时查看
echo hellow world > file  写入 file中

[kiosk@foundation20 Desktop]$ find /etc -name passwd
find: ‘/etc/pki/CA/private’: Permission denied                  ##没有进入权力,报错
find: ‘/etc/selinux/targeted/modules/active’: Permission denied
/etc/passwd                                                     ##正确输出

find /etc -name passwd > file        ##重定向正确输出
find /etc -name passwd 2> file        ##重定向错误输出
find /etc -name passwd &> file        ##重定向所有输出

注意: >, 2> ,&>  都会覆盖源文件内容
>file                    ##清空file

find /etc -name passwd >> file        ##追加正确输出
find /etc -name passwd 2>> file        ##追加错误输出
find /etc -name passwd &>> file        ##追加所有输出

注意:>> 2>> &>> 不会覆盖源文件内容,会把相应的输出字符方到文件的最后

####2.“|”的使用####

“|”:管道,将前一条命令得输出当成下一条命令的输入

ls /bin | wc -l          ##统计ls /bin 命令输出的行数


系统中错误的输出是无法通过管道的。
用 2>&1 可以把错误的输出编号由2变成1
tee   复制输出到指定位置

date |tee file |wc -l    ###tee命令复制date命令的输出到file中,并统计输出行数



cat -b 文件名   可以显示行号

####3.vim 命令模式####

在vim的命令模式下可以配置vim的工作方式
:set nu            ##行号添加
:set nonu        ##取消行号
:set mouse=a        ##添加鼠标选择
:set cursorline        ##行线显示
以上设定都是临时的,


##永久设定方式##

vim /etc/vimrc        ###此文件为vim的配置文件,可永久更改信息,如行号添加等

临时更改文件时,可不用进入文件,直接使用set命令



####4.vim命令模式下关键字搜索####
/关键字
n向下匹配
N向上匹配

####5.vim命令模式下字符的管理####
##1.字符的复制##
yl                 ##复制一个字母
y3l              ##复制3个字母
yw              ##复制一个单词
y3w           ##复制3个单词
yy               ##复制一行
y3y            ##复制3行
p               ##复制完成后按“P”粘贴

##2.字符的删除##
dl             ##删除一个字母
d3l          ##删除3个字母
dw          ##删除一个单词
d3w       ##删除3个单词
dd          ##删除一行
d3d       ##删除3行

##3.字符的剪切##
cl                                 ##剪切一个字母
c3l                               ##剪切3个字母
cw                                ##剪切一个单词
c3w                              ##剪切3个单词
cc                                 ##剪切一行
c3c                               ##剪切3行
esc ---> p                   ##剪切过后会进入到插入模式,在执行粘贴动作时一定要退出插入模式

##4.vim的可视化模式##
在命令模式下按“ctrl+v”进入到可视模式
在可视模式下可以区域选择字符

可视模式下批量添加字符
(1) ctrl+v 选中要加入字符所在列
(2)按“I”进入插入模式,写入要加入的字符
(3)按esc

##5.批量修改字符##

:%s/原有字符/替换后字符                 ##只替换每一行中出现的第一个原有字符
:%s/原有字符/替换后字符/g             ##替换所有
:%s/\t//g                                               ##把全文的tab键替去掉,\t 表示tab键
:%s/^\ *//g                                           ##把全文行首的空格去掉,"^\ *"表示行首的空格
:%s/^\#\ */#/g                                     ##把全文#后的空格去掉

##6.vim的分屏功能##
ctrl+w s                     ##上下分屏
ctrl+w v                     ##左右分屏
ctrl+w c                    ##关闭光标所在屏幕
ctrl+w 上下左右      ##光标移动到指定屏幕
:sp file2                    ##同时编辑当前文件和file2
ctrl+w按完后再按命令

##7.vim光标移动##
在命令模式下
:数字           ##移动到指定的行
G                    ##文件最后一行
gg                  ##文件第一行


##8.插入模式下的命令##

在插入模式下
i              ##光标所在位置插入
I              ##光标所在行行首
a              ##光标所在字符的下一个字符
A              ##光标所在行行尾
o              ##光标所在行的下一行
O              ##光标所在行的下一行
s              ##删除光标所在字符后插入
S              ##删除光标所在行后插入
命令只能在命令模式下输入,每输入一次需按esc退出

##9.vim的退出模式##
:q             ##用vim打开文件但是并没有对字符做任何的操作
:q!            ##用vim打开文件并且对字符进行操作,放弃所有操作后退出
:wq            ##保存退出
:wq!           ##强行保存退出,仅对超级用户或文件所有人生效

##10.vim手册##
vimtutor       ##vim的手册
:q            ##退出vimtutor

####6.gedit命令的使用####
ctrl+n         ##在gedit中打开一个新的tab
ctrl+s         ##保存文件
ctrl+o         ##打开文件
ctrl+x         ##剪切字符
ctrl+v         ##粘贴字符
ctrl+c         ##复制字符
yelp help:gedit       ##查看gedit的图形手册

####用户理解####
用户就是系统使用者的身份
在系统中用户存储为若干串字符+若干个系统配置文件
用户信息涉及到的系统配置文件:
/etc/passwd           ###用户信息
用户:密码:uid:gid:说明:家目录:用户使用的shell
/etc/passwd           ###用户认证信息
用户:密码;最后一次密码修改时间:最短有效期:最长有效期:警告期:非活跃期:帐号到期日
/etc/group            ##组信息
组名称:组密码:组id:附加组成员
/etc/gshadow          ##组认证信息
/home/username        ##用户家目录
/etc/skel/.*          ##用户骨架文件

watch -n 1 'tail -n 3 /etc/passwd /etc/group;echo ====;ls /home/'   ##监控用户信息

2.##用户删除##
userdel -r 用户名称  ##删除用户的所有信息及用户的系统配置

3.##组的建立##
groupadd -g        ##建立初始组信息
groupdel 组名字     ##删除组

4.##用户id信息查看##
id       参数       用户
          -u       ##用户uid
          -g       ##用户初始组id(gid)
          -G       ##用户所有所在组id
          -n       ##显示名称而不是id数字

          -a       ##显示所有信息


5.##用户信息添加##
useradd   参数
          -d       ##指定家目录
          -s       ##指定用户使用的shell
          -c       ##指定用户的说明
          -g       ##指定用户的初始组
          -G       ##指定用户的附加组         



6.##用户信息更改##
usermod    参数     用户
           -l       ##更改用户的名称
           -u       ##更改用户uid
           -g       ##更改用户初始组id(gid)
           -G       ##更改附加组
           -aG      ##添加附加组
           -c       ##更改用户说明
           -d       ##更改用户指定家目录
           -md      ##更改用户指定家目录,并修改家目录名称
           -s       ##更改用户使用的shell
           -L       ##冻结帐号
           -U       ##解锁

##使用passwd -l 冻结的帐号,需要使用两次usermod -U进行解锁



-9 ##强行结束不提示
kill -9    ##


echo westos|passwd --stdin linux  ##将用户linux的密码更改为westos
!!帐号未被激活
watch -n 1 "tail -n 1 /etc/shadow"    ##监控shadow的信息     

######用户权力下放######
1.在系统中超级用户可以下放普通用户不能执行的操作给普通用户
下放权力配置文件:/etc/sudoers

####2.下放权力的方法####
(1).超级用户执行visudo进入编辑/etc/sudoers模式
(2).格式
获得权限用户        主机名称=(获得到的用户身份)                命令
linux         desktop20.example.com=(root)        /usr/sbin/useradd
linux用户能在desktop20.example.com以超级用户身份执行/usr/sbin/useradd

####3.执行下放权限命令####
sudo    命令    ##如果第一次执行sudo需要输入当前用户密码
在/etc/sudoers中如果设置如下:
westos    desktop20.example.com=(root)     NOPASSWD: /usr/sbin/useradd
表示用户westos在调用sudo命令的时候不需要输入自己密码

####4.用户认证信息的控制####
chage     参数    用户
    -d    ##用户密码组后一次修改的时间,如果设定成0,用户登陆系统后必须修改自己的密码    
    -m    ##最短有效期
    -M    ##最长有效期
    -W    ##警告期
    -I    ##用户非活跃天数
    -E    ##帐号到期日格式 -E "YYYY-MM-DD"

######文件权限######
##1.文件属性的查看##
ls -l filename
-          |rw-r--r--.| 1 | root| root| 46|       Oct 1 05:03 |  filename
——   ———— — —— —— —— ——————— ————
1                  2      3     4       5      6                7                     8

1.“-”:文件类型
-      ##普通用户
d      ##目录
c      ##字符设备
s      ##套接字
p      ##管道
b      ##快设备
l      ##连接

2.“rw-r--r--":文件读写权限
rw-|r--|r--
 *   $   @
*所有人的权限
$所有组的权限
@其他人的权限

3.“1”
对文件:文件内容被系统记录的次数
对目录:目录中文件属性的字节数

4.“root”:文件所有人

5.“root”:文件所有组

6.“46”:文件内容的大小

7.“Oct 1 05:03":文件最后一次被修改的时间

8."filename":文件名字

##2.文件所有人所有组的管理##

chown     username        file|dir    ##更改文件的所有人
chown     username:groupname    file|dir    ##更改所有人所有组
chown -R username        dir        ##更改目录本身及里面所有内容的所有人
chgrp -R groupname        dir        ##更改目录本身及里面所有内容的所有组

监控命令
watch -n 1 ls -lR /mnt

##3.文件普通权限##
rw-|r--|r--
 u   g   o
u:文件所有人对文件可以读写
g:文件组成员对文件可读
o:其他人对文件可读
u优先匹配,g次优先,o当u,g不匹配时匹配

1.r
对文件:可以查看文件中的字符
对目录:可以查看目录中文件的信息

2.w
对文件:可以更改文件内字符
对目录:可以在目录中添加删除文件

3.x
对文件:可以运行文件内记录的程序动作
对目录:可以进入目录中

4.字符方式修改该文件权限
chmod [-R] <u|g|o><+|-|=><r|w|x> file|dir    

chmod u-x file1            ##file1拥有者去掉x权限
chmod g+w file1            ##file1拥有组添加w权限
chmod u-x,g+w file1        ##file1拥有者去掉x权,file1拥有组添加w权限
chmod ugo-r file2        ##file2的用户组其他人去掉r权限
chmod ug+x,o-r file3        ##file3用户和组添加x权限,其他人去掉r权限
对目录而言,能写就能够执行
对文件而言,能写不代表能执行


5.数字方式修改该文件权限
在linux中
r=4
w=2
x=1
文件权限数字表示方式
rw-|r--|r--
 u   g   o
u=rw-=4+2+0=6
g=r--=4+0+0=4
o=r--=4+0+0=4
所以文件权限表示为644

chmod    修改后权限值    file
chmod    777    file

7=rwx
6=rw-
5=r-x
4=r--
3=-wx
2=-w-
1=--x
0=---

####4.系统默认权限的设定####

从系统存在角度来说,开放权力越大,系统存在意义越高
从系统安全角度来说,开放权力越少,系统安全性越高
所以系统设定新建文件或目录会去掉一些权限
设定方式
umask        ##查看系统保留权限默认为022
umask 077    ##修改该系统保留权限为077,此设定为临时设定,只当前shell中生效

永久设定方式:
vim /etc/bashrc        ##shell
 70     if [ $UID -gt 199 ] && [ "`id -gn`" = "`id -un`" ]; then
 71        umask 002    ##普通用户umask
 72     else
 73        umask 077    ##超级用户umask                                                                      
 74     fi

vim /etc/profile    ##系统
 59 if [ $UID -gt 199 ] && [ "`id -gn`" = "`id -un`" ]; then
 60     umask 002    ##普通用户umask
 61 else
 62     umask 077       ##超级用户umask                                                                                         
 63 fi

以上两个文件umask设定值必须保持一致
source /etc/bashrc
source /etc/profile
让设定立即生效

默认情况下,对于目录,用户所能拥有的最大权限是777;对于文件,用户所能拥有的最大权限是目录的最大权限去掉执行权限,即666。

对于root用户,他的umask值是022。当root用户创建目录时,默认的权限就是用最大权限777去掉相应位置的umask值权限,,所以目录的默认权限就是755;当root用户创建文件时,默认的权限则是用最大权限666去掉相应位置的umask值,即文件的默认权限是644。

若是设定普通用户新建文件权限为“r--r-----”,也就是440.那么在umask中,你需要输入的值就应当为226

####5.特殊权限####
1.suid        ##冒险位
只针对二进制可执行文件,文件内记录的程序产生的进程的所有人为文件所有人,和进程发起人身份无关

设定方式:
chmod u+s file
suid=4
chmod 4xxx file

2.sgid        ##强制位
对文件:只针对二进制可执行文件,任何人运行二进制文件,程序时产生的进程的所有组都是文件的所有组,和程序发起人组无关
对目录:当目录有sgid权限后,目录中新建的所有文件的所有组都自动归属到目录的所有组之中,和文件建立者所在的组无关

设定方式:

chmod g+s file|dir
sgid=2
chmod 2xxx file|dir
   
3.sticky    ##粘制位
t权限:
只针对与目录,当一个目录上有t权限,那么目录中的文件只能被文件所有人删除

设定方式:
chmod o+t direcotry
t=1
chmod    1777 direcotry

ps ax -o user,group,comm | grep watch   ##查看所有的含有watch的程序及所有人,用户组


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值