Linux教程

linux基础-2

本文主要是介绍linux基础-2,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

文章目录

      • 准备工作
  • 一、搜索命令
  • 1.find 搜索
    • 1.1 目标
    • 1.2 路径
    • 1.3 实现 : 在指定目录中 根据名称 搜索
      • 命令格式
        • 第一步: 搜索指定目录下, 文件是 abc.txt的文件
        • 第二步: 搜索指定目录下, 文件名 包含 `1` 的文件
        • 第三步: 搜索指定目录下,所有以`.txt` 为扩展名的文件
        • 第四步: 搜索指定目录下, 以数字`1`开头的文件
    • 1.3 小结
  • 解压缩命令
    • 1.目标
    • 2 路径
    • 3.实现
      • 3.1 第一步: 打包 和 解包
        • 3.1.1 打包
        • 3.1.2 解包
        • 小结
      • 3.2 第二步: 使用gzip格式 压缩 和 解压缩
      • 小结
      • 3.3 第三步: 使用 bzip2 格式 压缩 和 解压缩
      • 小结
  • VI编辑器_终端编辑器(重点重点重点)
  • 目标
  • 1 简介
    • 1.1 学习vi的目的
    • 1.2 vi 和 vim
      • 1.2.1 VI
      • 1.2.2 VIM
  • 2 打开和新建文件
    • 2.1 打开文件并且定位行
    • 2.2 异常处理
    • 2.3 VI三种工作模式
    • 2.4 末行模式命令
  • 4 常用命令
    • 命令线路图
    • 学习提示
    • 4.1 移动
      • 1) 上 下 左 右
      • 2) 行内移动
      • 3) 行数移动
      • 4) 屏幕移动
    • 4.2 移动(程序)
      • 1) 段落移动
      • 2) 括号切换
      • 3) 标记
    • 4.3 选中文本(可视模式)
    • 4.4 撤销和恢复撤销(保命指令)
    • 4.5 删除文本
    • 4.6 复制和剪切
    • 4.7 替换
    • 4.8 缩排和重复执行
    • 4.9 查找
    • 4.10 查找并替换
    • 4.11 插入命令(重点重点重点)
    • 4.12 练习
      • 演练1 -- 编辑命令 和 数字连用
      • 演练2 -- 利用 可视块 给多行代码增加注释
      • 演练3: 坦克大战案例(另存为 备份)
  • 用户权限相关命令
    • 目标
    • 01.用户和权限的基本概念
      • 1.1 基本概念
      • 1.2 组
      • 1.3 ls -l 扩展
    • 02.组管理 终端命令
    • 03.用户管理 终端命令
      • 3.1 创建用户 / 设置密码 / 删除用户
      • 3.2 查看用户信息
      • 3.3 `su` 切换用户
      • 3.4 **sudo**
      • 3.4.1 给 指定用户 授予 权限
      • 3.4.2 使用 用户 `lisi` 登录, 操作管理员命令
    • 04.修改用户权限
    • 4.1 方式一: 修改用户权限
      • 目标演练:
    • 4.2 方式二
      • 目标演练:
    • 4.3 方式三: 简化方式二
      • 目标演练:
  • 系统信息相关命令
  • 目标
  • 1.时间和日期
    • 1.1 date 时间
      • 第一步: 显示当前时间
      • 第二步: 设置系统时间
    • 1.2 cal 日历
  • 02.磁盘信息
  • 03.进程信息

准备工作

