[精通Linux]-101-命令行的艺术

装逼shell

  • sl
$ sl
-a An accident seems to happen. You'll feel pity for people who cry for help.

-l shows little one.

-F It flies.

-e Allow interrupt by Ctrl+C.
$ alias ls=sl
  • fortune
$ fortune # 诗歌
  • cmatrix
$ cmatrix # 黑客帝国
  • figlet toilet 命令
$ figlet ni hao shi jie

$ toilet hello world
  • yes
$ yes 我很NB

网络常见命令

ping

$ ping 主机名
$ ping ip
# 测试顺序
$ ping 127.0.0.1 #如果测试成功,表明网卡、TCP/IP 协议的安装、IP 地址、子网掩码的设置正常
$ ping 本机ip # 如果测试不成功,则表示本地配置或安装存在问题,应当对网络设备和通讯介质进行测试、检查并排除。
$ ping 局域网内其他 IP #如果测试成功,表明本地网络中的网卡和载体运行正确。但如果收到 0 个回送应答,那么表示子网掩码不正确或网卡配置错误或电缆系统有问题。
$  ping 网关 IP #这个命令如果应答正确,表示局域网中的网关路由器正在运行并能够做出应答。

ipconfig

netstat

netstat 命令能够显示活动的 TCP 连接、计算机侦听的端口、以太网统计信息、IP 路由表、IPv4 统计信息(对于 IP、ICMP、TCP 和 UDP 协议)以及 IPv6 统计信息(对于 IPv6、ICMPv6、通过 IPv6 的 TCP 以及 UDP 协议)。使用时如果不带参数,netstat 显示活动的 TCP 连接。

查找文件

$ find /path/ -name new.txt
$ find . "*.xml"
$ find . -name "*.xml"|xargs grep "hello world"
$ grep -H 'spring'*.xml

$ kill -9 pid
$ su username
$ chmod 777 file
$ tar -czf test.tar.gz /dirname
$ tar -xvzf test.tar.gz
$ lsof -l :8080

