1.linux极速进阶

目录

  • 概述
  • 文件相关
    • vi文件编辑
    • 查找字符串
    • 查找某一行内容
    • 复制粘贴
    • 快速删除
    • 快速跳到文件首行和末行
  • 进程相关
    • ps/netstat
    • jps
    • top
    • kill
  • linux三剑客
    • grep
    • sed
      • 添加方面操作
      • 删除方面
      • 替换操作
    • awk
  • 结束

概述

身为后端开发,大数据平台搭建,对 linux 系统的操作最起码要入门,此文目标,快速进阶 linux 命令行操作

文件相关

vi文件编辑

  • 可以先使用touch创建一个空文件,再使用vi命令去编辑文件内容,亦可以直接使用vi操作一个不存在的文件,都是支持的
  • vi三种模式:1.不可编辑模式即命令模式(使用vi编辑文件进入的时候状态);2.i按键进入可编辑模式,esc退出编辑模式进入命令模式;在命令模式下按shift+: 后输入wq w写入,q是退出

查找字符串

在命令模式下,输入/,然后再输入想要查询的字符串,最后按回车键就可以进行查询
如果文件中有多个root字符串,如果第一次查找的不是想要的,可以按n这个键继续查找,n表示next的意思

vi anaconda-ks.cfg

查找某一行内容

如果知道要修改的内容在文件的第几行,可以直接定位那一行
显示行号: shift和:输入set nu,这个时候可以看到行号,再shift和: 输入10,就可以看到直接跳至10行

	  1 #version=DEVEL
      2 # System authorization information
      3 auth --enableshadow --passalgo=sha512
      4 # Use CDROM installation media
      5 cdrom
      6 # Use graphical install
      7 graphical
      8 # Run the Setup Agent on first boot
      9 firstboot --enable
     10 ignoredisk --only-use=sda
     11 # Keyboard layouts
     12 keyboard --vckeymap=us --xlayouts='us'
     13 # System language
     14 lang en_US.UTF-8
     15 
     16 # Network information
     17 network  --bootproto=dhcp --device=ens192 --onboot=off --ipv6=auto --no-activate
     18 network  --hostname=KS8P-Test-K8S05
     19 
:10

复制粘贴

需要在文件中根据某一行内容快速复制几行
使用vi命令打开hello.txt,将光标移动至希望复制的那一行,然后连按yy,这样一行就复制上了,按p就会将刚才复制的内容粘贴到下一行,按一次p粘贴一行

快速删除

删除文件中的内容,默认可以进入编辑模式使用退格键删除
另一种进入命令模式,将光标定位到想要删除的那一行内容上面,连接dd,就可以将当前行的内容删除
如果你想清光当行及当前行下面所有的内容,先按999,再连按dd

快速跳到文件首行和末行

大命令行模式下,能过大写的G可以快速将光标移动至最后一行
输入小写的gg可以快速的回到第一行

进程相关

ps/netstat

ps 命令是用来显示进程相关信息的,典型应用就是后面跟e和f参数
显示系统内所有进程 ps -ef

netstat 也是显示进程相关信息的,只不过可以ps命令额外显示端口相关信息
默认是没有安装的 yum install -y net-tools
常见用法:netstat -anp

[root@KS8P-Test-K8S05 ~]# yum install -y net-tools
已安装:
  net-tools.x86_64 0:2.0-0.25.20131004git.el7                          
完毕!
[root@KS8P-Test-K8S05 ~]# netstat -anp
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name    
tcp        0      0 0.0.0.0:139             0.0.0.0:*               LISTEN      16220/smbd  

上面显示很多的进程和端口信息,netstat需要和grep命令结合使用
若想看一下ssh服务端口是42222(公司的22关闭了),只发开启了,这个端口就会被监听

[root@KS8P-Test-K8S05 ~]# netstat -anp | grep 42222
tcp        0      0 0.0.0.0:42222           0.0.0.0:*               LISTEN      6083/sshd           
tcp        0      0 10.32.36.135:42222      10.35.226.137:52403     ESTABLISHED 18951/sshd: root@pt 
tcp6       0      0 :::42222      

jps

