shell与shell script 学习总结

news2025/1/3 1:06:09

文章目录

  • shell与shell script 学习总结
  • vi
  • vim
    • 可视化区块
    • 多文件编辑
    • 多窗口功能
    • vim环境设置与记录
    • 中文编码问题
    • 语系编码转换
  • Shell的变量功能
    • 变量的使用与设置
      • echo(变量的使用)
      • 变量设置的规则
    • 环境变量的功能
      • env(观察环境变量)
      • set(观察所有变量)
      • unset(取消变量)
    • locale(语系变量)
    • read、declare、数组(变量键盘读取、数组与声明)
      • read
      • declare
      • 数组变量类型
    • ulimit(与文件系统及程序的限制关系)
    • 变量内容的删除、取代与替换
      • 变量内容的删除与替换
      • 变量的测试与内容替换
  • 命令别名、历史命令以及命令补全
    • history(命令历史记录)
    • ~/.bash_history(历史命令记录文件)
    • TAB(命令与文件补全)
    • alias、unalias(命令别名设置功能)
  • /etc/issue、/etc/motd(bash的登录与欢迎信息)
    • /etc/issue
    • /etc/motd
  • bash的环境配置文件
    • source(读入环境配置文件的命令)
    • stty、set(终端的环境设置)
  • 通配符与特殊符号
  • 数据流重定向
    • 使用案例
  • ;、&&、||(命令执行的判断根据)
    • 使用案例
  • 管道命令
    • cut(选取内容)
    • grep(搜索内容)
    • sort(排序命令)
    • uniq(显示重复的数据)
    • wc(查看文件内容多少字)
    • tee(双向重定向)
    • split(划分命令)
  • shell脚本

shell与shell script 学习总结

vi

vi共分为3种模式,分别是命令模式输入模式底线命令模式

使用【vi filename】进入命令模式

vi csq.txt

下面是比较常用的参数:

  1. i:进入插入模式,允许输入文字
  2. ESC:退出插入模式
  3. 0或[home]键:移动到这一行的最前面
  4. $或[end]键:移动到这一行的最后面
  5. :wq:保存文件并退出vi
  6. :q!:强制退出vi
  7. dd:删除当前行
  8. yy:复制当前行
  9. p:粘贴复制的内容
  10. /word:在文件内容里查找word字符串
  11. shift+g:移动到这个文件的最后一行
  12. gg:移动到这个文件的第一行

vim

vim是vi的升级版(vi能用的参数vim一样用),提供了更多功能和更好的性能。

可视化区块

  1. ctrl +v:可视化区块,可以用矩形的方式选择数据

  2. v:字符选择,会将光标经过的地方泛白选择

  3. y:将泛白的地方复制起来

  4. d:将泛白的地方删除掉

  5. p:将刚刚复制的区块,在光标所在处粘贴

下图就是使用ctrl + v可视化区块,矩形的方式展现

image-20230505193100190

多文件编辑

  1. :n:编辑下一个文件
  2. :N:编辑上一个文件
  3. :files:列出目前这个vim开启的所有文件

通过【vim csq csqcsq.txt 】来打开两个文件

image-20230505210418284

多窗口功能

  1. :sp[filename]:打开一个新窗口,如果有加filename,表示在新窗口创建一个新文件,否则表示两个窗口为同一个文件内容(同步显示)
  2. ctrl + w + ↓:光标可移动到下方窗口
  3. ctrl + w + ↑:光标可移动到上方窗口

使用【vim csq】然后再划分窗口,打开csqcsq.txt文件

image-20230505211413283

vim关键词补全功能

【ctrl + x】 => 【ctrl + n】 通过目前正在编辑的这个【文件的内容文字】作为关键字,给予补齐

【ctrl + x】=> 【ctrl + f】 以当前目录内的文件名作为关键词,给予补齐

【ctrl + x】=> 【ctrl + o】 以扩展名为语法补充,以vim内置的关键词,给予补齐

vim环境设置与记录

常用的vim环境设置参数:

  1. set nu:显示行号
  2. set hlsearch:高亮搜索结果
  3. set autoindent:自动缩进

~/.vimrc是Vim的配置文件,其中包含了用户自定义的Vim设置,例如键映射、颜色方案、插件设置等等。每当Vim启动时,它会读取这个文件来初始化用户的配置。

[root@localhost ~]# vim .vimrc
set nu
set autoindent
set hlsearch

~/.viminfo是Vim的历史记录文件,其中保存了用户在Vim中使用的命令、搜索、缓冲区等等信息。当用户下次启动Vim时,它会读取这个文件来恢复上次的会话,使得用户可以继续上次的编辑工作。用户也可以通过设置来控制Vim保存哪些信息到这个文件中。

[root@localhost ~]# vim .viminfo

image-20230505213151656

中文编码问题

遇到无法正常显示中文可能是编码问题可以使用

LANG=zh_CN.UTF-8
export LC_ALL=zh_CN.UTF-8

语系编码转换

将/root/csq 从BIG-5编码转换为UTF-8编码

iconv -f BIG-5 -t UTF-8 csq 
# -f:就是来源的意思,后面接原本的编码格式
# -t:就是后来的新编码是什么格式

最后使用file命令查看是否修改成功

file

Shell的变量功能

变量的使用与设置

echo(变量的使用)

打印出${PATH}的变量

[root@csq ~]# echo ${PATH}
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin

设置PATH的变量

[root@csq ~]# PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:~/shelldir
[root@csq ~]# echo ${PATH}
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/root/shelldir

变量设置的规则

  1. 变量名必须以字母或下划线开头,不能以数字开头。
  2. 变量名只能包含字母、数字和下划线。
  3. 变量名区分大小写。
  4. 变量赋值时,等号两侧不能有空格,例如:
name="John" # √ 正确
name = "John" # × 错误
  1. 如果变量值中包含空格或特殊字符,需要使用引号将变量值括起来。单引号和双引号的作用略有不同:
  • 单引号:单引号中的文本会被原样输出,变量不会被解析。例如:
