零基础入门学习Python第二阶03玩转Linux操作系统02

文本处理
  1. 字符流编辑器 - sed

    sed是操作、过滤和转换文本内容的工具。假设有一个名为fruit.txt的文件,内容如下所示。

    [root ~]# cat -n fruit.txt 
         1  banana
         2  grape
         3  apple
         4  watermelon
         5  orange
    

    接下来,我们在第2行后面添加一个pitaya。

    [root ~]# sed '2a pitaya' fruit.txt 
    banana
    grape
    pitaya
    apple
    watermelon
    orange
    

    注意:刚才的命令和之前我们讲过的很多命令一样并没有改变fruit.txt文件,而是将添加了新行的内容输出到终端中,如果想保存到fruit.txt中,可以使用输出重定向操作。

    在第2行前面插入一个waxberry。

    [root ~]# sed '2i waxberry' fruit.txt
    banana
    waxberry
    grape
    apple
    watermelon
    orange
    

    删除第3行。

    [root ~]# sed '3d' fruit.txt
    banana
    grape
    watermelon
    orange
    

    删除第2行到第4行。

    [root ~]# sed '2,4d' fruit.txt
    banana
    orange
    

    将文本中的字符a替换为@。

    [root ~]# sed 's#a#@#' fruit.txt 
    b@nana
    gr@pe
    @pple
    w@termelon
    or@nge
    

    将文本中的字符a替换为@,使用全局模式。

    [root ~]# sed 's#a#@#g' fruit.txt 
    b@n@n@
    gr@pe
    @pple
    w@termelon
    or@nge
    
  2. 模式匹配和处理语言 - awk

    awk是一种编程语言,也是Linux系统中处理文本最为强大的工具,它的作者之一和现在的维护者就是之前提到过的Brian Kernighan(ken和dmr最亲密的伙伴)。通过该命令可以从文本中提取出指定的列、用正则表达式从文本中取出我们想要的内容、显示指定的行以及进行统计和运算,总之它非常强大。

    假设有一个名为fruit2.txt的文件,内容如下所示。

    [root ~]# cat fruit2.txt 
    1       banana      120
    2       grape       500
    3       apple       1230
    4       watermelon  80
    5       orange      400
    

    显示文件的第3行。

    [root ~]# awk 'NR==3' fruit2.txt 
    3       apple       1230
    

    显示文件的第2列。

    [root ~]# awk '{print $2}' fruit2.txt 
    banana
    grape
    apple
    watermelon
    orange
    

    显示文件的最后一列。

    [root ~]# awk '{print $NF}' fruit2.txt 
    120
    500
    1230
    80
    400
    

    输出末尾数字大于等于300的行。

    [root ~]# awk '{if($3 >= 300) {print $0}}' fruit2.txt 
    2       grape       500
    3       apple       1230
    5       orange      400
    

    上面展示的只是awk命令的冰山一角,更多的内容留给读者自己在实践中去探索。

用户管理

  1. 创建和删除用户 - useradd / userdel

    [root home]# useradd hellokitty
    [root home]# userdel hellokitty
    
    • -d - 创建用户时为用户指定用户主目录
    • -g - 创建用户时指定用户所属的用户组
  2. 创建和删除用户组 - groupadd / groupdel

    说明:用户组主要是为了方便对一个组里面所有用户的管理。

  3. 修改密码 - passwd

    [root ~]# passwd hellokitty
    New password: 
    Retype new password: 
    passwd: all authentication tokens updated successfully.
    

    说明:输入密码和确认密码没有回显且必须一气呵成的输入完成(不能使用退格键),密码和确认密码需要一致。如果使用passwd命令时没有指定命令作用的对象,则表示要修改当前用户的密码。如果想批量修改用户密码,可以使用chpasswd命令。

    • -l / -u - 锁定/解锁用户。
    • -d - 清除用户密码。
    • -e - 设置密码立即过期,用户登录时会强制要求修改密码。
    • -i - 设置密码过期多少天以后禁用该用户。
  4. 查看和修改密码有效期 - chage

    设置hellokitty用户100天后必须修改密码,过期前15天通知该用户,过期后7天禁用该用户。

    chage -M 100 -W 15 -I 7 hellokitty
    
  5. 切换用户 - su

    [root ~]# su hellokitty
    [hellokitty root]$
    
  6. 以管理员身份执行命令 - sudo

    [hellokitty ~]$ ls /root
    ls: cannot open directory /root: Permission denied
    [hellokitty ~]$ sudo ls /root
    [sudo] password for hellokitty:
    

    说明:如果希望用户能够以管理员身份执行命令,用户必须要出现在sudoers名单中,sudoers文件在 /etc目录下,如果希望直接编辑该文件也可以使用下面的命令。

  7. 编辑sudoers文件 - visudo

    这里使用的编辑器是vi,关于vi的知识在后面有讲解。该文件的部分内容如下所示:

    ## Allow root to run any commands anywhere 
    root    ALL=(ALL)   ALL
    
    ## Allows members of the 'sys' group to run networking, software, 
    ## service management apps and more.
    # %sys ALL = NETWORKING, SOFTWARE, SERVICES, STORAGE, DELEGATING, PROCESSES, LOCATE, DRIVERS
    ## Allows people in group wheel to run all commands
    %wheel  ALL=(ALL)   ALL
    
    ## Same thing without a password
    # %wheel    ALL=(ALL)   NOPASSWD: ALL
    
    ## Allows members of the users group to mount and unmount the
    ## cdrom as root
    # %users  ALL=/sbin/mount /mnt/cdrom, /sbin/umount /mnt/cdrom
    
    ## Allows members of the users group to shutdown this system
    # %users  localhost=/sbin/shutdown -h now
    
  8. 显示用户与用户组的信息 - id

  9. 给其他用户发消息 -write / wall

    发送方:

    [root ~]# write hellokitty
    Dinner is on me.
    Call me at 6pm.
    

    接收方:

    [hellokitty ~]$ 
    Message from root on pts/0 at 17:41 ...
    Dinner is on me.
    Call me at 6pm.
    EOF
    
  10. 查看/设置是否接收其他用户发送的消息 - mesg

