Linux知识总结
linux命令在线查询
https://wangchujiang.com/linux-command/
基础知识
Linux系统的文件结构
- /bin: binary 二进制文件,放系统常用命令
- /boot :系统启动分区,系统启动时读取的核心文件,包括一些链接文件及镜像文件
- /dev : device 存放的是linux的外部设备文件,在linux中访问设备的方式和访问文件的方式是相同的
- /etc : 存放系统管理所需要的大多数配置文件和子目录
- /home : 普通用户的主目录
- /lib : 32位函数库
- /lost+found :当系统非法关机后,这里就存放了一些文件
- /lib64 : 64位库
- /media : linux系统会自动识别一些设备,例如光驱、U盘等等,当识别后,将设备挂载到这个目录下
- /mnt :手动临时挂载点,临时挂载别的文件系统(本地的文件)
- /opt :第三方软件安装位置
- /proc :进程信息及硬件信息
- /root :超级管理员的用户主目录
- /sbin :super user 系统管理员使用的系统管理命令
- /srv :该目录存放着一些服务启动后需要提取的数据
- /var :存放不断扩充着的数据,习惯将那些经常修改的目录放到这个目录下,包括各种日志文件
- /sys :内核相关信息
- /tmp :存放临时文件。用完即丢的文件,可以放到这个目录下,安装包!
- /usr :Unix Software Resource 用户相关设定
- /usr/bin : 系统用户使用的应用程序
- /usr/sbin : 超级用户使用的比较高级的管理程序和系统守护程序
- /usr/src : 内核源代码默认的存放目录
- /run : 十一个临时文件系统,存储系统启动以来的信息。当系统重启时,这个目录下的文件应该被删除或清除。
- /www : 存放服务器网站相关的资源
linux下"."代表当前目录
Linux系统命令行的含义
示例: root@app00:~#
root //用户名,root为超级用户
@ //分隔符
app00 //主机名称
~ //当前所在目录,默认用户目录为~,会随着目录切换而变化,例如:(root@app00:/bin# ,当前位置在bin目录下)
# //表示当前用户是超级用户,普通用户为$,例如:("yao@app00:/root$" ,表示使用用户"yao"访问/root文件夹)
命令的组成
命令 参数名 参数值
注:在命令中,当含有多个参数时,可以同时使用多个参数
例如:
ls -a
ls -l
ls -al 或 ls -la
基础操作
关机操作
# 立刻关机
shutdown now
shutdown -h now
poweroff
# 两分钟后关机
shutdown -h +2
重启操作
# 立刻重启
shutdown -r now
reboot
# 两分钟后重启
shutdown -r +2
帮助命令(--help)--常用
# 查看 ifconfig 命令的用法
ifconfig --help
命令说明书(man)--常用
# 打开命令说明后,可按“q”键退出
man shutdown
切换用户(su)== Switch user
# 切换为用户GeekScribe
su GeekScribe
# 退出当前用户
exit
清空窗口所有信息(clear)
clear
目录操作
切换目录(cd)== change directory
cd / //切换到根目录
cd /bin //切换到根目录下的bin目录
cd ../ //切换到上一级目录 或者使用命令:cd ..
cd ~ //切换到home目录
cd - //切换到上次访问的目录
cd xx(文件夹名) //切换到本目录下的名为xx的文件目录,如果目录不存在报错
cd /xxx/xx/x //可以输入完整的路径,直接切换到目标目录,输入过程中可以使用tab键快速补全
查看目录(ls)== list
ls //查看当前目录下的所有目录和文件
ls -a //查看当前目录下的所有目录和文件(包括隐藏的文件)
ls -l //列表查看当前目录下的所有目录和文件(列表查看,显示更多信息),与命令"ll"效果一样
ls /bin //查看指定目录下的所有目录和文件
创建目录(mkdir)== make directory
mkdir tools //在当前目录下创建一个名为tools的目录
mkdir /bin/tools //在指定目录下创建一个名为tools的目录
删除目录与文件(rm)== remove
rm 文件名 //删除当前目录下的文件
rm -f 文件名 //删除当前目录的的文件(不询问)
rm -r 文件夹名 //递归删除当前目录下此名的目录
rm -rf 文件夹名 //递归删除当前目录下此名的目录(不询问)
rm -rf * //将当前目录下的所有目录和文件全部删除
rm -rf /* //将根目录下的所有文件全部删除【慎用!相当于格式化系统】
修改目录(mv)== move
mv 当前目录名 新目录名 //修改目录名,同样适用与文件操作
mv /usr/tmp/tool /opt //将/usr/tmp目录下的tool目录剪切到 /opt目录下面
mv -r /usr/tmp/tool /opt //递归剪切目录中所有文件和文件夹
拷贝目录(cp)== copy
cp /usr/tmp/tool /opt //将/usr/tmp目录下的tool目录复制到 /opt目录下面
cp -r /usr/tmp/tool /opt //递归剪复制目录中所有文件和文件夹
rcp [-pr][源文件或目录][目标文件或目录]
# rcp命令用于复制远程文件或目录。
# rcp指令用在远端复制文件或目录,如同时指定两个以上的文件或目录,且最后的目的地是一个已经存在的目录,则它会把前面指定的所有文件或目录复制到该目录中。
scp [可选参数] file_source file_target
# Linux scp 命令用于 Linux 之间复制文件和目录。
# scp 是 secure copy 的缩写, scp 是 linux 系统下基于 ssh 登陆进行安全的远程文件拷贝命令。
# scp 是加密的,rcp 是不加密的,scp 是 rcp 的加强版。
搜索目录(find)
find /bin -name 'a*' //查找/bin目录下的所有以a开头的文件或者目录
查看当前目录(pwd)== print working directory
pwd //显示当前位置路径
文件操作
新增文件(touch)
touch a.txt //在当前目录下创建名为a的txt文件(文件不存在),如果文件存在,将文件时间属性修改为当前系统时间
删除文件(rm) == remove
rm 文件名 //删除当前目录下的文件
rm -f 文件名 //删除当前目录的的文件(不询问)
编辑文件(vi vim)
vi 文件名 //打开需要编辑的文件
--进入后,操作界面有三种模式:命令模式(command mode)、插入模式(Insert mode)和底行模式(last line mode)
命令模式
-刚进入文件就是命令模式,通过方向键控制光标位置,
-使用命令"dd"删除当前整行
-使用命令"/字段"进行查找
-按"i"在光标所在字符前开始插入
-按"a"在光标所在字符后开始插入
-按"o"在光标所在行的下面另起一新行插入
-按":"进入底行模式
插入模式
-此时可以对文件内容进行编辑,左下角会显示 "-- 插入 --""
-按"ESC"进入底行模式
底行模式
-退出编辑: :q
-强制退出: :q!
-保存并退出: :wq
## 操作步骤示例 ##
1.保存文件:按"ESC" -> 输入":" -> 输入"wq",回车 //保存并退出编辑
2.取消操作:按"ESC" -> 输入":" -> 输入"q!",回车 //撤销本次修改并退出编辑
## 补充 ##
vim +10 filename.txt //打开文件并跳到第10行
vim -R /etc/passwd //以只读模式打开文件
查看文件
cat a.txt //查看文件最后一屏内容
less a.txt //PgUp向上翻页,PgDn向下翻页,"q"退出查看
more a.txt //显示百分比,回车查看下一行,空格查看下一页,"q"退出查看
tail -100 a.txt //查看文件的后100行,"Ctrl+C"退出查看
文件权限
权限说明
文件权限简介:'r' 代表可读(4),'w' 代表可写(2),'x' 代表执行权限(1),括号内代表"8421法"
##文件权限信息示例:-rwxrw-r--
-第一位:'-'就代表是文件,'d'代表是文件夹
-第一组三位:拥有者的权限
-第二组三位:拥有者所在的组,组员的权限
-第三组三位:代表的是其他用户的权限
修改文件权限(chmod)== change mode
# 符号模式
# 符号模式使用符号来表示权限的变更。
# + 表示添加权限,- 表示删除权限,= 表示设置权限。
# u 表示所有者,g 表示群组,o 表示其他用户,a 表示所有用户。
# r 表示读权限,w 表示写权限,x 表示执行权限。
chmod +x a.txt //为所有用户添加执行权限
chmod u=rw,g=r,o=r a.txt //修改权限
chmod g-x a.txt //删除文件所在组执行权限
# 数值模式
8421法 chmod 777 a.txt //1+2+4=7,"7"说明授予所有权限
打包与解压
说明
.zip、.rar //windows系统中压缩文件的扩展名
.tar //Linux中打包文件的扩展名
.gz //Linux中压缩文件的扩展名
.tar.gz //Linux中打包并压缩文件的扩展名
打包文件(tar)
tar -zcvf 打包压缩后的文件名 要打包的文件
参数说明:
z:调用gzip压缩命令进行压缩;
c:打包文件;
v:显示运行过程;
f:指定文件名;
z、c、v、f的顺序任意,例如也可以 -cvzf
示例:
tar -zcvf a.tar file1 file2,... //多个文件压缩打包
解压文件
tar -zxvf a.tar //解包至当前目录
tar -zxvf a.tar -C /usr------ //指定解压的位置
unzip test.zip //解压*.zip文件
unzip -l test.zip //查看*.zip文件的内容
其他常用命令
find
find . -name "*.c" //将目前目录及其子目录下所有延伸档名是 c 的文件列出来
find . -type f //f代表file 将目前目录其其下子目录中所有一般文件列出
find . -ctime -20 //将目前目录及其子目录下所有最近 20 天内更新过的文件列出。ctime = change time
find /var/log -type f -mtime +7 -ok rm {} \; //查找/var/log目录中更改时间在7日以前的普通文件,并在删除之前询问它们。 mtime = modification time
find . -type f -perm 644 -exec ls -l {} \; //查找前目录中文件属主具有读、写权限,并且文件所属组的用户和其他用户具有读权限的文件
find / -type f -size 0 -exec ls -l {} \; //为了查找系统中所有文件长度为0的普通文件,并列出它们的完整路径
whereis
# whereis 用于查找二进制、源码和帮助页面文件的位置。
whereis ls //查找'ls'命令的位置
which
# which 命令用于确定在系统的执行路径中查找到的特定命令的路径。找到系统中可执行文件的位置。
# 说明:which指令会在环境变量$PATH设置的目录里查找符合条件的文件。
which ls //查看指令“ls”的绝对路径
sudo
说明:是一个在Unix和类Unix系统中用于以超级用户(root)权限执行命令的命令行工具。
它允许系统管理员授予普通用户一些或全部超级用户的权限,以便执行特定的任务,而无需完全切换到超级用户账户。
使用权限:在 /etc/sudoers 中有出现的使用者
sudo -l //列出目前的权限
$ sudo -u yao vi ~www/index.html //以 yao 用户身份编辑 home 目录下www目录中的 index.html 文件
grep
grep -i "the" demo_file //在文件中查找字符串(不区分大小写)
grep -A 3 -i "example" demo_text //输出成功匹配的行,以及该行之后的三行
grep -r "ramesh" * //在一个文件夹中递归查询包含指定字符串的文件
service || systemctl
# 说明:service命令用于运行System V init脚本,这些脚本一般位于/etc/init.d文件下,这个命令可以直接运行这个文件夹里面的脚本,而不用加上路径
service ssh status //查看服务状态
service --status-all //查看所有服务状态
service ssh restart //重启服务
# service 命令的具体使用可能会因系统的不同而有所不同,例如,在一些系统上可能使用 systemctl 来管理服务。请根据你使用的具体系统和服务进行相应的调整。
free
# 说明:这个命令用于显示系统当前内存的使用情况,包括已用内存、可用内存和交换内存的情况
free -g //以G为单位输出内存的使用量,-g为GB,-m为MB,-k为KB,-b为字节
free -t //查看所有内存的汇总
top
top //显示当前系统中占用资源最多的一些进程, shift+m 按照内存大小查看
df ==disk free
说明:显示文件系统的磁盘使用情况
df -h //一种易看的显示
mount
mount /dev/sdb1 /u01 //挂载一个文件系统,需要先创建一个目录,然后将这个文件系统挂载到这个目录上
dev/sdb1 /u01 ext2 defaults 0 2 //添加到fstab中进行自动挂载,这样任何时候系统重启的时候,文件系统都会被加载
uname
说明:uname可以显示一些重要的系统信息,例如内核名称、主机名、内核版本号、处理器类型之类的信息
uname -a
yum
说明:安装插件命令
yum install httpd //使用yum安装apache
yum update httpd //更新apache
yum remove httpd //卸载/删除apache
rpm
说明:插件安装命令
rpm -ivh httpd-2.2.3-22.0.1.el5.i386.rpm //使用rpm文件安装apache
rpm -uvh httpd-2.2.3-22.0.1.el5.i386.rpm //使用rpm更新apache
rpm -ev httpd //卸载/删除apache
date
date -s "01/31/2010 23:59:53" ///设置系统时间
wget
说明:使用wget从网上下载软件、音乐、视频
示例:wget http://prdownloads.sourceforge.net/sourceforge/nagios/nagios-3.2.1.tar.gz
//下载文件并以指定的文件名保存文件
wget -O nagios.tar.gz http://prdownloads.sourceforge.net/sourceforge/nagios/nagios-3.2.1.tar.gz
ftp
ftp IP/hostname //访问ftp服务器
mls *.html - //显示远程主机上文件列表
scp
scp /opt/data.txt 192.168.1.101:/opt/ //将本地opt目录下的data文件发送到192.168.1.101服务器的opt目录下
系统管理
防火墙操作
service iptables status //查看iptables服务的状态
service iptables start //开启iptables服务
service iptables stop //停止iptables服务
service iptables restart //重启iptables服务
chkconfig iptables off //关闭iptables服务的开机自启动
chkconfig iptables on //开启iptables服务的开机自启动
##centos7 防火墙操作
systemctl status firewalld.service //查看防火墙状态
systemctl start firewalld //启动防火墙
systemctl stop firewalld.service //关闭运行的防火墙
systemctl restart firewalld //重启防火墙
systemctl disable firewalld //禁止防火墙开机自启动、
systemctl enable firewalld //启动防火墙开机自启动
systemctl disable firewalld.service //永久禁止防火墙服务
firewall-cmd --list-all //列出防火墙规则
# 开放端口
firewall-cmd --zone=public --add-port=80/tcp --permanent
firewall-cmd --reload
修改主机名(CentOS 7)
hostnamectl set-hostname 主机名
查看网络
ifconfig
修改IP
修改网络配置文件,文件地址:/etc/sysconfig/network-scripts/ifcfg-eth0
------------------------------------------------
主要修改以下配置:
TYPE=Ethernet //网络类型
BOOTPROTO=static //静态IP
DEVICE=ens00 //网卡名
IPADDR=192.168.1.100 //设置的IP
NETMASK=255.255.255.0 //子网掩码
GATEWAY=192.168.1.1 //网关
DNS1=192.168.1.1 //DNS
DNS2=8.8.8.8 //备用DNS
ONBOOT=yes //系统启动时启动此设置
-------------------------------------------------
修改保存以后使用命令重启网卡:service network restart
配置映射
修改文件: vi /etc/hosts
在文件最后添加映射地址,示例如下:
192.168.1.101 node1
192.168.1.102 node2
192.168.1.103 node3
配置好以后保存退出,输入命令:ping node1 ,可见实际 ping 的是 192.168.1.101。
查看进程
ps -ef //查看所有正在运行的进程
结束进程
kill pid //杀死该pid的进程
kill -9 pid //强制杀死该进程
查看链接
ping IP //查看与此IP地址的连接情况
netstat -an //查看当前系统端口
netstat -an | grep 8080 //查看指定端口
快速清屏
ctrl+l //清屏,往上翻可以查看历史操作
远程主机
ssh IP //远程主机,需要输入用户名和密码
评论区