linux学习日记八 认识与学习bash 【百科全说】-凯发k8官方旗舰厅

腾讯视频/爱奇艺/优酷/外卖 充值4折起

只要能够操作应用程序的接口都能称为shell。狭义的shell指的是命令行方面的软件,包括bash。广义的shell则包括图形界面软件,因为图形界面其实也可以操作各种应用程序来调用内核工作,不过,在这里我们主要指的是bash。

# type [-tpa] command –> 查看命令是否为bash的内置命令或者是外部命令

* 利用$var或者是${var}可获取变量var的值

* bash中的双引号:特殊字符如$等,可以保有原本的特性

* bash中的单引号:所有的字符均为普通的字符,没有其他含义

* 可以用/将特殊字符变成一般字符

* 可用$(其他命令)来在命令中嵌套其他命令的返回值,也就是说:${var}取得变量var的值,$(command)取得命令返回值

* 若变量需要在其他子进程中执行,需要export var 来使变量成为环境变量

* unset var 可取消变量var的定义

====环境变量====

# env –> 查看当前系统的环境变量

$本身也是一个变量,表示本shell的pid号,比如 # echo $$ 输出本shell的pid

?本事也是一个变量,表示上一个执行的命令的返回值,一般如果是0表示执行成功,如果非0表示有问题。

公共的语系编码设置:/etc/sysconfig/i18n

# read [-pt] variable –> 键盘读取变量输入值

-p:后面可以跟提示符

-t:后面可以接等待的秒数,不会一直等待用户输入

====变量的声明====

# declare [-aixrp] var

-a:将后面的var定义为数组类型

-i:将后面的var定义为integer整数类型

-x:用法与export一样,就是将后面的var变成环境变量

-r:将变量var设置成readonly状态,该变量不能被更改,也不能重设

-p:单独列出变量的类型

如果把-改成 表示取消操作

====限制用户的计算机资源使用====

# ulimit [-shacdfltu] [配额]

-h:hardlimit,严格的限制,必定不能超过这个数值

-s:softlimit,可以超过这个值,但有警告信息

-a:后面不接任何参数,列出所有的限制额度

-c:某些进程发生错误的时候,系统会将该进程在内存中的信息写成文件,称为内核文件。限制每个内核文件的最大容量

-f:此shell可创建的最大单一文件容量,单位为kb

-d:进程可以使用的最大内存量

-l:可用于lock的内存量

-t:最大的cpu时间(单位为秒)

-u:单一用户可使用的最大进程(process)数量

====变量内容的删除与替换====

# echo ${path#/*:} –> 删除path变量中最前面的那个以/开头,以:结尾的

# echo ${path##/*:} –> 删除最长的那个,也就是说只保留了最后的一个路径

# –> 符合替换文字的最短的那个

## –> 符合替换文字的最长的那个

如果想从后面开始删,用%替换#即可

接下来讲替换功能:

# echo ${path/sbin/sbin} –> 将第一个sbin替换成sbin

# echo ${path//sbin/sbin} –> 将所有的sbin替换成sbin

我们将这部分总结说明下一下:

