Linux基础教学

Linux简介

Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 UNIX 的多用户、多任务、支持多线程和多 CPU 的操作系统。

Linux 能运行主要的 UNIX 工具软件、应用程序和网络协议。它支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

远程登录与关机

远程登录

# ssh远程登录命令
# ssh [-p 22] 用户名@服务器地址  -p端口不写,则默认是22
ssh root@127.0.0.0

关机

sync # 将数据由内存同步到硬盘中。

shutdown # 关机指令,你可以man shutdown 来看一下帮助文档。例如你可以运行如下命令关机:

shutdown –h 10 # 这个命令告诉大家,计算机将在10分钟后关机

shutdown –h now # 立马关机

shutdown –h 20:25 # 系统会在今天20:25关机

shutdown –h +10 # 十分钟后关机

shutdown –r now # 系统立马重启

shutdown –r +10 # 系统十分钟后重启

reboot # 就是重启,等同于 shutdown –r now

halt # 关闭系统,等同于shutdown –h now 和 poweroff

文件目录

通过ls命令查看根目录结构

# 进入跟目录
[root@iZuf6bcosqnwhijwt0w2quZ /]# cd /
# 查看目录
[root@iZuf6bcosqnwhijwt0w2quZ /]# ls
bin  boot  dev  etc  home  lib  lib64  lost+found  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var

  • /bin:bin是Binary的缩写, 这个目录存放着最经常使用的命令。
  • /boot: 这里存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件。
  • /dev : dev是Device(设备)的缩写, 存放的是Linux的外部设备,在Linux中访问设备的方式和访问文件的方式是相同的。
  • /etc: 这个目录用来存放所有的系统管理所需要的配置文件和子目录。
  • /home:用户的主目录,在Linux中,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。
  • /lib:这个目录里存放着系统最基本的动态连接共享库,其作用类似于Windows里的DLL文件。
  • /lost+found:这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。
  • /media:linux系统会自动识别一些设备,例如U盘、光驱等等,当识别后,linux会把识别的设备挂载到这个目录下。
  • /mnt:系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将光驱挂载在/mnt/上,然后进入该目录就可以查看光驱里的内容了。
  • /opt:这是给主机额外安装软件所摆放的目录。比如你安装一个ORACLE数据库则就可以放到这个目录下。默认是空的。
  • /proc:这个目录是一个虚拟的目录,它是系统内存的映射,我们可以通过直接访问这个目录来获取系统信息。
  • /root:该目录为系统管理员,也称作超级权限者的用户主目录。
  • /sbin:s就是Super User的意思,这里存放的是系统管理员使用的系统管理程序。
  • /srv:该目录存放一些服务启动之后需要提取的数据。
  • /sys:这是linux2.6内核的一个很大的变化。该目录下安装了2.6内核中新出现的一个文件系统 sysfs 。
  • /tmp:这个目录是用来存放一些临时文件的。
  • /usr:这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似于windows下的program files目录。
  • /usr/bin: 系统用户使用的应用程序。
  • /usr/sbin: 超级用户使用的比较高级的管理程序和系统守护程序。
  • /usr/src: 内核源代码默认的放置目录。
  • /var:这个目录中存放着在不断扩充着的东西,我们习惯将那些经常被修改的目录放在这个目录下。包括各种日志文件。
  • /run:是一个临时文件系统,存储系统启动以来的信息。当系统重启时,这个目录下的文件应该被删掉或清除。

基本命令

查询目录

ls [可选参数]  # 查询所有文件

ls -a         # 查询全部文件,包括隐藏文件
ls -l         # 查询全部文件,包括文件属性,权限等信息

切换目录

cd /  # 切换到根目录
cd ../ #返回上一层
cd /home # 进入指定绝对路径
cd ~     # 进入用户目录

创建目录

mkdir test            # 创建test文件夹
mkdir -p test1/test2  # 创建多级目录
mkdir -m 711 test2    # 创建一个配置了权限的文件夹

删除目录

rmdir test            # 删除test文件夹,无法删除非空目录
rmdir -p test1        # 连同上一级空目录也一起删除

复制或移动目录

# 复制文件或目录  
cp [可选参数] 源文件  目标文件
-p  # 连同文件属性一起复制,常用于备份
-d  # 若来源档为连结档的属性(link file),则复制连结档属性而非文件本身
-l  # 若目标档(destination)已经存在时,在覆盖时会先询问动作的进行
-r  # 递归持续复制
-a  # pdr的组合使用
-f  # 若目标文件已经存在且无法开启,则移除后再尝试一次
-i  # 若目标档已经存在时,在覆盖时会先询问动作的进行
-s  # 复制成为符号连结档 (symbolic link),亦即『捷径』文件

