linux中常见命令使用

开头

本文参考自https://www.cnblogs.com/mchina/archive/2013/01/30/2880680.html
省略了一些我看不懂的话, 然后复制粘贴了一些我常用的指令以及介绍,并且稍微经过了我的二次加工,需要详细了解的可参考如上博客

screen常见使用指令

GNU Screen是一款由GNU计划开发的用于命令行终端切换的自由软件。用户可以通过该软件同时连接多个本地或远程的命令行会话,并在其间自由切换。
GNU Screen可以看作是窗口管理器的命令行界面版本。它提供了统一的管理多个会话的界面和相应的功能。

screen -S yourname -> 新建一个叫yourname的session
screen -ls -> 列出当前所有的session
screen -r yourname -> 回到yourname这个session
screen -d yourname -> 远程detach某个session
screen -d -r yourname -> 结束当前session并回到yourname这个session
# 按键盘上的ctrl+a+d也可以退出当前会话回到主窗口

screen语法

会话恢复

只要Screen本身没有终止,在其内部运行的会话都可以恢复。这一点对于远程登录的用户特别有用——即使网络连接中断,用户也不会失去对已经打开的命令行会话的控制。只要再次登录到主机上执行screen -r就可以恢复会话的运行。同样在暂时离开的时候,也可以执行分离命令detach,在保证里面的程序正常运行的情况下让Screen挂起(切换到后台)。这一点和图形界面下的VNC很相似。

多窗口

在Screen环境下,所有的会话都独立的运行,并拥有各自的编号、输入、输出和窗口缓存。用户可以通过快捷键在不同的窗口下切换,并可以自由的重定向各个窗口的输入和输出。Screen实现了基本的文本操作,如复制粘贴等;还提供了类似滚动条的功能,可以查看窗口状况的历史记录。窗口还可以被分区和命名,还可以监视后台窗口的活动。
会话共享
Screen可以让一个或多个用户从不同终端多次登录一个会话,并共享会话的所有特性(比如可以看到完全相同的输出)。它同时提供了窗口访问权限的机制,可以对窗口进行密码保护。
GNU’s Screen 官方站点:http://www.gnu.org/software/screen/

语法

参数说明
screen -A  将所有的视窗都调整为目前终端机的大小。
screen -d <作业名称>  将指定的screen作业离线。
screen -h <行数>  指定视窗的缓冲区行数。
screen -m  即使目前已在作业中的screen作业,仍强制建立新的screen作业。
screen -r <作业名称>  恢复离线的screen作业。
screen -R  先试图恢复离线的作业。若找不到离线的作业,即建立新的screen作业。
screen -s  指定建立新视窗时,所要执行的shell。
screen -S <作业名称>  指定screen作业的名称。
screen -v  显示版本信息。
screen -x  恢复之前离线的screen作业。
screen -ls或--list  显示目前所有的screen作业。
screen -wipe  检查目前所有的screen作业,并删除已经无法使用的screen作业。

在每个screen session 下,所有命令都以 ctrl+a(C-a) 开始。
ctrl+a+? -> 显示所有键绑定信息
ctrl+a+c -> 创建一个新的运行shell的窗口并切换到该窗口
ctrl+a+n -> Next,切换到下一个 window
ctrl+a+p -> Previous,切换到前一个 window
ctrl+a+0..9 -> 切换到第 0…9 个 window
ctrl+a+[Space] -> 由视窗0循序切换到视窗9
ctrl+a+ctrl+a -> 在两个最近使用的 window 间切换
ctrl+a+x -> 锁住当前的 window,需用用户密码解锁
ctrl+a+d -> detach,暂时离开当前session,将目前的 screen session (可能含有多个 windows) 丢到后台执行,并会回到还没进 screen 时的状态,此时在 screen session 里,每个 window 内运行的 process (无论是前台/后台)都在继续执行,即使 logout 也不影响。
ctrl+a+z -> 把当前session放到后台执行,用 shell 的 fg 命令则可回去。
ctrl+a+w -> 显示所有窗口列表
ctrl+a+t -> Time,显示当前时间,和系统的 load

使用

我一般是将screen和打印日志连起来使用的

screen -S Argonum #创建一个名为Argonum的会话
screen -r Argonum #连接进入这个Argonum的会话中
screen -ls  # 列出所有的会话,显示attach,则代表我处于这个会话中,显示dettach,则表示我没有处于该会话中
touch log.txt # 创建一个空白文件
python run.py >> log.txt #将日志写入log.txt文件中
ctrl+a+d  退出当前会话
more log.txt | grep ‘xxxx’  # 查看含有xxxx字段的日志中的内容,这个命令可以在主窗口执行,实际上screen窗口中还在执行上面的run.py命令

iptables

来源https://www.zsythink.net/archives/1199

从逻辑上讲。防火墙可以大体分为主机防火墙和网络防火墙。

  • 主机防火墙:针对于单个主机进行防护。

  • 网络防火墙:往往处于网络入口或边缘,针对于网络入口进行防护,服务于防火墙背后的本地局域网。

