开头
本文参考自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不对当前行执行对应的动作,而是直接处理下一行
总结
干巴爹( ̄▽ ̄)*