测试:

# 创建yml文件目录
[root@iZuf6bcosqnwhijwt0w2quZ home]# mkdir yml
[root@iZuf6bcosqnwhijwt0w2quZ home]# cd yml
# 进入yml目录,并创建一个文件
[root@iZuf6bcosqnwhijwt0w2quZ yml]# touch test.java
[root@iZuf6bcosqnwhijwt0w2quZ yml]# cd /home/
# 回到home目录,该目录下只有一个yml目录
[root@iZuf6bcosqnwhijwt0w2quZ home]# ls
yml
# 将yml复制到同级目录下,目录名为yml-copy
[root@iZuf6bcosqnwhijwt0w2quZ home]# cp -ai yml yml-copy
[root@iZuf6bcosqnwhijwt0w2quZ home]# ls
yml  yml-copy
[root@iZuf6bcosqnwhijwt0w2quZ home]# cd yml-copy/
[root@iZuf6bcosqnwhijwt0w2quZ yml-copy]# ls
test.java

删除文件或目录

rm [可选参数] 文件或目录

可选参数:

  • -f:忽略不存在的文件
  • -i:交互式删除,删除前会询问
  • -r:递归删除,线上尽量避免

测试:

[root@iZuf6bcosqnwhijwt0w2quZ yml-copy]# ls
test.java
[root@iZuf6bcosqnwhijwt0w2quZ yml-copy]# cd ..
[root@iZuf6bcosqnwhijwt0w2quZ home]# rm -rf yml-copy/
[root@iZuf6bcosqnwhijwt0w2quZ home]# ls
yml

移动文件或目录,修改名称

mv [可选参数] 源文件(目录) 目标文件(目录)

可选参数:

  • -f:如果目标文件已存在,直接覆盖
  • -i:交互式,若目标文件已存在,询问是否覆盖

测试:

# 将home目录下的yml目录移动到root目录
[root@iZuf6bcosqnwhijwt0w2quZ home]# mv yml /root/
[root@iZuf6bcosqnwhijwt0w2quZ home]# cd ~
[root@iZuf6bcosqnwhijwt0w2quZ ~]# ls
yml
# 将yml重命名为yml01
[root@iZuf6bcosqnwhijwt0w2quZ ~]# mv yml yml01
[root@iZuf6bcosqnwhijwt0w2quZ ~]# ls
yml01

文件查看与编辑

文件查看

文件查看是最常用的命令。常用的命令有如下几种:

  • cat:从头查看文件所有内容
  • tac:从最后一行显示,倒序查看文件所有内容
  • more:一页一页显示
  • less:一页一页显示,可以上下翻
  • head:显示头部几行
  • tail:显示尾部几行
cat查看
cat [可选参数] 文件名

可选参数:

  • A:vET的组合
  • b:显示行号,只针对非空白行
  • E:显示结尾的断行字节$
  • n:显示行号,包括空白行
  • T:将tab按键以^|显示
  • v:列出一些看不出来的特殊字符

测试:

# 查看EnvConfig.java ,带行号
[root@iZuf6bcosqnwhijwt0w2quZ home]# ls
EnvConfig.java  yml
[root@iZuf6bcosqnwhijwt0w2quZ home]# cat -n EnvConfig.java 
     1  package com.xtech.hello.server.common.hellocn.config;
     2  
     3  import com.xtech.hello.server.common.hellocn.enums.EnvEnum;
     4  import org.apache.commons.lang3.StringUtils;
     5  import org.slf4j.Logger;
     6  import org.slf4j.LoggerFactory;
     7  import org.springframework.beans.factory.annotation.Value;
     8  import org.springframework.stereotype.Component;
     9  
    10  import javax.annotation.PostConstruct;
    11  import java.util.Arrays;
    12  import java.util.List;
    13  import java.util.stream.Collectors;
    14  
    15  /**
    16   * @author YML
    17   * @desc 环境工具
    18   */
    19  @Component
    20  public class EnvConfig {
    21  
    22      private final Logger logger = LoggerFactory.getLogger(this.getClass());
    23  
    24      private EnvEnum env = EnvEnum.PROD;
    25  
    26      @Value("${spring.profiles.active:prod}")
    27      private String active;
    28  
    29      @PostConstruct
    30      public void initEnv(){
    31          for (EnvEnum value : EnvEnum.values()) {
    32              if (StringUtils.equalsIgnoreCase(value.name(),active)){
    33                  env = value;
    34              }
    35          }
    36          if (env == EnvEnum.LOCAL){
    37              env = EnvEnum.DEV;
    38          }
    39          logger.info("当前运行环境==={}",env);
    40      }
    41  
    42      /**
    43       * 判断是否包含当前环境
    44       * @date 2022/3/30
    45       * @author YML
    46       * @param envEnums:
    47       * @return boolean
    48       */
    49      public boolean isEnvs(EnvEnum... envEnums){
    50          if (envEnums == null || envEnums.length==0){
    51              return false;
    52          }
    53          List<EnvEnum> list = Arrays.stream(envEnums).collect(Collectors.toList());
    54          return list.contains(env);
    55      }
    56  
    57      /**
    58       * 获取当前环境
    59       * @since 2022/7/14
    60       * @author YML
    61       * @return com.xtech.hello.server.common.enums.EnvEnum
    62       */
    63      public EnvEnum getEnv() {
    64          return env;
    65      }
    66  }
    
 # 倒序查看EnvConfig.java 