[root@csq ~]# name='csqcsq'
[root@csq ~]# echo ${name}
csqcsq
  • 双引号:双引号中的变量会被解析,可以在变量中插入其他文本。例如:
[root@csq ~]# name="chenshiren"
[root@csq ~]# echo "My name is ${name}"
My name is chenshiren
  1. 变量可以被重新赋值,例如:
[root@csq ~]# name="csq"
[root@csq ~]# echo ${name}
csq
[root@csq ~]# name="zhw"
[root@csq ~]# echo ${name}
zhw
  1. $()括号中的命令会被执行,并将输出结果返回给变量。
  • $()也可以嵌套使用,例如:
[root@csq ~]# name=$(echo "csq")
[root@csq ~]# echo ${name}
csq
  • 可以将$()和其他变量组合使用,例如:
[root@csq ~]# dir=$(pwd)
[root@csq ~]# echo ${dir}
/root
# 输出为当前目录的路径
  • $(( ))是算数扩展语法,它用于进行数学运算
[root@csq ~]# sum=$((5 * 5 ))
[root@csq ~]# echo ${sum}
25
  1. 如果你变量中想输入空格可以利用转义字符
[root@csq ~]# name=csq\ zhw
[root@csq ~]# echo ${name}
csq zhw

环境变量的功能

环境变量是一种全局变量,用于存储系统信息或用户配置信息

env(观察环境变量)

列出目前shell环境下所有环境变量与其内容

[root@csq ~]# env
HISTSIZE=1000
USER=root
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/root/shelldir
LANG=zh_CN.UTF-8
HOME=/root
# 删除了一部分仅列出了常用的环境变量
  1. USER:指定当前的用户名

  2. HOME:指定当前用户的主目录

  3. PATH:指定系统在执行命令的时候需要搜索的路径

  4. LANG:指定系统的语言设置

  5. HISTSIZE:指内存中记录的历史命令最大条数

  6. RANDOM:这个环境变量在/dev/random。我们可以通过${RANDOM}来使用他,系统会随机取出一个介于0~32767的数值。

    • 如果我想要取出0~9的数值

      [root@csq ~]# suijinu=$((${RANDOM}*10/32768))
      [root@csq ~]# echo ${suijinu}
      3
      

set(观察所有变量)

set 和env不同的是可以观察环境变量和自定义变量

[root@localhost ~]# set
BASH=/bin/bash    # bash的主程序路径
BASH_VERSINFO=([0]="4" [1]="2" [2]="46" [3]="2" [4]="release" [5]="x86_64-redhat-linux-gnu")                            
BASH_VERSION='4.2.46(2)-release'   # 这两行是bash的版本
COLUMNS=109                        # 在目前的终端环境下,使用的栏位有几个字符长度   
HISTFILE=/root/.bash_history       # 历史命令记录的放置文件,隐藏文件
HISTFILESIZE=1000                  # 历史命令文件最大记录数1000(存在上面这个变量文件里)
HISTSIZE=1000                      # 内存中记录历史命令条数最大1000条
IFS=$' \t\n'                       # 默认的分隔符号
LINES=24                           # 目前终端下的最大行数
MACHTYPE=x86_64-redhat-linux-gnu   # 安装的机器类型
OSTYPE=linux-gnu                   # 操作系统类型
PS1='[\u@\h \W]\$ '                # 命令提示符
PS2='> '                           # 如果你使用转义字符(\),这是第二行以后的提示字符
$                                  # 目前中shell所使用的PID
?  

PS1:Shell提示符的格式

PS1常见的参数详解

  1. \u:目前用户的名称
  2. @:显示时间,12小时格式的【am:pm】样式
  3. \t:显示时间,24小时哥哥是的【HH:MM:SS】
  4. \h:仅取主机名在第一个小数点之前的名字。
  5. \W:获取正在工作目录的名称
  6. \KaTeX parse error: Expected 'EOF', got '#' at position 13: :如果是root,就提示#̲,否则是

简单的设置一下Shell提示符格式

[root@localhost ~]# PS1='[\u \@ \h \W] \$ '

image-20230506173516415

$(关于本shell的PID)

美元符本身就是个变量,代表的是目前这个shell的进程号

[root 05:37 下午 localhost ~] # echo $$
1963

?(关于上个执行命令的返回值)

例如你执行命令发生错误

[root 05:39 下午 localhost ~] # sl
-bash: sl: 未找到命令
[root 05:39 下午 localhost ~] # echo $?
127

export(自定义变量转成环境变量)

export主要作用就是将自定义变量转换成环境变量。子进程会继承父进程的环境变量,子进程不会继承父进程的自定义变量。我们设置的自定义变量进入子进程后会消失不见,一直到你离开子进程并回到父进程变量才会出现

[root@localhost ~]# name=csq
[root@localhost ~]# bash
[root@localhost ~]# echo ${name}

[root@localhost ~]# exit
exit
[root@localhost ~]# echo ${name}
csq

当我们使用export后将name转换为环境变量就可以在子进程中使用了

[root@localhost ~]# export name
[root@localhost ~]# bash
[root@localhost ~]# echo ${name}
csq

image-20230423142954077

unset(取消变量)

[root@csq ~]# unset name
[root@csq ~]# echo ${name}
         # 没有变量就什么也不会输出

locale(语系变量)

Linux支持多少语系呢?

[root@localhost ~ 14:45:43]# locale -a
......
...
zh_CN
zh_CN.gb18030    # gbk 中文编码
zh_CN.gb2312
zh_CN.gbk     
zh_CN.utf8       # 简体中文编码
....
....

如何自定义编码?