# 切换目录到 /export/ 且 清空内容
cd /export/ && rm -rf /export/* && tree

# 新增目录 且 切换目录 且 新增文件
mkdir -p /export/aaa/bbb/ccc/ddd/eee/ 
touch /export/aaa/bbb/ccc/ddd/eee/abc.txt
touch /export/aaa/123.txt
touch /export/aaa/312.txt

# 查看 /export 目录中的内容
tree /export

一、搜索命令

1.find 搜索

1.1 目标

  • 通过find命令 在特定目录下(包含它的后代目录) 搜索 符合条件的文件

1.2 路径

  • 第一步: 搜索指定目录下, 文件是 abc.txt的文件
  • 第二步: 搜索指定目录下, 文件名 包含 1 的文件
  • 第三步: 搜索指定目录下,所有以.txt 为扩展名的文件
  • 第四步: 搜索指定目录下, 以数字1开头的文件

1.3 实现 : 在指定目录中 根据名称 搜索

select * from 表名

[where 条件]

  • 命令格式

序号命令格式作用
01find [路径] -name ‘*.txt’查找指定路径下扩展名是 .txt的文件, 包括子目录
  • 如果省略路径, 表示在当前文件夹下查找
  • 之前学习的通配符, 在使用find命令时同时可用
  • 第一步: 搜索指定目录下, 文件是 abc.txt的文件

# ===================实现目标============================
# 方式一: 指定全目录
find /export/ -name 'abc.txt'
# 方式二: 当前目录
find . -name 'abc.txt'
# 方式三: 当前目录 可以 省略 不写
find -name 'abc.txt'
  • 第二步: 搜索指定目录下, 文件名 包含 1 的文件

# =================实现目录===============
find /export/ -name "*1*"
  • 第三步: 搜索指定目录下,所有以.txt 为扩展名的文件

find /export/ -name "*.txt"
  • 第四步: 搜索指定目录下, 以数字1开头的文件

find /export -name "1*"

1.3 小结

  • 通过 find [path] -name "*1*" 完成根据名称搜索文件

解压缩命令

  • 准备工作
# 清空指定目录内容
cd /export/ && rm -rf *

# 创建测试文件
touch 1.txt 2.txt 3.txt

# 创建有内容的测试目录
mkdir -p /export/aaa/
touch /export/aaa/4.txt /export/aaa/5.txt

# 查看结果
tree /export

1.目标

  • 从第三方 下载 压缩包, 解压缩后 安装到 服务器上[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9epEikYf-1618325440065)(assets/1558527865552.png)]
  • 通过 打包压缩 备份文件

jar : java rar java项目的压缩包

war : web rar web项目的压缩包

2 路径

  • 2.1 第一步: 打包 和 解包

  • **2.2 第二步: 打包压缩 和 解包解压缩 **

    3.实现

3.1 第一步: 打包 和 解包

3.1.1 打包

  • 类似将 冬天的衣服 放到 袋

  • 打包之后的大文件 需要以 .tar 结尾.

tar 打包命令格式

# 将 一系列文件 打包成 一个大文件
tar -cvf 打包名.tar 被打包的目录
tar -cvf 打包名.tar 被打包的文件1 被打包的文件2 被打包的文件3

tar 选项说明

命令英文含义
ccreate生成档案文件, 创建打包文件
vverbosely(啰嗦的)像 ‘唐僧’ 一样报告进度
ffile指定档案的文件名称, f后面一定是 .tar 文件, 所以必须放到左后
练习1: 将1.txt、2.txt、3.txt 打包成 123.tar文件

练习2: 将有内容的aaa目录 打包成 aaa.tar 文件
[root@node01 export]# tar -cvf 123.tar 1.txt 2.txt 3.txt 
1.txt
2.txt
3.txt
[root@node01 export]# ll
total 16
-rw-r--r--. 1 root root 10240 Jul 31 06:04 123.tar
-rw-r--r--. 1 root root     0 Jul 31 06:03 1.txt
-rw-r--r--. 1 root root     0 Jul 31 06:03 2.txt
-rw-r--r--. 1 root root     0 Jul 31 06:03 3.txt
drwxr-xr-x. 2 root root  4096 Jul 31 06:03 aaa
[root@node01 export]# tar -cvf aaa.tar aaa/
aaa/
aaa/4.txt
aaa/5.txt
[root@node01 export]# ll
total 28
-rw-r--r--. 1 root root 10240 Jul 31 06:04 123.tar
-rw-r--r--. 1 root root     0 Jul 31 06:03 1.txt
-rw-r--r--. 1 root root     0 Jul 31 06:03 2.txt
-rw-r--r--. 1 root root     0 Jul 31 06:03 3.txt
drwxr-xr-x. 2 root root  4096 Jul 31 06:03 aaa
-rw-r--r--. 1 root root 10240 Jul 31 06:04 aaa.tar
[root@node01 export]# rm -rf *.txt aaa
[root@node01 export]# ll
total 24
-rw-r--r--. 1 root root 10240 Jul 31 06:04 123.tar
-rw-r--r--. 1 root root 10240 Jul 31 06:04 aaa.tar
[root@node01 export]# 
[root@node01 export]# tree
.
├── 123.tar
└── aaa.tar

3.1.2 解包

  • 类似将 冬天的衣服 从 袋子里取出来

tar 解包命令格式

# 将一个打包后的 分解成 一系列小文件, 分解位置为 当前目录
tar -xvf 打包名.tar

# 将一个打包后的 分解成 一系列小文件, 分解位置为 指定目录
tar -xvf 打包名.tar -C 解包路径位置
命令英文含义
xextract (提取)解包
C (大写C)directory (目录)默认保存到当前目录, 通过-C 更改解压目录, 注意: 解压目录必须存在
练习1: 将 123.tar 解压到 当前目录中

练习2: 将 aaa.tar 解包到 /export/test/a1/b1/c1/ 目录中
[root@node01 export]# ll
total 24
-rw-r--r--. 1 root root 10240 Jul 31 06:04 123.tar
-rw-r--r--. 1 root root 10240 Jul 31 06:04 aaa.tar
[root@node01 export]# tar -xvf 123.tar 
1.txt
2.txt
3.txt
[root@node01 export]# ll
total 24
-rw-r--r--. 1 root root 10240 Jul 31 06:04 123.tar
-rw-r--r--. 1 root root     0 Jul 31 06:03 1.txt
-rw-r--r--. 1 root root     0 Jul 31 06:03 2.txt
-rw-r--r--. 1 root root     0 Jul 31 06:03 3.txt
-rw-r--r--. 1 root root 10240 Jul 31 06:04 aaa.tar
[root@node01 export]# mkdir -p /export/test/a1/b1/c1
[root@node01 export]# tree
.
├── 123.tar
├── 1.txt
├── 2.txt
├── 3.txt
├── aaa.tar
└── test
    └── a1
        └── b1
            └── c1

4 directories, 5 files
[root@node01 export]# tar -xvf aaa.tar -C /export/test/a1/b1/c1
aaa/
aaa/4.txt
aaa/5.txt
[root@node01 export]# tree
.
├── 123.tar
├── 1.txt
├── 2.txt
├── 3.txt
├── aaa.tar
└── test
    └── a1
        └── b1
            └── c1
                └── aaa
                    ├── 4.txt
                    └── 5.txt

小结

打包: tar -cvf 打包之后的文件名.tar   被打包的目录或文件名
	
解包: tar -xvf 打包之后的文件名.tar  [ -C  指定解包位置 ]
  • 准备工作

    # 清空指定目录内容
    cd /export/ && rm -rf *
    
    # 创建测试文件
    touch 1.txt 2.txt 3.txt
    
    # 创建有内容的测试目录
    mkdir -p /export/aaa/
    touch /export/aaa/4.txt /export/aaa/5.txt
    
    # 查看结果
    tree /export
    

3.2 第二步: 使用gzip格式 压缩 和 解压缩

  • 打包压缩 是两件事

  • 类似与 先将冬天衣服放到压缩袋, 再抽取里面的空气

  • Linux 中, 最常用的压缩文件格式是 xxx.tar.gz

  • tar 命令中有一个选项 -z 可以调用 gzip , 从而可以方便的实现压缩和解压缩的功能

命令格式如下

# 压缩文件
tar -zcvf 打包压缩文件名.tar.gz 被压缩的文件/目录

# 解压缩文件(记忆敲门: 至孝潍坊)
tar -zxvf 打包文件.tar.gz

# 解压缩到指定路径
tar -zxvf 打包文件.tar.gz -C 目录路径

tar 的选项说明

命令英文含义
zgzip使用gzip压缩和解压缩
jbzip2使用bzip2压缩和解压缩
需求1: 将1.txt、2.txt、3.txt 打包压缩成 123.tar.gz文件(gzip压缩格式)

需求2: 将有内容的aaa目录 打包成 aaa.tar.gz 文件(gzip压缩格式)

需求3: 将 123.tar.gz 解压到 当前目录中(gzip压缩格式)

需求4: 将 aaa.tar.gz 解包到 /export/bbb 目录中(gzip压缩格式)

需求1和需求2答案

[root@node01 export]# tree
.
├── 1.txt
├── 2.txt
├── 3.txt
└── aaa
    ├── 4.txt
    └── 5.txt

1 directory, 5 files
[root@node01 export]# tar -zcvf 123.tar.gz 1.txt 2.txt 3.txt 
1.txt
2.txt
3.txt
[root@node01 export]# tar -zcvf aaa.tar.gz aaa/
aaa/
aaa/4.txt
aaa/5.txt
[root@node01 export]# ll
total 12
-rw-r--r--. 1 root root  122 Jul 31 06:11 123.tar.gz
-rw-r--r--. 1 root root    0 Jul 31 06:10 1.txt
-rw-r--r--. 1 root root    0 Jul 31 06:10 2.txt
-rw-r--r--. 1 root root    0 Jul 31 06:10 3.txt
drwxr-xr-x. 2 root root 4096 Jul 31 06:10 aaa
-rw-r--r--. 1 root root  142 Jul 31 06:11 aaa.tar.gz

清空无用内容

[root@node01 export]# tree
.
├── 123.tar.gz
├── 1.txt
├── 2.txt
├── 3.txt
├── aaa
│   ├── 4.txt
│   └── 5.txt
└── aaa.tar.gz

1 directory, 7 files
[root@node01 export]# rm -rf *.txt aaa/
[root@node01 export]# tree
.
├── 123.tar.gz
└── aaa.tar.gz

需求3和需求4 答案

[root@node01 export]# tree
.
├── 123.tar.gz
├── 1.txt
├── 2.txt
├── 3.txt
└── aaa.tar.gz

0 directories, 5 files
[root@node01 export]# mkdir -p /export/bbb
[root@node01 export]# tar -zxvf aaa.tar.gz -C /export/bbb/
aaa/
aaa/4.txt
aaa/5.txt
[root@node01 export]# tree
.
├── 123.tar.gz
├── 1.txt
├── 2.txt
├── 3.txt
├── aaa.tar.gz
└── bbb
    └── aaa
        ├── 4.txt
        └── 5.txt

小结

打包压缩: tar -zcvf 打包之后的文件名.tar.gz   被打包压缩的目录或文件名
	
解包解压缩: tar -zxvf 打包之后的文件名.tar.gz  [ -C  指定解包位置 ]
  • 准备工作

    # 清空指定目录内容
    cd /export/ && rm -rf *
    
    # 创建测试文件
    touch 1.txt 2.txt 3.txt
    
    # 创建有内容的测试目录
    mkdir -p /export/aaa/
    touch /export/aaa/4.txt /export/aaa/5.txt
    
    # 查看结果
    tree /export
    

3.3 第三步: 使用 bzip2 格式 压缩 和 解压缩

  • bzip 是压缩的第二种方式
  • 类似与 先将冬天衣服放到压缩袋, 再抽取里面的空气
  • Linux 中, bzip2 压缩文件格式是 xxx.tar.bz2
  • tar 命令中有一个选项 -j 可以调用 bzip2 , 从而可以方便的实现压缩和解压缩的功能

命令格式如下

# 压缩文件
tar -jcvf 打包压缩文件名.tar.bz2 被压缩的文件/目录

# 解压缩文件 (绩效潍坊)
tar -jxvf 打包文件.tar.bz2

# 解压缩到指定路径
tar -jxvf 打包文件.tar.bz2 -C 目录路径

tar 的选项说明

命令英文含义
zgzip使用gzip压缩和解压缩
jbzip2使用bzip2压缩和解压缩
练习1: 将1.txt、2.txt、3.txt 打包压缩成 123.tar.bz2文件(bzip2压缩格式)

练习2: 将有内容的aaa目录 打包成 aaa.tar.bz2 文件(bzip2压缩格式)

练习3: 将 123.tar.bz2 解压到 当前目录中(bzip2压缩格式)

练习4: 将 aaa.tar.bz2 解压到 /export/bbb 目录中(bzip2压缩格式)

需求1和需求2答案

[root@node01 export]# tar -jcvf 123.tar.bz2 1.txt 2.txt 3.txt 
1.txt
2.txt
3.txt
[root@node01 export]# tar -jcvf aaa.tar.bz2 aaa/
aaa/
aaa/4.txt
aaa/5.txt
[root@node01 export]# tree
.
├── 123.tar.bz2
├── 1.txt
├── 2.txt
├── 3.txt
├── aaa
│   ├── 4.txt
│   └── 5.txt
└── aaa.tar.bz2

清空内容

[root@node01 export]# rm -rf *.txt
[root@node01 export]# rm -rf aaa/
[root@node01 export]# tree
.
├── 123.tar.bz2
└── aaa.tar.bz2

需求3和需求4答案

[root@node01 export]# tar -jxvf 123.tar.bz2 
1.txt
2.txt
3.txt
[root@node01 export]# mkdir -p /export/bbb
[root@node01 export]# tar -jxvf aaa.tar.bz2 -C /export/bbb/
aaa/
aaa/4.txt
aaa/5.txt
[root@node01 export]# tree
.
├── 123.tar.bz2
├── 1.txt
├── 2.txt
├── 3.txt
├── aaa.tar.bz2
└── bbb
    └── aaa
        ├── 4.txt
        └── 5.txt

小结

打包压缩: tar -jcvf 打包之后的文件名.tar.bz2   被打包压缩的目录或文件名
	
解包解压缩: tar -jxvf 打包之后的文件名.tar.bz2  [ -C  指定解包位置 ]

关机

halt

重启

reboot

VI编辑器_终端编辑器(重点重点重点)

目标

  1. vi简介
  2. 打开和新建文件
  3. 三种工作模式
  4. 常用命令查询

1 简介

1.1 学习vi的目的

  • 在工作中, 要对 服务器上的 文件进行 简单 的修改, 可以使用 ssh 登录到远程服务器上, 并且使用 vi编辑器 进行简单的编辑即可

  • 需要修改的文件包括

    • 源代码
    • 配置文件
      • 例如: tomcat服务器的配置文件
      • 例如: 网卡信息的配置文件

    在没有图形界面的环境下, 要编辑文件, vi是最佳选择
    每一个使用linux的程序员,都应该或多或少的学习一些vi的常用命令

1.2 vi 和 vim

  • 在很多linux发行版中, 直接把vi做成vim的 软连接

1.2.1 VI

  • vi是 visual interface的简称, 是linux中最经典的文本编辑器

  • vi 的核心设计思想

    • 让程序员的手指始终保持在键盘的 核心区域, 就能完成所有的编辑操作

    • [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YNMC0lil-1618325440068)(…/…/…/…/…/%E5%A4%87%E8%AF%BE/linux/vim%E7%BC%96%E8%BE%91%E5%99%A8_%E5%88%98%E5%87%A1/%E7%AC%94%E8%AE%B0/assets/1557838354322.png)]

  • vi的特点

    • 只能是编辑 文本内容, 不能对 字体 段落进行排版
    • 不支持鼠标操作
    • 没有菜单
    • 只有命令
  • vi编辑器在 系统管理 服务器管理 编辑文件时, 其功能永远不是图形界面的编辑器能比拟的

1.2.2 VIM

vim = vi improved
viM 是从vi发展出来的文本编辑器, 支持代码补全、编译 及 错误跳转等方便编程的功能提别丰富, 在程序员中被广泛使用, 被称为编辑器之神

2 打开和新建文件

  • 在终端中输入vim在后面跟上 文件名 即可
vim 文件名
  • 如果文件已经存在, 会直接打开该文件
  • 如果文件不存在, 保存且退出时 就会新建一个文件
1 vim 没有的文件名
2 编辑内容
	2.1 编写类
	2.2 输出一行语句
	2.3 复制粘贴 2.2内容 19次
	2.4 保存且退出
3 查看

注意: 本节重点是 打开 和 新建文件, 其他命令后面会一一讲解

[root@node01 export]# cd /export/ && rm -rf *
[root@node01 export]# vim Hello.java
public class Hello {

        public static void main(String[] args) {
                System.out.println("Hello World!");
                // 1 将光标移动到上一行, 按 yy
                // 2 按 ESC 键 退出编辑模式
                // 3 按 19p
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                System.out.println("Hello World!");
                // 1 按 ESC 退出编辑模式
                // 2 按 : 进入莫行模式
                // 3 输入 wq(write quit)保存且退出 按回车键执行 
        }
}

2.1 打开文件并且定位行

  • 在日常工作中, 有可能会遇到打开一个文件, 并定位到指定行的情况
  • 例如: 在开发是, 知道某一行代码有错误, 可以 快速定位 到出错误代码的位置
  • 这个时候, 可以使用以下命令打开文件
vim 文件名 +行数
[root@node01 export]# vim Hello.java +10

2.2 异常处理

  • 如果 vi 异常退出, 在磁盘上可能会保存有 交换文件
  • 下次再使用 vi 编辑文件时, 会看到以下屏幕信息, 按下字母 d 删除交换文件即可

提示: 按下键盘时, 注意关闭输入法

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xveW5pFk-1618325440071)(day02.assets/1564497368689.png)]

  • 如何产生
    • 编辑文件, 没有退出, 关闭回话窗口

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JLlGWA2o-1618325440072)(day02.assets/1564497274207.png)] .

2.3 VI三种工作模式

  • VI有三种工作模式
  1. 命令模式
    • 打开文件首先进入命令模式, 是使用vi的入口
    • 通过 命令 对文件进行常规的编辑操作, 例如 定位 翻页 复制 粘贴 删除 … …
    • 在其他图形编辑器下, 通过 快捷键 或者 鼠标 实现的操作, 都在 命令模式 下实现
  2. 末行模式 – 执行 保存 退出等操作
    • 要退出 vi 返回到控制台, 需要在莫行模式下输入命令
    • 末行模式 是 vi 的出口
  3. 编辑模式 – 正常的编辑文字

工作模式切换

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-09OQAVcn-1618325440074)(…/…/…/…/…/%E5%A4%87%E8%AF%BE/linux/vim%E7%BC%96%E8%BE%91%E5%99%A8_%E5%88%98%E5%87%A1/%E7%AC%94%E8%AE%B0/assets/1557848331423.png)]

2.4 末行模式命令

命令英文功能
wwrite保存
qquit退出,如果没有保存,不允许退出
q!quit强行退出,不保存退出
wqwrite & quit保存且退出(莫行模式)
x保存并退出(莫行模式)
ZZ保存并退出(命令模式)

4 常用命令

命令线路图

  1. 重复次数
  • 在命令模式下, 先输入一个数字, 再加上一个命令, 可以让该命令 重复执行n次, 如: 19p
  1. 移动和选择(多练)
    vi之所以快, 关键在于 能够快速定位到要编辑的代码行
    移动命令 能够和 编辑操作 组合使用
  2. 编辑操作
    • 删除 复制 粘贴 替换 缩排
  3. 撤销和重复
  4. 查到替换
  5. 编辑

学习提示

  1. vi命令较多, 不要期望一下子全部都记住, 个别命令忘记了, 只是会影响编辑速度而已
    . 在使用vi命令时, 注意 关闭中文输入法

4.1 移动

要熟练使用vi, 首先应该学会怎么在 命令模式下 快速移动光标
编辑操作命令 能够和移动命令一起使用

1) 上 下 左 右

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-c0USoYxU-1618325440074)(assets/1558278451153.png)]

命令功能手指
h向左食指
j向下食指
k向上中指
l向右无名指

2) 行内移动

命令英文功能
wword向后移动一个单词
bback向前移动一个单词
0行首
^行首, 第一个不是空白字符的位置
$行尾

3) 行数移动

命令英文功能
gggo文件顶部
Ggo文件末尾
数字gggo移动到 数字 对应行数
数字Ggo移动到 数字 对应行数
: 数字移动到数字对应的 行数

4) 屏幕移动

命令英文功能
Ctrl + bback向上翻页
Ctrl + fforward向下翻页
HHead屏幕顶部
MMiddle屏幕中间
LLow屏幕底部

4.2 移动(程序)

1) 段落移动

  • vim中使用 空行 来区分段落

  • 程序开发时, 通常 一段功能相关的代码会写在一起 – 之间没有空行

    命令功能
    {上一段
    }下一段

2) 括号切换

  • 在程序世界中, **()、[]、{}**使用率很高, 而且 都是成对出现的.

    命令功能
    %括号匹配及切换

3) 标记

  • 在开发时, 某一块代码可能需要稍后处理, 例如: 编辑、查看
  • 此时先试用 m 增加一个标记, 这样可以 在需要时快速的跳转回来 或者 执行其他编辑操作
  • 标记名称 可以是 a~z 或者 A~Z 之间的任意 一个 字母
  • 添加了标记的 行如果删除, 标记同时被删除
  • 如果 在其他行添加了相同名称的标记, 之前添加的标记也会被替换掉
命令英文功能
mxmark添加编辑x, x是a~z 或者 A~Z的任意一个字母
'x直接定位到标记x所在的位置

4.3 选中文本(可视模式)

  • 学习 复制 命令前, 应该先学会 怎么样选中 要复制的代码
  • 在 vi 中要选择文本, 需要显示 visual 命令切换到 可视模式
  • vi 中提供了 三种 可视模式, 可以方便程序员的选择 选中文本的方式
  • 按 ESC 可以放弃选中, 返回到 命令模式
命令模式功能
v可视模式从光标位置开始按照正常模式选择文本
V可视化模式选中光标经过的完整行
Ctrl + v可是块模式垂直方向选中文本
  • 可视模式下, 可以和 移动命令 连用, 例如 ggVG 能够 选中所有的内容

4.4 撤销和恢复撤销(保命指令)

在学习编辑命令之前,先要知道怎样撤销之前一次 错误的 编辑操作

命令英文功能
uundo撤销上次的命令(ctrl + z)
Ctrl + ruredo10dd恢复撤销的命令

4.5 删除文本

命令英文功能
xcut删除光标所在的字符,或者选中的文字
d(移动命令)delete删除移动命令对应的内容
dddelete删除光标所在行, 可以ndd删除多行
Ddelete删除至行尾

提示: 如果使用 可视模式 已经选中了一段文本, 那么无论使用 d 还是 x, 都可以删除选中文本

删除命令可以和移动命令连用, 以下是常见的组合命令(扩展):

命令作用
dw从光标位置删除到单词末尾
d0从光标位置删除到一行的起始位置
d}从光标位置删除到段落末尾
ndd从光标位置向下连续删除 n 行
d’a从光标所在行 删除到 标记a 之间的所有代码

4.6 复制和剪切

  • vi 中提供有一个 被复制文本的缓冲区
    • 复制 命令会将选中的文字保存在缓冲区
    • 删除 命令删除的文字会被保存在缓冲区
    • 在需要的位置, 使用 粘贴 命令可以将缓冲对的文字插入到光标所在的位置
命令英文功能
y(复制命令)copy复制
yycopy复制一行,可以nyy复制多行
d(剪切命令)delete剪切
dd(剪切)delete剪切一行, 可以 ndd 剪切n行
ppaste粘贴

提示:

  • 命令 d 、x 类似于图形界面的 剪切操作 – ctrl + x
  • 命令 y 类似于 图形界面的 复制操作 – Ctrl +
  • 命令 p 类似于图形界面的 粘贴操作 – Ctrl + v
  • vi中的文本缓冲区只有一个,如果后续做过 复制、剪切操作, 之前缓冲区中的内容会被替换.

注意

  • vi中的 文本缓冲区 和 系统的 剪切板 不是同一个
  • 所以在其他软件中使用 Ctrl + C 复制的内容, 不能再 vi 中通过 p 命令粘贴
  • 可以在 编辑模式 下使用 鼠标右键粘贴

4.7 替换

命令英文功能工作模式
rreplace替换当前字符命令模式
Rreplace替换当前行光标后的字符替换模式
  • R 命令可以进入 替换模式, 替换完成后, 按下ESC , 按下 ESC 可以回到 命令模式
  • 替换命令 的作用就是不用进入 编辑模式, 对文件进行 轻量级的修改

4.8 缩排和重复执行

命令功能
>>向右增加缩进
<<向左减少缩进
.重复上次命令
  • 缩进命令 在开发程序时, 统一增加代码的缩进 比较有用!
    • 一次性 在选中代码前增加 4 个空格, 就叫做 增加缩进
    • 一次性 在选中代码前删除 4 个空格, 就叫做 较少缩进
  • 可视模式 下, 缩排命令 主需要使用 一个 > 或者 <

在程序中, 缩进 通常用来表示代码的归属关系

  • 前面空格越少, 代码的级别越高
  • 前面空格越多, 代码的级别越低

4.9 查找

常规查找

命令功能
/str查找str
  • 查找到指定内容之后, 使用 Next 查找下一个出现的位置

    • n : 查找下一个
    • N : 查找上一个
  • 如果不想看到高亮显示, 可以随便查找一个文件中不存在的内容即可

  • 单词快速匹配

命令功能
*向后查找当前光标所在单词
#向前查找当前光标所在单词
  • 在开发中, 通过单词快速匹配, 可以快速看到这个单词在其他位置使用过

4.10 查找并替换

  • vi 中查找和替换命令需要在 末行模式 下执行
  • 记忆命令格式
:%s///g
  1. 全局替换
  • 一次向 替换文件中的 所有出现的旧文本

  • 命令格式如下

    :%s/旧文本/新文本/g
    
  1. 可视区域替换
  • 先选中 要替换文字的 范围
  • 命令格式如下
:s/旧文本/新文本/g
  1. 确认替换:

c confirm 确认

  • 如果把末尾的 g 改成 gc 在替换的时候, 会有提示! 推荐使用

  • 命令格式如下

    :%s/旧文本/新文本/gc
    
  1. y - yes 替换
  2. n - no 不替换
  3. a - all 替换所有
  4. q -quit 退出替换
  5. l - last 最后一个, 并把光标移动到行首
  6. ^E 向下滚屏
  7. ^Y 向上滚屏

4.11 插入命令(重点重点重点)

  • 在 vi 中除了常用 i 进入编辑模式 外, 还提供了一下命令同样可以进入编辑模式
命令英文功能常用
iinsert在当前字符前插入文本常用
Iinsert在行首插入文本较常用
aappend在当前字符后添加文本
Aappend在行末添加文本较常用
o在当前行后面插入一空行常用
O在当前行前面插入一空行常用

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-o4X9K9J6-1618325440075)(assets/1558543477231.png)]

4.12 练习

演练1 – 编辑命令 和 数字连用

  • 在开发中, 可能会遇到连续输入 N 个同样的字符
  • 例如: ********** 连续10个星号

要实现这个效果可以在 命令模式 下:

  1. 输入 10, 表示要重复10次
  2. 输入 i 进入 编辑模式
  3. 输入 * 也就是重复的文字
  4. 按下 ESC 返回 命令模式, 返回之后 vi 就会把 第 2、3 两步的操作重复 10

提示: 正常开发时, 在 进入编辑模式之前,不要按数字

演练2 – 利用 可视块 给多行代码增加注释

  • 在开发中, 可能会遇到一次向给多行代码 增加注释 的情况

在java中, 要给代码增加注释, 可以在代码

前增加一个 //

要实现这个效果可以在 命令模式

  1. 移动到要添加注释的 第1行代码, 按 ^ 来到行首
  2. Ctrl + v 进入 可视化 模式
  3. 使用 j 向下连续选中要添加的代码行
  4. 输入 I 进入编辑模式 , 并在 行首插入, 注意: 一定要使用 I
  5. 输入 // 也就是 注释符号
  6. 按下 ESC 返回到 命令::模式, 返回之后 vi 会在之前选中的每一行代码 前 插入 //

演练3: 坦克大战案例(另存为 备份)

  • 已经学习过的 末行命令
命令英文功能
:w 文件另存为
:wwrite保存(ctrl + s)
:qquit退出, 如果没有保存,不允许退出
:q!quit强行退出, 不保存退出
:wqwrite & quit保存并退出
:x保存并退出

在实际开发中, 可以使用 w 命令 阶段性的备份代码

用户权限相关命令

目标

  • 理解 用户权限 的基本概念
  • 用户管理 终端命令
  • 组管理 终端命令
  • 修改权限 终端命令

01.用户和权限的基本概念

1.1 基本概念

  • 用户 是Linux系统工作中重要的一环, 用户管理包括 用户 管理

  • 在Linux系统中, 不论是由本级或是远程登录系统, 每个系统都必须拥有一个账号, 并且对于不同的系统资源拥有不同的使用权限

  • 文件 / 目录 的权限包括:

序号权限英文缩写数字序号
01readr4
02writew2
03执行executex1
04无权限-0
  • 在 Linux中 ,可以指定 每一个用户 针对 不同的文件或者目录不同权限

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-djYTTZj0-1618325440076)(assets/1558581559021.png)]

1.2 组

  • 为了方便用户管理, 提出了 的概念, 如下图所示[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QauWwX7j-1618325440076)(assets/1558487112521.png)]

1.3 ls -l 扩展

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hFk8Odzl-1618325440077)(…/…/…/…/…/00_%E8%AF%BE%E4%BB%B6/01_linux/201905/%E7%AC%94%E8%AE%B0/assets/1558012930591.png)]

  • ls -l 可以查看文件夹下文件的详细信息, 从左到右 依次是:

    • 权限, 第一个字符如果是 d 表示目录
    • 硬链接数, 通俗的讲就是有多少种方式, 可以访问当前目录和文件
    • 拥有者, 家目录下 文件 / 木兰路 的拥有者通常都是 当前用户
    • , 在linux中, 很多时候, 会出现组名 和 用户名 相同的情况, 后续会讲
    • 大小
    • 时间
    • 名称

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WQIrXZMy-1618325440078)(assets/1558487141422.png)]

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GVpHJmC2-1618325440078)(assets/1558583116607.png)]

02.组管理 终端命令

本质: 给 同一类型用户 分配权限

序号命令作用
01groupadd 组名添加组
02groupdel 组名删除组
03cat /etc/group确认组信息
04chgrp 组名 文件/目录名修改文件/目录的所属组

提示:

  • 组信息保存在 /etc/group 文件中
  • /etc 目录是专门用来保存 系统配置信息 的目录
  • 在实际应用中, 可以预先针对 设置好权限, 然后 将不同的用户添加到对应的组中, 从而不用依次为每一个用户设置权限

chgrp : change group

演练目标

  1. 在 指定目录下 创建 aaa 目录
  2. 新建 dev
  3. aaa 目录的组修改为 dev
[root@node01 export]# mkdir -p aaa/
[root@node01 export]# ll
total 4
drwxr-xr-x. 2 root root 4096 Jul 31 06:48 aaa
[root@node01 export]# chgrp dev aaa/
[root@node01 export]# ll
total 4
drwxr-xr-x. 2 root dev 4096 Jul 31 06:48 aaa

03.用户管理 终端命令

3.1 创建用户 / 设置密码 / 删除用户

命令作用说明
useradd -m -g 组 新建用户名添加新用户-m 自动建立用户家目录
-g 指定用户所在的组, 否则会建立一个和同名的组
passwd 用户名设置用户密码如果是普通用户,
直接用 passwd可以修改自己的账号密码
userdel -r 用户名删除用户-r 选项会自动删除用户家目录
cat /etc/passwd | grep 用户名确认用户信息新建用户后,用户信息会保存在 /etc/passwd文件夹中

提示:

  • 创建用时, 如果忘记添加 -m 选项指定新用户的家目录 – 最简单的方式就是删除用户,重新创建
  • 创建用户时, 默认会创建一个和用户名同名的组名
  • 用户信息保存在 /etc/passwd 文件中

/etc/passwd 文件存放的是用户的信息, 由6个分好组成的7个信息, 分别是

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xuFOH2FA-1618325440079)(…/…/…/…/…/00_%E8%AF%BE%E4%BB%B6/01_linux/201905/day02_%E6%89%93%E5%8C%85%E5%8E%8B%E7%BC%A9_vim%E7%BC%96%E8%BE%91%E5%99%A8_%E7%B3%BB%E7%BB%9F%E7%AE%A1%E7%90%86_%E7%94%A8%E6%88%B7%E6%9D%83%E9%99%90/%E7%AC%94%E8%AE%B0/assets/1558487197175.png)]

  1. 用户名
  2. 密码 (x, 表示加密的密码)
  3. UID (用户标志)
  4. GID(组标志)
  5. 用户全名或本地账号
  6. 家目录
  7. 登录使用的Shell, 就是登录之后, 使用的终端命令

需求

1 创建用户 zhangsan, 指定归属于 dev 组
2 设置用户 zhangsan 的密码
3 查看配置文件中是否增加用户 zhangsan 观察 zhangsan 的家目录是否创建
4 删除 zhangsan 用户
[root@node01 export]# useradd -m -g dev zhangsan
[root@node01 export]# passwd zhangsan
Changing password for user zhangsan.
New password: 
BAD PASSWORD: it is too simplistic/systematic
BAD PASSWORD: is too simple
Retype new password: 
passwd: all authentication tokens updated successfully.

[root@node01 export]# cat /etc/passwd | grep zhangsan
zhangsan:x:500:500::/home/zhangsan:/bin/bash
[root@node01 export]# tree /home
/home
└── zhangsan

[root@node01 export]# userdel -r zhangsan
[root@node01 export]# cat /etc/passwd | grep zhangsan
[root@node01 export]# tree /home
/home

3.2 查看用户信息

序号命令作用
01id [用户名]查看用户UID 和 GID 信息
02who查看当前所有登录的用户列表
03whoami查看当前登录用户的账户名
[root@node01 ~]# useradd -m -g dev lisi
[root@node01 ~]# passwd lisi
Changing password for user lisi.
New password: 
BAD PASSWORD: it is too simplistic/systematic
BAD PASSWORD: is too simple
Retype new password: 
passwd: all authentication tokens updated successfully.
[root@node01 ~]# id lisi
uid=500(lisi) gid=500(dev) groups=500(dev)
[root@node01 ~]# who
root     pts/0        2019-07-31 07:02 (192.168.100.2)
[root@node01 ~]# whoami
root

3.3 su 切换用户

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LZHdqdrx-1618325440079)(assets/1558614565424.png)]

  • 因为 普通用户 不能使用某些权限, 所以需要 切换用户
序号命令作用说明
01su - 用户名切换用户, 并且企划目录- 可以切换到用户家目录, 否则保持位置不变
02exit退出当前登录用户
  • su 不接用户名, 可以切换到 root , 但是不推荐使用, 因为不安全
  • exit 示意图如下:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1UMOAy1U-1618325440080)(assets/1558487219340.png)]

[lisi@node01 ~]$ whoami
lisi
[lisi@node01 ~]$ su - root
Password: 
[root@node01 ~]# whoami
root
[root@node01 ~]# exit
logout
[lisi@node01 ~]$ whoami
lisi

3.4 sudo

  • 虽然 通过 su -u root 可以切换到 root用户, 但是 存在严重的 安全隐患
  • linux系统中的 root 账号通常 用于系统的维护和管理, 对操作系统的所有资源 具有访问权限

  • 如果不小心使用 rm -rf ... ... , 就可能将系统搞瘫痪

  • 在大多数版本的linux中, 都不推荐 直接只用 root 账号登录系统

  • sudo 命令用来以其他身份来执行命令, 预设的身份为 root

  • 用户使用 sudo 时, 必须先输入密码, 之后5分钟的有效期限, 超过期限则必须重新输入密码

    提示: 若其未经授权的用户企图使用 sudo, 则会发出警告邮件给管理员

3.4.1 给 指定用户 授予 权限

  • 本质: 通知 服务器 给 特定用户 分配 临时管理员权限

vim /etc/sudoers

# 默认存在: root用户 具备所有的权限
root    ALL=(ALL)       ALL

# 授予 lisi 用户 所有的权限
lisi    ALL=(ALL)       ALL 

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VpSK2IOo-1618325440081)(day02.assets/1564499316459.png)]

3.4.2 使用 用户 lisi 登录, 操作管理员命令

  • 本质: 使用临时管理员权限
# 不切换root用户, 也可以完成 添加用户的功能 
sudo useradd -m -g dev zhaoliu
[lisi@node01 ~]$ sudo useradd -m -g dev zhaoliu

We trust you have received the usual lecture from the local System
Administrator. It usually boils down to these three things:

    #1) Respect the privacy of others.
    #2) Think before you type.
    #3) With great power comes great responsibility.

[sudo] password for lisi: 
[lisi@node01 ~]$ sudo cat /etc/passwd | grep zhaoliu
zhaoliu:x:501:500::/home/zhaoliu:/bin/bash

准备工作: 使用root用户操作

# 清空目录中的内容
rm -rf /export/*

# 创建测试目录
mkdir -p /export/aaa/

# 创建测试文件
touch /export/aaa/01.txt /export/aaa/02.txt

# 查看指定目录内容
tree /export

04.修改用户权限

序号命令作用
01chmod修改权限

4.1 方式一: 修改用户权限

  • chmod 可以修改 用户/组文件/目录 的权限

  • 命令格式如下:

    chmod +/- rwx 文件名|目录名
    

    提示: 已上方式会一次向修改 拥有者 / 权限

目标演练:

# 1. 使用 root 删除目录的可读 可写 可执行权限

# 2. 使用 其他用户如 lisi 无法切换到 这个目录

# 3. 使用 root 增加目录的执行权限, 再次 使用 lisi 切换到目录试试

答案:# 1. 使用 root 删除目录的可读 可写 可执行权限

[root@node01 export]# ll
total 4
drwxr-xr-x. 2 root root 4096 Jul 31 07:10 aaa
[root@node01 export]# chmod -rwx aaa/
[root@node01 export]# ll
total 4
d---------. 2 root root 4096 Jul 31 07:10 aaa

需求2答案: 使用 其他用户如 lisi 无法切换到 这个目录

[lisi@node01 ~]$ cd /export/
[lisi@node01 export]$ ll
total 4
d---------. 2 root root 4096 Jul 31 07:10 aaa
[lisi@node01 export]$ cd aaa/
-bash: cd: aaa/: Permission denied

需求3答案: 使用 root 增加目录的执行权限, 再次 使用 lisi 切换到目录试试

[root@node01 export]# chmod +x aaa/
[root@node01 export]# ll
total 4
d--x--x--x. 2 root root 4096 Jul 31 07:10 aaa
[lisi@node01 export]$ cd aaa/
[lisi@node01 aaa]$ pwd
/export/aaa

4.2 方式二

  • 虽然 方式一 直接修改文件|目录读|写|执行 权限, 但是不能精确到 拥有者|组|其他 权限
  • 命令格式如下:( u 表示所属用户 / g 表示所属组 / o 表示其他)
chmod -R u=rwx,g=rx,o=rwx 文件|目录
序号权限英文缩写数字序号
01readr4
02writew2
03执行executex1
04无权限-0

目标演练:

# 1 使用root用户给 所属用户分配 可读、可写、可执行 权限, 
    所属组 分配 可读、可执行 权限, 
    其他人 分配 可读、可执行 权限 
[root@node01 export]# chmod u=rwx,g=rx,o=rx aaa/
[root@node01 export]# ll
total 4
drwxr-xr-x. 2 root root 4096 Jul 31 07:10 aaa

4.3 方式三: 简化方式二

  • 命令格式如下:
chmod -R 755 文件|目录
  • 说明 第一个数字拥有者权限, 第二个数字组权限, 第三个数字其他用户权限

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jmUgyqy2-1618325440081)(assets/1558487247085.png)]

常用数字组合有( u 表示用户 / g 表示组 / o 表示其他)

  • 777 ===> u=rwx, g=rwx, o=rwx
  • 755 ===> u=rwx, g=rx, o=rx
  • 644 ===> u=rw, g=r, o=r

目标演练:

# 1 使用root用户给 所属用户分配 可读、可写、可执行 权限, 
    所属组 分配 可读、可执行 权限, 
    其他人 分配 可读、可执行 权限 
[root@node01 export]# chmod 755 bbb/
[root@node01 export]# ll
total 8
drwxr-xr-x. 2 root root 4096 Jul 31 07:10 aaa
drwxr-xr-x. 3 root root 4096 Jul 31 07:19 bbb

系统信息相关命令

  • 本节内容主要是为了方便通过远程终端维护服务器时, 查看服务器上当前 系统日期和时间 / 磁盘空间占用情况 /程序执行情况
  • 本小结学习终端命令都是查询命令, 通过这些命令对系统资源的使用情况有个了解

目标

  • 时间和日期
    • date
    • cal
  • 磁盘和目录空间
    • df
    • du
  • 进程信息
    • ps
    • top
    • kill

1.时间和日期

1.1 date 时间

命令作用
date查看系统时间(默认)
date +"%Y-%m-%d %H:%M:%S"查看系统时间(指定格式)
date -s “时间字符串”设置系统时间

第一步: 显示当前时间

# 显示时间
date

# 按照指定格式显示时间
date +"%Y-%m-%d %H:%M:%S"

第二步: 设置系统时间

date -s "时间字符串"
[root@node01 export]# date
Wed Jul 31 07:20:31 CST 2019
[root@node01 export]# date +"%Y-%m-%d %H:%M:%S"
2019-07-31 07:20:49
[root@node01 export]# date -s '2019-07-31 20:21:49'
Wed Jul 31 20:21:49 CST 2019
[root@node01 export]# date +"%Y-%m-%d %H:%M:%S"    
2019-07-31 20:21:52

1.2 cal 日历

序号命令作用
01cal查看当前月的日历
02cal -y查看当前年的日历
03cal 2020查看2020年的日历
04cal 10 2020查看2020年10月的日历

02.磁盘信息

序号命令作用
01df -hdisk free 显示磁盘剩余空间
02du -h [目录名]disk usage 显示目录下的目录大小
03free -h查看内存使用率
  • 选项说明
参数含义
-h以人性化的方式显示文件的大小

03.进程信息

  • 所谓 进程, 通俗的说就是 当前正在执行的一个进程
序号命令作用
01ps auxprocess status 查看进程的详细情况
02top动态显示运行中进程并且排序
03kill [-9] 进程代号终止指定代号的进程 -9 表示强行终止

ps 默认只会显示当前用户通过终端启动的应用程序

  • ps 选项说明功能

    选项含义
    a显示终端上的所有进程,包括其他用户的进程
    u显示进程的详细状态
    x显示没有控制终端的进程

    提示: 使用kill命令时, 最好只终止由当前用户开启的进程, 而不要终止root身份开启的进程, 否则可能导致系统崩溃

  • 要退出 top 可以直接输入 q

这篇关于linux基础-2的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!