[hellokitty ~]$ mesg
is y
[hellokitty ~]$ mesg n
[hellokitty ~]$ mesg
is n

文件系统

文件和路径
  1. 命名规则:文件名的最大长度与文件系统类型有关,一般情况下,文件名不应该超过255个字符,虽然绝大多数的字符都可以用于文件名,但是最好使用英文大小写字母、数字、下划线、点这样的符号。文件名中虽然可以使用空格,但应该尽可能避免使用空格,否则在输入文件名时需要用将文件名放在双引号中或者通过\对空格进行转义。
  2. 扩展名:在Linux系统下文件的扩展名是可选的,但是使用扩展名有助于对文件内容的理解。有些应用程序要通过扩展名来识别文件,但是更多的应用程序并不依赖文件的扩展名,就像file命令在识别文件时并不是依据扩展名来判定文件的类型。
  3. 隐藏文件:以点开头的文件在Linux系统中是隐藏文件(不可见文件)。
目录结构
  1. /bin - 基本命令的二进制文件。
  2. /boot - 引导加载程序的静态文件。
  3. /dev - 设备文件。
  4. /etc - 配置文件。
  5. /home - 普通用户主目录的父目录。
  6. /lib - 共享库文件。
  7. /lib64 - 共享64位库文件。
  8. /lost+found - 存放未链接文件。
  9. /media - 自动识别设备的挂载目录。
  10. /mnt - 临时挂载文件系统的挂载点。
  11. /opt - 可选插件软件包安装位置。
  12. /proc - 内核和进程信息。
  13. /root - 超级管理员用户主目录。
  14. /run - 存放系统运行时需要的东西。
  15. /sbin - 超级用户的二进制文件。
  16. /sys - 设备的伪文件系统。
  17. /tmp - 临时文件夹。
  18. /usr - 用户应用目录。
  19. /var - 变量数据目录。
访问权限
  1. chmod - 改变文件模式比特。

    [root ~]# ls -l
    ...
    -rw-r--r--  1 root       root 211878 Jun 19 16:06 sohu.html
    ...
    [root ~]# chmod g+w,o+w sohu.html
    [root ~]# ls -l
    ...
    -rw-rw-rw-  1 root       root 211878 Jun 19 16:06 sohu.html
    ...
    [root ~]# chmod 644 sohu.html
    [root ~]# ls -l
    ...
    -rw-r--r--  1 root       root 211878 Jun 19 16:06 sohu.html
    ...
    

    说明:通过上面的例子可以看出,用chmod改变文件模式比特有两种方式:一种是字符设定法,另一种是数字设定法。除了chmod之外,可以通过umask来设定哪些权限将在新文件的默认权限中被删除。

    长格式查看目录或文件时显示结果及其对应权限的数值如下表所示。

    在这里插入图片描述

  2. chown - 改变文件所有者。

    [root ~]# ls -l
    ...
    -rw-r--r--  1 root root     54 Jun 20 10:06 readme.txt
    ...
    [root ~]# chown hellokitty readme.txt
    [root ~]# ls -l
    ...
    -rw-r--r--  1 hellokitty root     54 Jun 20 10:06 readme.txt
    ...
    
  3. chgrp - 改变用户组。

磁盘管理
  1. 列出文件系统的磁盘使用状况 - df

    [root ~]# df -h
    Filesystem      Size  Used Avail Use% Mounted on
    /dev/vda1        40G  5.0G   33G  14% /
    devtmpfs        486M     0  486M   0% /dev
    tmpfs           497M     0  497M   0% /dev/shm
    tmpfs           497M  356K  496M   1% /run
    tmpfs           497M     0  497M   0% /sys/fs/cgroup
    tmpfs           100M     0  100M   0% /run/user/0
    
  2. 磁盘分区表操作 - fdisk

    [root ~]# fdisk -l
    Disk /dev/vda: 42.9 GB, 42949672960 bytes, 83886080 sectors
    Units = sectors of 1 * 512 = 512 bytes
    Sector size (logical/physical): 512 bytes / 512 bytes
    I/O size (minimum/optimal): 512 bytes / 512 bytes
    Disk label type: dos
    Disk identifier: 0x000a42f4
       Device Boot      Start         End      Blocks   Id  System
    /dev/vda1   *        2048    83884031    41940992   83  Linux
    Disk /dev/vdb: 21.5 GB, 21474836480 bytes, 41943040 sectors
    Units = sectors of 1 * 512 = 512 bytes
    Sector size (logical/physical): 512 bytes / 512 bytes
    I/O size (minimum/optimal): 512 bytes / 512 bytes
    
  3. 磁盘分区工具 - parted

  4. 格式化文件系统 - mkfs

    [root ~]# mkfs -t ext4 -v /dev/sdb
    
    • -t - 指定文件系统的类型。
    • -c - 创建文件系统时检查磁盘损坏情况。
    • -v - 显示详细信息。
  5. 文件系统检查 - fsck

  6. 转换或拷贝文件 - dd

  7. 挂载/卸载 - mount / umount

  8. 创建/激活/关闭交换分区 - mkswap / swapon / swapoff

说明:执行上面这些命令会带有一定的风险,如果不清楚这些命令的用法,最好不用随意使用,在使用的过程中,最好对照参考资料进行操作,并在操作前确认是否要这么做。

  • 27
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值