变量设定方式 说明
${变量#关键字}
${变量##关键字}
若变量?热荽油房?嫉氖?莘?稀汗丶?帧唬?蚪??系淖疃淌?萆境?/span>
若变量?热荽油房?嫉氖?莘?稀汗丶?省唬?蚪??系淖畛な?萆境?/span>
${变量%关键字}
${变量%%关键字}
若变量?热荽游蚕蚯暗氖?莘?稀汗丶?帧唬?蚪??系淖疃套柿仙境?/span>
若变量?热?奈蚕蚯暗氖?莘?稀汗丶?帧唬?蚪??系淖铋l资料删除
${变量/旧字串/新字串}
${变量//旧字串/新字串}
若变量?热莘?稀壕勺执??t『第一??旧字串会被新字串取代』
若变量?热莘?稀壕勺执??t『全部的旧字串会被新字串取代』

# username=${username:-root} –> 如果username非空就取原值,如果没有设置或者为空字符串就设置成root

====bash登录界面与登录成功后的欢迎界面====

tips:最好是单一bash登陆,然后利用job control来切换不同的工作,这样的话shell的history才能完全保存下来

命令的执行搜索路径顺序:先alias,再builtin,再$path

bash的登陆界面配置文件:/etc/issue,远处登陆界面配置文件:/etc/issue.net

命令# man mingetty查看issue中各个代码的意义

登陆成功后显示的信息配置文件:/etc/motd

====bash环境变量====

login shell的配置文件:

/etc/profile:系统全局配置文件,最好不要修改这个文件

~/.bash_profile或者~/.bash_login或者~/.profile:用户自定义bash配置文件

~/.bashrc,这个配置文件login shell和non-login shell都会读取

====bash中的通配符和特殊字符====

符号 意义
* 代表『 0 个到无穷多个』任意字符
? 代表『一定有一个』任意字元
[ ] 同样代表『一定有一个在括号?取坏淖衷?非任意字元)。例如 [abcd] 代表『一定有一个字元, 可能是 a, b, c, d 这四个任何一个』
[ - ] 若有减号在中括号内时,代表『在编码顺序?鹊乃?凶衷?弧@? [0-9] 代表 0 到 9 之间的所有数字,因为数字的语系编码是连续的!
[^ ] 若中括号?鹊牡谝桓鲎衷??甘?? (^) ,那表示『反向选择』,例如 [^abc] 代表 一定有一个字元,只要是非 a, b, c 的其他字元就接受的意思。

除了通配符之外,bash ?境中的特殊符?有哪些呢?底下我??先汇整一下:

符号 ?热?/span>
# 注释符号:这个最常被使用在 script 当中,视为说明#在后的语句均不执行
/ 跳脱符号:?ⅰ禾厥庾址?蛲蛴米址?换乖?梢话阕衷?/span>
| 管道 (pipe):分隔两个管道命令的界定(后两节介?);
; 连续指令下达分隔符:连续性命令的界定 (注意!与管道命令不相同)
~ 使用者的家目录
$ 取用变量前置字元:亦即是变量之前需要加的变量取代值
& 工作控制 (job control):将指令变成背景下工作
! 逻辑运算意义上的『非』 not 的意思!
/ 目录符号,路径分割符号
>, >> 数据流重导向:输出导向,分?e是『取代』与『累加』
<, << 数据流重导向:输入导向 (这两个以后说明)
‘ ‘ 单引号,里面全是普通字符,不具备变量置换功能
” “ 具有变量置换的功能!
` ` 两个『 ` 』中间为可以先执行的指令,亦可使用 $( )
( ) 在中间为子 shell 的起始与结束
{ } 在中间为命令区块的?合!

====数据流重导向====

1,标准输入(stdin):代码为0,使用<或者<<

2,标准输出(stdout):代号为1,使用>或者>>

3,标准错误输出(stderr):代号为2,使用2>或者2>>

>表示清空后添加,>>表示累加添加,append的意思。了解?o(?□?)o

<表示原本由键盘输入的改由文件输入,而<<则表示遇到后面的字符串的时候结束输入。

/dev/null:超级黑洞,它会吃掉任何导向到它的数据流,很强大的,不是麽。

正确和错误输出到同一个文件的语法格式:

find /home -name .bashrc > list 2>&1

====管道命令====

管道命令需要注意的是:

1,管道命令仅能处理standard output,对于stderr会忽略掉

2,管道命令必须要能够接受来自前一个命令的数据成为standard input继续处理才行

====选取命令cut和grep====

# cut -d ‘分割字符’ -f fields <== 用于分割字符

# cut -c 字符范围 <== 用于排列整齐的信息

-d:后面接分割字符,与-f一起使用

-f:依据-d的分割字符将一段信息切割成为数段,用-f取出第几段的意思(-f 3,5)

-c:以字符的单位取出固定字符区间 (-c 12-34)

grep以行为单位分析信息,如果该行符合条件,则把该行提出出来

# grep [-acinv] [--color=auto] ’查找的字符串’ filename

-a:将binary文件以text文件方式查找

-c:计算找到’查找的字符串’的次数

-i:忽略大小写

-n:顺便输出行号

-v:反向选择,即显示出没有 ‘字符串’内容的那些行

–color=auto : 关键字加上颜色

====排序命令sort,wc,uniq====

# sort [-fbmnrtuk] [file or stdin]

-f:忽略大小写

-b:忽略最前面的空格

-m:以月份的名字排序

-n:使用数字排序(默认是文字来排序)

-r:反向排序

-u:就是uniq,相同的数据中,仅出现一行代表

-t:分隔符,默认以tab分割

-k:以那个区间进行排序

# cat /etc/passwd | sort -t “:” -k 3 <== 以第三列进行排序

# last | cut -d ‘ ‘ -f 1 | sort

# uniq [-ic] <==排序完成后将重复的数据仅列出一个显示

-i:忽略大小写

-c:进行计数

# last | cut -d ‘ ‘ -f1 | sort | uniq -ic

# wc [-lwm] <== 行数,字数,字符数统计命令

-l:仅列出行

-w:仅列出多少字(英文单词word)

-m:多少字符(char)

# cat /etc/man.config | wc

====双向重定向tee====

# tee [-a] file

-a:以累加(append)方式,将数据加入到file中

# ls -l /home | tee -a ~/homefile | more

====字符转换命令:tr,col,join,paste,expand====

# tr [-ds] set1 …

-d:删除信息中的set1这个字符串;

-s:替换掉重复的字符

# last | tr -s ‘[a-z]‘ ‘[a-z]‘

# cat /etc/passwd | tr -d “:”

# col [-xb]

-x:将tab键转换成对等的空格键

-b:如果在文字内有反斜杠(/),仅保留反斜杠最后接的字符

# join [-ti12] file1 file2

-t:join默认以空格符分割数据,并且对比第一个字段的数据,如果相同,合并到一行,且第一个字段放在第一个

-i:忽略大小写

-1:代表第一个文件要用那个字段来分析

-2:代表第二个文件要用哪个字段来分析

# join -t “:” -1 4 /etc/passwd -2 3 /etc/group

# paste [-d] file1 file2 …

-d:后面可以接分割字符,默认以tab来分割

-:如果-file写成-,则表示来自stdin的数据

# expand [-t] file

-t :后面接数字,表示一个tab键可以转换成几个空格键

# grep ‘^manpath’ /etc/man.config | head -n 3 | expand -t 6 – | cat -a

====切割命令split====

# split [-bl] -file prefix

-b:后面接欲切割成的文件的大小,可以加单位,如b,k,m,g等

-l:以行数进行切割

prefix:前导符,可作为切割文件的前导文字

# split -b 300k /etc/termcap tercap

====参数代换xargs====

# xargs [-0epn] command

-0:如果输入的stdin含有特殊字符,比如`,/,空格键等,这个参数可以将其还原成一般字符

-e:eof,后面可以接一个字符串,当xargs遇到这个字符串的时候,就停止继续工作

-p:每次执行命令的参数时,询问用户

-n:后面接次数,每次command执行时,要使用几个参数的意思

# cut -d ‘:’ -f1 /etc/passwd | xargs -p -n 5 finger

使用xargs的原因是:很多命令其实不支持管道命令,因此我们可以通过xargs来提供该命令引用stdin之用。

# find /sbin -perm 7000 | xargs ls -l <== 找出/sbin下具有特殊权限的文件名

===============end====================

02/22 13:43
随着时代的发展,我们已经可以通过一些手机应用来进行学习,而在timing这款软件中,我们呢不光可以学习,还可以发布学习日记.接下来就有小编来告诉大家如何操作.具体如下:1.第一步,打开timing软件,在凯发app官网登录主页面中点击下方的学习圈选项.2. 第二步,在点击学习圈按钮后就会出现一个悬浮图标,点击该悬浮图标.3. 第三步,点击后即可进入发布学习日记页面,点击空白处并输入学习心得.4.第四步,不仅可以输入文字,还可以通过点击下方的相机图标进行图片的上传.5. 第五步,在内容与图片均编辑好后,点击右上角的
09/19 20:59
一、什么是rootkit? rootkit是linux平台下最常见的一种木马后门工具,它主要通过替换系统文件来达到入侵和和隐蔽的目的,这种木马比普通木马后门更加危险和隐蔽,普通的检测工具和检查手段很难发现这种木马。rootkit攻击能力极强,对系统的危害很大,它通过一套工具来建立后门和隐藏行迹,从而让攻击者保住权限,以使它在任何时候都可以使用root权限登录到系统。 rootkit主要有两种类型:文件级别和内核级别,下面分别进行简单介绍。 1、文件级别rootkit 文件级别
01/14 14:05
相信很多小伙伴都有在使用学习强国app,其中的学习组织如何才能创建呢?方法很简单,下面小编就来为大家介绍.具体如下:1. 首先,解锁手机,打开手机上的"学习强国".2. 进入凯发k8官方旗舰厅首页后,点击左下角的"消息".3. 进入消息页面后,点击下图箭头所指处:4. 进入通讯录页面后,点击"创建学习组织".5. 如果我们没有进行过实名认证,就会出现下图所示窗口,点击"去认证",完成实名认证即可.6. 接着,将学习组织相关的信息完善,然后点击下
02/17 01:45
现在越来越多的小伙伴们在学习强国app上学习查看期刊.古籍.公开课.歌曲.戏曲.电影.图书等资料,今天小编来教大家怎么在学习强国app上查看学习排行榜具体如下:1. 第一步,进入"学习强国"app,选择页面下方"消息"2. 第二步,选择"学校强国助手"对话框3. 第三步,选择发来的"学习排行"消息下的"立即查看"4. 第四步,在"排行榜"页面可以看到近7日排名,也可以点击"总积
08/05 16:18
当我们在使用手机的时候,可以下载学习强国app来进行线上学习,同时我们可以在学习强国app中添加学习组织,那么如何退出这些学习组织呢?接下来就由小编来到告诉大家.具体如下:1. 第一步,打开手机中的学习强国应用,进入凯发app官网登录主页后,点击上方的通讯录图标.2. 第二步,进入通讯录页面后,点击想要退出的学习组织下方的组织架构按钮.3. 第三步,进入组织架构页面后,点击右上角的更多按钮.4. 第四步,点击下方弹出菜单中的退出学习组织按钮.5. 第五步,点击弹出确认窗口中的确定按钮.6. 第六步,如下图所示,就
01/15 12:18
今天给大家介绍一下如何在学习强国app中创建学习组织的具体操作步骤.1. 首先打开手机,找到桌面上的"学习强国"app,打开并登陆.2. 进入凯发k8官方旗舰厅首页后,点击左下角的图标,然后在打开的页面,选择顶部的第一个图标点击,进入通讯录页面.3. 然后在通讯录页面,点击"创建学习组织",然后就进入实名认证页面,依次输入姓名,身份证号,确认提交,然后进行采集人脸.4. 然后我们就可以等待上级组织的审核批准了.若需要"添加党员"的话,现在就可以添加了,也可以等批准
02/24 17:12
学习强国上的代学功能,是在我们偶尔比较忙的时候,实在抽不出时间的情况下,通过托管完成当天的学习任务.当然不建议依赖此功能,一致使用哦.今天就跟大家介绍一下如何在学习强国上设置托管学习即代学的具体操作步骤.1. 首先打开我们手机上的学习强国app,然后找到学习积分助手公众号,在页面回复数字  1,获取托管链接.如果我们需要人工客服,回复数字 3即可.2. 然后我们按照提示步骤,进行绑定账号.3. 绑定之后,账户并没有激活,我们可以选择充值账户,或邀请好友绑定(免费),进行激活.4. 然后当账户激活
07/02 16:18
如果我们需要每天在学习强国中累积一定的积分,该怎么才能获得呢?今天就跟大家介绍一下怎么累积学习强国app中的学习积分的具体操作步骤.1. 首先打开手机上的学习强国app,每日登陆必得0.1个积分.2. 然后我们可以选择阅读文章,阅读一篇就会增加0.1个积分,最多增加0.5个积分.然后会弹出提示窗口,点击去看看可以快速获得积分.3. 另外,观看一个视频会增加0.1积分,而且在活跃时段观看的话,是双倍积分,同样有0.5积分的上限.4. 学习时长就是我们在学习强国中学习时间的长短,可以看视频或者阅读文
04/09 19:45
===一个简单的ls -al的例子:=== -rw-r–r–. 1 root root 57494 oct 1 08:08 install.log 第一列表示文件的权限,共有10个字符组成。第一个字符表示文件类型: d:表示目录;-:表示是文件;l表示是链接文件linkfile;b表示块设备文件(设备文件里面的可供存储的接口设备);c表示字符设备文件(设备文件中的串行端口设备,例如键盘、鼠标等一次性读取设备),s表示套接字sockets文件,p表示管道fifo文件。接下来三个一组,分别代表own
网站地图