# linux系统基础
- linux系统分三层
- - 硬件系统:内存和中央处理器
- - 内核:管理硬件是硬件和软件的通讯接口
- - 进程是计算机运行的所有的程序。有内核同一管理,他们组成了最顶层
- - - ![linux系统的基本组成](https://ws4.sinaimg.cn/large/006tKfTcgy1g1doj9k8scj30s40mu0u0.jpg)
- 内核的组要作用:
- - - 进程:内核决定那个进程可以使用CPU
- - - 内存:内存管理所有的内存,为进程分配内存,管理进程间的共享内存以及空闲内存。
- - - 设备驱动程序:作为硬件和进程的接口,内核负责控制硬件设备。
- - - 系统调用和支持:进程通常使用系统调用的和内核进行通讯。
## 进程的管理
- 进程的管理包括:启动、停止、恢复、终止
- fork():内核创建几乎和该进程一模一样的副本。
## 用户空间:
- 内核分配给用户进程的内存:用户空间
- ![](https://ws4.sinaimg.cn/large/006tKfTcgy1g1dp9m27pej30so0cm75e.jpg)
## 基础命令和目录结构

1. 查看密码:cat /ect/passwd
2. Unix进程使用I/O流来读写数据。进程从输入流中读取数据,向输出流写出数据。数据流非常灵活,比如输入流可以是文件、设备、终端,甚至还可以是来自其他进程的输出流。
3. 删除文件夹:rmdir dir
4. grep keyword 文件:显示keword所在的行的内容
5. diff file1 file2:比较两个文件的不同
6. head file:打印前10行的内容
7. sort 每行的首字母排序
8. 命令行的结果输入到 文本:command >> file
## 网络基础
- ![](https://ws1.sinaimg.cn/large/006tKfTcgy1g1dvxip0xoj30to0deq3m.jpg)
- 局域网:(Local Area Network)简称Lan
- 网络的层次 :![](https://ws4.sinaimg.cn/large/006tKfTcgy1g1dw13aztaj30tm0mywhg.jpg)
- ![](https://ws1.sinaimg.cn/large/006tKfTcgy1g1dw2d99cej30s004saag.jpg)
- ![](https://ws1.sinaimg.cn/large/006tKfTcgy1g1dws48xmlj30u20f875d.jpg)
- 查看ip地址
- - ifconfig
- - ping ipaddress
## Linux 下的文本查找技巧 grep
- 结合通道|来使用它,即对文本内容搜索的命令似乎没有涉及。
- ps -ef|grep redis
### 在指定的文件中查找关键字
- grep ”find key“ 文件路径
- 查找包含关键字的文件:grep -rn "int main()"

## 常用命令
- uname:查看系统名字
- history:查看历史命令
- reboot/init 6 重启电脑/shutdown /init 0 关机
- apt-get常用命令:
update – 取回更新的软件包列表信息
upgrade – 进行一次升级
install – 安装新的软件包(注:软件包名称是 libc6 而非 libc6.deb)
remove – 卸载软件包
purge – 卸载并清除软件包的配置
autoremove – 卸载所有自动安装且不再使用的软件包
dist-upgrade – 发布版升级,见 apt-get(8)
dselect-upgrade – 根据 dselect 的选择来进行升级
build-dep – 为源码包配置所需的编译依赖关系
clean – 删除所有已下载的包文件
autoclean – 删除已下载的旧包文件
check – 核对以确认系统的依赖关系的完整性
source – 下载源码包文件
download – 下载指定的二进制包到当前目录
changelog – 下载指定软件包,并显示其changelog
- 关于软连接和硬链接
    - 硬链接是指向文件系统的指针
    - 软连接指向
# sftp
- ![sftp命令](http://ww2.sinaimg.cn/large/006tNc79gy1g4b2gzmeukj319g0t4t9t.jpg)
# 管道命令符
- 管道的定义:一个命令的输出作为另外一个命令的输入。命令A|命令B
- sudo ls -l ./Desktop/ | more 查看当前路径下有多少文件

# 环境变量
```sh
$ echo $PATH
$ PATH=$PATH:/root/bin

基本操作

  1. $  w     显示谁登录了系统并执行了哪些程序。
    $ w -h
    显示指定用户的信息
    $ w
    2.nmon
    Nmon(nigel’s monitor 的简写)是一个显示系统性能信息的工具。
    $ sudo apt-get install nmon
    更新系统$ sudo apt-get update
    查看cpu:lscpu
    查看CPU总线:lscpi
    查看多个硬件信息:lshw
    安装inxi软件:sudo apt-get install inxi
    inxi -Fx  :非技术人员也能看的懂的报告
    快捷键设置:screenshot     gnome-screenshot -a    ctrl+alt+z
  2. 操作系统:是一种作为用户和计算机之间的接口的软件程序。功能是管理计算机硬件、系统资源、内存、计算机和用户之间的交互,同时也是开发应用软件的基础。操作系统可以说是计算机的灵魂。
  3. 操作系统的功能:命令解释、进程管理、内存管理、设备管理、文件管理。
  4. linux体系结构:内核、shell、实用程序、应用程序组成。[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hkjGc4JM-1680172661838)(./pic-1542167083454.png “pic-1542167083454.png”)]
  5. 内核——操作系统程序。内核控制计算机资源,把他们分配给不同的用户和任务。
  6. shell——Linux有一个简单的称为shell的用户接口,提供用户要求的服务,通过shell用户可以与计算机进行交互。
  7. linux实用工具和应用程序——Linux 工具或命令是一组为日常处理要求服务的应用程序
  8. Linux系统登录:系统登录用户的名和口令。
  9. 文件系统:Linux最重要的特征是支持多种文件系统,到目前为止,Linux支持ext、ext2、xia、minix等十几种文件管理系统。
  10. tet文本文件、doc信息文件、sh:shell过程文件、html:HTML超文本文件、pl:PERL语言编写程序文件、o:编译文件产生的目标文件、tar:tar命令产生的备份包文件、gz:gzip命令文件产生的压缩文件、rpm:由rpm产生的文件包,linux程序安装包。
  11. 绝对路径与性对路径:只有一个根目录(“/”表示),即linux的顶层目录,其中含有下级子目录或文件的信息;子目录中又可含有更下级的子目录或者文件信息。
  12. Linux目录文件:§显示当前工作目录
[root@localhost root]# pwd

§改变当前目录

[root@localhost root]# cd  [directoryName]

§创建目录

[root@localhost root]#mkdir  [选项]  DirectoryName

§列出目录内容  [root@localhost root]#  ls  [选项]  [目录或文件] 
  1. 常用文件命令§显示文件内容命令
1.Cat命令

  当用户需要查看一个文件的内容时,可以根据显示要求的不同选用不同的命令。

2\. More命令

  More命令的功能是在终端屏幕按屏显示文本文件。

3\. Less命令

  Less命令的功能几乎和more命令一样,也用来按页显示文件,不同之处在于less命令在显示文件时允许用户既可以向前又可以向后翻阅文件。
  1. 文件操作
1.复制文件和目录cp

如果想要建立新服务或是进行文件备份等,都需要复制文件和目录。

[root@localhost root]#cp [选项][源文件和目录列表][目标目录名] 

2.删除文件和目录rm

系统中随时会有文件变得过时且毫无用处,用户可以用rm命令将其删除。

[root@localhost root]# rm [选项] [文件和目录列表]

3.移动文件和目录mv

mv命令用来移动指定的文件或目录,其命令格式如下:

[root@localhost root]# mv [选项] [源文件目录列表] [目标目录名]
  1. 局域网通信(聊天功能):配置网络(“主菜单”、“系统设置”、“网络”)
  2. Linux Shell与其他程序语言一样,允许定义和使用变量,Shell支持具有字符串的变量。变量用来存储信息的内存单元,是可存放数据的识别符。
  3. Shell变量分为:用户变量、系统变量、特殊变量;
  4. 在Linux Shell的实际使用过程中,设置变量的方式:直接设置变量值、变量之间的置换、从命令行参数获取、从环境变量获取、用户输入、
  5. Shell 分全局变量和局部变量。局部变量仅限在其命令行所在的Shell或Shell脚本中。全局变量的作用范围则包括本Shell进程及其所有子进程,即贯穿整个当前用户环境。
  6. 分支机构:if结构
  7. case…esac命令,为条件选择语句。
  8. while结构:while<条件表达式>   do   命令表  done
  9. until结构:until命令是一种循环结构,它和while命令相似:until<条件表达式>  do  命令表  done
  10. break、continue命令,无条件控制语句。break用于立即终止当前循环的执行,continue用于不执行循环中后面的语句立即开始下一个循环的执行。仅仅在do和done之间才有效。while语句可以使用continue命令 。
  11. 参数用来把值从命令传递给Shell脚本,参数是任何单词或字符串,它在Shell提示符后跟命令或文件名一起给出。
  12. 嵌入式系统的概念:以应用为中心,以计算机技术为基础,采用可剪裁的软硬件,适用于功能、可靠性、成本、体积、功耗等有严格要求的计算机专用系统。必须有处理的内核(cpu、DSP、)针对特定的需求来设置的、体积不可以太大,存储容量小、功耗比较小。
  13. 桌面、服务器、嵌入式系统。
  14. 计算机网络可以看成由通信子网和资源子网两部分组成。
  15. 局域网:主要的特点是由地理位置相近的计算机组成,主要有三大类局域网:局部区域网、高速区域网、计算机交换机。
  16. 城域网(MAN):分布队列双总线(DQDB),由两条单向总线组成。
  17. 广域网(WAN)远程网,分为三大类:陆地网、卫星网、分组无线网、
  18. 网络的功能:资源共享、均衡负荷以及分布处理、信息的快速传递和集中处理、综合信息服务。
  19. 数据传输系统[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Fm0c4csh-1680172661839)(./pic-1542167083456.png “pic-1542167083456.png”)]
  20. 信道:通信中传输信息的通道,它由相应的发送信息和接受信息的设备以及传输介质组成。信道分类可以分为:模拟信道、数字信道;按用途分类专用信道和公共信道,按传输介质分为有线信道和无线信道。
  21. 传输速度:1、波特(信号传输快慢的单位,在数据系统中,每秒传送的脉冲数Nb可以:Nb=1/Ts);2、比特/秒:比特/秒是信息系统每秒钟所传送的信息量,也称为数据传输速度或信息速度。
  22. 数据传递方式:模拟数通信与数字数据通信(模拟数据是某个区间连续的值,数字数据则是离散的值。)[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7XaH7cpq-1680172661839)(./pic-1542167083457.png “pic-1542167083457.png”)]
  23. linux的GUI解决方案:X-Windows System
  24. X-Windws System有三部分组成:控制实际的显示和输入设备;X-client:向X-Server发送请求以完成特定的窗口操作。通信通道:负责X-Server与Xclient的通信。
  25. linux terminal终端的输入:上下箭头可以翻阅历史命令,如果在一行执行多个命令,可以用;隔开。断开一个有很多行的命令可以使用\反斜杠,增强文章的可读性。
  26. 浏览目录类命令:pwd命令用于显示用户当前所在的目录。
  27. cd命令:不同目录的切换。Linux系统中用.表示当前目录;用…表示父目录;用~表示用户的个人home目录。
  28. ls命令:列出所有文件和目录信息。格式为:ls [参数][目录或文件]:-a:显示所有文件,包括.开头的隐藏文件;-A显示制定目录下的所有子目录及文件。但是不显示.和…;-c按文件的修改时间时间排序;-C分成多列显示各行。-d如果参数是目录,只显示其名称而不显示其下的各个文件;-l:以长格式形式显示文件的详细信息。-i在输入的第一列显示文件的i节点号。
  29. cat命令:cat [参数] 文件名   -b对输出内容中的非空行标注行号。-n:对输出内容中的所有行标注行号。
  30. 进入root用户操作:首次登陆root用户:sudo   passwd root;登陆root权限:su root
  31. shell是命令解释层。
Shell简介:用户和Linux操作系统之间的接口。Linux中有很多shell,其中缺省使用的是bash。
  1. Linux 中的 shell 有多种类型 其中最常用的几种是 Bourne shell (sh)、 C shell(csh )和 Korn shell (ksh )三种 shell 各有优缺
  2. 控制台:使用字符来操作界面的人机接口。
  3. 常用命令使用:登陆和退出Linux系统:$是普通用户的提示符;#是超级用户的提示符。
  4. pwd用来显示当前的工作路径。
  5. 创建新的用户:useradd  name  -p;
  6. 删除一个用户:userdel   name
  7. 创建一个群组:groupadd  name
  8. 删除一个群组:groupdel  name
  9. 超级用户还可以修改其他用户的口令,命令如下: passwd   用户名
    1. $  w     显示谁登录了系统并执行了哪些程序。
2.  $ w -h显示指定用户的信息
3.  $ w <username>
4.  2.nmonNmon(nigel’s monitor 的简写)是一个显示系统性能信息的工具。
5.  $ sudo apt-get install nmon
6.  更新系统$ sudo apt-get update
7.  查看cpu:lscpu
8.  查看CPU总线:lscpi
9.  查看多个硬件信息:lshw
10.  安装inxi软件:sudo apt-get install inxi
1.  inxi -Fx  :非技术人员也能看的懂的报告
2.  快捷键设置:screenshot     gnome-screenshot -a    ctrl+alt+z
  1. https://www.netcraft.com/

  2. 解决问题的智慧,表达清楚 ,子集找答案,

  3. 学习英文单词

  4. 忘掉windows思维方式

  5. Vmware快照和克隆功能

  6. 桥接:虚拟机直接使用真实的网卡,如真实的电脑

  7. 其他方式是使用的虚拟网卡

  8. SecureCRT远程连接工具

  9. winscp:win和linux相互传送文件

  10. 第三节兄弟连

  • pc:personal computer
  • os:operation system
  • linux:最核心的是内核
  • cd #change dir
  • touch 文件名
  • 命令:参数可以合并可以不分先后顺序
  • man #manual手册
  • tree  #查看文件树
  • vim:yy #复制所在的行
    1. p #粘贴
    2. dd #删除  2dd :删除向下的两行
    3. find --help    #从一个路径找文件
  • tar  归档管理
    • tar -cvf  打包名字   打包内容
    • tar -xvf   包名
    • 压缩    #tar  -zcvf    打包名    打包内容
    • 解压缩  #tar -zxvf  压缩包名
  • which 文件名
  • cal  -y   年
  • date   #当前时期
  • htop  #查看当前的内存
  • kill -9  进程号
  • 添加账户:sudo useradd 用户名 -m   不设置密码
    • 设置密码:sudo passwd shuaige
    • 退出当前账户:exit

文件系统

  • /:为系统的文件系统
  • [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-N86gKjqa-1680172665386)(null)]
  • 可分享的:
    • 可以为其他的系统挂在的目录。
  • 不可分享的:
    • 不适合分享与其他主机分享的系统
  • 不变的
    • 有些数据是不会经常改变的。例如库文件
  • 可改变
    • [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Nxa9KVBA-1680172664726)(null)]
  • FHS:/分区越小越好,并且应用程序所在的安装的软件最好不要与根目录在同一个分区内,并且保持越小越好。
      • /bin
        • 系统放置很多执行档的目录:cat,chmod(修改权限), chown, date, mv, mkdir, cp, bash等等常用的指令。
      • /boot目录
        • 放置开机有关的文档
      • /dev 目录 存放linux设备的目录
      • /etc目录
        • 所有的配置文档存放的目录
      • /lib:库文件
      • /media目录
      • /mnt目录
      • /opt :第三方润健存在的地方

整体结构

整体的目录结构

添加组

sudo groupadd 组名
sudo groupdel 组名

监控服务器

  • watch
watch -n 5 date
watch -n 10 who 
watch uptime # 系统运行比较慢,查看平均负载

命令行的艺术

curl

  • get请求:curl https://www.example.com
  • post请求:curl -d’login=emma&password=123’-X POST https://google.com/login

bash

  • 重定向
wc < filename # 输出文件行数,单词数,大小
  • 管道
command1 | command2 #管道:command1的输出给command2
  • 数学运算 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gRjqAZVU-1680172661841)(evernotecid://990D8831-DCFF-4D1B-AE60-0FA766F439F7/appyinxiangcom/11012738/ENResource/p1912)]
  • bc 计算器
$ bc # 退出计算机quit
  • if then
bash shell的if语句会运行if后面的那个命令。如果该命令的退出状态码(参见第11章)是0 (该命令成功运行),位于then部分的命令就会被执行.如果返回是其他值,则then后面的命令不会被执行。
  • if then else
if command then
commands
else
commands
fi
  • test 比较
    • [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-zLfBXQ3Y-1680172661841)(evernotecid://990D8831-DCFF-4D1B-AE60-0FA766F439F7/appyinxiangcom/11012738/ENResource/p1913)]
    • 字符比较
      • [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-l3lrO48T-1680172661842)(evernotecid://990D8831-DCFF-4D1B-AE60-0FA766F439F7/appyinxiangcom/11012738/ENResource/p1914)]
  • 设置快捷
$ alias now='date' # 设置快捷
$ unalias now     # 关闭快捷
  • $ sleep 10
  • while
while true; 
    do echo ok
done
  • Math using dc
echo '2 3 + p' | dc

基础

  • 学习 Bash 的基础知识。具体地,在命令行中输入 man bash 并至少全文浏览一遍; 它理解起来很简单并且不冗长。其他的 shell 可能很好用,但 Bash 的功能已经足够强大并且到几乎总是可用的( 如果你学习 zsh,fish 或其他的 shell 的话,在你自己的设备上会显得很方便,但过度依赖这些功能会给您带来不便,例如当你需要在服务器上工作时)。

  • 熟悉至少一个基于文本的编辑器。通常而言 Vim (vi) 会是你最好的选择,毕竟在终端中编辑文本时 Vim 是最好用的工具(甚至大部分情况下 Vim 要比 Emacs、大型 IDE 或是炫酷的编辑器更好用)。

  • 学会如何使用 man 命令去阅读文档。学会使用 apropos 去查找文档。知道有些命令并不对应可执行文件,而是在 Bash 内置好的,此时可以使用 helphelp -d 命令获取帮助信息。你可以用 type 命令 来判断这个命令到底是可执行文件、shell 内置命令还是别名。

  • 学会使用 >< 来重定向输出和输入,学会使用 | 来重定向管道。明白 > 会覆盖了输出文件而 >> 是在文件末添加。了解标准输出 stdout 和标准错误 stderr。

  • 学会使用通配符 * (或许再算上 ?[]) 和引用以及引用中 '" 的区别(后文中有一些具体的例子)。

  • 熟悉 Bash 中的任务管理工具:&ctrl-zctrl-cjobsfgbgkill 等。

  • 学会使用 ssh 进行远程命令行登录,最好知道如何使用 ssh-agentssh-add 等命令来实现基础的无密码认证登录。

  • 学会基本的文件管理工具:lsls -l (了解 ls -l 中每一列代表的意义),lessheadtailtail -f (甚至 less +F),lnln -s (了解硬链接与软链接的区别),chownchmoddu (硬盘使用情况概述:du -hs *)。 关于文件系统的管理,学习 dfmountfdiskmkfslsblk。知道 inode 是什么(与 ls -idf -i 等命令相关)。

  • 学习基本的网络管理工具:ipifconfigdig

  • 学习并使用一种版本控制管理系统,例如 git

  • 熟悉正则表达式,学会使用 grepegrep,它们的参数中 -i-o-v-A-B-C 这些是很常用并值得认真学习的。

  • 学会使用 apt-getyumdnfpacman (具体使用哪个取决于你使用的 Linux 发行版)来查找和安装软件包。并确保你的环境中有 pip 来安装基于 Python 的命令行工具 (接下来提到的部分程序使用 pip 来安装会很方便)。

日常使用

  • 在 Bash 中,可以通过按 Tab 键实现自动补全参数,使用 ctrl-r 搜索命令行历史记录(按下按键之后,输入关键字便可以搜索,重复按下 ctrl-r 会向后查找匹配项,按下 Enter 键会执行当前匹配的命令,而按下右方向键会将匹配项放入当前行中,不会直接执行,以便做出修改)。

  • 在 Bash 中,可以按下 ctrl-w 删除你键入的最后一个单词,ctrl-u 可以删除行内光标所在位置之前的内容,alt-balt-f 可以以单词为单位移动光标,ctrl-a 可以将光标移至行首,ctrl-e 可以将光标移至行尾,ctrl-k 可以删除光标至行尾的所有内容,ctrl-l 可以清屏。键入 man readline 可以查看 Bash 中的默认快捷键。内容有很多,例如 alt-. 循环地移向前一个参数,而 alt-* 可以展开通配符。

  • 你喜欢的话,可以执行 set -o vi 来使用 vi 风格的快捷键,而执行 set -o emacs 可以把它改回来。

  • 为了便于编辑长命令,在设置你的默认编辑器后(例如 export EDITOR=vim),ctrl-x ctrl-e 会打开一个编辑器来编辑当前输入的命令。在 vi 风格下快捷键则是 escape-v

  • 键入 history 查看命令行历史记录,再用 !nn 是命令编号)就可以再次执行。其中有许多缩写,最有用的大概就是 !$, 它用于指代上次键入的参数,而 !! 可以指代上次键入的命令了(参考 man 页面中的“HISTORY EXPANSION”)。不过这些功能,你也可以通过快捷键 ctrl-ralt-. 来实现。

  • cd 命令可以切换工作路径,输入 cd ~ 可以进入 home 目录。要访问你的 home 目录中的文件,可以使用前缀 ~(例如 ~/.bashrc)。在 sh 脚本里则用环境变量 $HOME 指代 home 目录的路径。

  • 回到前一个工作路径:cd -

  • 如果你输入命令的时候中途改了主意,按下 alt-# 在行首添加 # 把它当做注释再按下回车执行(或者依次按下 ctrl-a#enter)。这样做的话,之后借助命令行历史记录,你可以很方便恢复你刚才输入到一半的命令。

  • 使用 xargs ( 或 parallel)。他们非常给力。注意到你可以控制每行参数个数(-L)和最大并行数(-P)。如果你不确定它们是否会按你想的那样工作,先使用 xargs echo 查看一下。此外,使用 -I{} 会很方便。例如:

      find . -name '*.py' | xargs grep some_function
      cat hosts | xargs -I{} ssh root@{} hostname
  • pstree -p 以一种优雅的方式展示进程树。

  • 使用 pgreppkill 根据名字查找进程或发送信号(-f 参数通常有用)。

  • 了解你可以发往进程的信号的种类。比如,使用 kill -STOP [pid] 停止一个进程。使用 man 7 signal 查看详细列表。

  • 使用 nohupdisown 使一个后台进程持续运行。

  • 使用 netstat -lntpss -plat 检查哪些进程在监听端口(默认是检查 TCP 端口; 添加参数 -u 则检查 UDP 端口)或者 lsof -iTCP -sTCP:LISTEN -P -n (这也可以在 OS X 上运行)。

  • lsof 来查看开启的套接字和文件。

  • 使用 uptimew 来查看系统已经运行多长时间。

  • 使用 alias 来创建常用命令的快捷形式。例如:alias ll='ls -latr' 创建了一个新的命令别名 ll

  • 可以把别名、shell 选项和常用函数保存在 ~/.bashrc,具体看下这篇文章。这样做的话你就可以在所有 shell 会话中使用你的设定。

  • 把环境变量的设定以及登陆时要执行的命令保存在 ~/.bash_profile。而对于从图形界面启动的 shell 和 cron 启动的 shell,则需要单独配置文件。

  • 要想在几台电脑中同步你的配置文件(例如 .bashrc.bash_profile),可以借助 Git。

  • 当变量和文件名中包含空格的时候要格外小心。Bash 变量要用引号括起来,比如 "$FOO"。尽量使用 -0-print0 选项以便用 NULL 来分隔文件名,例如 locate -0 pattern | xargs -0 ls -alfind / -print0 -type d | xargs -0 ls -al。如果 for 循环中循环访问的文件名含有空字符(空格、tab 等字符),只需用 IFS=$'\n' 把内部字段分隔符设为换行符。

  • 在 Bash 脚本中,使用 set -x 去调试输出(或者使用它的变体 set -v,它会记录原始输入,包括多余的参数和注释)。尽可能地使用严格模式:使用 set -e 令脚本在发生错误时退出而不是继续运行;使用 set -u 来检查是否使用了未赋值的变量;试试 set -o pipefail,它可以监测管道中的错误。当牵扯到很多脚本时,使用 trap 来检测 ERR 和 EXIT。一个好的习惯是在脚本文件开头这样写,这会使它能够检测一些错误,并在错误发生时中断程序并输出信息:

      set -euo pipefail
      trap "echo 'error: Script failed: see failed command above'" ERR
  • 在 Bash 脚本中,子 shell(使用括号 (...))是一种组织参数的便捷方式。一个常见的例子是临时地移动工作路径,代码如下:
      # do something in current dir
      (cd /some/other/dir && other-command)
      # continue in original dir
  • 在 Bash 中,变量有许多的扩展方式。${name:?error message} 用于检查变量是否存在。此外,当 Bash 脚本只需要一个参数时,可以使用这样的代码 input_file=${1:?usage: $0 input_file}。在变量为空时使用默认值:${name:-default}。如果你要在之前的例子中再加一个(可选的)参数,可以使用类似这样的代码 output_file=${2:-logfile},如果省略了 2 ,它的值就为空,于是 ‘ o u t p u t f i l e ‘ 就会被设为 ‘ l o g f i l e ‘ 。数学表达式: ‘ i = 2,它的值就为空,于是 `output_file` 就会被设为 `logfile`。数学表达式:`i= 2,它的值就为空,于是outputfile就会被设为logfile。数学表达式:i=(( (i + 1) % 5 ))。序列:{1…10}。截断字符串:KaTeX parse error: Expected '}', got 'EOF' at end of input: …ar%suffix}` 和 `{var#prefix}。例如,假设 var=foo.pdf,那么 echo ${var%.pdf}.txt将输出foo.txt`。

  • 使用括号扩展({})来减少输入相似文本,并自动化文本组合。这在某些情况下会很有用,例如 mv foo.{txt,pdf} some-dir(同时移动两个文件),cp somefile{,.bak}(会被扩展成 cp somefile somefile.bak)或者 mkdir -p test-{a,b,c}/subtest-{1,2,3}(会被扩展成所有可能的组合,并创建一个目录树)。

  • 通过使用 <(some command) 可以将输出视为文件。例如,对比本地文件 /etc/hosts 和一个远程文件:

      diff /etc/hosts <(ssh somehost cat /etc/hosts)
  • 编写脚本时,你可能会想要把代码都放在大括号里。缺少右括号的话,代码就会因为语法错误而无法执行。如果你的脚本是要放在网上分享供他人使用的,这样的写法就体现出它的好处了,因为这样可以防止下载不完全代码被执行。
{
      # 在这里写代码
}
  • 了解 Bash 中的“here documents”,例如 cat <<EOF ...

  • 在 Bash 中,同时重定向标准输出和标准错误:some-command >logfile 2>&1 或者 some-command &>logfile。通常,为了保证命令不会在标准输入里残留一个未关闭的文件句柄捆绑在你当前所在的终端上,在命令后添加 </dev/null 是一个好习惯。

  • 使用 man ascii 查看具有十六进制和十进制值的ASCII表。man unicodeman utf-8,以及 man latin1 有助于你去了解通用的编码信息。

  • 使用 screentmux 来使用多份屏幕,当你在使用 ssh 时(保存 session 信息)将尤为有用。而 byobu 可以为它们提供更多的信息和易用的管理工具。另一个轻量级的 session 持久化解决方案是 dtach

  • ssh 中,了解如何使用 -L-D(偶尔需要用 -R)开启隧道是非常有用的,比如当你需要从一台远程服务器上访问 web 页面。

  • 对 ssh 设置做一些小优化可能是很有用的,例如这个 ~/.ssh/config 文件包含了防止特定网络环境下连接断开、压缩数据、多通道等选项:

      TCPKeepAlive=yes
      ServerAliveInterval=15
      ServerAliveCountMax=6
      Compression=yes
      ControlMaster auto
      ControlPath /tmp/%r@%h:%p
      ControlPersist yes
  • 一些其他的关于 ssh 的选项是与安全相关的,应当小心翼翼的使用。例如你应当只能在可信任的网络中启用 StrictHostKeyChecking=noForwardAgent=yes

  • 考虑使用 mosh 作为 ssh 的替代品,它使用 UDP 协议。它可以避免连接被中断并且对带宽需求更小,但它需要在服务端做相应的配置。

  • 获取八进制形式的文件访问权限(修改系统设置时通常需要,但 ls 的功能不那么好用并且通常会搞砸),可以使用类似如下的代码:

      stat -c '%A %a %n' /etc/timezone
  • 使用 percol 或者 fzf 可以交互式地从另一个命令输出中选取值。

  • 使用 fppPathPicker)可以与基于另一个命令(例如 git)输出的文件交互。

  • 将 web 服务器上当前目录下所有的文件(以及子目录)暴露给你所处网络的所有用户,使用:
    python -m SimpleHTTPServer 7777 (使用端口 7777 和 Python 2)或python -m http.server 7777 (使用端口 7777 和 Python 3)。

  • 以其他用户的身份执行命令,使用 sudo。默认以 root 用户的身份执行;使用 -u 来指定其他用户。使用 -i 来以该用户登录(需要输入_你自己的_密码)。

  • 将 shell 切换为其他用户,使用 su username 或者 sudo - username。加入 - 会使得切换后的环境与使用该用户登录后的环境相同。省略用户名则默认为 root。切换到哪个用户,就需要输入_哪个用户的_密码。

  • 了解命令行的 128K 限制。使用通配符匹配大量文件名时,常会遇到“Argument list too long”的错误信息。(这种情况下换用 findxargs 通常可以解决。)

  • 当你需要一个基本的计算器时,可以使用 python 解释器(当然你要用 python 的时候也是这样)。例如:

>>> 2+3
5

文件及数据处理

  • 在当前目录下通过文件名查找一个文件,使用类似于这样的命令:find . -iname '*something*'。在所有路径下通过文件名查找文件,使用 locate something (但注意到 updatedb 可能没有对最近新建的文件建立索引,所以你可能无法定位到这些未被索引的文件)。

  • 使用 ag 在源代码或数据文件里检索(grep -r 同样可以做到,但相比之下 ag 更加先进)。

  • 将 HTML 转为文本:lynx -dump -stdin

  • Markdown,HTML,以及所有文档格式之间的转换,试试 pandoc

  • 当你要处理棘手的 XML 时候,xmlstarlet 算是上古时代流传下来的神器。

  • 使用 jq 处理 JSON。

  • 使用 shyaml 处理 YAML。

  • 要处理 Excel 或 CSV 文件的话,csvkit 提供了 in2csvcsvcutcsvjoincsvgrep 等方便易用的工具。

  • 当你要处理 Amazon S3 相关的工作的时候,s3cmd 是一个很方便的工具而 s4cmd 的效率更高。Amazon 官方提供的 aws 以及 saws 是其他 AWS 相关工作的基础,值得学习。

  • 了解如何使用 sortuniq,包括 uniq 的 -u 参数和 -d 参数,具体内容在后文单行脚本节中。另外可以了解一下 comm

  • 了解如何使用 cutpastejoin 来更改文件。很多人都会使用 cut,但遗忘了 join

  • 了解如何运用 wc 去计算新行数(-l),字符数(-m),单词数(-w)以及字节数(-c)。

  • 了解如何使用 tee 将标准输入复制到文件甚至标准输出,例如 ls -al | tee file.txt

  • 要进行一些复杂的计算,比如分组、逆序和一些其他的统计分析,可以考虑使用 datamash

  • 注意到语言设置(中文或英文等)对许多命令行工具有一些微妙的影响,比如排序的顺序和性能。大多数 Linux 的安装过程会将 LANG 或其他有关的变量设置为符合本地的设置。要意识到当你改变语言设置时,排序的结果可能会改变。明白国际化可能会使 sort 或其他命令运行效率下降许多倍。某些情况下(例如集合运算)你可以放心的使用 export LC_ALL=C 来忽略掉国际化并按照字节来判断顺序。

  • 你可以单独指定某一条命令的环境,只需在调用时把环境变量设定放在命令的前面,例如 TZ=Pacific/Fiji date 可以获取斐济的时间。

  • 了解如何使用 awksed 来进行简单的数据处理。 参阅 One-liners 获取示例。

  • 替换一个或多个文件中出现的字符串:

      perl -pi.bak -e 's/old-string/new-string/g' my-files-*.txt
  • 使用 repren 来批量重命名文件,或是在多个文件中搜索替换内容。(有些时候 rename 命令也可以批量重命名,但要注意,它在不同 Linux 发行版中的功能并不完全一样。)
      # 将文件、目录和内容全部重命名 foo -> bar:
      repren --full --preserve-case --from foo --to bar .
      # 还原所有备份文件 whatever.bak -> whatever:
      repren --renames --from '(.*)\.bak' --to '\1' *.bak
      # 用 rename 实现上述功能(若可用):
      rename 's/\.bak$//' *.bak
  • 根据 man 页面的描述,rsync 是一个快速且非常灵活的文件复制工具。它闻名于设备之间的文件同步,但其实它在本地情况下也同样有用。在安全设置允许下,用 rsync 代替 scp 可以实现文件续传,而不用重新从头开始。它同时也是删除大量文件的最快方法之一:
mkdir empty && rsync -r --delete empty/ some-dir && rmdir some-dir
  • 若要在复制文件时获取当前进度,可使用 pvpycpprogressrsync --progress。若所执行的复制为block块拷贝,可以使用 dd status=progress

  • 使用 shuf 可以以行为单位来打乱文件的内容或从一个文件中随机选取多行。

  • 了解 sort 的参数。显示数字时,使用 -n 或者 -h 来显示更易读的数(例如 du -h 的输出)。明白排序时关键字的工作原理(-t-k)。例如,注意到你需要 -k1,1 来仅按第一个域来排序,而 -k1 意味着按整行排序。稳定排序(sort -s)在某些情况下很有用。例如,以第二个域为主关键字,第一个域为次关键字进行排序,你可以使用 sort -k1,1 | sort -s -k2,2

  • 如果你想在 Bash 命令行中写 tab 制表符,按下 ctrl-v [Tab] 或键入 $'\t' (后者可能更好,因为你可以复制粘贴它)。

  • 标准的源代码对比及合并工具是 diffpatch。使用 diffstat 查看变更总览数据。注意到 diff -r 对整个文件夹有效。使用 diff -r tree1 tree2 | diffstat 查看变更的统计数据。vimdiff 用于比对并编辑文件。

  • 对于二进制文件,使用 hdhexdump 或者 xxd 使其以十六进制显示,使用 bvihexedit 或者 biew 来进行二进制编辑。

  • 同样对于二进制文件,strings(包括 grep 等工具)可以帮助在二进制文件中查找特定比特。

  • 制作二进制差分文件(Delta 压缩),使用 xdelta3

  • 使用 iconv 更改文本编码。需要更高级的功能,可以使用 uconv,它支持一些高级的 Unicode 功能。例如,这条命令移除了所有重音符号:

      uconv -f utf-8 -t utf-8 -x '::Any-Lower; ::Any-NFD; [:Nonspacing Mark:] >; ::Any-NFC; ' < input.txt > output.txt
  • 拆分文件可以使用 split(按大小拆分)和 csplit(按模式拆分)。

  • 操作日期和时间表达式,可以用 dateutils 中的 dateadddatediffstrptime 等工具。

  • 使用 zlesszmorezcatzgrep 对压缩过的文件进行操作。

  • 文件属性可以通过 chattr 进行设置,它比文件权限更加底层。例如,为了保护文件不被意外删除,可以使用不可修改标记:sudo chattr +i /critical/directory/or/file

  • 使用 getfaclsetfacl 以保存和恢复文件权限。例如:

   getfacl -R /some/path > permissions.txt
   setfacl --restore=permissions.txt
  • 为了高效地创建空文件,请使用 truncate(创建稀疏文件),fallocate(用于 ext4,xfs,btrf 和 ocfs2 文件系统),xfs_mkfile(适用于几乎所有的文件系统,包含在 xfsprogs 包中),mkfile(用于类 Unix 操作系统,比如 Solaris 和 Mac OS)。

系统调试

  • curlcurl -I 可以被轻松地应用于 web 调试中,它们的好兄弟 wget 也是如此,或者也可以试试更潮的 httpie

  • 获取 CPU 和硬盘的使用状态,通常使用使用 tophtop 更佳),iostatiotop。而 iostat -mxz 15 可以让你获悉 CPU 和每个硬盘分区的基本信息和性能表现。

  • 使用 netstatss 查看网络连接的细节。

  • dstat 在你想要对系统的现状有一个粗略的认识时是非常有用的。然而若要对系统有一个深度的总体认识,使用 glances,它会在一个终端窗口中向你提供一些系统级的数据。

  • 若要了解内存状态,运行并理解 freevmstat 的输出。值得留意的是“cached”的值,它指的是 Linux 内核用来作为文件缓存的内存大小,而与空闲内存无关。

  • Java 系统调试则是一件截然不同的事,一个可以用于 Oracle 的 JVM 或其他 JVM 上的调试的技巧是你可以运行 kill -3 <pid> 同时一个完整的栈轨迹和堆概述(包括 GC 的细节)会被保存到标准错误或是日志文件。JDK 中的 jpsjstatjstackjmap 很有用。SJK tools 更高级。

  • 使用 mtr 去跟踪路由,用于确定网络问题。

  • ncdu 来查看磁盘使用情况,它比寻常的命令,如 du -sh *,更节省时间。

  • 查找正在使用带宽的套接字连接或进程,使用 iftopnethogs

  • ab 工具(Apache 中自带)可以简单粗暴地检查 web 服务器的性能。对于更复杂的负载测试,使用 siege

  • wiresharktsharkngrep 可用于复杂的网络调试。

  • 了解 straceltrace。这俩工具在你的程序运行失败、挂起甚至崩溃,而你却不知道为什么或你想对性能有个总体的认识的时候是非常有用的。注意 profile 参数(-c)和附加到一个运行的进程参数 (-p)。

  • 了解使用 ldd 来检查共享库。但是永远不要在不信任的文件上运行

  • 了解如何运用 gdb 连接到一个运行着的进程并获取它的堆栈轨迹。

  • 学会使用 /proc。它在调试正在出现的问题的时候有时会效果惊人。比如:/proc/cpuinfo/proc/meminfo/proc/cmdline/proc/xxx/cwd/proc/xxx/exe/proc/xxx/fd//proc/xxx/smaps(这里的 xxx 表示进程的 id 或 pid)。

  • 当调试一些之前出现的问题的时候,sar 非常有用。它展示了 cpu、内存以及网络等的历史数据。

  • 关于更深层次的系统分析以及性能分析,看看 stapSystemTap),perf,以及sysdig

  • 查看你当前使用的系统,使用 unameuname -a(Unix/kernel 信息)或者 lsb_release -a(Linux 发行版信息)。

  • 无论什么东西工作得很欢乐(可能是硬件或驱动问题)时可以试试 dmesg

  • 如果你删除了一个文件,但通过 du 发现没有释放预期的磁盘空间,请检查文件是否被进程占用:
    lsof | grep deleted | grep "filename-of-my-big-file"

单行脚本

一些命令组合的例子:

  • 当你需要对文本文件做集合交、并、差运算时,sortuniq 会是你的好帮手。具体例子请参照代码后面的,此处假设 ab 是两内容不同的文件。这种方式效率很高,并且在小文件和上 G 的文件上都能运用(注意尽管在 /tmp 在一个小的根分区上时你可能需要 -T 参数,但是实际上 sort 并不被内存大小约束),参阅前文中关于 LC_ALLsort-u 参数的部分。
      sort a b | uniq > c   # c 是 a 并 b
      sort a b | uniq -d > c   # c 是 a 交 b
      sort a b b | uniq -u > c   # c 是 a - b
  • 使用 grep . *(每行都会附上文件名)或者 head -100 *(每个文件有一个标题)来阅读检查目录下所有文件的内容。这在检查一个充满配置文件的目录(如 /sys/proc/etc)时特别好用。

  • 计算文本文件第三列中所有数的和(可能比同等作用的 Python 代码快三倍且代码量少三倍):

      awk '{ x += $3 } END { print x }' myfile
  • 如果你想在文件树上查看大小/日期,这可能看起来像递归版的 ls -l 但比 ls -lR 更易于理解:
      find . -type f -ls
  • 假设你有一个类似于 web 服务器日志文件的文本文件,并且一个确定的值只会出现在某些行上,假设一个 acct_id 参数在 URI 中。如果你想计算出每个 acct_id 值有多少次请求,使用如下代码:
      egrep -o 'acct_id=[0-9]+' access.log | cut -d= -f2 | sort | uniq -c | sort -rn
  • 要持续监测文件改动,可以使用 watch,例如检查某个文件夹中文件的改变,可以用 watch -d -n 2 'ls -rtlh | tail';或者在排查 WiFi 设置故障时要监测网络设置的更改,可以用 watch -d -n 2 ifconfig

  • 运行这个函数从这篇文档中随机获取一条技巧(解析 Markdown 文件并抽取项目):

      function taocl() {
        curl -s https://raw.githubusercontent.com/jlevy/the-art-of-command-line/master/README-zh.md|
          pandoc -f markdown -t html |
          iconv -f 'utf-8' -t 'unicode' |
          xmlstarlet fo --html --dropdtd |
          xmlstarlet sel -t -v "(html/body/ul/li[count(p)>0])[$RANDOM mod last()+1]" |
          xmlstarlet unesc | fmt -80
      }

冷门但有用

  • expr:计算表达式或正则匹配

  • m4:简单的宏处理器

  • yes:多次打印字符串

  • cal:漂亮的日历

  • env:执行一个命令(脚本文件中很有用)

  • printenv:打印环境变量(调试时或在写脚本文件时很有用)

  • look:查找以特定字符串开头的单词或行

  • cutpastejoin:数据修改

  • fmt:格式化文本段落

  • pr:将文本格式化成页/列形式

  • fold:包裹文本中的几行

  • column:将文本格式化成多个对齐、定宽的列或表格

  • expandunexpand:制表符与空格之间转换

  • nl:添加行号

  • seq:打印数字

  • bc:计算器

  • factor:分解因数

  • gpg:加密并签名文件

  • toe:terminfo 入口列表

  • nc:网络调试及数据传输

  • socat:套接字代理,与 netcat 类似

  • slurm:网络流量可视化

  • dd:文件或设备间传输数据

  • file:确定文件类型

  • tree:以树的形式显示路径和文件,类似于递归的 ls

  • stat:文件信息

  • time:执行命令,并计算执行时间

  • timeout:在指定时长范围内执行命令,并在规定时间结束后停止进程

  • lockfile:使文件只能通过 rm -f 移除

  • logrotate: 切换、压缩以及发送日志文件

  • watch:重复运行同一个命令,展示结果并/或高亮有更改的部分

  • when-changed:当检测到文件更改时执行指定命令。参阅 inotifywaitentr

  • tac:反向输出文件

  • shuf:文件中随机选取几行

  • comm:一行一行的比较排序过的文件

  • strings:从二进制文件中抽取文本

  • tr:转换字母

  • iconvuconv:文本编码转换

  • splitcsplit:分割文件

  • sponge:在写入前读取所有输入,在读取文件后再向同一文件写入时比较有用,例如 grep -v something some-file | sponge some-file

  • units:将一种计量单位转换为另一种等效的计量单位(参阅 /usr/share/units/definitions.units

  • apg:随机生成密码

  • xz:高比例的文件压缩

  • ldd:动态库信息

  • nm:提取 obj 文件中的符号

  • abwrk:web 服务器性能分析

  • strace:调试系统调用

  • mtr:更好的网络调试跟踪工具

  • cssh:可视化的并发 shell

  • rsync:通过 ssh 或本地文件系统同步文件和文件夹

  • wiresharktshark:抓包和网络调试工具

  • ngrep:网络层的 grep

  • hostdig:DNS 查找

  • lsof:列出当前系统打开文件的工具以及查看端口信息

  • dstat:系统状态查看

  • glances:高层次的多子系统总览

  • iostat:硬盘使用状态

  • mpstat: CPU 使用状态

  • vmstat: 内存使用状态

  • htop:top 的加强版

  • last:登入记录

  • w:查看处于登录状态的用户

  • id:用户/组 ID 信息

  • sar:系统历史数据

  • iftopnethogs:套接字及进程的网络利用情况

  • ss:套接字数据

  • dmesg:引导及系统错误信息

  • sysctl: 在内核运行时动态地查看和修改内核的运行参数

  • hdparm:SATA/ATA 磁盘更改及性能分析

  • lsblk:列出块设备信息:以树形展示你的磁盘以及磁盘分区信息

  • lshwlscpulspcilsusbdmidecode:查看硬件信息,包括 CPU、BIOS、RAID、显卡、USB设备等

  • lsmodmodinfo:列出内核模块,并显示其细节

  • fortuneddatesl:额,这主要取决于你是否认为蒸汽火车和莫名其妙的名人名言是否“有用”

仅限 OS X 系统

以下是仅限于 OS X 系统的技巧。

  • brew (Homebrew)或者 port (MacPorts)进行包管理。这些可以用来在 OS X 系统上安装以上的大多数命令。

  • pbcopy 复制任何命令的输出到桌面应用,用 pbpaste 粘贴输入。

  • 若要在 OS X 终端中将 Option 键视为 alt 键(例如在上面介绍的 alt-balt-f 等命令中用到),打开 偏好设置 -> 描述文件 -> 键盘 并勾选“使用 Option 键作为 Meta 键”。

  • open 或者 open -a /Applications/Whatever.app 使用桌面应用打开文件。

  • Spotlight:用 mdfind 搜索文件,用 mdls 列出元数据(例如照片的 EXIF 信息)。

  • 注意 OS X 系统是基于 BSD UNIX 的,许多命令(例如 pslstailawksed)都和 Linux 中有微妙的不同( Linux 很大程度上受到了 System V-style Unix 和 GNU 工具影响)。你可以通过标题为 “BSD General Commands Manual” 的 man 页面发现这些不同。在有些情况下 GNU 版本的命令也可能被安装(例如 gawkgsed 对应 GNU 中的 awk 和 sed )。如果要写跨平台的 Bash 脚本,避免使用这些命令(例如,考虑 Python 或者 perl )或者经过仔细的测试。

  • sw_vers 获取 OS X 的版本信息。

仅限 Windows 系统

以下是仅限于 Windows 系统的技巧。

在 Winodws 下获取 Unix 工具

  • 可以安装 Cygwin 允许你在 Microsoft Windows 中体验 Unix shell 的威力。这样的话,本文中介绍的大多数内容都将适用。

  • 在 Windows 10 上,你可以使用 Bash on Ubuntu on Windows,它提供了一个熟悉的 Bash 环境,包含了不少 Unix 命令行工具。好处是它允许 Linux 上编写的程序在 Windows 上运行,而另一方面,Windows 上编写的程序却无法在 Bash 命令行中运行。

  • 如果你在 Windows 上主要想用 GNU 开发者工具(例如 GCC),可以考虑 MinGW 以及它的 MSYS 包,这个包提供了例如 bash,gawk,make 和 grep 的工具。MSYS 并不包含所有可以与 Cygwin 媲美的特性。当制作 Unix 工具的原生 Windows 端口时 MinGW 将特别地有用。

  • 另一个在 Windows 下实现接近 Unix 环境外观效果的选项是 Cash。注意在此环境下只有很少的 Unix 命令和命令行可用。

实用 Windows 命令行工具

  • 可以使用 wmic 在命令行环境下给大部分 Windows 系统管理任务编写脚本以及执行这些任务。

  • Windows 实用的原生命令行网络工具包括 pingipconfigtracert,和 netstat

  • 可以使用 Rundll32 命令来实现许多有用的 Windows 任务

Cygwin 技巧

  • 通过 Cygwin 的包管理器来安装额外的 Unix 程序。

  • 使用 mintty 作为你的命令行窗口。

  • 要访问 Windows 剪贴板,可以通过 /dev/clipboard

  • 运行 cygstart 以通过默认程序打开一个文件。

  • 要访问 Windows 注册表,可以使用 regtool

  • 注意 Windows 驱动器路径 C:\ 在 Cygwin 中用 /cygdrive/c 代表,而 Cygwin 的 / 代表 Windows 中的 C:\cygwin。要转换 Cygwin 和 Windows 风格的路径可以用 cygpath。这在需要调用 Windows 程序的脚本里很有用。

  • 学会使用 wmic,你就可以从命令行执行大多数 Windows 系统管理任务,并编成脚本。

  • 要在 Windows 下获得 Unix 的界面和体验,另一个办法是使用 Cash。需要注意的是,这个环境支持的 Unix 命令和命令行参数非常少。

  • 要在 Windows 上获取 GNU 开发者工具(比如 GCC)的另一个办法是使用 MinGW 以及它的 MSYS 软件包,该软件包提供了 bash、gawk、make、grep 等工具。然而 MSYS 提供的功能没有 Cygwin 完善。MinGW 在创建 Unix 工具的 Windows 原生移植方面非常有用。

更多资源

时间

$ date "+%Y-%m-%d %H:%M:%S

其他

  • 服务器,DIY自己组装的服务器。
  • 1991年linux系统诞生,gnu计划:完全开放自由的操作系统
  • 合理的利用时间,零碎的时间去学习技术。linus是一个内核,www.kernel.org
  • linux开源系统——全球互联网公司首先解决方案。
  • 每日过万职位选择
  • 月薪过万,越老越值钱。
  • 操作系统:fedora 、CentOS=RedHat
  • 鸟哥的书是一本字典,多练习
  • 组装服务器:Intel 5500  适合intel平台 华硕主板 ;CPU:主频 核心数量 缓存大点好; 硬盘:64MB缓存 鲁大师确认硬件
  • linux终端:PTS伪终端:Ctrl+shift+T
  • ls :-l:显示详细信息
  • ls -a:显示隐藏文件  。表示隐藏文件   …上级目录
  • ls -d
  • pwd:当前目录
  • cd:切换目录
  • hwclock:#指的是bios时间
  • shutdown --help    -r  # reboot;-h  关机;-h +时间   shutdown -c :#取消(ctrl +c)中断  ;shutdown -h now:#立即关机
  • init #切换运行级别 ;0#关机;6#重启;1#单用户模式;2#多用户模式;5#X-window桌面系统
  • runlevel:当前的级别
  • 修改密码passwd:passwd 用户
  • [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-zwXJfyUc-1680172661843)(./pic-1542881636855.png “pic-1542881636855.png”)]
  • 查看当前系统内存的使用情况 free
  • 查看文件系统的磁盘空间占用情况df
  • 查看磁盘分区情况对磁盘济宁分区管理fdisk:
    • [root@localhost root]# fdisk -l此外fdisk必须root
  • mount:加载硬盘:
    • 装载一个光盘:mount -t iso9660 /dev/hdc /mnt/cd-rom
    • 挂载一个SCSI格式的U盘:mount –t vfat /dev/sda1 /mnt/u
    • umount进行卸载
  • 文件目录相关命令:改进工作目录:cd(可以是相对路径或者绝对路径
  • 显示当前目录下的所有文件和目录:ls-l
  • 创建一个目录:mkdir 名字
  • 查看文件内容:cat
    • cat /root/.bash_profile

    • -n参数对所有输出的行编号:[root@localhost /]# cat -n /root/.bash_profile
    • 一次显示多个文件的内容:cat hello1.c hello2.c
  • 复制命令:cp
    • cp file1 file2 将文件file1复制成file2。
    • cp file1 dir1 将文件file1复制到目录dir1下,文件名仍为file1。
    • cp /tmp/file1 . 将目录/tmp下的文件file1复制到当前目录下,文件名仍为file1。
    • cp /tmp/file1 file2将目录/tmp下的文件file1复制到当前目录下,文件名为file2。
    • cp –r dir1 dir2 复制整个目录。-r参数表示递归复制该目录下所有子目录和文件。
  • 移动或更改文件、目录名称:mv
    • mv file1 file2 将文件file1更名为file2。
    • mv file1 dir1 将文件file1复制到目录dir1下,文件名仍为file1。
    • mv dir1 dir2 将目录dir1更名为目录dir2。
  • 删除文件:rm
    • rm file1 删除文件名为file1的文件。
    • rm file? 删除文件中有五个字符且前四个字符为file的所有文件。
    • rmf*删除文件名中以f为首的所有文件
  • Linux 的软件包一般是以.gz或.tar 或者.tar.gz、.tar.bz2结尾的
    • 把linux-2.4.x.tar.gz解压:tar xzf linux-2.4.x. .tar.gz
    • 把目录linux-2.4.x压缩成一个文件linux-2.4.x.tar.gz:tar czf linux-2.4.x.tar.gz linux-2.4.x
    • 解压缩bz2 格式压缩包:tar -xjf linux.bz2
    • 建立bz2 格式压缩包:tar -cjf linux-2.4.x.tar.bz2 /develop/linux-2.4.x
  • 帮助系统:help        用法:命令-help。ls-help
  • man命令:man ls   会列出linux命令手册中该命令ls的完整用法。

awk

  • awk是一个功能非常强大的文本处理工具,它能把文本当做数据库,然后把数据库中的每一行切分为多个字段,可以实现分别对多个字段或行进行处理,并使之按照一定的格式输出,所以awk是文本报告生成器,它能格式化文本。而要选择性地处理字段或行,则可以使用模式(PATTERN)来匹配。
$ ll | gawk '{print$1, $2,$3,$4,$5,$6,$7,$8,$9}'

账号安全

  • 用户信息文件 /etc/passwd
 # 用户名:密码:用户ID:组ID:用户说明:家目录:登陆之后的 shell
root:x:0:0:root:/root:/bin/bash
  • 影子文件:/etc/shadow
# 用户名:加密密码:密码最后一次修改日期:两次密码的修改时间间隔:密码有效期:密码修改到期到的警告天数:密码过期之后的宽限天数:账号失效时间:保留
root:$6$oGs1PqhL2p3ZetrE$X7o7bzoouHQVSEmSgsYN5UD4.kMHx6qgbTqwNVC5oOAouXvcjQSt.Ft7ql1WpkopY0UV9ajBwUt1DpYxTCVvI/:16809:0:99999:7:::
$ who     # 查看当前登录系统的所有用户(tty 本地登陆  pts 远程登录)
$ w       # 显示已经登录系统的所用用户,以及正在执行的指令
$ uptime  # 查看登陆多久、多少用户,负载状态
  1. 排查用户信息
# 显示logged in表示用户还在登录
# pts表示从SSH远程登录
# tty表示从控制台登录,就是在服务器旁边登录
last
  1. 查看远程登录失败的用户
# ssh表示从SSH远程登录
# tty表示从控制台登录
sudo lastb
  1. sudo 用户列表
/etc/sudoers
# 1、保存1万条命令:
sed -i 's/^HISTSIZE=1000/HISTSIZE=10000/g' /etc/profile

# 2、在/etc/profile的文件尾部添加如下行数配置信息:
USER_IP=`who -u am i 2>/dev/null | awk '{print $NF}' | sed -e 's/[()]//g'`
if [ "$USER_IP" = "" ]
then
USER_IP=`hostname`
fi
export HISTTIMEFORMAT="%F %T $USER_IP `whoami` "
shopt -s histappend
export PROMPT_COMMAND="history -a"

# 3、让配置生效
source /etc/profile
  1. 检查端口连接情况
netstat -antlp | more
  1. 日志分析技巧
1、定位有多少IP在爆破主机的root帐号:    
grep "Failed password for root" /var/log/secure | awk '{print $11}' | sort | uniq -c | sort -nr | more

定位有哪些IP在爆破:
grep "Failed password" /var/log/secure|grep -E -o "(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)"|uniq -c

爆破用户名字典是什么?
grep "Failed password" /var/log/secure|perl -e 'while($_=<>){ /for(.*?) from/; print "$1\n";}'|uniq -c|sort -nr

2、登录成功的IP有哪些:   
grep "Accepted " /var/log/secure | awk '{print $11}' | sort | uniq -c | sort -nr | more

登录成功的日期、用户名、IP:
grep "Accepted " /var/log/secure | awk '{print $1,$2,$3,$9,$11}' 

3、增加一个用户kali日志:
Jul 10 00:12:15 localhost useradd[2382]: new group: name=kali, GID=1001
Jul 10 00:12:15 localhost useradd[2382]: new user: name=kali, UID=1001, GID=1001, home=/home/kali
, shell=/bin/bash
Jul 10 00:12:58 localhost passwd: pam_unix(passwd:chauthtok): password changed for kali
#grep "useradd" /var/log/secure 

4、删除用户kali日志:
Jul 10 00:14:17 localhost userdel[2393]: delete user 'kali'
Jul 10 00:14:17 localhost userdel[2393]: removed group 'kali' owned by 'kali'
Jul 10 00:14:17 localhost userdel[2393]: removed shadow group 'kali' owned by 'kali'
# grep "userdel" /var/log/secure

5、su切换用户:
Jul 10 00:38:13 localhost su: pam_unix(su-l:session): session opened for user good by root(uid=0)

sudo授权执行:
sudo -l
Jul 10 00:43:09 localhost sudo:    good : TTY=pts/4 ; PWD=/home/good ; USER=root ; COMMAND=/sbin/shutdown -r now
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AI拉呱

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值