jps类似ps命令,不同的是ps是用来显示所有进程信息的,而jps只显示java进程,准确的说jps是显示当前用户已启动的java进程信息,信息包括进程号和简短的进程command
注意:jps是java提供的命令,只有在安装配置好java环境之后才能使用

[root@KS8P-Test-K8S05 ~]# jps
6595 jar
6759 jar
10519 jar
25031 Jps

top

top命令:主要作用在于动态显示系统消耗资源最多的进程信息,包括进程ID,内存占用,CPU占用等和ps命令作用基本相同,唯一的区别是top命令能够动态显示进程信息
具体:
在这里插入图片描述
注意:这里的cpu使用情况是总体cpu的使用情况,如果是多核,想看每个cpu的情况可以按键盘上的1,会显示每个cpu的情况

在这里插入图片描述
按q可以退出此监控模式

kill

先使用ps命令得到程序对应的PID,然后使用kill命令杀掉这个进程,进程被杀掉了,程序自然停止
kill PID 相当于我告诉你一声让你自杀,然后你就自己挥刀自杀了
kill -9 PID 针对不自觉的,没有自杀成功,那就直接亲自出马

linux三剑客

grep

grep常用于查找文件里符合条件的字符串

[root@KS8P-Test-K8S05 ~]# cat hello.txt 
hello world
hello world
abx
abc
[root@KS8P-Test-K8S05 ~]# grep abx hello.txt 
abx

grep 后面跟的这个字符串是可以支持正则表达式的
查询 hello.txt中以字母a开头的内容

[root@KS8P-Test-K8S05 ~]# grep ^a hello.txt 
abx
abc

在查的时候,忘记需要查询的字符串是大写还是小写,此时可以使用忽略大小写功能

[root@KS8P-Test-K8S05 ~]# grep -i Abc hello.txt 
abc

还有一些场景需要查询出来对应字符串的行号,方便快速在文件中定位字符串所在的位置,通过-n参数就可以实现

[root@KS8P-Test-K8S05 ~]# grep -i Abc -n hello.txt 
4:abc

grep 在查java进程时多了以下的内容

root     28582 18953  0 14:38 pts/0    00:00:00 grep --color=auto java

完整的如下

[root@KS8P-Test-K8S05 ~]# ps -ef | grep java
root      6595     1  0 4月22 ?       1-07:17:48 java -Xms512m -Xmx512m -jar long-cloud-eureka-server.jar
root     28582 18953  0 14:38 pts/0    00:00:00 grep --color=auto java

如何去掉,使用grep加上-v参数再做一次过滤即可,表示忽略包含指定字符串的数据

[root@KS8P-Test-K8S05 ~]# ps -ef | grep java |grep -v grep
root      6595     1  0 4月22 ?       1-07:17:48 java -Xms512m -Xmx512m -jar long-cloud-eureka-server.jar
root      6759     1  0 4月22 ?       12:57:07 java -Xms512m -Xmx512m -jar config-server.jar --eureka-server=http://10.xx.xx.1x5:8761/eureka/ --git-username=root
root     10519     1 99 4月22 ?       424-16:46:58 java -Xms512m -Xmx512m -jar long-cloud-zipkin-server.jar --eureka-server=http://10.32.xx.xx:8761/eureka/

sed

添加方面操作

能过sed命令向文件中添加一行内容
需求:想要在hello.txt文件的第二行内容下面添加一行内容

[root@KS8P-Test-K8S05 ~]# cat hello.txt 
hello world
hello world
abx
abc
[root@KS8P-Test-K8S05 ~]# sed '2a\haha' hello.txt 
hello world
hello world
haha
abx
abc

注意:sed默认不会直接修改源文件数据,而是将数据复制到缓冲区中,修改也仅限于缓冲区中的数据,最终是将缓冲区内的数据输出控制台
这种方式的好处在于,测试非常方便,不会影响源文件
刚才的a参数表示指定行的下面添加数据,但是如果想在第一行添加数据怎么做
参数 i,表示在指定行的前面插入一行

[root@KS8P-Test-K8S05 ~]# sed '1i\第一行之前插入' hello.txt 
第一行之前插入
hello world
hello world
abx
abc

总结:参数a表示append的意思,在指定行后面添加内容;i表示insert的意思,是在指定行的前面插入,这是i与a的区别

如果在一个文件最后一行后面与前面添加内容,如何做

