侧边栏壁纸
博主头像
极客手札博主等级

Do everything!

  • 累计撰写 31 篇文章
  • 累计创建 16 个标签
  • 累计收到 1 条评论

目 录CONTENT

文章目录

linux学习

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       //远程主机,需要输入用户名和密码
0

评论区