Linux常见操作命令

关注微信公众号塔容万物

免密码登录服务器

ssh有两种认证方式,一种是使用密码,一种是使用密钥来进行登录,这里介绍使用密钥登录的方法。

生成密钥

ssh-keygen [email protected]

将密钥传送到服务器

ssh-copy-id username@ip

设置别名

通过设置home目录下的.ssh文件下的config文件

#  ~/.ssh/config
Host 别名   # 这里你可以设置一个人简短的名字
   HostName ip  # 上一步目标服务器的ip
   Port 22
   User 上一步你的用户名

设置完成后,我们就可以使用别名来直接进行登录了,假如你设置的别名是deng,那么你就可以使用下面这种方法来进行登录。

ssh deng

Windows用户因为没有bash终端,所以上面的命令不能执行,你可以通过下载一个git bashhttps://gitforwindows.org/)来解决这个问题。另外,Windows的目录应该是C:\Users\你的用户名\.ssh,其余操作与Linux相同。这里推荐你安装一个Windows下的WSL子系统(不在本文的讨论范畴),这样就可以直接通过WSL作为跳板机,来进行服务器的登录。

文件目录

pwd

显示当前目录

cd

进入目录 按一次tab键可以自动补全路径,按两次可以将所有匹配的路径列出来

cd        # 进入home目录
cd ../    # 进入上一级目录(相对的)
cd /      # 进入根目录(绝对的)
cd ../../ # 进入上一级的上一级目录(相对的)
cd /opt   # 进入根目录下的opt目录下

ls

列出文件和目录

ls         # 列出当前目录下的文件和目录
ls /opt    # 列出/opt目录下的文件和目录
ls -l      # 列出当前目录下的文件和目录(带有详细信息)
ls -a      # 列出当前目录下的所有的文件和目录
ls -t      # 按照最后一次修改时间进行排序
ls -h      # 以人易于理解的方式显示信息(文件大小以Kb Mb Gb进行显示)

du

查看目录和文件的大小

du -h            # 以人类易于理解的方式进行显示
du --summarize   # 当前目录的大小信息
du --max-depth=N # 显示N级的大小信息,N=0时,等价于--summarize
								 # N=1时,显示当前目录下,各个目录和文件的大小信息

touch

创建文件

touch  文件名

mkdir

创建目录

mkdir 目录名

文件浏览

cat

将文件内容全部打印出来

cat 文件名      # 打印当前文件
cat -n  文件名  # 打印时带有行号

less

浏览文件内容,可以使用上下左右方向键来控制内容移动

less  文件名    # 浏览当前文件
less -S 文件名  # 不换行显示内容
less -N 文件名  # 显示行号

显示文件前几行的内容

head 文件名         # 显示文件前10行内容
head 文件名 -n 100  # 显示文件前100行内容

文件改动

rm

删除文件和目录

rm 1.txt        # 删除1.txt文件
rm -r test      # 删除test目录和该目录下的内容(相当于删除了一个文件夹)
rm -f 1.txt     # 强制删除1.txt
rm -i 1.txt     # 在删除之前会再次向你确认是否要进行删除操作

mv

移动/重命名 文件和目录

mv 1.txt 2.txt      # 把1.txt重命名为2.txt
mv 1.txt /opt       # 把1.txt移动到/opt目录下
mv test /opt        # 把test目录移动到/opt目录下
mv test /opt -i     # 把test目录移动到/opt目录下,如果/opt下已经存在同名的test目录,会询问是否覆盖
mv test /opt -f     # 把test目录移动到/opt目录下,如果/opt下已经存在同名的test目录,会直接是否覆盖

cp

复制文件

cp 1.txt 2.txt      # 将1.txt复制一份,存为2.txt
cp -r test /opt     # 将test目录和其中的内容复制到/opt目录下

文件权限

权限说明

在运行ls -l命令时,可以看到以下信息,第一列即为权限信息

root@sajhkjfsdhsds45sdfsd:/$ ls -l
total 1364
drwxr-xr-x  1 root root    4096 Nov  5 09:21 bin
drwxr-xr-x  1 root root    4096 May 14  2019 boot
drwxr-xr-x  1 root root    4096 Nov 12 09:16 dev
drwxr-xr-x  1 root root    4096 Nov 12 09:16 etc
drwxr-xr-x  1 root root    4096 Jul 15  2020 home

完整的权限信息为drwxrwxrwx,第一个字母代表类型,d为目录,后面的9个字母可以看作3个rwx的重复

第一组是所有者的权限,第二组是群组的权限,第三组是其他用户的权限,在编写shell时,可能会出现文件不能执行的问题,这主要是因为没有x权限,你可以通过以下命令来设置权限

chomod

假如这里有一个test.sh文件,他的权限信息为-rw-r--r--,即这个文件用户是没有执行权限的,我们可以通过下面的命令来加上X权限

chmod u+x test.sh  # u就是user  x就是执行权限  u+x就是给user加上执行权限
chmod u-x test.sh  # u就是user  x就是执行权限  u-x就是给user去掉执行权限

文件压缩

tar

用来打包文件

tar -cf 1.tar 1.txt     # 把文件1.txt打包成1.tar
tar -cf test.tar test/  # 把目录test打包成test.tar
tar -xf 1.tar           # 把1.tar这个包打开(解包)
tar -zxf test.tar.gz    # 直接将test.tar.gz解压解包成test

gzip/gunzip

压缩和解压