# 通常来说只用设置 LANG 和 LC_ALL 这两个变量。
[root@localhost ~]# locale
LANG=zh_CN.UTF-8
LC_CTYPE="zh_CN.UTF-8"
LC_NUMERIC="zh_CN.UTF-8"
LC_TIME="zh_CN.UTF-8"
LC_COLLATE="zh_CN.UTF-8"
LC_MONETARY="zh_CN.UTF-8"
LC_MESSAGES="zh_CN.UTF-8"
LC_PAPER="zh_CN.UTF-8"
LC_NAME="zh_CN.UTF-8"
LC_ADDRESS="zh_CN.UTF-8"
LC_TELEPHONE="zh_CN.UTF-8"
LC_MEASUREMENT="zh_CN.UTF-8"
LC_IDENTIFICATION="zh_CN.UTF-8"
LC_ALL=

也可以通过修改系统的默认语系文件,可以自定义语系

[root@localhost ~]# cat /etc/locale.conf 
LANG="zh_CN.UTF-8"

read、declare、数组(变量键盘读取、数组与声明)

read

要读取来自键盘输入的变量,就是用read这个命令。

read -pt 变量
选项:
-p:后面接提示字符
-t:后面可以接等待的秒数

使用案例

询问用户是否喜欢Linux

[root@localhost ~]# read -p "我喜欢学习Linux,你呢?" stdin
我喜欢学习Linux,你呢?i like        
[root@localhost ~]# echo ${stdin}
i like

询问用户是否喜欢Linux如果3秒钟不回答就退出

[root@localhost ~]# read -p "我喜欢学习Linux,你呢?" -t 3 stdin
我喜欢学习Linux,你呢?[root@localhost ~]# 
# 超时了

declare

declare就是命令声明变量的类型的。

declare [-aixr] 变量
选项:
-a:将后面名为 xxx的变量定义为数组类型
-i:将后面名为 xxx的变量定义为整数类型
-x:将后面的xxx变量变成环境变量
-r:将变量设置为只读类型,不能被更改也不能被unset
-p:单独列出变量的类型

使用案例

让变量sum进行300+200+100求和

[root@localhost ~]# declare -i sum=300+200+100
[root@localhost ~]# echo ${sum}
600

将sum变成环境变量

[root@localhost ~]# declare -x sum
[root@localhost ~]# bash
[root@localhost ~]# echo ${sum}
600

将sum变成非环境变量

[root@localhost ~]# declare +x sum
[root@localhost ~]# bash
[root@localhost ~]# echo ${sum}

列出sum的类型

[root@localhost ~]# declare -p sum
declare -i sum="600"
# 仅有-i的参数

数组变量类型

数组的设置方式

var[1]=csq

意思就是数组名为var,第一个数组内容为 csq,可以自行设置第二个第三个…(重点要用中括号来设置)

ulimit(与文件系统及程序的限制关系)

ulimit是Linux系统中用于设置和显示用户进程资源限制的命令。它可以用于限制用户进程使用系统资源的数量,例如CPU时间、内存、打开文件数等。

ulimit [-af] 配额

使用案例

列出你目前身份【假设为一般账号】的所有限制数值

[root@localhost ~]# su - zzh
[zzh@localhost ~]$ ulimit -a
core file size          (blocks, -c) 0          # 只要是0就是代表没限制
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited  # 可建立单一的文件大小
pending signals                 (-i) 31116
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited  # 同时可开启的文件数量
open files                      (-n) 1024
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 4096
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

限制使用者仅能建立10MB以下的容量文件

[root@localhost ~]# ulimit -f 10240
[zzh@localhost ~]$ ulimit -a
core file size          (blocks, -c) 0
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) 10240
pending signals                 (-i) 31116
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 1024
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 4096
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited
[zzh@localhost ~]$ dd if=/dev/zero of=csq bs=1M count=20
文件大小超出限制

变量内容的删除、取代与替换

变量内容的删除与替换