[root@KS8P-Test-K8S05 ~]# sed '$i\最后一行的前面添加一笔数据' hello.txt 
hello world
hello world
abx
最后一行的前面添加一笔数据
abc
[root@KS8P-Test-K8S05 ~]# sed '$a\最后一行的后面添加一笔数据' hello.txt 
hello world
hello world
abx
abc
最后一行的后面添加一笔数据

删除方面

删除文件中第3行内容

[root@KS8P-Test-K8S05 ~]# cat hello.txt 
hello world
hello world
abx
abc
[root@KS8P-Test-K8S05 ~]# sed '3d' hello.txt 
hello world
hello world
abc

替换操作

替换最常见的场景就是修改配置文件里面的服务器地址相关信息,以及账号密码的
sed 参数格式 [address]s/pattern/replacement/flags
address表示指定要操作的具体行,是一个可选项
s表示替换操作,pattern指的是需要替换的内容,replacement指的是要替换的新内容,flags有多种用法
第一种:flags可以表示为1-512之间的任意一个数字 ,表示指定要替换的字符串在这一行中出现第几时才进行替换
第二种:flags可以直接表示为g,意思就是对每一行数据中所有匹配到的内容全部进行替换,如果flags位置的值为空,则只会在第一次匹配成功时做替换操作

比较下面随着匹配次数不同,替换的位置也不同

[root@KS8P-Test-K8S05 ~]# cat hello.txt 
hello world
hello world
abx
abc
[root@KS8P-Test-K8S05 ~]# sed 's/l/a/1' hello.txt 
healo world
healo world
abx
abc
[root@KS8P-Test-K8S05 ~]# sed 's/l/a/2' hello.txt 
helao world
helao world
abx
abc
[root@KS8P-Test-K8S05 ~]# sed 's/l/a/3' hello.txt 
hello worad
hello worad
abx
abc

上面是替换都是会匹配文件中的所有行,如果要替换指定行中的内容,只需增加address参数即可

[root@KS8P-Test-K8S05 ~]# sed '2s/l/a/g' hello.txt 
hello world
heaao worad
abx
abc

上述sed命令所有操作,都不会影响原文件,只需要加一个 -i参数即可改变原文件

[root@KS8P-Test-K8S05 ~]# sed -i '2s/l/a/g' hello.txt 
[root@KS8P-Test-K8S05 ~]# cat hello.txt 
hello world
heaao worad
abx
abc

awk

aw是一个强大的分析工具,以空白字条为默认分隔符将每行内容切片,切开部分再进行各种分析处理
awk的基本格式:awk [option] programe file
option是一个可选项,一般在这里来指定文件中数据的字段分隔符
programe 是具体的处理逻辑
file 表示我们要操作的文件

在具体使用awk之前,还需要掌握awk的一个特性,就是awk在处理文本数据的时候,它会自动给每行中的每个字段分配一个变量
变量从1开始
$1表示是文本中的第1个数据字段 (有种第几列的样子)
$2表示是文本中的第2个数据字段
以此类推
还有一个特殊的$0它代表整个文本行的内容
下面实操一下hello.txt文件

[root@KS8P-Test-K8S05 ~]# cat hello.txt 
hello world
heaao worad
abx
abc
[root@KS8P-Test-K8S05 ~]# awk '{print $1}' hello.txt 
hello
heaao
abx
abc
[root@KS8P-Test-K8S05 ~]# awk '{print $2}' hello.txt 
world
worad


[root@KS8P-Test-K8S05 ~]# awk '{print $0}' hello.txt 
hello world
heaao worad
abx
abc

linux中还有一个文件/etc/password里面存储的是用户信息
但是这个文件中的字段之间是使用:分割的,这个时候想要操作列就需要手动指定字段分割字符

awk -F: '{print $1}' /etc/passwd
[root@KS8P-Test-K8S05 ~]# awk -F: '{print $1}' /etc/passwd
root
bin
daemon
adm
lp
sync
shutdown
halt
mail
operator
games
ftp
nobody
systemd-network
dbus
polkitd
sshd
postfix
ntp
tss
luxshare

处理数据的时候还可以对数据进行一些过滤操作,只获取满足条件的数据
在programe中可以使用正则表达式进行过滤
awk ‘/world/ {print $1}’ hello.txt 表示对每次读取到的那一行数据进行匹配

