前言
在学习命令之前先学习我们该如何去学习linux 命令。
几乎每一个命令都有参数,每个参数的含义是什么,我们一般也不是全部都能记住,所以我们必须有一个可以知道每一个命令下各个参数的含义的方法。
命令 --help 这个就是查询每一个命令的使用方式和各个参数的使用说明。
举例:mkdir --help
我们可以看到显示的信息对mkdir 做了说明,对-p -m -v -z 这几个参数也一一做了说明。
1. 文件和目录
cd 打开文件夹的命令,通过cd命令我们可以*的操作文件的切换。
cd /home 打开home文件夹
cd .. 打开上级目录
cd ../.. 打开上上级目录
cd ~ 打开自己的主目录
cd - 打开上次访问的目录
ls 是查看当前目录下的文件夹和文件的情况。
ls 查看当前目录下的文件夹和文件
ls -l (ll) 查看当前目录下的文件夹和文件的详细信息。 ll 是ls -l 的简写
ls -a 查看当前目录下的文件夹和文件包含隐藏文件
ls -lh 查看当前目录下的文件夹和文件并且带上文件的大小信息
ls *[j]* 查看当前目录下的带j的文件夹及文件夹里面的内容
pwd 显示当前目录的全路径。
mkdir 创建文件夹。
mkdir xxx 创建一个叫xxx的文件夹
mkdir -p xxx/xxx 创建xxx文件和xxx文件里面的xxx文件
mkdir bbb ccc 创建bbb和ccc两个文件夹
touch 用于创建文件。
touch bbb.txt 创建一个bbb.txt文件
vi 用于编辑文件内容,vi 等同于 vim.
vi bbb.txt 进入文件bbb.txt,默认不能修改。 修改需要按下键盘“i”字母
文件底部会出现INSERT, 这个时候就表示可以输入内容了。
i 在vi下表示进入编辑状态。
输入信息后,先按Esc推出编辑模式,然后输入“:wq” 表示保存并退出。
:wq 表示保存并退出
:q 表示直接退出
:q! 表示强行退出
:set fileencoding=utf-8 设置文件编码为utf-8(文件内容不会变化)
这个时候再使用vi查看,就可以看到我们输入的信息了。vi命令是我们最常用的命令,vi 下还包含大量快速操作文本的命令,有需要的自学。^-^!
rm 用于删除文件和文件夹。
rm aaa.txt 表述删除文件aaa.txt。 这个命令会给出一个提示是否需要删除,选择y就是删除,选择n 就是不删除
rm -f bbb.txt -f 参数表示删除文件的意思,这个时候删除就不会有提示,直接删除
rm -rf aaa -rf参数表示删除文件夹及文件夹里面的全部内容
rmdir bbb 表示删除文件夹,文件里面不能包含内容。
mv 移动文件或文件夹,还有修改文件名的功能。
mv aaa.txt aaa 表示移动文件aaa.txt 到目录aaa下面。
mv bbbb aaa 表示将bbbb文件夹移动到aaa下面。
mv aaa.txt bbb.txt 表示将文件aaa.txt改名成bbb.txt
cp 复制文件夹或者文件信息
cp aaa.txt bbb.txt 复制文件aaa.txt 的内容到bbb.txt,当bbb.txt 不存在的时候的会创建一个。存在会覆盖,覆盖会有提示。
cp -a /home/bbbb /home/aaa/ 复制文件夹到另外一个文件夹
cat 命令用于连接文件并打印到标准输出设备上。
cat aaa.txt 查询aaa.txt 文件内容,打印到输出设备上
cat -n aaa.txt 给输出信息编上行号。
tail 命令可用于查看文件的内容,有一个常用的参数 -f 常用于查阅正在改变的日志文件。
tail aaa.txt 显示文件尾部10行信息
tail -f aaa.txt 显示文件尾部10行信息,并且不断更新信息,适合查询程序运行中日志的打印情况,Ctrl + c 退出文件显示
tail -f -n20 aaa.txt 显示文件尾部20行信息,并且不断更新信息,适合查询程序运行中日志的打印情况,Ctrl + c 退出文件显示
find 命令用来在指定目录下查找文件。
find . -name "*.txt" 将目前目录及其子目录下所有扩展名是 txt 的文件列出来
find . -name "aaa.txt" 将目前目录及其子目录下所有aaa.txt的文件列出
find /home/aaa/ -name "aaa.txt" 将指定目录及其子目录下所有aaa.txt的文件列出
find / -user jar 将根目录下属于用户jar的文件全部列出
find . -ctime -20 将目前目录及其子目录下所有最近 20 天内更新过的文件列出
file 该命令用于辨识文件类型
file aaa.txt 查看aaa.txt的文件的编码,文件类型。
iconv 该命令用于转换指定文件的编码,默认输出到标准输出设备,亦可指定输出文件。
iconv -f utf-8 -t gb2312 aaa.txt >bbb.txt 将aaa.txt文件内容复制到bbb.txt中并且将编码从utf-8改成gb2312
2. 用户、组
/etc/group 存储当前系统中的用户组信息
注意:
1.当该组内只有一个用户,并且用户名和组名相同时,在组列表中,包含用户一列可以为空
2.系统中root分组的组编号一定为0
3.组号1~499为系统预留的组编号,一般是预留给系统安装的软件或者服务的编号,越早安装的软件或者服务的组编号约早。用户手动创建的用户组编号从500开始
4.组密码占位符,无一例外,全部用x表示
/etc/gshadow 存储当前系统中用户组的密码信息
注意:
1.如果组密码处为“*” “!”或者为空时候,则该组没有密码
2.如果组管理者为空,则表示该组内所有成员都可以管理该组
/etc/passwd 存储当前系统中所有的用户信息
/etc/shadow 存储当前系统中所有用户的密码信息
useradd 创建用户。
useradd hu 创建一个名叫hu的用户
在下面两个地方可以看到我们的创建信息
1.会在/etc/passwd文件中添加xxx用户的信息
2.会在/etc/group文件中添加一个名为xxx的用户组信息
useradd -d /home/helloworld hu 创建用户和用户的home目录
useradd -m hello 创建用户和home文件夹,文件夹在当前路径下新建
useradd -g root hello 创建用户hello,并为其分配已经存在的组
usermod 修改用户信息。
usermod -l huu hu 将hu用户的名字修改成huu
usermod -u 888 huu 修改huu用户的id
usermod -d aaa huu 修改用户huu的home目录
usermod -g root huu 修改用户的主用户组
userdel 删除用户信息。
userdel hu1 删除用户信息
在/etc/passwd文件中就看不到hu1用户的信息
userdel -r huu 删除用户信息及用户的home目录信息
groupadd 创建一个用户组。
groupadd hu 创建一个用户组hu
groupmod 修改用户组信息。
groupmod -n hu4 hu 修改用户组hu3成hu4
groupdel 删除用户组信息。
groupdel hu4 删除用户组hu4
chgrp 修改所属用户组信息。
chgrp hello hu 将文件夹hu的所属用户组改成hello
chown 修改文件或者文件夹的所属用户和用户组信息
chown hu2:hu2 hu 将文件夹hu的所属用户和用户组改成hu2
chown hello hu 将文件夹hu的所属用户改成hello
su 切换用户
su hu 切换成hu用户
3. 权限
如图所示:
文档类型说明:
d - 目录,例如上表档名为『.gconf』的那一行;
- - 文档,例如上表档名为『install.log』那一行;
l - 连结档(link file);
b - 装置文件里面的可供储存的接口设备(可随机存取装置);
c - 装置文件里面的串行端口设备,例如键盘、鼠标(一次性读取装置)。
权限由rwx三个字幕表示,分别表示为可读、可写、可执行,如果没有该权限,则用“ - ”表示,对于目录来说,必须有x权限,否则无法读取目录内容
如果文件名前面有“ . ”,则表示这个文档或目录是隐藏的
chmod 修改文件或者文件夹权限。
chmod 777 hello 修改文件夹hello的权限,改成最大权限
rwxst r 读权限; w 写权限; x 可执行权限; s 执行文件时,拥有该文件所有者的权限; t 临时拥有权限可读可写,但是都只能操作自己的文件,不能操作别人的文件。
-rw------- (600) -- 只有属主有读写权限。
-rw-r--r-- (644) -- 只有属主有读写权限;而属组用户和其他用户只有读权限。
-rwx------ (700) -- 只有属主有读、写、执行权限。
-rwxr-xr-x (755) -- 属主有读、写、执行权限;而属组用户和其他用户只有读、执行权限。
-rwx--x--x (711) -- 属主有读、写、执行权限;而属组用户和其他用户只有执行权限。
-rw-rw-rw- (666) -- 所有用户都有文件读、写权限。这种做法不可取。
-rwxrwxrwx (777) -- 所有用户都有读、写、执行权限。更不可取的做法。
操作权限的另外一种方式:
chmod u+w hello 给文件或者文件夹所属用户加上w权限
chmod g-r hello 给文件或者文件夹所属用户组去掉r权限
chmod a+x hello 给用户,组,其他都加上x权限
root 用户之所以可以再任何地方执行任何文件,就是/etc/sudoers 文件配置的。
/etc/sudoers
上图可以看到有好几种设置权限的地方。
4. 进程、端口
执行 top 命令会显示下图信息
PID 进程号
USER 进程所属用户信息
PR piriority,优先级,数字越小越优先被执行
NI nice,与priority相关,也是数字越小越先被执行
VIRT 占用虚拟内存的总量
RES 进程占用的物理内存
SHR 共享内存大小
S 进程状态 R 运行状态、S 睡眠状态、D 不可中断的睡眠状态、T 暂停状态、Z 退出状态,僵死进程、X 退出状态,进程即将被销毁
%CPU CUP使用占比
%MEM 内存使用占比
TIME+ 进程累计使用cpu进行运算的时间
COMMAND 进程名称
ps 命令用于显示当前进程 (process) 的状态。
ps -ef 查看全部进程情况(信息全)
ps -aux 与ps -ef 效果差不多
ps -axjfc 查看全部进程情况,进程名显示简称
ps aux | grep tomcat 查询用户tomcat使用的全部进程情况
top 展示系统的当前状态以及进程信息,并且定时刷新.
top -p 21481 查询PID 等于 21481的进程详情
top -H -p 21481 查询PID 等于 21481的全部线程程详情
top -u jar 查询用户为jar的进程详情
因为top命令显示的是动态结果:我们就会存在如下需求,能不能显示结果按照内存大小排序,按照CUP使用情况排序等。
以下是交互命令:
按“h”或者“?”,会显示帮助,如下
Z:改变颜色;B:加粗
t:显示和隐藏任务/cpu信息;m:内存信息
1:监控每个逻辑CPU的状况;
f:进入字段显示配置模式,可增加或者移除显示字段,按相应的字母新增或去除;o:进入字段顺序设置模式,可配置显示位置顺序,按相应的字母往下移动,按“shift+相应的字母”往上移动 ---------常用
F:进入字段排序配置模式,可设置排序的字段;
R:正常排序/反向排序;
s:设置刷新的时间--------常用
u:输入用户,显示用户的任务
i:忽略闲置和僵死进程。这是一个开关式命令。
r:重新安排一个进程的优先级别。系统提示用户输入需要改变的进程PID以及需要设置的进程优先级值。输入一个正值将使优先级降低,反之则可以使该进程拥有更高的优先权。默认值是10。
c:切换显示命令名称和完整命令行。
M:根据驻留内存大小进行排序。-------------常用
P:根据CPU使用百分比大小进行排序。-----------常用
H:显示线程
kill 该命令用于删除执行中的程序或工作.
kill 123456 杀死PID为123456的进程
kill -KILL 123456 强制杀死PID为123456的进程
kill -9 123456 彻底杀死PID为123456的进程
ss 该命令可以用来获取socket统计信息。
ss -napt | grep 18910 通过进程号,查询使用的端口号
图中8080就是进程18910使用的端口号。
ss -lntpd | grep :8080 通过端口号查询进程号信息
图中18910就是端口8080使用的进程号。
netstat 因为已经全面被ss 命令替代,故这里直接跳过。
grep 命令用于查找文件里符合条件的字符串,经过配合其他命令一起使用,单独使用较少。
grep jj *txt 查询后缀为txt文件中出现jj的行信息并且打印到控制台。
grep -n '2019-10-24 00:01:11' *.log 查询后缀为log文件中出现'2019-10-24 00:01:11' 的行信息,带行号并且打印到控制台。
grep -e '^j' *.txt -e 是正则表达式查询信息,^j 是首字母为j的意思。
5. 在线软件下载安装和删除
yum( Yellow dog Updater, Modified)是一个在Fedora和RedHat以及SUSE中的Shell前端软件包管理器。
yum list | grep zip 查询当前系统是否已经安装zip
yum install zip 安装zip,执行完该命令侯,zip命令就可以使用了,我们可以通过zip压缩文件
yum update zip 更新软件包
yum remove zip 卸载zip
6. 打包、解包
tar 该命令用于备份文件。
tar cvf aaa.tar aaa.txt 将aaa.txt 打包进aaa.tar 中
tar cvf aaa.tar bbb.txt aaa.txt 将多个文件打包进aaa.tar 中
tar tvf aaa.tar 列出aaa.tar包中的文件信息
tar xvf aaa.tar 解压aaa.tar包中文件到当前目录下
tar xvf aaa.tar -C dddd 解压到指定目录dddd下
文件后缀为.tar.gz,在linux 中更加常见。
tar zcvf aaa.tar.gz aaa.txt 将aaa.txt 打包进aaa.tar.gz 中
tar zcvf aaa.tar.gz bbb.txt aaa.txt 将多个文件打包进aaa.tar 中
tar ztvf aaa.tar.gz 列出aaa.tar包中的文件信息
tar zxvf aaa.tar.gz 解压aaa.tar包中文件到当前目录下
tar zxvf aaa.tar.gz -C dddd 解压到指定目录dddd下
zip 该命令用于压缩文件。
zip -q -r dddd.zip /home/dddd/ 压缩dddd文件夹到dddd.zip中
zip -q -r dddd.zip * 压缩当前文件夹的全部内容到dddd.zip中
unzip 命令用于解压缩zip文件。
unzip dddd.zip 解压dddd.zip将文件放到当前目录
unzip -l dddd.zip 查看压缩包里面的文件列表
unzip dddd.zip -d ee 解压文件到指定目录ee下面,这个路径也可以是绝对路径
7. 远程协议登录
ssh 远程登录协议。
ssh -l root 149.225.47.23 linux服务中远程连接ip为149.225.47.23 服务器,root是用户,后面还会让你输入密码,输入正确密码即可,退出通过exit 命令即可
免密登录设置:
ssh-keygen -t rsa 生成秘钥,按多次回车直到秘钥生成
ssh-copy-id 149.225.47.23 连接远程机器,第一次需要输入密码, 再次使用命令(ssh -l root 149.225.47.23) 就可以直接登录,不需要密码了
进入“.ssh”会生成以下几个文件
authorized_keys:存放远程免密登录的公钥,主要通过这个文件记录多台机器的公钥
id_rsa : 生成的私钥文件
id_rsa.pub : 生成的公钥文件
know_hosts : 已知的主机公钥清单
如果希望ssh公钥生效需满足至少下面两个条件:
1) .ssh目录的权限必须是700
2) .ssh/authorized_keys文件权限必须是600
scp 命令用于 Linux 之间复制文件和目录。
scp id_rsa.pub root@149.225.47.23:/root/.ssh/authorized_keys 将本系统文件id_rsa.pub,复制到 root@149.225.47.23:/root/.ssh/authorized_keys下面
scp id_rsa.pub 49.235.147.233:/root/.ssh/authorized_keys 复制文件还可以简单的使用这个命令
scp -r .ssh 49.235.147.233:/root/ 加-r 复制整个文件夹。
8. 其他常用命令
> test.log 清空文件内容
sh 是shell命令语言解释器,执行命令从标准输入读取或从一个文件中读取. (简单的说是执行可执行文件使用)。
sh d.sh 执行d.sh 文件
文件里面就写了一句:
重点说明:当文件没有执行权限我们才用sh。 有执行权限我们可以通过./ 来执行
./d.sh 执行d.sh 文件
date 用于显示和修改时间的命令
date 显示系统日期
date '+%Y-%m-%d %H:%M:%S' 显示我们习惯的日期显示方式
date '+%Y-%m-%d %H:%M:%S %A' 显示我们习惯的日期显示方式加上星期的显示
date '+%Y-%m-%d %X %A %Z' 也可以显示时间
date -s 05/08/20 修改系统年月日
date -s '2020-05-07 09:09:09' 修改系统年月日时分秒
ntpdate 同步时间命令。
ntpdate -u ntp.ntsc.ac.cn 同步时间与国家授时中心时间对齐(对齐时间之前需要先确认你的时区设置是否有问题)
hostname 显示主机名。
hostname myzjm 修改主机名,重启无效
set 查看当前进程中的变量。
clear 该命令用于清除屏幕。
locale 查询linux系统编码
export LANG=en_US.UTF-8 修改linux系统编码
rz 上传命令 一般默认没有,需要下载安装(yum install -y lrzsz)
选择文件上传即可。
rz -y 上传的文件覆盖已有文件
rz -b 使用二进制传输
sz 下载命令 一般默认没有,需要下载安装(yum install -y lrzsz)
sz 新建文本文档.txt 下载新建文本文档.txt 到你的电脑。
sz -b 新建文本文档.txt 使用二进制传输下载。
ping 网络主机发送ICMP回传请求
ping baidu.com 一直请求和接收反馈信息。
ping -c 5 baidu.com 5次请求和接收反馈信息。
which 在环境变量$PATH设置的目录里查找符合条件的文件
which mysqld 在环境变量$PATH设置的目录里查找mysqld 文件。
ifconfig -a 查询linux ip地址。
scp -P 55255 root@10.23.185.16:/usr/local/xxx.jar /usr/local/xxx.jar -- 55255 表示端口,如果是22端口可以不写,root是用户。
输入密码即可。
ln -s /usr/local/mysql/mysql-5.7.22-linux-glibc2.12-x86_64/bin/mysql /usr/bin -- 建立软链接,就相当于windows 的创建快捷方式
passwd 用户名 -- 登入root用户,修改其他用户的密码。
大家在学习和工作中遇到的常用命令欢迎留言。。。。。。