[root@iZuf6bcosqnwhijwt0w2quZ home]# tac EnvConfig.java 
}
    }
        return env;
    public EnvEnum getEnv() {
     */
     * @return com.xtech.hello.server.common.enums.EnvEnum
     * @author YML
     * @since 2022/7/14
     * 获取当前环境
    /**

    }
        return list.contains(env);
        List<EnvEnum> list = Arrays.stream(envEnums).collect(Collectors.toList());
        }
            return false;
        if (envEnums == null || envEnums.length==0){
    public boolean isEnvs(EnvEnum... envEnums){
     */
     * @return boolean
     * @param envEnums:
     * @author YML
     * @date 2022/3/30
     * 判断是否包含当前环境
    /**

    }
        logger.info("当前运行环境==={}",env);
        }
            env = EnvEnum.DEV;
        if (env == EnvEnum.LOCAL){
        }
            }
                env = value;
            if (StringUtils.equalsIgnoreCase(value.name(),active)){
        for (EnvEnum value : EnvEnum.values()) {
    public void initEnv(){
    @PostConstruct

    private String active;
    @Value("${spring.profiles.active:prod}")

    private EnvEnum env = EnvEnum.PROD;

    private final Logger logger = LoggerFactory.getLogger(this.getClass());

public class EnvConfig {
@Component
 */
 * @desc 环境工具
 * @author YML
/**

import java.util.stream.Collectors;
import java.util.List;
import java.util.Arrays;
import javax.annotation.PostConstruct;

import org.springframework.stereotype.Component;
import org.springframework.beans.factory.annotation.Value;
import org.slf4j.LoggerFactory;
import org.slf4j.Logger;
import org.apache.commons.lang3.StringUtils;
import com.xtech.hello.server.common.hellocn.enums.EnvEnum;

package com.xtech.hello.server.common.hellocn.config;
[root@iZuf6bcosqnwhijwt0w2quZ home]# 

tac查看

与cat正好相反,语法相同

more查看
more 文件名

可选操作:

  • 空白键:向下翻页
  • 回车键:向下翻一行
  • /字符串:向下搜索“字符串”
  • :f :显示档名与目前显示行数
  • q:退出查看
less查看
less 文件名

可选操作:

  • 空白键:向下翻页
  • pagedown键:向下翻一页
  • pageup键:向上翻一页
  • q:退出less模式
  • /字符串:向下查询“字符串”
  • ?字符串:向上查询“字符串”
  • n:继续查询下一个
  • N:继续向上查询一个
head查看
# 读取头部20行数据
head -n 20 文件名
tail查看
# 读取尾部20行数据
tail -n 20 文件名

# 动态读取文件
tail -f 文件名

文件编辑

文件编辑使用Vim编辑器。它有三种模式:命令模式,输入模式,底线命令模式

命令模式
vim 文件名

刚启动Vim时便进入命令模式,按i键则进入输入模式,此时底部会出现**–INSERT–**字样

输入模式

输入模式用于对文件的编辑操作。在输入模式中,可以像在文本编辑器中一样编辑文件。按ESC键则退出输入模式,进入命令模式

底线命令模式

在命令模式下按下:(英文冒号)则进入底线命令模式。常用的组合命令为:

  • q :退出程序
  • w :保存文件

链接管理

Linux链接分为硬链接与软连接。

硬链接:允许一个文件拥有多个路径,当删除源文件时,链接文件不受影响,通常用于防止误删操作

软连接:类似Windows的快捷方式,当删除源文件时,软连接无法使用

ln 源文件 目标文件

# 创建硬链接,将yml01链接到yml
ln yml yml01
# 创建软链接,将yml02链接到yml
ln -s yml yml02

用户与权限

Linux系统是一种典型的多用户系统,这就涉及到了不同用户对于不同文件或目录的访问、操作权限。Linux系统对权限有着不同的规定,它按文件所有者、文件所有者同组用户和其他用户来规定了不同的文件访问权限。

权限管理

认识文件属性

通过ll或者ls -l命令查看文件列表。

[root@iZuf6bcosqnwhijwt0w2quZ ~]# cd /
[root@iZuf6bcosqnwhijwt0w2quZ /]# ls -l
总用量 60
lrwxrwxrwx.  1 root root     7 19 20:46 bin -> usr/bin
dr-xr-xr-x.  5 root root  4096 19 21:02 boot
drwxr-xr-x  19 root root  2960 222 19:46 dev
drwxr-xr-x. 80 root root  4096 222 17:53 etc
drwxr-xr-x.  2 root root  4096 222 22:50 home
lrwxrwxrwx.  1 root root     7 19 20:46 lib -> usr/lib
lrwxrwxrwx.  1 root root     9 19 20:46 lib64 -> usr/lib64
drwx------.  2 root root 16384 19 20:46 lost+found
drwxr-xr-x.  2 root root  4096 411 2018 media
drwxr-xr-x.  2 root root  4096 411 2018 mnt
drwxr-xr-x.  2 root root  4096 411 2018 opt
dr-xr-xr-x  93 root root     0 222 19:46 proc
dr-xr-x---.  6 root root  4096 222 22:50 root
drwxr-xr-x  25 root root   760 222 19:46 run
lrwxrwxrwx.  1 root root     8 19 20:46 sbin -> usr/sbin
drwxr-xr-x.  2 root root  4096 411 2018 srv
dr-xr-xr-x  13 root root     0 222 19:56 sys
drwxrwxrwt.  8 root root  4096 223 03:22 tmp
drwxr-xr-x. 13 root root  4096 19 20:46 usr
drwxr-xr-x. 19 root root  4096 19 12:51 var

从左到右第一列代表文件的属性与权限。其中,首字母代表文件的类型,剩余字母代表的是权限。

首字母的取值有以下几种:

  • d:表示当前为目录
  • **- ** :表示当前为文件
  • l :表示当前是链接文档,相当于Windows的快捷方式
  • b :表示装置文件里可供存储的接口设备
  • c :表示装置文件里面的串行端口设备,例如键盘、鼠标

接下来的字母以3个为一组,且均为rwx三个字母按顺序的排列组合,共三组。

  • r:可读权限
  • w:可写权限
  • x:可执行权限

当没有指定权限的时候,以-表示,如r-x,表示可读可执行,但不可写。

home目录举例drwxr-xr-x

文件类型所属用户权限所属用户组权限其他用户权限
drwxr-xr-x
表示当前是目录表示所属用户可读可写可执行表示所属用户组可读,可执行,不可写表示其他用户可读,可执行,不可写

第三列表示所属用户,第四列则表示所属用户组。

修改文件所属用户
chown [-R] 用户名 文件名
chown [-R] 用户名:用户组  文件名
  • -R表示递归修改,会同步修改目录下的子文件所属用户
修改文件所属用户组
chgrp [-R] 用户组 文件名
  • -R表示递归修改,会同步修改目录下的子文件所属用户组
修改文件权限
chmod [-R] 权限值 文件或目录

通常我们以数字表示4种权限,以三个为一组,将各自数字累加进行赋权。

r:4
w:2
x:1
-:0

rwx的值就是4+2+1=7

测试:

[root@iZuf6bcosqnwhijwt0w2quZ home]# ll
总用量 4
drwxr-xr-x 2 root root 4096 223 10:34 yml
# 将yml文件夹赋权,所属用户rwx,所属用户组-wx,其他用户r--
[root@iZuf6bcosqnwhijwt0w2quZ home]# chmod 734 yml/
[root@iZuf6bcosqnwhijwt0w2quZ home]# ls
yml
[root@iZuf6bcosqnwhijwt0w2quZ home]# ll
总用量 4
drwx-wxr-- 2 root root 4096 223 10:34 yml

账号管理

Linux系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。

用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另一方面也可以帮助用户组织文件,并为用户提供安全性保护。

每个用户账号都拥有一个唯一的用户名和各自的口令。

用户在登录时键入正确的用户名和口令后,就能够进入系统和自己的主目录。

用户组

每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux 系统对用户组的规定有所不同,如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。

添加用户组
groupadd [可选参数] 用户组

可选参数:

  • -g :指定新用户组的组标识号(GID)
  • -o :与-g同时使用,表示新用户组的GID可以与系统已有用户组的GID相同

测试:

# 创建yml用户组
groupadd yml
修改用户组
groupmod [可选参数] 用户组

可选参数同添加添加用户组参数,同时多出以下参数:

  • -n :新用户组 将用户组的名字改为新名字

测试:

# 修改用户组yml的组标识为101
groupmod -g 101 yml
# 将用户组yml修改为yml01
groupmod -n yml01 yml
删除用户组
groupdel 用户组
添加账号
useradd [可选参数] 用户名

可选参数:

  • -c:描述信息
  • -d:指定用户主目录,如果此目录不存在,则同时使用-m选项,可以创建主目录
  • -g:指定用户组
  • -G:指定用户所属的附加组
  • -m:使用者目录如不存在则自动建立
  • -s: 指定用户的登录Shell
  • -p:新账户密码

测试:

# 创建一个yml用户,并添加到用户组yml01,并生成主目录
[root@iZuf6bcosqnwhijwt0w2quZ home]# useradd -g yml01 -m yml

修改账号
usermod [可选参数] 用户名

可选参数同新增账号

删除账号
userdel 用户名
切换账号
su 用户名
# 将当前账号切换至yml
su yml
口令管理

超级用户可以为自己或其他用户指定口令,普通用户只能修改自己的口令。如果用户名参数为空,则修改当前账号的口令。修改自己口令时会先校验原密码,然后输入新密码,修改其他用户密码,则直接修改密码。

passwd [可选参数] 用户名

可选参数:

  • -l:锁定用户,lock,禁用账号
  • -u:口令解锁
  • -d:使账号无口令
  • -f:强迫用户下次登录修改口令

磁盘管理

Linux磁盘管理常用命令为 df、du。

  • df :列出文件系统的整体磁盘使用量
  • du:检查磁盘空间使用量

磁盘容量查询

df

检查文件系统的磁盘空间占用情况。可以利用该命令来获取硬盘被占用了多少空间,目前还剩下多少空间等信息。

df [可选参数] 目录或文件名

可选参数:

  • -a :列出所有的文件系统,包括系统特有的 /proc 等文件系统;
  • -k :以 KBytes 的容量显示各文件系统;
  • -m :以 MBytes 的容量显示各文件系统;
  • -h :以人们较易阅读的 GBytes, MBytes, KBytes 等格式自行显示;
  • -H :以 M=1000K 取代 M=1024K 的进位方式;
  • -T :显示文件系统类型, 连同该 partition 的 filesystem 名称 (例如 ext3) 也列出;
  • -i :不用硬盘容量,而以 inode 的数量来显示

测试:

# 获取磁盘占用信息
[root@iZuf6bcosqnwhijwt0w2quZ home]# df
文件系统          1K-块    已用     可用 已用% 挂载点
devtmpfs         888652       0   888652    0% /dev
tmpfs            899236       0   899236    0% /dev/shm
tmpfs            899236     480   898756    1% /run
tmpfs            899236       0   899236    0% /sys/fs/cgroup
/dev/vda1      41152812 2284016 36965088    6% /
tmpfs            179848       0   179848    0% /run/user/0
# 获取磁盘占用信息,并格式化容量单位
[root@iZuf6bcosqnwhijwt0w2quZ home]# df -h
文件系统        容量  已用  可用 已用% 挂载点
devtmpfs        868M     0  868M    0% /dev
tmpfs           879M     0  879M    0% /dev/shm
tmpfs           879M  480K  878M    1% /run
tmpfs           879M     0  879M    0% /sys/fs/cgroup
/dev/vda1        40G  2.2G   36G    6% /
tmpfs           176M     0  176M    0% /run/user/0

du

du 命令也是查看使用空间的,但是与 df 命令不同的是 Linux du 命令是对文件和目录磁盘使用的空间的查看,还是和df命令有一些区别的。

与 df 不一样的是,du 这个命令其实会直接到文件系统内去搜寻所有的文件数据。

du [可选参数] 文件或目录

可选参数:

  • -a :列出所有的文件与目录容量,因为默认仅统计目录底下的文件量而已。
  • -h :以人们较易读的容量格式 (G/M) 显示;
  • -s :列出总量而已,而不列出每个各别的目录占用容量;
  • -S :不包括子目录下的总计,与 -s 有点差别。
  • -k :以 KBytes 列出容量显示;
  • -m :以 MBytes 列出容量显示;

测试:

[root@iZuf6bcosqnwhijwt0w2quZ home]# du -h
16K     ./yml
28K     .

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值