从物理上讲,防火墙可以分为硬件防火墙和软件防火墙。

  • 硬件防火墙:在硬件级别实现部分防火墙功能,另一部分功能基于软件实现,性能高,成本高。

  • 软件防火墙:应用软件处理逻辑运行于通用硬件平台之上的防火墙,性能低,成本低。

netfilter/iptables(下文中简称为iptables)组成Linux平台下的包过滤防火墙,与大多数的Linux软件一样,这个包过滤防火墙是免费的,它可以代替昂贵的商业防火墙解决方案,完成封包过滤、封包重定向和网络地址转换(NAT)等功能。
我们知道iptables是按照规则来办事的,我们就来说说规则(rules),规则其实就是网络管理员预定义的条件,规则一般的定义为”如果数据包头符合这样的条件,就这样处理这个数据包”。规则存储在内核空间的信息包过滤表中,这些规则分别指定了源地址、目的地址、传输协议(如TCP、UDP、ICMP)和服务类型(如HTTP、FTP和SMTP)等。当数据包与规则匹配时,iptables就根据规则所定义的方法来处理这些数据包,如放行(accept)、拒绝(reject)和丢弃(drop)等。配置防火墙的主要工作就是添加、修改和删除这些规则。

iptables为我们提供了如下”表”

  • filter表:负责过滤功能,防火墙;内核模块:iptables_filter

  • nat表:network address translation,网络地址转换功能;内核模块:iptable_nat

  • mangle表:拆解报文,做出修改,并重新封装 的功能;iptable_mangle

  • raw表:关闭nat表上启用的连接追踪机制;iptable_raw
    在这里插入图片描述

  • PREROUTING 的规则可以存在于:raw表,mangle表,nat表。

  • INPUT 的规则可以存在于:mangle表,filter表,(centos7中还有nat表,centos6中没有)。

  • FORWARD 的规则可以存在于:mangle表,filter表。

  • OUTPUT 的规则可以存在于:raw表mangle表,nat表,filter表。

  • POSTROUTING 的规则可以存在于:mangle表,nat表。

在这里插入图片描述
在这里插入图片描述
iptables的规则,之前打过一个比方,每条”链”都是一个”关卡”,每个通过这个”关卡”的报文都要匹配这个关卡上的规则,如果匹配,则对报文进行对应的处理,比如说,你我二人此刻就好像两个”报文”,你我二人此刻都要入关,可是城主有命,只有器宇轩昂的人才能入关,不符合此条件的人不能入关,于是守关将士按照城主制定的”规则”,开始打量你我二人,最终,你顺利入关了,而我已被拒之门外,因为你符合”器宇轩昂”的标准,所以把你”放行”了,而我不符合标准,所以没有被放行,其实,”器宇轩昂”就是一种”匹配条件”,”放行”就是一种”动作”,”匹配条件”与”动作”组成了规则。

匹配条件

匹配条件分为基本匹配条件与扩展匹配条件

处理动作

ACCEPT:允许数据包通过。

DROP:直接丢弃数据包,不给任何回应信息,这时候客户端会感觉自己的请求泥牛入海了,过了超时时间才会有反应。

REJECT:拒绝数据包通过,必要时会给数据发送端一个响应的信息,客户端刚请求就会收到拒绝的信息。

SNAT:源地址转换,解决内网用户用同一个公网地址上网的问题。

MASQUERADE:是SNAT的一种特殊形式,适用于动态的、临时会变的ip上。

DNAT:目标地址转换。

REDIRECT:在本机做端口映射。

LOG:在/var/log/messages文件中记录日志信息,然后将数据包传递给下一条规则,也就是说除了记录以外不对数据包做任何其他操作,仍然让下一条规则去匹配。

命令

iptables -t 表名 -L  # 查看指定表的所有规则
iptables -t 表名 -v -L 链名  # 查看指定表的链的规则
iptables -t 表名 -v -L   # 查看指定表的所有规则
iptables -t 表名 -n -L    # 表示查看表的所有规则,并且在显示规则时,不对规则中的IP或者端口进行名称反解,-n选项表示不解析IP地址。
iptables --line-numbers -t 表名 -L  # 表示查看表的所有规则,并且显示规则的序号
 


# 其他命令总结
### 以下为常见命令

