基础学习
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 1月 9 20:46 bin -> usr/bin
dr-xr-xr-x. 5 root root 4096 1月 9 21:02 boot
drwxr-xr-x 19 root root 2960 2月 22 19:46 dev
drwxr-xr-x. 80 root root 4096 2月 22 17:53 etc
drwxr-xr-x. 2 root root 4096 2月 22 22:50 home
lrwxrwxrwx. 1 root root 7 1月 9 20:46 lib -> usr/lib
lrwxrwxrwx. 1 root root 9 1月 9 20:46 lib64 -> usr/lib64
drwx------. 2 root root 16384 1月 9 20:46 lost+found
drwxr-xr-x. 2 root root 4096 4月 11 2018 media
drwxr-xr-x. 2 root root 4096 4月 11 2018 mnt
drwxr-xr-x. 2 root root 4096 4月 11 2018 opt
dr-xr-xr-x 93 root root 0 2月 22 19:46 proc
dr-xr-x---. 6 root root 4096 2月 22 22:50 root
drwxr-xr-x 25 root root 760 2月 22 19:46 run
lrwxrwxrwx. 1 root root 8 1月 9 20:46 sbin -> usr/sbin
drwxr-xr-x. 2 root root 4096 4月 11 2018 srv
dr-xr-xr-x 13 root root 0 2月 22 19:56 sys
drwxrwxrwt. 8 root root 4096 2月 23 03:22 tmp
drwxr-xr-x. 13 root root 4096 1月 9 20:46 usr
drwxr-xr-x. 19 root root 4096 1月 9 12:51 var
从左到右第一列代表文件的属性与权限。其中,首字母代表文件的类型,剩余字母代表的是权限。
首字母的取值有以下几种:
- d:表示当前为目录
- **- ** :表示当前为文件
- l :表示当前是链接文档,相当于Windows的快捷方式
- b :表示装置文件里可供存储的接口设备
- c :表示装置文件里面的串行端口设备,例如键盘、鼠标
接下来的字母以3个为一组,且均为rwx
三个字母按顺序的排列组合,共三组。
- r:可读权限
- w:可写权限
- x:可执行权限
当没有指定权限的时候,以-
表示,如r-x
,表示可读可执行,但不可写。
以home
目录举例drwxr-xr-x
文件类型 | 所属用户权限 | 所属用户组权限 | 其他用户权限 |
---|---|---|---|
d | rwx | r-x | r-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 2月 23 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 2月 23 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 .