linux 操作系统(二)

1、linux用户和权限

1.1、用户分类:

        在linux中的用户可以分为两类,一类是root用户,root用户拥有linux操作系统的最大的权限,另外一类就是普通用户,相比于root用户,普通用户的权限受到一定的限制(对于文件的读写删除等操作)。普通用户在home目录内一般是不受限制的,一旦出了home目录,那么普通用户只有读和执行的权限,没有修改的权限!

1.1.1、用户切换

语法:su [-] 用户名

  1. 符号是可选的,表示是否在切换用户后加载环境变量(后续讲解),建议带上

  2. 参数:用户名,表示要切换的用户,用户名也可以省略,省略表示切换到root

  3. 切换用户后,可以通过exit命令退回上一个用户,也可以使用快捷键:ctrl + d

  4. 使用普通用户,切换到其它用户需要输入密码,如切换到root用户

  5. 使用root用户切换到其它用户,无需密码,可以直接切换

1.1.2、命令权限赋予

        在我们得知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 保存!最后使用的话切换过去普通用户!

1.2、用户和用户组

        Linux系统中可以:配置多个用户、配置多个用户组、用户可以加入多个用户组中,Linux中关于权限的管控级别有2个级别,分别是:

  • 针对用户的权限控制

  • 针对用户组的权限控制

        比如,针对某文件,可以控制用户的权限,也可以控制用户组的权限。所以,我们需要学习在Linux中进行用户、用户组管理的基础命令,为后面学习权限控制打下基础。

1.2.1、创建用户:

创建用户组:groupadd 用户组名

删除用户组:groupdel 用户组名

1.2.2、创建用户组

创建用户:useradd [-g -d] 用户名

  • 选项:-g指定用户的组,不指定-g,会创建同名组并自动加入,指定-g需要组已经存在,如已存在同名组,必须使用-g

  • 选项:-d指定用户HOME路径,不指定,HOME目录默认在:/home/用户名

删除用户:userdel [-r] 用户名

  • 选项:-r,删除用户的HOME目录,不使用-r,删除用户时,HOME目录保留

查看用户所属组:id [用户名]

  • 参数:用户名,被查看的用户,如果不提供则查看自身

修改用户所属组:usermod -aG 用户组 用户名,将指定用户加入指定用户组

1.2.3、查看用户以及用户组
  1. 查看用户:

    语法: getent passwd

    获取的信息:用户名 密码(x) 用户ID 组ID 描述信息(无用) HOME目录 执行终端(默认bash)

  2. 查看用户组:

        语法:getent group

        获取的信息:组名称 组认证(显示为x) 组ID

1.3、权限

1.3.1、权限信息:

查看linux中的权限信息如下

drwxrwxr-x. 3 songzhishu songzhishu 101 12月 17 20:52 file

        查询的信息大概可以分为四个部分,权限信息、用户、用户组、文件信息,其中权限信息又可以分为:

linux 操作系统(二)_第1张图片

r表示读权限、w表示写权限、x表示执行权限

针对文件、文件夹的不同,rwx的含义有细微差别

r:

  • 针对文件可以查看文件内容

  • 针对文件夹,可以查看文件夹内容,如ls命令

w:

  • 针对文件表示可以修改此文件

  • 针对文件夹,可以在文件夹内:创建、删除、改名等操作

x:

  • 针对文件表示可以将文件作为程序执行

  • 针对文件夹,表示可以更改工作目录到此文件夹,即cd进入

1.3.2、修改权限信息

        chmod命令可以修改文件、文件夹的权限信息,但是只有文件、文件夹所属的用户或者是root用户才可以进行权限的修改。

语法 chmod  [-R]  权限  文件或者文件夹 

其中 -R 可以对文件夹内的全部内容使用相同的操作。

​        权限书写方式:u=rwx,g=rx,o=x,u代表所属用户,g所属用户组,o其他用户,也可使使用数字代替777代表全部的权限都开放,没有限制!7其实就是111,懂啦叭

1.3.3、修改用户用户组

​        使用chown命令,可以修改文件、文件夹的所属用户和用户组,普通用户无法修改所属为其它用户或组,所以此命令只适用于root用户执行

语法:chown  [-R] [用户]:[用户组]  文件或文件夹

  1. 选项,-R,同chmod,对文件夹内全部内容应用相同规则
  2. 选项,用户,修改所属用户
  3. 选项,用户组,修改所属用户组
  4. :用于分隔用户和用户组

示例:

  1. chown root hello.txt,将hello.txt所属用户修改为root
  2. chown :root hello.txt,将hello.txt所属用户组修改为root
  3. chown root:itheima hello.txt,将hello.txt所属用户修改为root,用户组修改为itheima
  4. chown -R root test,将文件夹test的所属用户修改为root并对文件夹内全部内容应用同样规则

2、软件安装

        Linux中安装软件的方式可以分为两种,一种是yum安装,在线的方式去仓库下载软件然后安装,另外一种是rpm源码安装,这不需要联网,但是要提供源码包,第一种方式比较简单容易,第二种方式操作比较复杂,怎么说呐各有好处叭!