[root@KS8P-Test-K8S05 ~]# awk '/world/ {print $0}' hello.txt 
hello world
[root@KS8P-Test-K8S05 ~]# cat hello.txt 
hello world
heaao worad
abx
abc

如果只想对某一列数据进行匹配

awk '($1 ~ /world/) {print $0}' hello.txt  

上面通过$来指定具体的哪一列,需要将具体的对比逻辑放到小括号里面

[root@KS8P-Test-K8S05 ~]# awk '($1 ~ /world/) {print $0}' hello.txt  
[root@KS8P-Test-K8S05 ~]# awk '($2 ~ /world/) {print $0}' hello.txt  
hello world
[root@KS8P-Test-K8S05 ~]# awk '($2 ~ /wor[a-z]d/) {print $0}' hello.txt  
hello world
heaao worad

上面最后一个使用了正则表达式

结束

linux 极速进阶,至此告一阶段,后续会在使用过程中,不断补充。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

高阶组件和Hooks

目录 1. 高阶组件(Higher-Order Components) 1.1 创建高阶组件 1.2 使用高阶组件 2. Hooks 2.1 使用useState Hook管理状态 2.2 创建自定义Hook 结论 1. 高阶组件(Higher-Order Components) 高阶组件是一个接受一个组件作为…

面向对象--------三巨头

꒰˃͈꒵˂͈꒱ write in front ꒰˃͈꒵˂͈꒱ ʕ̯•͡˔•̯᷅ʔ大家好,我是xiaoxie.希望你看完之后,有不足之处请多多谅解,让我们一起共同进步૮₍❀ᴗ͈ . ᴗ͈ ა 本文由xiaoxieʕ̯•͡˔•̯᷅ʔ 原创 CSDN 如需转载还请通知˶⍤⃝˶个人主页&am…

Apache Airflow (四) :Airflow 调度shell命令

🏡 个人主页:IT贫道_大数据OLAP体系技术栈,Apache Doris,Clickhouse 技术-CSDN博客 🚩 私聊博主:加入大数据技术讨论群聊,获取更多大数据资料。 🔔 博主个人B栈地址:豹哥教你大数据的个人空间-豹…

Unity 制作血量滑动条(Slider)

1.创建UI slider 层级面板点击右键-UI-slider 2.调整UI位置 选择2D视图,调整锚点和滑动条位置 3.PS中制作UI 导出2个图层,PNG格式。 4.改成精灵模式(sprite2d) 把两个PNG导入Unity仓库中,选中两个图,右…

【LeetCode刷题笔记】堆和优先级队列

358. K 距离间隔重排字符串 解题思路: 大根堆 + 队列 , 1)首先 计数数组 统计 每个字符出现的次数 ,然后将 计数 > 0 的 字符 和 次数 一起放入 大根堆 ,大根堆中

Matlab的多项式留数与极点的计算

Matlab的多项式留数与极点的计算 以下面的多项式为例: 运算代码: clc clear closesyms p % 定义多项式 Zp(5*p^571*p^370*p)/(2*p^635*p^4117*p^236); % 提取分子与分母 [I,D]numden(Zp); Idouble(coeffs(I,p,"All"));%分子 Ddouble(coeffs…

Git系列之Git集成开发工具及git扩展使用

🎉🎉欢迎来到我的CSDN主页!🎉🎉 🏅我是君易--鑨,一个在CSDN分享笔记的博主。📚📚 🌟推荐给大家我的博客专栏《Git实战开发》。🎯🎯 &a…

基于若依的ruoyi-nbcio流程管理系统仿钉钉流程json转bpmn的flowable的xml格式(支持并行网关)

更多ruoyi-nbcio功能请看演示系统 gitee源代码地址 前后端代码: https://gitee.com/nbacheng/ruoyi-nbcio 演示地址:RuoYi-Nbcio后台管理系统 这个章节来完成并行网关,前端无需修改,直接后端修改就可以了。 1、并行网关后端修…

C#开发的OpenRA游戏之世界存在的属性CombatDebugOverlay(3)

C#开发的OpenRA游戏之世界存在的属性CombatDebugOverlay(3) 这次来分析CombatDebugOverlay属性,这个属性只有在调试游戏的时候才会使用。当你设置这个属性的时候,就可以看到如下图的结果: 可以看到物品的周边都有一个圆圈,以及有一些十字的点位标志。 那些十字表示的点…

【ATTCK】MITRE Caldera 朴素贝叶斯规划器

CALDERA是一个由python语言编写的红蓝对抗工具(攻击模拟工具)。它是MITRE公司发起的一个研究项目,该工具的攻击流程是建立在ATT&CK攻击行为模型和知识库之上的,能够较真实地APT攻击行为模式。 通过CALDERA工具,安全…

C++源文件的编译过程 学习 CMake 文档的前置知识

OHHHH,发现自己的基础知识真他妈的是呼呼漏风,,,,,,,,,,, 尴尬得意识到,不仅是英语水平有问题,他码的基础知识…

Web实验总

目录 网站需求: 思路: 实验步骤: 第一步:准备工作 第二步:新建一个存储网页的目录 第三步:修改本地hosts映射 第四步:修改配置文件,建立基于http服务的网站 1)创建用户song和…