```powershell
mkdir xxxx #创建文件夹
touch XXXX #创建文件
wc xxxx  #统计,第一个数字为统计行数,第二个数字为统计列数,第三个数字为统计字节数,第四个为文件名
pwd # 显示当前路径
head -n 6 xxxx # 显示文件前6行的内容
tail -n 6 xxxx # 显示文件最后6行的内容
sed -n '6,10p' xxxx #显示文件中第6行到第10行的内容
cat xxxx | head -n 10 | tail -n +6  #显示文件中第6到第10行的内容
awk -F '' '{print $6, $7, $8}' xxxx #打印文件中第6,7,8列的内容,并以空格的形式进行分割
cat xxxx | tr -s "\r\n" "\n" > xx # 将文件末尾的^M替换成linux系统中的\n
sort -unr xxxx -o xx  # 将文件中的数据按照从大到小的顺序排列,并进行去重,然后输入到xx文件
# -b 忽略每行前面开始出的空格字符。
# -c 检查文件是否已经按照顺序排序。
# -d 排序时,处理英文字母、数字及空格字符外,忽略其他的字符。
# -f 排序时,将小写字母视为大写字母。
# -i 排序时,除了040至176之间的ASCII字符外,忽略其他的字符。
# -m 将几个排序好的文件进行合并。
# -M 将前面3个字母依照月份的缩写进行排序。
# -n 依照数值的大小排序。
# -u 意味着是唯一的(unique),输出的结果是去完重了的。
# -o<输出文件> 将排序后的结果存入指定的文件。
# -r 以相反的顺序来排序。
# -t<分隔字符> 指定排序时所用的栏位分隔字符。
# +<起始栏位>-<结束栏位> 以指定的栏位来排序,范围由起始栏位到结束栏位的前一栏位。
# --help 显示帮助。
# --version 显示版本信息。
# -k [[field1],[field2]] 按指定的列进行排序。

linux下不同压缩格式的文件对应的解压命令

原内容来自博客https://blog.csdn.net/findzk/article/details/100998304
  • *.tar 用tar –xvf解压
  • *.gz 用 gzip -d或者gunzip 解压
  • .tar.gz和.tgz 用tar –xzf解压
  • *.bz2 用 bzip2 -d或者用bunzip2 解压
  • *.tar.bz2用tar –xjf 解压
  • *.Z 用 uncompress 解压
  • *.tar.Z 用tar –xZf 解压
  • *.rar 用 unrar e解压
  • *.zip 用 unzip 解压

修改路径

vim ~/.bashrc    # 修改路径
source ~/.bashrc #修改路径,并且之后都使用该路径

linux文本编辑命令

  • grep 更适合单纯的查找或匹配文本

  • sed 更适合编辑匹配到的文本

  • awk 更适合格式化文本,对文本进行较复杂格式处理

awk

语法:

  • awk [options] ‘Pattern{Action}’ file
  • Pattern有两个动词,一个BEGIN,一个END
    在这里插入图片描述
    在这里插入图片描述

选项

*-F : 指定分隔符,后面接指定的分隔符
*-v : 自定义变量,后面接赋值语句

内置变量:
  • FS:输入字段分隔符, 默认为空白字符

  • OFS:输出字段分隔符, 默认为空白字符

  • RS:输入记录分隔符(输入换行符), 指定输入时的换行符

  • ORS:输出记录分隔符(输出换行符),输出时用指定符号代替换行符

  • NF:number of Field,当前行的字段的个数(即当前行被分割成了几列),字段数量

  • NR:行号,当前处理的文本行的行号。

  • FNR:各文件分别计数的行号

  • FILENAME:当前文件名

  • ARGC:命令行参数的个数

  • ARGV:数组,保存的是命令行所给定的各参数

内置变量NR表示每一行的行号,内置变量NF表示每一行中一共有几列,下面表示第一行有10列,第二行到第五行有35列,$0表示打印整行信息,FNR内置变量的作用,当awk处理多个文件时,分别对每个文件的行数进行计数,FILENAME就是显示文件名,ARGC则表示参数的数量,也可以理解为ARGV数组的长度。
在这里插入图片描述在这里插入图片描述

自定义变量

方法一:-v varname=value 变量名区分字符大小写。

方法二:在program中直接定义,变量定义后需加分号;

在这里插入图片描述

printf

可以用正则表达式,我觉得,%s不就是表示字符串的意思吗
在这里插入图片描述
在这里插入图片描述

条件判断
正则表达式

awk '/正则表达式/{动作}' file

除了常见的,大于,大于等于,小于,小于等于,不等于,等于,均满足以外,还有以下也满足
在这里插入图片描述
* 在这里插入图片描述
注意事项:

  • 1、当在awk命令中使用正则模式时,使用到的正则用法属于”扩展正则表达式”(如果不理解,请参考博客中的”正则表达式”系列文章)。

  • 2、当使用 {x,y} 这种次数匹配的正则表达式时,需要配合–posix选项或者–re-interval选项。

在这里插入图片描述

行范围模式

awk '/正则表达式1/', '/正则表达式2/{动作}' file
打印第一次出现的正则表达式1与第一次出现的正则表达式2中间的句子
在这里插入图片描述

关系运算模式

awk '条件 {动作}' file

打印第3行到第6行
在这里插入图片描述
* 在这里插入图片描述

控制语句
条件判断if…else

awk ' {if(判断语句){执行语句1;执行语句;}}' file
在这里插入图片描述
if…else…
在这里插入图片描述
if…else if…else使用
在这里插入图片描述

循环判断for或者while

awk ' {for(判断语句){执行语句1;执行语句;}}' file
在这里插入图片描述

  • contiune:退出本次循环
  • break:退出整个循环
  • exit:退出当前命令
  • next:促使awk不对当前行执行对应的动作,而是直接处理下一行
    在这里插入图片描述

总结

干巴爹( ̄▽ ̄)*

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值