2.1、YUM安装

        yum:RPM包软件管理器,用于自动化安装配置Linux软件,并可以自动解决依赖问题。yum命令需要root权限,可以su切换到root,或使用sudo提权。而且yum命令需要联网!

语法:yum [-y] [install] |[remove] |[search] 软件名

选项:

  • -y:自动确认,无需手动确认安装或卸载过程

  • install:安装

  • remove:卸载

  • search:搜索

2.3、文件压缩、解压

市面上有非常多的压缩格式zip格式、7zip、rar、tar、gzip在Windows系统中常用的软件如:winrar、bandizip等软件,都支持各类常见的压缩格式,现在要学习,如何在Linux系统中操作:tar、gzip、zip这三种压缩格式。

2.3.1、tar命令

.tar,称之为tarball,归档文件,即简单的将文件组装到一个.tar的文件内,并没有太多文件体积的减少,仅仅是简单的封装。

语法:tar [-c -v -x -f -z -C] ... 参数

参数:

  • -c,创建压缩文件,用于压缩模式

  • -v,显示压缩、解压过程,用于查看进度

  • -x,解压模式

  • -f,要创建的文件,或要解压的文件,-f选项必须在所有选项中位置处于最后一个

  • -z,gzip模式,不使用-z就是普通的tarball格式

  • -C,选择解压的目的地,用于解压模式

2.3.1.1、tar 命令压缩

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选项,必须在选项位最后一个

2.3.1.2、tar解压

常用的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)

注意:

  1. -f选项,必须在选项组合体的最后一位

  2. -z选项,建议在开头位置

  3. -C选项单独使用,和解压所需的其它参数分开

2.3.2、zip命令
2.3.2.1、压缩

可以使用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文件内

2.3.2.2、解压

使用unzip命令,可以方便的解压zip压缩包

语法:unzip -d 参数

  • -d,指定要解压去的位置,同tar的-C选项

  • 参数,被解压的zip压缩包文件

示例:

  1. unzip test.zip, 将test.zip解压到当前目录

  2. unzip test.zip -d /home/itheima, 将test.zip解压到指定文件夹内(/home/itheima)

3、系统设置:

3.1、systemctl

        Linux系统很多软件(内置或第三方)均支持使用systemctl命令控制:启动、停止、开机自启,能够被systemctl管理的软件,一般也称之为:服务

语法:sysytemctl start|stop|status|enable|disable 服务名

系统内置的服务比较多,比如:

  • NetworkManager,主网络服务

  • network,副网络服务

  • firewalld,防火墙服务

  • sshd,ssh服务(FinalShell远程登录Linux使用的就是这个服务)

 3.2、软链接

​        在系统中创建软连接,将文件或者文件夹链接到其他的位置,类似快捷方式,这里建议文件或者文件夹的路径写成绝对路径,不然会出现   类似的情况 cat: demo.txt: 符号连接的层数过多

语法:ln -s 参数1 参数2

- -s选项,创建软连接
- 参数1:被链接的文件或文件夹
- 参数2:要链接去的目的地

实例:

- ln -s /etc/yum.conf ~/yum.conf
- ln -s /etc/yum ~/yum

3.3、时间和时区

3.3.1、时间

通过date命令可以在命令行中查看系统的时间

语法:data [-d] [格式化字符串]

  1. -d 按照给定的字符串显示日期,一般用于日期计算

    data -d "+1 day" "+%y-%m-%d"

    大概得意思就是加一天后的时间格式是什么!可以配合加减

    1. year**年**

    2. month**月**

    3. day**天**

    4. hour**小时**

    5. minute**分钟**

    6. second**秒**

  2. 格式化字符串:通过特定的字符串标记,来控制显示的日期格式

    1. %Y 年

    2. %y 年份后两位数字 (00..99)

    3. %m 月份 (01..12)

    4. %d 日 (01..31)

    5. %H 小时 (00..23)

    6. %M 分钟 (00..59)

    7. %S 秒 (00..60)

    8. %s 自 1970-01-01 00:00:00 UTC 到现在的秒数

3.3.2、时区

        使用root权限,执行如下命令,修改时区为东八区时区:将系统自带的localtime文件删除,并将/usr/share/zoneinfo/Asia/Shanghai文件链接为localtime文件即可

rm -f /etc/localtime
sudo ln -s /user/share/zoneinfo/Aisa/Shanghai /etc/localtime

3.4、ip,主机名

3.4.1、ip

​    使用ifconfig可以查看ip,其实这里的知识点不太多,会查就可以!

3.4.2、主机名

使用hostname可以查看主机名字,当然既然是名字可以改动,命令如下

hostname set -hostname 主机名
4.4.3、域名解析

​        IP地址实在是难以记忆,有没有什么办法可以通过主机名或替代的字符地址去代替数字化的IP地址呢?

        实际上,我们一直都是通过字符化的地址去访问服务器,很少指定IP地址--也就是域名解析,现在本地找主机名和ip的对应关系,然后没有找到的话就到联网的DNS服务器找。

 linux 操作系统(二)_第2张图片