gzip 1.tar         # 将1.tar压缩,得到1.tar.gz
gunzip  1.tar.gz   # 将1.tar.gz解压,得到1.tar

zcat/zless

直接查看压缩文本文件的内容

zcat 1.txt.gz   # 结果与cat相同
zless 1.txt.gz  # 结果与less相同

进程管理

ps

查看当前系统运行的进程

ps            # 打印出当前系统的进程
#  PID TTY          TIME CMD
#   14 tty2     00:00:00 bash
#   67 tty2     00:00:00 ps

ps -aux       # 通过CPU和内存的使用来过滤出当前用户进行的进程

kill

停止一个进程

kill pid      # 停止pid号对应的进程,pid号为ps输出的第一列
kill -9 pid   # -9 为强制停止

nohup

将一个任务放到后台执行

nohup  命令  &                # 在后台运行命令,默认输出nohup.log日志文件
# nohup gunzip test.gz &      # 在后台解压文件
nohup 命令 >/dev/null 2>&1 &  # 在后台运行命令,同时不输出日志内容

下载

wget

下载内容

wget https://www.baidu.com/index.html  # 将该网址的内容index.

# 将该网址的内容index.html下载下来,保存为index1.html
wget https://www.baidu.com/index.html -O index1.html

# 将该网址的内容index.html下载下来,保存为index1.html,同时保存到/opt目录下
wget https://www.baidu.com/index.html -O index1.html  -P /opt

# 断点续传(下载一半突然命令被关掉了,下次下载的时候从上次的地方接着下载)
wget -c https://www.baidu.com/index.html

scp

从服务器上传/下载文件

# 从服务器下载到本地
# 将服务器/opt目录下的test.txt下载到当前目录
scp username@ip:/opt/test.txt ./1.txt

# 从本地上传到服务器
# 将本地的1.txt上传到服务器的/opt目录下
scp ./1.txt username@ip:/opt/

# scp也可以进行目录(文件夹)的上传与下载,需要加上 -r 参数

管道

在执行命令的时候,管道|符可以将上一个命令的输出作为下一个命令的输入

echo "abc" | wc  # 将echo的输出作为wc的输入
ls -l | less     # 将ls -l 的结果作为less的输入(可以一页一页的显示目录信息)

重定向

将输出>放到文件,或则从文件读取<

echo "abc" > a.txt      # 将abc输出到a.txt文件
cat from.txt > to.txt   # 将文件from.txt文件里面的内容输出到to.txt

文本处理

grep

文本搜索,是“global search regular expression and print out the line”的简称,搜索结果会将目标行输出, 最常使用的是从文件里面进行搜索。

grep abc /opt/test.txt        # 搜索/opt/test.txt文件中含有abc的行
grep abc -r /opt              # 搜索/opt目录下所有文件,并输出含有abc的行
grep abc -rn /opt             # 输出的时候带上行号
cat test.txt | grep abc       # 从test.txt文件里面搜索abc字符串
cat test.txt | grep -i abc    # 忽略大小写
cat test.txt | grep -E [0-9]+ # 使用正则表达式进行搜索
cat test.txt | grep -n abc    # 结果结果带有行号
cat test.txt | grep -c abc    # 输出搜索的结果数量,只输出一个数字
cat test.txt | grep -v abc    # 输出不含abc的行

sed

用来编辑文件,编辑后的结果直接输出到终端上,下面以test.txt为例

1
2
3
4
5
6

sed在自己编写指令时,需要-e来指定指令 sed中编辑相关的命令,每个编辑的命令都需要来指定行数

cat test.txt | sed -e 4a\abcd    # 在test.txt第四行后面加一行,内容是abcd
cat test.txt | sed -e 1,4a\abcd  # 在test.txt第1-4行每一行后面都加一行,内容是abcd
cat test.txt | sed -e 1d         # 删除第一行
cat test.txt | sed -e 1,4i\abc   # 在1-4行每一行行前插入一行
cat test.txt | sed -e 1.4c\abc   # 1.4行的内容替换为abc,这里是将四行的内容换成了一行内容

uniq

将内容去重,单位是行

# test.txt
1
2
2

cat test.txt | uniq
# 1
# 2

split

将一个文件按照给定的规则进行分割,可以按照大小,比如一个10MB的文件拆分成10个1MB的文件;也可以按照行数来进行分割,比如5行一个文件

split -6 test.txt output       # 按照行数,每6行拆成一个文件
split -c 1024 test.txt output  # 按照大小,每1024个字节分成一个文件,尽量保持每一行的完整

wc

统计

wc -w test.txt  # 统计字数
wc -l test.txt  # 统计行数
wc -c test.txt  # 统计字节数

awk

awk是一种编程语言,但是我更推荐你去学一学python,本文不在讨论。

查找

find

根据给定的规则来查找文件名和目录

find /opt -name "*.c"    # 查找/opt目录下所有.c为后缀的文件和目录
find /opt -iname "*test" # 查找/opt目录下所有含有test字符串的的文件和目录,并且忽略大小写
find /opt -size "+1M"    # 查找/opt目录下所有大小大于1MB的文件和目录
find /opt -size "-1M"    # 查找/opt目录下所有大小小于1MB的文件和目录
find /opt -ctime "+7"    # 查找/opt目录下7天前更改过的文件

size中的+/-:

ctime中的+/-

写在最后

这两篇文章介绍了只一部分命令的使用,下面这些命令你可能还会需要,这里需要你自行去了解这些内容。

最后,学会使用Linux命令最好的方法是亲自去多敲一敲。