iOS移动应用安全加固:保护您的App免受恶意攻击的重要步骤

目录 iOS移动应用安全加固:保护您的App免受恶意攻击的重要步骤 摘要 引言 一、APP加固的概念 二、APP加固方案的比较 三、保护iOS应用的安全 四、总结 参考资料 摘要 本文介绍了移动应用程序(App)加固的概念和流程,以及市…

[模版总结] - 树的基本算法1 - 遍历

树结构定义 一种非线性存储结构,具有存储“一对多”关系的数据元素集合 种类 General Tree TrieB/B 树二叉树 满/完满/完全二叉树 完美BT : 除了叶子结点外所有节点都有两个字节点,每一层都完满填充完全BT: 除最后一层以外其他每一层都完美…

单元测试工具-Junit

文章目录 一. 认识Junit二. Junit中常用的注解1. Test2. Disabled3. BeforeAll & AfterAll4. BeforeEach & AfterEach 三. ParameterizedTest参数化1. 单参数2. 多参数2.1. CSV 获取参数2.2. 方法获取参数 四. Order控制测试用例的执行顺序五. 断言六. 测试套件1. 通过…

Docker进阶——再次认识docker的概念 Docker的结构 Docker镜像结构 镜像的构建方式

前言 在微服务大量应用的互联网时代,经常能看到docker的身影。作为docker的爱好者(在服务器安装MySQL,Redis。。。我用的都是docker),我也会持续深入学习和认识docker。 本篇博客再次介绍docker的基本概念&#xff0…

SmartBear正式收购Stoplight,并计划在核心API设计、文档和门户产品中集成其功能

不久前,软件开发和可视化工具提供商SmartBear正式宣布收购全球领先的API设计公司Stoplight。这一收购是为了打造业内最全面的API开发平台,为寻求现代化API实践的开发团队提供更好的透明度、自动化与生产力。将Stoplight在API方面的优势(包括治…

吴恩达《机器学习》7-1->7-4:过拟合问题、代价函数、线性回归的正则化、正则化的逻辑回归模型

一、过拟合的本质 过拟合是指模型在训练集上表现良好,但在新数据上的泛化能力较差。考虑到多项式回归的例子,我们可以通过几个模型的比较来理解过拟合的本质。 线性模型(欠拟合): 第一个模型是一个线性模型&#xff0…

Elasticsearch:Lucene 中引入标量量化

作者:BENJAMIN TRENT 我们如何将标量量化引入 Lucene。 Lucene 中的自动字节量化 虽然 HNSW 是一种强大而灵活的存储和搜索向量的方法,但它确实需要大量内存才能快速运行。 例如,查询 768 维的 1MM float32 向量大约需要 1,000,000*4*(7681…

多维时序 | MATLAB实现TCN时间卷积神经网络多变量时间序列预测

多维时序 | MATLAB实现TCN时间卷积神经网络多变量时间序列预测 目录 多维时序 | MATLAB实现TCN时间卷积神经网络多变量时间序列预测预测效果基本介绍模型描述程序设计参考资料 预测效果 基本介绍 MATLAB实现TCN时间卷积神经网络多变量时间序列预测 模型描述 MATLAB实现TCN时间卷…