3.5、配置固定的ip

        当前我们虚拟机的Linux操作系统,其IP地址是通过DHCP服务获取的。DHCP:动态获取IP地址,即每次重启设备后都会获取一次,可能导致IP地址频繁变更。对于我们配置的域名接卸的ip的话,频繁的更改会使我们不断的修改配置文件,所以我们想要ip固定下来!固定ip的配置可以分为两大步骤:

  1. 在VMware Workstation中配置IP地址网关和网段(IP地址的范围)
  2. 在Linux中修改配置文件然后固定IP
3.5.1、VMware Workstation

第一步打开虚拟网络编辑器:

linux 操作系统(二)_第3张图片

第二步修改IP地址和网段

linux 操作系统(二)_第4张图片

第三步:在dhcp中设置网关为192.168.88.2

3.5.2、修改linux中的配置文件

第一步:使用vim编辑/etc/sysconfig/network-scripts/ifcfg-ens33文件,填入如下内容

linux 操作系统(二)_第5张图片

 然后使用systemctl restart network 重启网卡,再次查看ip就是你自己配置的啦

3.6、网络传输

3.6.1、ping

        使用ping可以测试指定的网络服务器是不是可以联通

语法: ping [-c num] ip或者主机名

  • 选项:-c,检查的次数,不使用-c选项,将无限次数持续检查

  • 参数:ip或主机名,被检查的服务器的ip地址或主机名地址

3.6.2、wget

        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

3.6.3、端口

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 端口号

3.6.4、进程

        程序运行在操作系统中,是被操作系统所管理的。为管理运行的程序,每一个程序在运行的时候,便被操作系统注册为系统中的一个:进程,并会为每一个进程都分配一个独有的:进程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,表示强制关闭进程。不使用此选项会向进程发送信号要求其关闭,但是否关闭看进程自身的处理机制。

3.7、主机状态监控

3.7.1、查看系统资源

可以通过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占用

linux 操作系统(二)_第6张图片

  • PID:进程id
  • USER:进程所属用户
  • PR:进程优先级,越小越高
  • NI:负值表示高优先级,正表示低优先级
  • VIRT:进程使用虚拟内存,单位KB
  • RES:进程使用物理内存,单位KB
  • SHR:进程使用共享内存,单位KB
  • S:进程状态(S休眠,R运行,Z僵死状态,N负数优先级,I空闲状态)
  • %CPU:进程占用CPU
  • %MEM:进程占用内存率
  • TIME+:进程使用CPU时间总计,单位10毫秒
  • COMMAND:进程的命令或名称或程序文件路径

top 命令的其他的选项:

linux 操作系统(二)_第7张图片

top交互式选项 

linux 操作系统(二)_第8张图片

3.7.2、磁盘信息监控

        对于查看磁盘的使用情况,可以使用以下的命令:

语法:df [-h]

选项:-h 以更加人性化的方式的单位去展示信息

linux 操作系统(二)_第9张图片

        可以使用iostat查看CPU、磁盘的相关信息

语法:iostat [-x] [num1] [num2]

选项:

  • -x,显示更多信息

  • num1:数字,刷新间隔

  • num2:数字,刷新几次

linux 操作系统(二)_第10张图片

  1. rrqm/s: 每秒这个设备相关的读取请求有多少被Merge了(当系统调用需要读取数据的时候,VFS将请求发到各个FS,如果FS发现不同的读取请求读取的是相同Block的数据,FS会将这个请求合并Merge, 提高IO利用率, 避免重复调用);

  2. wrqm/s: 每秒这个设备相关的写入请求有多少被Merge了。

  3. rsec/s: 每秒读取的扇区数;sectors

  4. wsec/: 每秒写入的扇区数。

  5. rKB/s: 每秒发送到设备的读取请求数

  6. wKB/s: 每秒发送到设备的写入请求数

  7. avgrq-sz 平均请求扇区的大小

  8. avgqu-sz 平均请求队列的长度。毫无疑问,队列长度越短越好。

  9. await: 每一个IO请求的处理的平均时间(单位是微秒毫秒)。

  10. svctm 表示平均每次设备I/O操作的服务时间(以毫秒为单位)

  11. %util: 磁盘利用率

3.8、环境变量

        学习which命令的时候,我们知道使用的一系列命令其实本质上就是一个个的可执行程序。比如,cd命令的本体就是:/usr/bin/cd 这个程序文件。但是我不是在特定的文件目录来执行,而是在任意的路径下执行,这就是环境变量的作用,其实和windows下配置的环境变量差不多。环境变量是操作系统(Windows、Linux、Mac)在运行的时候,记录的一些关键性信息,用以辅助系统运行。

在Linux系统中执行:env命令即可查看当前系统中记录的环境变量

3.8.1、自行设置环境变量

Linux环境变量可以用户自行设置,其中分为:

  1. 临时设置,语法:export 变量名=变量值

  2. 永久生效

    • 针对当前用户生效,配置在当前用户的: ~/.bashrc文件中

    • 针对所有用户生效,配置在系统的: /etc/profile文件中

    • 并通过语法:source 配置文件,进行立刻生效,或重新登录FinalShell生效

你可能感兴趣的:(Linux,linux,服务器,运维)