变量设置方式说明
KaTeX parse error: Expected '}', got '#' at position 4: {变量#̲关键词}<br/>②{变量##关键词}①若变量内容从头开始的数据符合【关键词】,则将符合的最短数据删除
②若变量内容从头开始的数据符合【关键词】,则将符合最长数据删除
KaTeX parse error: Expected '}', got 'EOF' at end of input: {变量%关键词}<br/>②{变量%%关键词}①若变量内容从尾向前的数据符合【关键词】,则将符合的最短数据删除
②若变量内容从尾向前的数据符合【关键词】,则将符合的最长数据删除
变量 / 旧字符串 / 新字符串 < b r / > ② {变量/旧字符串/新字符串}<br/>② 变量/旧字符串/新字符串<br/>{变量//旧字符串/新字符串}①若变量内容符合【旧字符串】则【第一个旧字符串会被新字符串替换】
②若变量内容符合【旧字符串】则【全部的旧字符串会被新字符串替换】

使用案例

  1. #和##

让小写的path自定义变量设置的与PATH内容相同

[root@localhost ~]# path=${PATH}
[root@localhost ~]# echo ${path}
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin

假设我不喜欢local/bin,所以要将前一个目录删除掉怎么做?

[root@localhost ~]# echo ${path#/*local/bin:}
/usr/sbin:/usr/bin:/root/bin

删除前面所有的目录,仅保留最后一个目录

[root@localhost ~]# echo ${path##/*:}
/root/bin
  1. %和%%

我想要删除最后面的那个目录,就是从:到bin为止的字符

[root@localhost ~]# echo ${path%:*bin}
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin

那如果我只想要保留第一个目录?

[root@localhost ~]# echo ${path%%:*bin}
/usr/local/sbin
  1. /和//

将path的变量内容内的sbin替换成大写的SBIN

[root@localhost ~]# echo ${path/sbin/SBIN}
/usr/local/SBIN:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin

将path变量中的所有sbin变成大写

[root@localhost ~]# echo ${path//sbin/SBIN}
/usr/local/SBIN:/usr/local/bin:/usr/SBIN:/usr/bin:/root/bin

变量的测试与内容替换

变量内容的替换可以使用一些特殊符号来进行。

-符号的作用是在变量不存在或为空时使用默认值

:-符号的作用是在变量不存在或为空时使用默认值,并将其赋值给变量

=符号将右侧的值赋给左侧的变量。如果变量已经存在,则将其值替换为右侧的值

?符号用于错误处理。如果变量不存在或为空,则输出错误信息,并退出当前脚本

测试(-)用法

假设abc不存在(用unset),然后测试一下减号(-)用法

[root@localhost ~]# unset abc; def=${abc-xixixi}
[root@localhost ~]# echo "def=${def},abc=${abc}"
def=xixixi,abc=  

若abc已经存在,测试一下def会怎么样

[root@localhost ~]# abc=csq; def=${abc-xixixi}
[root@localhost ~]# echo "def=${def},abc=${abc}"
def=csq,abc=csq     

假设abc为空字符,测试一下def会怎么样

[root@localhost ~]# abc=""; def=${abc-xixixi}
[root@localhost ~]# echo "def=${def},abc=${abc}"
def=,abc=           

测试:-的用法

-和:- 的区别就是:-能设置空字符,-不能

假设abc为空字符,测试一下def会怎么样

[root@localhost ~]# abc=""; def=${abc:-xixixi}
[root@localhost ~]# echo "def=${def},abc=${abc}"
def=xixixi,abc=     

测试=的用法

如果你想要将旧变量内容也一起替换掉,就使用【=】

假设abc不存在,然后测试一下【=】的用法

[root@localhost ~]# unset abc; def=${abc=xixixi}
[root@localhost ~]# echo "def=${def},abc=${abc}"
def=xixixi,abc=xixixi

如果abc存在,然后再测试一下def会怎么样

[root@localhost ~]# abc=csq; def=${abc=xixixi}
[root@localhost ~]# echo "def=${def},abc=${abc}"
def=csq,abc=csq

测试?的用法

如果我只想知道,如果旧变量不存在,整个测试旧告知我【有错误】,此时就用到【?】的帮忙。

若abc不存在时,则def测试结果直接显示"无此变量"

[root@localhost ~]# unset abc; def=${abc?无此变量}
-bash: abc: 无此变量

若abc存在时,则def会与str相同

[root@localhost ~]# abc=csq; def=${abc?无此变量}
[root@localhost ~]# echo "def=${def},abc=${abc}"
def=csq,abc=csq

命令别名、历史命令以及命令补全

history(命令历史记录)

语法

history [n]
history [-c]
history [-r]
n:数字,列出最近n条命令
-c:将目前shell中所有history内容全部清除
-r:将historyfiles 的内容督导目前中国shell的history记录中

使用案例

使用history命令查看历史记录。

history
  1. 使用【!】来执行历史记录中的命令
!67
# 执行第67行的命令
  1. 使用【!!】来执行上一条命令
!!
  1. 使用【!】加上关键字来执行包含该关键字的命令。
!f
# 在历史命令当中执行以f开头的命令
  1. 使用【Ctrl + R】来搜索历史记录。
(reverse-i-search)`': 
# 输入关键字后,系统会搜索包含该关键字的历史记录,
# 并显示搜索结果,用户可以选择需要执行的命令。

~/.bash_history(历史命令记录文件)

这个文件在你的家目录,记录的是前一次登录以前所执行过的命令,而至于这一次登录所执行的命令都被存在内存中,当你注销系统,命令才会记录到【.bash_history】中,至于你【.bash_history】中能存多少数据就和你bash的【HISTFILESIZE】这个变量有关了。

TAB(命令与文件补全)

  • 【TAB】接在第一串命令的第一个字后面,则为命令补全

  • 【TAB】接在第一串命令的第二个字后面,则为【文件补齐】

  • 如果按照【bash-completion】软件,则某些命令后面使用【TAB】按键时,可以进行【选项/参数的补齐】功能

alias、unalias(命令别名设置功能)

命令别名是一种将一个命令或一系列命令绑定到一个自定义名称的方法。这可以帮助用户更快速地输入一些常用的命令,从而提高工作效率。

  1. 缩短常用命令
    例如,将"ls -alh"绑定到"ll"上,每次输入"ll"就相当于输入"ls -alh"。命令别名的设置方法为:
alias ll='ls -alh'
  1. 避免误操作
    例如,将"rm"命令绑定到"rm -i"上,每次执行"rm"命令时都会提示用户是否确认删除。命令别名的设置方法为:
alias rm='rm -i'
  1. 取消命令别名rm
[root@csq ~]# alias
alias cp='cp -i'
alias egrep='egrep --color=auto'
alias fgrep='fgrep --color=auto'
alias grep='grep --color=auto'
alias l.='ls -d .* --color=auto'
alias ll='ls -l --color=auto'
alias ls='ls --color=auto'
alias mv='mv -i'
alias rm='rm -i'
alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde'
[root@csq ~]# unalias rm
[root@csq ~]# alias
alias cp='cp -i'
alias egrep='egrep --color=auto'
alias fgrep='fgrep --color=auto'
alias grep='grep --color=auto'
alias l.='ls -d .* --color=auto'
alias ll='ls -l --color=auto'
alias ls='ls --color=auto'
alias mv='mv -i'
alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde'
# 可以看到rm命令别名已经没了

/etc/issue、/etc/motd(bash的登录与欢迎信息)

/etc/issue

/etc/issue文件是在用户登录时显示的信息,通常包括Linux发行版名称、版本号和系统架构等。该文件可以用于自定义登录信息,例如添加公司logo、联系方式等。

查看issue文件中的内容

[root@localhost ~]# cat /etc/issue
\S
Kernel \r on an \m

下面就是系统默认的登录信息

image-20230507145643063

issue内的各代码意义
\d 本地端时间的日期
\l 显示第几个终端
\m 显示硬件等级
\n 显示主机的网络名称
\O 显示domain name
\r 操作系统的版本
\t 显示本地端时间
\S 显示操作系统的名称
\v 显示操作系统的版本

我们来设置一下

[root@localhost ~]# vim /etc/issue
Name of operating system: \S
Logged in terminals: \l
Network name of host: \n
operating system version: \v
Time: \t

显示如下

image-20230507151201925

还有个/etc/issue.net,是提供给telnet这个远程登录程序用的。当我们使用telnet连接到主机,主机的登录画面会显示【/etc/issue.net】而不是【/etc/issue】

/etc/motd

/etc/motd文件是在用户登录后显示的信息,通常用于向用户传达一些系统公告或提示信息。该文件可以用于向用户提供有用的信息,例如系统更新、安全漏洞等。

查看文件内容

[root@localhost ~]# vim /etc/motd 
欢迎使用Centos 7操作系统
当前用户为root用户
# 上面内容是我自己写入进去的并非默认内容

也可以放入一些比较有意思的ascii画

[root@csq ~]# cat /etc/motd 
i   ,
_,,)\.~,,._
(()`  ``)\))),,_
 |     \ ''((\)))),,_          ____
 |6`   |   ''((\())) "-.____.-"    `-.-,
 |    .'\    ''))))'                  \)))
 |   |   `.     ''                     ((((
 \, _)     \/                          |))))
  `'        |                          (((((
            \                  |       ))))))
             `|    |           ,\     /((((((
              |   / `-.______.<  \   |  )))))
              |   |  /         `. \  \  ((((
              |  / \ |           `.\  | (((
              \  | | |             )| |  ))
               | | | |            / | |  '
               | | /_(           /_(/ /
               /_(/__]           \_/_(
              /__]                /__]

bash的环境配置文件

Bash shell的环境配置文件包括以下几个:

  1. /etc/profile:这是系统级别的Bash配置文件,在系统启动时会自动加载。该文件通常包含一些全局的环境变量、系统级别的命令别名等。它会在用户登录时被执行。

  2. /.bash_profile:这是用户级别的Bash配置文件,仅适用于当前用户登录时要执行的命令和环境变量设置。该文件通常包含一些个人的环境变量、个人级别的命令别名等。如果该文件不存在,Bash会尝试加载/.bash_login或~/.profile文件。该文件会在用户登录时被执行。

  3. ~/.bashrc:这是用户级别的Bash配置文件,用于设置个人的命令别名、环境变量等。该文件会在每次新开一个终端时加载,并且可以通过source命令重新加载。该文件通常包含一些个人的命令别名、环境变量等。

  4. /etc/bashrc:这是系统级别的Bash配置文件,用于设置全局的命令别名、环境变量等。该文件会在每次新开一个终端时加载,并且可以通过source命令重新加载。该文件通常包含一些全局的命令别名、环境变量等。

需要注意的是,在修改这些配置文件时,应该小心谨慎,以免影响系统的正常运行。如果您不确定如何修改,请先备份原始文件,然后进行修改。

source(读入环境配置文件的命令)

source 配置文件文件名

使用案例

假如我在【.bashrc】中修改了一些命令别名,我想让他立即生效怎么办

[root@csq ~]# cat .bashrc 
# .bashrc

# User specific aliases and functions

alias rm='rm -i'
alias cp='cp -i'
alias mv='mv -i'

# Source global definitions
if [ -f /etc/bashrc ]; then
        . /etc/bashrc
fi
[root@csq ~]# source ~/.bashrc 
# 或者
[root@csq ~]# .  ~/.bashrc

stty、set(终端的环境设置)

stty命令

stty命令用于设置和显示终端的各种属性。它可以设置终端的行为、字符集、键盘映射等。

stty [-a]
选项:
-a:将目前所有的stty参数列出来
使用案例:
列出所有的按键与按键内容
[root@csq ~]# stty -a
speed 38400 baud; rows 17; columns 132; line = 0;
intr = ^C; quit = ^\; erase = ^?; kill = ^U; eof = ^D; eol = <undef>; eol2 = <undef>; swtch = <undef>; start = ^Q; stop = ^S;
susp = ^Z; rprnt = ^R; werase = ^W; lnext = ^V; flush = ^O; min = 1; time = 0;
...
.....

上述部分关键词意义是:

  1. intr:终止正在运行的程序。^C 就是Ctrl + C
  2. quit:退出正在运行的程序
  3. erase:向后删除字符
  4. kill:删除目前命令行上的所有文字
  5. eof:代表【结束输入】
  6. start:代表程序停止后,重新启动他
  7. stop:停止屏幕输出
  8. susp:软件挂起,后台运行

如果我们想改一下intr 不使用默认^C了,可以这样修改

[root@csq ~]# stty intr ^K
[root@csq ~]# stty -a | grep intr
intr = ^K; quit = ^\; erase = ^?; kill = ^U; eof = ^D; eol = <undef>;

set命令

set命令不仅能够查看自定义变量和环境变量,还可以帮我们设置整个命令输出/输入的环境。例如记录历史命令,显示错误呢内容。

语法

set  [-uvCHhmBx]
选项:
-u:默认不启用,若启用后,当使用未设置变量时,会显示是错误信息
-v:默认不启用,若启用后,在信息被输出前,会先显示信息的原始内容
-x:默认不启用,若启用后,在命令被执行前,会显示命令内容(前面有++符号)
-h:默认启用,与历史命令有关。
-H:默认启用,与历史命令有关。
-m:默认启用,与任务管理有关。
-B:默认启用,与中括号[]的作用有关。
-C:默认不启用,若使用>等,则若文件存在时,该文件不会被覆盖。

使用案例

显示所有环境变量和自定义变量的值

set

设置若未定义变量时,则显示错误信息

[root@csq ~]# set -u
[root@csq ~]# echo ${adwdadw}
-bash: adwdadw: unbound variable

通配符与特殊符号

常用的通配符

img

常用的特殊符号

符号内容
#注释符号
常常在脚本中使用,视为说明,#号后面的数据均不执行
\转义符
将【特殊字符或通配符】还原成一般的字符
|管道:分隔两个管道命令的符号
;连续命令执行分隔符:连续性命令的界定(注意,与管道符并不相同)
~用户的家目录
$使用变量前导符:就是变量之前需要加的变量替换值
&任务管理:将命令变成后台任务
!逻辑运算意义上的【非】not的意思
/目录符号:路径分隔的符号
>、>>数据流重定向:输出重定向,分别是【替换】与【累加】
<、<<数据流重定向:输入定向
’ ’单引号,不具有变量替换的功能($ 变为纯文本)
" "具有变量替换的功能,($ 可保留相关功能)
` `两个 【`】中间为可以先执行的命令,也可以使用$( )
( )在中间为子 shell的起始于结束
{ }在中间为命令区块的组合

数据流重定向

  • 标准输入(STDIN):代码为0,使用<或<<
  • 标准输出(STDOUT):代码为1,使用>或>>
  • 标准错误输出(STDEER):代码为2,使用2>或2>>
  • 1>:以覆盖的方法将【正确的数据】输出到指定文件或设备上
  • 1>>:以累加的方法将【正确的数据】输出到指定文件或设备上
  • 2>:以覆盖的方法将【错误的数据】输出到指定的文件或设备上
  • 2>>:以累加的方法将【错误的数据】输出到指定的文件或设备上

使用案例

测试文件内容

[root@localhost ~]# cat csq
I am csq
[root@localhost ~]# cat zhw
I am zhw

将csq文本中的内容输出到 zhw文件中

[root@localhost ~]# cat csq > zhw
[root@localhost ~]# cat zhw 
I am csq

将csq文本中的内容累加到zhw文件中

[root@localhost ~]# cat csq >> zhw 
[root@localhost ~]# cat zhw 
I am zhw
I am csq

将zhw文本中的内容输入到csq文件里

[root@localhost ~]# cat > csq < zhw
[root@localhost ~]# cat csq
I am zhw

将csq中的内容添加上到此一游

[root@localhost ~]# cat >> csq << "eof"
> 到此一游
> eof
[root@localhost ~]# cat csq
I am csq
到此一游

输入sl错误命令将错误的信息输入到 error.txt文件中

[root@localhost ~]# sl 2> error.txt
[root@localhost ~]# cat error.txt 
-bash: sl: 未找到命令

输入sl错误命令将错误的信息累加输入到 error.txt文件中

[root@localhost ~]# sl 2>> error.txt
[root@localhost ~]# cat error.txt 
-bash: sl: 未找到命令
-bash: sl: 未找到命令

将正确的信息和错误的信息都输入到黑洞文件中去

[root@localhost ~]# sl >/dev/null 2>&1

;、&&、||(命令执行的判断根据)

  1. 分号(;):表示顺序执行,即先执行前面的命令,然后再执行后面的命令,不管前面的命令执行成功还是失败。

    例如,command1 ; command2 表示先执行 command1,然后再执行 command2

  2. 双竖线(||):表示逻辑或,即如果前面的命令执行失败,则执行后面的命令;如果前面的命令执行成功,则不执行后面的命令。

    例如,command1 || command2 表示如果 command1 执行失败,则执行 command2,否则不执行 command2

  3. 双与号(&&):表示逻辑与,即如果前面的命令执行成功,则执行后面的命令;如果前面的命令执行失败,则不执行后面的命令。

    例如,command1 && command2 表示如果 command1 执行成功,则执行 command2,否则不执行 command2

使用案例

以ls 测试/tmp/csq 是否存在,若存在则显示 “yes” 不存在则显示 “no”

[root@localhost ~]# ls /tmp/csq && echo "yes" || echo "no"
ls: cannot access /tmp/csq: No such file or directory
no

管道命令

cut(选取内容)

cut -d '分隔字符' -f 字段
cut -c 字符区间
选项:
-d:后面接分隔字符,与-f一起使用
-f:根据-d分隔字符将一段信息划分成为数段,用-f取出第几段的意思
-c:以字符的单位取出固定字符的区间
使用案例:
将PATH变量取出,我要找出第五个路径

[root@localhost ~]# echo ${PATH}
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
       1               2           3        4        5
[root@localhost ~]# echo ${PATH} | cut -d ':' -f 5
/root/bin
# 如同上面数字显示,我们是以【:】作为分隔,因此会出现/root/bin

grep(搜索内容)

grep [-acinv] [--color=auto] '查找字符' filename
选项:
-a:将二进制以文本文件的方式查找数据
-c:计算找到'查找字符'的次数
-i:忽略大小写的不同,所以大小写视为相同
-n:顺便输出行号
-v:反向选择,就是显示出没有'查找字符'内容的那一行
--color=auto:可以将找到的关键字的那一行加上颜色显示
使用案例:
在last的输出信息中,只要有root就取出,并且仅取第一栏

[root@localhost ~]# last |grep 'root'|cut -d ' ' -f 1
root
root
root
root
root
.......
....
# 在last输出信息中,利用cut命令的处理,就能够仅取第一栏

sort(排序命令)

sort  [-fbMnrtuk] [file   或  stdin]
选项:
-f:忽略大小写的差异,例如A与a视为编码相同
-b:忽略最前面的空格字符部分
-M:以月份的名字来排序,例如JAN、DEC等排序方法
-n:使用【纯数字】进行排序(默认是以文字形式来排序的)
-r:反向排序
-u:就是uniq,相同的数据中,仅出现一行代表。
-t:分隔符号,默认是使用[TAB]键来分隔
-k:以哪个区间来进行排序的意思。
使用案例:
/etc/passwd内容是以【:】分隔的,我想以第三栏来排序

[root@localhost ~]# cat /etc/passwd | sort -t ':' -k  3   
root:x:0:0:root:/root:/bin/bash
csq:x:1000:1000::/home/csq:/bin/bash
zhw:x:1001:1001::/home/zhw:/bin/bash
zzh:x:1002:1002::/home/zzh:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
....
......
..
# 发现了吗sort默认是以文字形式来排序的,如果想要数字排序
# cat /etc/passwd | sort -t ':' -k  3 -n 这样才行 加上-n来告知sort是以数字来排序

uniq(显示重复的数据)

uniq [-ic]
选项:
-i:忽略大小写字符的不同
-c:进行计数
使用案例:
使用last将账号列出,列出每个账户的登录次数

[root@localhost ~]# last | cut -d ' ' -f 1 | sort | uniq -c
      1 
      7 reboot
     34 root
      1 wtmp
# 1.先将所有的数据列出来 2.再将人名独立出来 3.经过排序 4.只显示一个
# 从上述案例得知可以发现reboot出现了7次,root登录则有34次,大部分都是root在登录
# wtmp与第一行的空白都是last的默认字符,两个可以忽略

wc(查看文件内容多少字)

wc [-lwm]
选项:
-l:仅列出行
-w:仅列出多少字
-m:多少字符
使用案例:
man_db.conf里面到底有多少行、字数、字符数呢?

[root@localhost ~]# cat /etc/man_db.conf | wc
    131     723    5171
# 输出的三个数字中,分别代表:【行、字数、字符数】

tee(双向重定向)

tee [-a] file
选项:
-a:以累加的方式,将数据加入file当中
使用案例:
将ls -l /home 的数据存一份到~/homefile,同时屏幕也有输出信息

[root@localhost ~]# ls -l /home | tee ~/homefile      
total 0
drwx------. 2 csq csq 162 Apr 25 14:48 csq
drwx------. 2 zhw zhw  62 Apr 25 09:52 zhw
drwx------. 2 zzh zzh  62 Apr 25 09:52 zzh
# 如果信息很多的话在后面可以加一个【 | less】

split(划分命令)

split [-bl] file PREFIX
选项:
-b:后面可接欲划分成的文件大小,可加单位,例如b、k、m等
-l:以行数来进行划分
PREFIX:代表前缀字符的意思,可作为划分文件的前缀文字
使用案例:
我的/etc/services 有600多K,若想要分成300K一个文件时

[root@localhost ~]# cd /tmp/;split -b 300K /etc/services services
[root@localhost tmp]# ll -k services*
-rw-r--r--. 1 root root 307200 Apr 26 16:10 servicesaa
-rw-r--r--. 1 root root 307200 Apr 26 16:10 servicesab
-rw-r--r--. 1 root root  55893 Apr 26 16:10 servicesac
# 这个文件名可随意取,我们只要写上前缀文字,小文件就会以xxxaaa,xxxab,xxxac等方式来建立小文件

shell脚本

Shell 脚本是一种编程语言,其语法和其他编程语言类似,包含以下几个基本部分:

  1. 注释:
    在 Shell 脚本中,注释以 # 开头,可以用于对代码进行说明或者临时禁用某些代码。
    如何编写第一个shell脚本 ⇐ 参考博客
  2. 变量:
    Shell 脚本中的变量和其他编程语言类似,使用 $ 符号来引用变量。变量名必须以字母或下划线开头,不能以数字开头,变量名中不能包含空格和特殊字符。
  3. 条件语句:
    Shell 脚本中的条件语句包括 if、else、elif,用于根据不同的条件执行不同的代码块。
    shell脚本的条件判断式 ⇐ 参考博客
  4. 循环语句:
    Shell 脚本中的循环语句包括 for、while、until,用于重复执行某个代码块,直到满足某个条件为止。
    shell脚本的循环 ⇐ 参考博客
  5. 输入输出:
    Shell 脚本中的输入输出包括 echo、read等命令,用于输出文本和读取用户输入。
  6. 命令执行:
    Shell 脚本中的命令执行包括使用反引号或 $() 符号来执行命令,并将命令的输出作为变量或参数传递给其他命令。
  7. 管道:
    Shell 脚本中的管道符号 | 可以将一个命令的输出作为另一个命令的输入,用于将多个命令组合在一起执行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/499603.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Hello Network】TCP协议相关理解

作者&#xff1a;小萌新 专栏&#xff1a;网络 作者简介&#xff1a;大二学生 希望能和大家一起进步 本篇博客简介&#xff1a;补充下对于TCP协议的各种理解 TCP协议相关实验 TCP相关试验理解CLOSE_WAIT状态理解TIME_WAIT状态解决TIME_WAIT状态引起的bind失败的方法理解listen的…

分布式 03 富文本处理插件和图片文件上传

01.使用富文本编辑器来上传图片文件。 02.最开始在html文件中去使用相关富文本的插件。 引入相关文件 <link href"/js/kindeditor-4.1.10/themes/default/default.css" type"text/css" rel"stylesheet"> <script type"text/java…

Redis面试题(上)

1.什么是 Redis&#xff1f; Redis 是一种基于内存的数据库&#xff0c;对数据的读写操作都是在内存中完成&#xff0c;因此读写速度非常快&#xff0c;常用于缓存&#xff0c;消息队列、分布式锁等场景。 Redis 提供了多种数据类型来支持不同的业务场景&#xff0c;比如 Strin…

Python机器学习入门 -- 支持向量机学习笔记

文章目录 前言一、支持向量机简介二、支持向量机的数学原理1. 距离解算2. 目标函数3. 约束下的优化求解4. 软间隔优化5. 核函数变换 三、Python实现支持向量机1. 惩罚力度对比2. 高斯核函数3. 非线性SVM 总结 前言 大部分传统的机器学习算法都可以实现分类任务&#xff0c;但这…

干货丨你真的了解反应持续时间吗?

Hello&#xff0c;大家好&#xff01; 这里是壹脑云科研圈&#xff0c;我是喵君姐姐~ 在今天的推文里&#xff0c;要给大家分享的是一种灵活、免费的心理科学工具——反应持续时间&#xff0c;快来一起看看哦~ 01 导读 简单按键的反应持续时间是一种容易获得但未被充分利用…

C++相比于C语言增加的8个小特性(详解)

C相比于C语言增加的8个小特性&#xff08;详解&#xff09; 文章目录 C相比于C语言增加的8个小特性&#xff08;详解&#xff09;一、命名空间二、C输入和输出三、缺省参数四、函数重载五、引用六、内联函数七、auto关键字八、指针空值nullptr总结 一、命名空间 c的命名空间是…

从一到无穷大 #8 Arrow,Parquet and ORC

文章目录 引言ArrowParquetNested EncodingRepetition LevelsDefinition Levels 列化压缩 ORC 引言 以我的机器为例来做一个简单的计算&#xff1a; 执行cat /proc/cpuinfo |grep MHz|uniq可以看到目前机器中CPU频率&#xff0c;得到值 2494.140MHZ&#xff5e;2494140000HZ&…

【算法】——全排列算法讲解

前言&#xff1a; 今天&#xff0c;我给大家讲解的是关于全排列算。我会从三个方面去进行展开&#xff1a; 首先&#xff0c;我会给大家分析关于全排列算法的思想和定义&#xff1b;紧接着通过手动实现出一个全排列代码来带大家见见是怎么实现的&#xff1b;最后我会给出两道题…

ESP32单片机入门篇

目录 一、ESP32单片机的基本概念 1.双核架构 2. Wi-Fi和蓝牙功能 3. 集成多种外设 4. 支持多种操作系统 二、开发环境 1. Arduino IDE 2. ESP-IDF 三、开发语言 四、注意事项 五、代码例程 &#xff08;1&#xff09;点亮LED灯 1. 电路图 2. 代码 3. 代码注释 …

【精品】Java-Stream流详解

Java-Stream流详解 如何学会JDK8中的Stream流&#xff0c;用它来提高开发效率&#xff1f;创建不可变的集合&#xff08;Immutable 不可变的&#xff09;场景方法 初试 Stream 流Stream 流的思想Stream 流的作用Stream 流的使用步骤Stream 流的中间方法Stream 流的终结方法 如何…

STM32:利用PWM波控制飞盈电调过程和注意事项

STM32&#xff1a;利用PWM波控制电调过程和注意事项 在进行模型控制的过程中&#xff0c;如四旋翼无人机等&#xff0c;需要用到电机&#xff0c;这些电机需要通过电调来控制电机的转速。在电调模块中带有的说明书一般都是利用遥控器进行控制&#xff0c;有些情况需要自己通过…

【自然语言处理】【大模型】CodeGeeX:用于代码生成的多语言预训练模型

CodeGeeX&#xff1a;用于代码生成的多语言预训练模型 《CodeGeeX: A Pre-Trained Model for Code Generation with Multilingual Evaluations on HumanEval-X》 论文地址&#xff1a;https://arxiv.org/pdf/2303.17568.pdf 相关博客 【自然语言处理】【大模型】CodeGeeX&#…

二叉排序树

二叉排序树 文章目录 二叉排序树创建遍历删除完整代码 假如给你一个数列 (7, 3, 10, 12, 5, 1, 9)&#xff0c;要求能够高效的完成对数据的查询和添加。 使用数组 数组未排序&#xff1a; 优点&#xff1a;直接在数组尾添加&#xff0c;速度快。 缺点&#xff1a;查找速度慢. 数…

[图形学] 射线和线段之间的最小距离

1 说在前面 本文的主要内容来自于Unity引擎中Spline功能的一个函数&#xff0c;一开始我难以理解这几个向量运算的作用和几何意义&#xff0c;经过一番思考后总结如下&#xff1a; 该段代码实际上更像是两个直线之间寻找最短距离&#xff0c;然后判断该距离对应的点在其中一条…

STM32利用USB的HID与QT上位机通信

之前使用kingst的逻辑分析仪&#xff0c;打开上位机软件&#xff0c;插上带usb的硬件就可以通信&#xff0c;也不需要打开串口什么的&#xff0c;感觉很方便&#xff0c;于是借用一个周末研究下这个技术。本文主要是用于记录自己学习的过程&#xff0c;顺便分享下学习感悟。 首…

大数据周会-本周学习内容总结012

开会时间&#xff1a;2023.05.07 16:00 线下会议 目录 01【es数据同步至mysql】 1.1【在es中插入数据后能够同步到mysql中】 1.2【修改与删除es中的数据】 02【nifi】 2.1【Nifi的单机及分布式集群部署】 2.2【nifi集群&#xff0c;getFile简单使用nifi】 2.3【nifi使用…

如何利用Requestly提升前端开发与测试的效率,让你事半功倍?

痛点 前端测试 在进行前端页面开发或者测试的时候&#xff0c;我们会遇到这一类场景&#xff1a; 在开发阶段&#xff0c;前端想通过调用真实的接口返回响应在开发或者生产阶段需要验证前端页面的一些 异常场景 或者 临界值 时在测试阶段&#xff0c;想直接通过修改接口响应来…

Nuvoton NK-980IOT开发板 u-boot 编译

前言 最近搭建了 Nuvoton NK-980IOT开发板 的开发编译环境&#xff0c;记录一下 u-boot 的 编译流程 Nuvoton NK-980IOT开发板 资源还是比较的丰富的&#xff0c;可以用于 嵌入式Linux 或者 RT-Thread 的学习开发 开发板上电比较的容易&#xff0c;两根 USB 线即可&#xff0…

进程与线程(二)

进程同步、进程互斥 同步亦称直接制约关系&#xff0c;是指为完成某种任务而建立的两个或多个进程&#xff0c;这些进程因为需要在某些位置上协调它们的工作次序而产生的制约关系。进程间的直接制约关系就是源于他们之间的相互合作。 操作系统要提供“进程同步机制”来解决异…

Oracle的学习心得和知识总结(二十四)|Oracle数据库DBMS程序包解密方法及SQL Developer和Unwrapper的安装与使用

目录结构 注&#xff1a;提前言明 本文借鉴了以下博主、书籍或网站的内容&#xff0c;其列表如下&#xff1a; 1、参考书籍&#xff1a;《Oracle Database SQL Language Reference》 2、参考书籍&#xff1a;《PostgreSQL中文手册》 3、EDB Postgres Advanced Server User Gui…