免密码登录服务器
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 bash
(https://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
显示文件前几行的内容
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
的重复
r
代表读取权限w
代表写入权限x
代表执行权限
第一组是所有者的权限,第二组是群组的权限,第三组是其他用户的权限,在编写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中编辑相关的命令,每个编辑的命令都需要来指定行数
a
添加d
删除c
替换i
插入
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中的+/-
+n
n天前-n
n天内
写在最后
这两篇文章介绍了只一部分命令的使用,下面这些命令你可能还会需要,这里需要你自行去了解这些内容。
- 使用
apt/yum
去安装软件 - 软连接和硬链接
ln
- 检查网络
ping/ipconfig
man
说明书的使用
最后,学会使用Linux命令最好的方法是亲自去多敲一敲。