在linux中的用户可以分为两类,一类是root用户,root用户拥有linux操作系统的最大的权限,另外一类就是普通用户,相比于root用户,普通用户的权限受到一定的限制(对于文件的读写删除等操作)。普通用户在home目录内一般是不受限制的,一旦出了home目录,那么普通用户只有读和执行的权限,没有修改的权限!
语法:su [-] 用户名
符号是可选的,表示是否在切换用户后加载环境变量(后续讲解),建议带上
参数:用户名,表示要切换的用户,用户名也可以省略,省略表示切换到root
切换用户后,可以通过exit命令退回上一个用户,也可以使用快捷键:ctrl + d
使用普通用户,切换到其它用户需要输入密码,如切换到root用户
使用root用户切换到其它用户,无需密码,可以直接切换
在我们得知root密码的时候,可以通过su命令切换到root得到最大权限。但是我们不建议长期使用root用户,避免带来系统损坏。我们可以使用sudo命令,为普通的命令授权,临时以root身份执行。
语法:sudo 其他的命令
在其它命令之前,带上sudo,即可为这一条命令临时赋予root授权,但是并不是所有的用户,都有权利使用sudo,我们需要为普通用户配置sudo认证。
切换到root用户,执行visudo命令,会自动通过vi编辑器打开:/etc/sudoers 在文件的最后添加:
songzhishu ALL=(ALL) NOPASSWD:ALL
代表给songzhishu这个用户所使用的命令赋予权限,其中最后的NOPASSWD:ALL 表示使用sudo命令,无需输入密码,最后通过 wq 保存!最后使用的话切换过去普通用户!
Linux系统中可以:配置多个用户、配置多个用户组、用户可以加入多个用户组中,Linux中关于权限的管控级别有2个级别,分别是:
针对用户的权限控制
针对用户组的权限控制
比如,针对某文件,可以控制用户的权限,也可以控制用户组的权限。所以,我们需要学习在Linux中进行用户、用户组管理的基础命令,为后面学习权限控制打下基础。
创建用户组:groupadd 用户组名
删除用户组:groupdel 用户组名
创建用户:useradd [-g -d] 用户名
选项:-g指定用户的组,不指定-g,会创建同名组并自动加入,指定-g需要组已经存在,如已存在同名组,必须使用-g
选项:-d指定用户HOME路径,不指定,HOME目录默认在:/home/用户名
删除用户:userdel [-r] 用户名
选项:-r,删除用户的HOME目录,不使用-r,删除用户时,HOME目录保留
查看用户所属组:id [用户名]
参数:用户名,被查看的用户,如果不提供则查看自身
修改用户所属组:usermod -aG 用户组 用户名,将指定用户加入指定用户组
查看用户:
语法: getent passwd
获取的信息:用户名 密码(x) 用户ID 组ID 描述信息(无用) HOME目录 执行终端(默认bash)
查看用户组:
语法:getent group
获取的信息:组名称 组认证(显示为x) 组ID
查看linux中的权限信息如下
drwxrwxr-x. 3 songzhishu songzhishu 101 12月 17 20:52 file
查询的信息大概可以分为四个部分,权限信息、用户、用户组、文件信息,其中权限信息又可以分为:
r表示读权限、w表示写权限、x表示执行权限
针对文件、文件夹的不同,rwx的含义有细微差别
r:
针对文件可以查看文件内容
针对文件夹,可以查看文件夹内容,如ls命令
w:
针对文件表示可以修改此文件
针对文件夹,可以在文件夹内:创建、删除、改名等操作
x:
针对文件表示可以将文件作为程序执行
针对文件夹,表示可以更改工作目录到此文件夹,即cd进入
chmod命令可以修改文件、文件夹的权限信息,但是只有文件、文件夹所属的用户或者是root用户才可以进行权限的修改。
语法 chmod [-R] 权限 文件或者文件夹
其中 -R 可以对文件夹内的全部内容使用相同的操作。
权限书写方式:u=rwx,g=rx,o=x,u代表所属用户,g所属用户组,o其他用户,也可使使用数字代替777代表全部的权限都开放,没有限制!7其实就是111,懂啦叭
使用chown命令,可以修改文件、文件夹的所属用户和用户组,普通用户无法修改所属为其它用户或组,所以此命令只适用于root用户执行
语法:chown [-R] [用户]:[用户组] 文件或文件夹
示例:
Linux中安装软件的方式可以分为两种,一种是yum安装,在线的方式去仓库下载软件然后安装,另外一种是rpm源码安装,这不需要联网,但是要提供源码包,第一种方式比较简单容易,第二种方式操作比较复杂,怎么说呐各有好处叭!
yum:RPM包软件管理器,用于自动化安装配置Linux软件,并可以自动解决依赖问题。yum命令需要root权限,可以su切换到root,或使用sudo提权。而且yum命令需要联网!
语法:yum [-y] [install] |[remove] |[search] 软件名
选项:
-y:自动确认,无需手动确认安装或卸载过程
install:安装
remove:卸载
search:搜索
市面上有非常多的压缩格式zip格式、7zip、rar、tar、gzip在Windows系统中常用的软件如:winrar、bandizip等软件,都支持各类常见的压缩格式,现在要学习,如何在Linux系统中操作:tar、gzip、zip这三种压缩格式。
.tar,称之为tarball,归档文件,即简单的将文件组装到一个.tar的文件内,并没有太多文件体积的减少,仅仅是简单的封装。
语法:tar [-c -v -x -f -z -C] ... 参数
参数:
-c,创建压缩文件,用于压缩模式
-v,显示压缩、解压过程,用于查看进度
-x,解压模式
-f,要创建的文件,或要解压的文件,-f选项必须在所有选项中位置处于最后一个
-z,gzip模式,不使用-z就是普通的tarball格式
-C,选择解压的目的地,用于解压模式
tar的常用组合为:
tar -cvf test.tar 1.txt 2.txt 3.txt 将1.txt 2.txt 3.txt 压缩到test.tar文件内
tar -zcvf test.tar.gz 1.txt 2.txt 3.txt 将1.txt 2.txt 3.txt 压缩到test.tar.gz文件内,使用gzip模式
注意:
-z选项如果使用的话,一般处于选项位第一个
-f选项,必须在选项位最后一个
常用的tar解压组合有
tar -xvf test.tar 解压test.tar,将文件解压至当前目录
tar -xvf test.tar -C /home/itheima 解压test.tar,将文件解压至指定目录(/home/itheima)
tar -zxvf test.tar.gz -C /home/itheima 以Gzip模式解压test.tar.gz,将文件解压至指定目录(/home/itheima)
注意:
-f选项,必须在选项组合体的最后一位
-z选项,建议在开头位置
-C选项单独使用,和解压所需的其它参数分开
可以使用zip命令,压缩文件为zip压缩包
语法:zip [-r] 参数1 参数2 ...参数n
-r,被压缩的包含文件夹的时候,需要使用-r选项,和rm、cp等命令的-r效果一致
示例:
zip test.zip a.txt b.txt c.txt 将a.txt b.txt c.txt 压缩到test.zip文件内
zip -r test.zip test itheima a.txt 将test、itheima两个文件夹和a.txt文件,压缩到test.zip文件内
使用unzip命令,可以方便的解压zip压缩包
语法:unzip -d 参数
-d,指定要解压去的位置,同tar的-C选项
参数,被解压的zip压缩包文件
示例:
unzip test.zip, 将test.zip解压到当前目录
unzip test.zip -d /home/itheima, 将test.zip解压到指定文件夹内(/home/itheima)
Linux系统很多软件(内置或第三方)均支持使用systemctl命令控制:启动、停止、开机自启,能够被systemctl管理的软件,一般也称之为:服务
语法:sysytemctl start|stop|status|enable|disable 服务名
系统内置的服务比较多,比如:
NetworkManager,主网络服务
network,副网络服务
firewalld,防火墙服务
sshd,ssh服务(FinalShell远程登录Linux使用的就是这个服务)
在系统中创建软连接,将文件或者文件夹链接到其他的位置,类似快捷方式,这里建议文件或者文件夹的路径写成绝对路径,不然会出现 类似的情况 cat: demo.txt: 符号连接的层数过多
语法:ln -s 参数1 参数2
- -s选项,创建软连接
- 参数1:被链接的文件或文件夹
- 参数2:要链接去的目的地
实例:
- ln -s /etc/yum.conf ~/yum.conf
- ln -s /etc/yum ~/yum
通过date命令可以在命令行中查看系统的时间
语法:data [-d] [格式化字符串]
-d 按照给定的字符串显示日期,一般用于日期计算
data -d "+1 day" "+%y-%m-%d"
大概得意思就是加一天后的时间格式是什么!可以配合加减
year**年**
month**月**
day**天**
hour**小时**
minute**分钟**
second**秒**
格式化字符串:通过特定的字符串标记,来控制显示的日期格式
%Y 年
%y 年份后两位数字 (00..99)
%m 月份 (01..12)
%d 日 (01..31)
%H 小时 (00..23)
%M 分钟 (00..59)
%S 秒 (00..60)
%s 自 1970-01-01 00:00:00 UTC 到现在的秒数
使用root权限,执行如下命令,修改时区为东八区时区:将系统自带的localtime文件删除,并将/usr/share/zoneinfo/Asia/Shanghai文件链接为localtime文件即可
rm -f /etc/localtime
sudo ln -s /user/share/zoneinfo/Aisa/Shanghai /etc/localtime
使用ifconfig可以查看ip,其实这里的知识点不太多,会查就可以!
使用hostname可以查看主机名字,当然既然是名字可以改动,命令如下
hostname set -hostname 主机名
IP地址实在是难以记忆,有没有什么办法可以通过主机名或替代的字符地址去代替数字化的IP地址呢?
实际上,我们一直都是通过字符化的地址去访问服务器,很少指定IP地址--也就是域名解析,现在本地找主机名和ip的对应关系,然后没有找到的话就到联网的DNS服务器找。
当前我们虚拟机的Linux操作系统,其IP地址是通过DHCP服务获取的。DHCP:动态获取IP地址,即每次重启设备后都会获取一次,可能导致IP地址频繁变更。对于我们配置的域名接卸的ip的话,频繁的更改会使我们不断的修改配置文件,所以我们想要ip固定下来!固定ip的配置可以分为两大步骤:
第一步打开虚拟网络编辑器:
第二步修改IP地址和网段
第三步:在dhcp中设置网关为192.168.88.2
第一步:使用vim编辑/etc/sysconfig/network-scripts/ifcfg-ens33文件,填入如下内容
然后使用systemctl restart network 重启网卡,再次查看ip就是你自己配置的啦
使用ping可以测试指定的网络服务器是不是可以联通
语法: ping [-c num] ip或者主机名
选项:-c,检查的次数,不使用-c选项,将无限次数持续检查
参数:ip或主机名,被检查的服务器的ip地址或主机名地址
wget是非交互式的文件下载器,可以在命令行内下载网络文件,注意:无论下载是否完成,都会生成要下载的文件,如果下载未完成,请及时清理未完成的不可用文件。
语法:
选项:-b,可选,后台下载,会将日志写入到当前工作目录的wget-log文件
参数:url,下载链接
示例:
下载apache-hadoop 3.3.0版本:wget http://archive.apache.org/dist/hadoop/common/hadoop-3.3.0/hadoop-3.3.0.tar.gz
Linux系统是一个超大号小区,可以支持65535个端口,这6万多个端口分为3类进行使用:
公认端口:1~1023,通常用于一些系统内置或知名程序的预留使用,如SSH服务的22端口,HTTPS服务的443端口,非特殊需要,不要占用这个范围的端口
注册端口:1024~49151,通常可以随意使用,用于松散的绑定一些程序\服务
动态端口:49152~65535,通常不会固定绑定程序,而是当程序对外进行网络链接时,用于临时使用。
在Linux中可以通过Linux命令去查看端口的占用情况,使用nmap命令,安装nmap:yum -y install nmap
语法:nmap 被查看的IP地址
也可以使用可以通过netstat命令,查看指定端口的占用情况,安装netstat:yum -y install net-tools
语法:netstat -anp | grep 端口号
程序运行在操作系统中,是被操作系统所管理的。为管理运行的程序,每一个程序在运行的时候,便被操作系统注册为系统中的一个:进程,并会为每一个进程都分配一个独有的:进程ID(进程号)。可以通过ps命令查看Linux系统中的进程信息
语法:ps [-e -f]
选项:-e,显示出全部的进程
选项:-f,以完全格式化的形式展示信息(展示全部信息)
一般来说,固定用法就是: ps -ef 列出全部进程的全部信息
UID PID PPID C STIME TTY TIME CMD
root 2 0 0 11:08 ? 00:00:00 [kthreadd]
UID**:进程所属的用户ID**
PID**:进程的进程号ID**
PPID**:进程的父ID(启动此进程的其它进程)**
C**:此进程的CPU占用率(百分比)**
STIME**:进程的启动时间**
TTY**:启动此进程的终端序号,如显示?,表示非终端启动**
TIME**:进程占用CPU的时间**
CMD**:进程对应的名称或启动路径或启动命令**
在Windows系统中,可以通过任务管理器选择进程后,点击结束进程从而关闭它。同样,在Linux中,可以通过kill命令关闭进程。
语法: kill -9 pid进程号
选项:-9,表示强制关闭进程。不使用此选项会向进程发送信号要求其关闭,但是否关闭看进程自身的处理机制。
可以通过top命令查看CPU、内存使用情况,类似Windows的任务管理器,默认每5秒刷新一次,语法:直接输入top即可,按q或ctrl + c退出。
top - 18:00:48 up 6:52, 4 users, load average: 0.00, 0.01, 0.05
Tasks: 268 total, 1 running, 267 sleeping, 0 stopped, 0 zombie
%Cpu(s): 0.1 us, 0.4 sy, 0.0 ni, 99.5 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
KiB Mem : 3861516 total, 2068208 free, 782436 used, 1010872 buff/cache
KiB Swap: 4063228 total, 4063228 free, 0 used. 2725752 avail Mem
第一行:
top:命令名称,14:39:58:当前系统时间,up 6 min:启动了6分钟,4 users:4个用户登录,load:1、5、15分钟负载
第二行:
Tasks:268个进程,1 running:1个进程子在运行,267 sleeping:267个进程睡眠,0个停止进程,0个僵尸进程
第三行:
%Cpu(s):CPU使用率,us:用户CPU使用率,sy:系统CPU使用率,ni:高优先级进程占用CPU时间百分比,id:空闲CPU率,wa:IO等待CPU占用率,hi:CPU硬件中断率,si:CPU软件中断率,st:强制等待占用CPU率
第四、五行:
Kib Mem:物理内存,total:总量,free:空闲,used:使用,buff/cache:buff和cache占用
KibSwap:虚拟内存(交换空间),total:总量,free:空闲,used:使用,buff/cache:buff和cache占用
top 命令的其他的选项:
top交互式选项
对于查看磁盘的使用情况,可以使用以下的命令:
语法:df [-h]
选项:-h 以更加人性化的方式的单位去展示信息
可以使用iostat查看CPU、磁盘的相关信息
语法:iostat [-x] [num1] [num2]
选项:
-x,显示更多信息
num1:数字,刷新间隔
num2:数字,刷新几次
rrqm/s: 每秒这个设备相关的读取请求有多少被Merge了(当系统调用需要读取数据的时候,VFS将请求发到各个FS,如果FS发现不同的读取请求读取的是相同Block的数据,FS会将这个请求合并Merge, 提高IO利用率, 避免重复调用);
wrqm/s: 每秒这个设备相关的写入请求有多少被Merge了。
rsec/s: 每秒读取的扇区数;sectors
wsec/: 每秒写入的扇区数。
rKB/s: 每秒发送到设备的读取请求数
wKB/s: 每秒发送到设备的写入请求数
avgrq-sz 平均请求扇区的大小
avgqu-sz 平均请求队列的长度。毫无疑问,队列长度越短越好。
await: 每一个IO请求的处理的平均时间(单位是微秒毫秒)。
svctm 表示平均每次设备I/O操作的服务时间(以毫秒为单位)
%util: 磁盘利用率
学习which命令的时候,我们知道使用的一系列命令其实本质上就是一个个的可执行程序。比如,cd命令的本体就是:/usr/bin/cd 这个程序文件。但是我不是在特定的文件目录来执行,而是在任意的路径下执行,这就是环境变量的作用,其实和windows下配置的环境变量差不多。环境变量是操作系统(Windows、Linux、Mac)在运行的时候,记录的一些关键性信息,用以辅助系统运行。
在Linux系统中执行:env命令即可查看当前系统中记录的环境变量
Linux环境变量可以用户自行设置,其中分为:
临时设置,语法:export 变量名=变量值
永久生效
针对当前用户生效,配置在当前用户的: ~/.bashrc文件中
针对所有用户生效,配置在系统的: /etc/profile文件中
并通过语法:source 配置文件,进行立刻生效,或重新登录FinalShell生效