Linux基础语法笔记

Linux学习笔记,含各种常用指令

一、Linux的目录结构

linux 的文件系统是采用级层式的树状目录结构,在此结构中的最上层是根目录“/ ”,然后在此目录下再创建其他的目录。
一句经典的话: 在Linux中,一切皆文件

img

1.具体的目录结构:

/bin [重点] (/usr/bin、/usr/local/bin)
•是Binary的缩写, 这个目录存放着最经常使用的命令

/sbin(/usr/sbin、/usr/local/sbin)
•s就是Super User的意思,这里存放的是系统管理员使用的系统管理程序。

/home [重点]
•存放普通用户的主目录,在Linux中每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。

/root [重点]
•该目录为系统管理员,也称作超级权限者的用户主目录。

/lib
•系统开机所需要最基本的动态连接共享库,其作用类似于Windows里的DLL文件。几乎所有的应用程序都需要用到这些共享库。

/lost+found
•这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。

/etc [重点]
•所有的系统管理所需要的配置文件和子目录my.conf

/usr [重点]
•这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似与windows下的program files目录。

/boot [重点]
•存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件

/proc
•这个目录是一个虚拟的目录,它是系统内存的映射,访问这个目录来获取系统信息。

/srv
•service缩写,该目录存放一些服务启动之后需要提取的数据。
/sys
•这是linux2.6内核的一个很大的变化。该目录下安装了2.6内核中新出现的一个文件系统sysfs
/tmp
•这个目录是用来存放一些临时文件的。

/dev
•类似于windows的设备管理器,把所有的硬件用文件的形式存储。
/media [重点]
•linux系统会自动识别一些设备,例如U盘、光驱等等,当识别后,linux会把识别的设备挂载到这个目录下。
/mnt [重点]
•系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将外部的存储挂载在/mnt/上,然后进入该目录就可以查看里的内容了。d:/myshare

/opt
•这是给主机额外安装软件所摆放的目录。如安装ORACLE数据库就可放到该目录下。默认为空。
/usr/local [重点]
•这是另一个给主机额外安装软件所安装的目录。一般是通过编译源码方式安装的程序。

/var [重点]
•这个目录中存放着在不断扩充着的东西,习惯将经常被修改的目录放在这个目录下。包括各种日志文件。

/selinux [security-enhanced linux] 360
•SELinux是一种安全子系统,它能控制程序只能访问特定文件。

二、vi和vim编辑器

1.vi和vim的基本介绍

所有的Linux 系统都会内建vi 文本编辑器。
Vim 具有程序编辑的能力,可以看做是Vi的增强版本,可以主动的以字体颜色辨别语法的正确性,方便程序设计。代码补完、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用。

2.三种模式

基本上 vi/vim 共分为三种模式,分别是命令模式(Command mode),输入模式(Insert mode)和底线命令模式(Last line mode)

  1. 命令模式

    用户刚刚启动 vi/vim,便进入了命令模式。 此状态下敲击键盘动作会被Vim识别为命令,而非输入字符。比如我们此时按下i,并不会输入一个字符,i被当作了一个命令。
    在此模式下的命令:
    (1)i 切换到输入模式,以输入字符。
    (2)x 删除当前光标所在处的字符。
    (3): 切换到底线命令模式,以在最底一行输入命令。

    命令模式只有一些最基本的命令,因此仍要依靠底线命令模式输入更多命令。

  2. 输入/编辑模式

    在命令模式下按下 i, I, o, O, a, A, r, R 等任何一个字母之后才会进入编辑模式, 一般来说按 i 即可。

  3. 底线命令模式

    在命令模式下按下:(英文冒号)就进入了底线命令模式。 底线命令模式可以输入单个或多个字符的命令,可用的命令非常多。完成读取、存盘、替换、离开 vim 、显示行号等的动作则是在此模式中达成的。比如:
    :wq//写并退出
    :q//直接退出
    :q!//强制退出不保存

img

3.快捷键的一些使用案例
  • 拷贝当前行:yy , 拷贝当前行向下的 5 行:5yy(yy5也可),并粘贴:p
  • 删除当前行:dd , 删除当前行向下的 5 行 :5dd
    (以上两条要在命令模式中使用,也就是vim刚进去的那个模式)
  • 设置文件的行号(:set nu,回车),取消文件的行号(:set nonu,回车),这个即命令模式 : 后进入底线命令模式

在这里插入图片描述img

  • 在输入模式下输入 “hello” ,再ESC退出到正常模式,输入u,可以撤销先前的输入操作

  • 在第2行进行输入或删除
    (1)先显示行号,:set nu(底线命令模式)
    (2)输入2,在输入shift+g

  • 在命令模式下输入V可以选中当前行,然后按上下键可以选中多行,按shift+>或者shift+< 可以实现缩进或退格

三、开机、重启和用户登录注销

1、关机&重启命令
  • shutdown:关机
    shutdown -h now:立即关机
    shutdown -h 1:表示1分钟后关机
    shutdown -r now:立即重启
  • halt:直接使用,效果等价于关机
  • reboot:重启系统
  • sync:把内存的数据同步到磁盘
    **关机或重启时,都应该执行一下sync,防止数据丢失 **
2、用户登录和注销
  • 登录时尽量少用root登录,避免操作失误,因为root有最大的权限。可以用普通用户登录,再su -用户名 切换
  • 在提示符后输入logout(在运行级别3以下才有效)即可注销登录。(root用户输入exit,普通用户用logout)

四、用户管理

Linux是一个多用户、多任务的操作系统,要使用资源,必须先申请一个账号,然后以这个账号的身份进入系统。

Linux的用户至少要属于一个组。

1、用户添加
[root@localhost ~]# useradd userA

当创建用户成功后,会自动的创建和用户同名的家目录,也可以通过

[root@localhost ~]# useradd -d /home/AAA/userA

在指定的目录下添加。用passwd userA指定密码。
补充:cd /home 切换目录到home下 cd表示 change directory切换目录

2、删除用户

[root@localhost ~]# userdel userA 删除用户,但保留家目录
[root@localhost ~]# userdel -r userA 删除用户以及用户主目录

3、查询用户信息
id userA

在这里插入图片描述

uid:用户id

gid:所在组的id

组(0):组名

  • su -用户名 可以切换用户
  • 当需要返回到原来用户时,使用 exit 指令
  • 从权限低的用户切换到权限高的用户,需要密码,反之则不用
4、用户组
groupadd wudang//添加组
groupdel wudang//删除组
useradd -g  wudang zwj//增加用户时直接加上组

groupadd shaolin
usermod -g shaolin zwj//将zwj用户修改到shaolin组
5、相关文件
  • /etc/passwd文件:用户的配置文件,记录用户的各种信息
root:x:0:0:root:/root:/bin/bash//用户名:口令:用户标识号:组标识号:注释性描述:主目录:登录 Shell
  • /etc/shadow文件:口令的配置文件
    每行的含义:登录名:加密口令:最后一次修改时间:最小时间间隔:最大时间间隔:警告时间:不活动时间:失效时间:标志
  • /etc/group文件:组的配置文件,记录linux包含的组的信息
    每行含义:组名:口令:组标识号:组内用户列表
    在这里插入图片描述

五、实用指令

1、运行级别
0:关机
1:单用户【找回丢失密码】
2:多用户状态,没有网络服务
3:多用户状态:有网络服务
4:系统未使用保留给用户
5:图形界面
6:系统重启

常用运行级别是3和5 ,要修改默认的运行级别可改文件
/etc/inittab的id:5:initdefault:这一行中的数字
命令:init [012356]

面试题:如果不小心忘记root密码,怎么找回?
思路:进入单用户模式,然后修改root密码,因为进入单用户模式,root不需要密码就可以登录。(博主太懒,这部分等有心情有时间再来细说吧,也可以自行百度一下,注意centOS 8 和6.几的版本可能方法不太一样)

2、帮助指令

man ls:查看ls命令的帮助信息
help cd:查看cd命令的帮助信息3、文件目录类

3、文件目录类

(1) pwd,ls

pwd //显示当前工作目录的绝对路径
ls [选项] [目录或文件] //查看当前目录下的文件
ls -l //以长列表形式显示
ls -al //显示所有的,包括隐藏的

(2)cdcd [参数]切换到指定目录

绝对路径和相对路径

  • 绝对路径:路径的写法一定是由根目录 / 写起的,例如/usr/local/mysql
  • 相对路径:路径的写法不是由根目录 / 写起的。
    例如:使用相对路径到/root 目录
    这里我们需要知道该用户目录在哪个目录下,才能写出这个指令,假设在/usr/lib,则 cd ../../root, 表示回到当前目录的上一级目录用cd ..

(3)mkdir创建目录,rmdir删除目录

mkdir /home/dog :在home下创建一个dog目录
mkdir -p /home/animal/dog :-p 创建多级目录
rmdir /home/dog:删除目录dog

** rmdir删除的是空目录,有内容的话无法删除,如果需要删除非空目录,需要使用 rm -rf 要删除的目录 **

(4)touch创建文件

touch hello.txt
touch hello1.txt hello2.txt 一次创建两个

(5)cp拷贝(重要)

基本语法:cp [选项] source dest
常用选项 -r :递归复制整个文件夹

案例 1: 将  /home/aaa.txt 拷贝到	/home/bbb 目录下 [拷贝单个文件]
touch aaa.txt
mkdir bbb
cp aaa.txt bbb/    //表示将aaa.txt文件拷贝到当前目录的bbb这个目录下

案例 2: 递归复制整个文件夹,举例:将/home/test 整个目录拷贝到 /home/zwj 目录
cp -r test/ zwj/   //注意当前位置,要准确定位源目录、目标目录
\cp -r test/ zwj/   //会强制覆盖原来的文件,不提示12345678910
tips: 可以通过 上下箭头的键,调出原来使用过的指令

(6)rm删除指令
rm 指令移除【删除】文件或目录

  • 基本语法:rm [选项] 要删除的文件

  • 常用:-r:递归删除整个文件夹, -f:强制删除不提示

  • 举例:

    rm aaa.txt //删除文件
    rm -rf bbb/ //删除目录,递归删除文件夹
    

(7) mv指令

  • 基本语法:mv oldNameFile newNameFile (功能等价于重命名)

  • mv temp/movefile /targetFolder (功能:移动文件)

  • 实例:

    mv aaa.txt bbb.txt //将aaa.txt重命名为bbb.txt
    mv a.txt /root/ //将a.txt移动到/root目录下
    

(8)cat指令
cat查看文件内容,以只读的方式打开

  • 基本语法:cat [选项] 要查看的文件
  • 常用选项:-n 显示行号
  • 实例:
    cat -n /etc/profile | more //分页显示,并显示行号
    ** cat指令只能浏览文件,而不能修改文件,为了浏览方便,一般会带上管道命令 | more **

(9)more和less指令

more 指令是一个基于 VI 编辑器的文本过滤器,它以全屏幕的方式按页显示文本文件的内容。more 指令中内置了若干快捷键。

  • 基本语法:more 要查看的文件

  • 举例:用more查看文件

    more /etc/profile
    空白键:向下翻页
    enter:向下一行
    q:离开more,不显示文件内容
    ctrl+F:向下滚动一屏
    ctrl+B:返回上一屏
    =:输出当前行的行号
    :f :输出文件名和当前行行号
    

less 指令用来分屏查看文件内容,它的功能与 more 指令类似,但是比 more 指令更加强大,支持各种显示终端。less 指令在显示文件内容时,并不是一次将整个文件加载之后才显示,而是根据显示需要加载内容,对于显示大型文件具有较高的效率。

空格:向下翻动一页;
pageup:向上翻动一页;
pagedown:向下翻动一页
/字串:向上搜寻[字串]的功能 n:向下查找 N:向上查找
?字串:向上搜寻[字串]的功能 n:向上查找 N:向下查找
q:离开less程序

(10) >指令和>>指令

> : 输出重定向 : 会将原来的文件的内容覆盖
>> :追加,不会覆盖原来文件的内容,而是追加到文件的尾部
cat 文件 1 > 文件 2 (功能描述:将文件 1 的内容覆盖到文件 2)

写的时候都要注意各种空格

ls -l > a.txt     //ls -l 命令的内容显示到a.txt中(覆盖写,如果a文件不存在则创建一个)
ls -l >> b.txt   //追加显示到b后面
cat /etc/profile > c.txt  //将profile的内容覆盖到c
ls -l /home/ > /home/info.txt ///home下的文件列表写到info里面
cal >> /home/mycal  //将当前日历信息追加到mycal下

(11)echo指令输出内容到控制台

  • 基本语法: echo [选项] [输出内容]

  • 实例:

    echo $PATH //输出$PATH环境变量
    

(12)head和tail指令

head 用于显示文件的开头部分内容,默认情况下 head 指令显示文件的前 10 行内容
基本语法:
①head 文件 (功能描述:查看文件头 10 行内容)
②head -n 5 文件 (功能描述:查看文件头 5 行内容,5 可以是任意行数)

head -n 5 /etc/profile  //查看/etc/profile 的前面 5 行代码

tail 用于输出文件中尾部的内容,默认情况下 tail 指令显示文件的后 10 行内容
基本语法:
①tail 文件 (功能描述:查看文件后 10 行内容)
②tail -n 5 文件 (功能描述:查看文件后 5 行内容,5 可以是任意行数)
③tail -f 文件 (功能描述:实时追踪该文档的所有更新,工作中常用)

在qq.txt末端追加在这里插入图片描述

在Xshell中查看qq.txt立马显示追加后的结果

在这里插入图片描述

(13)ln指令

软链接,也叫符号链接,类似于 windows 里的快捷方式,主要存放了链接其他文件的路径
基本语法:
ln -s [原文件或目录] [软链接名] (功能描述:给原文件创建一个软链接)
举例:把linkToroot软连接到root

[root@localhost root]# rm -rf linkToroot //删除,注意软连接名字后面没有/

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ub3nfXju-1602676199860)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201007162020953.png)]

细节说明:

当使用pwd指令查看目录时,仍然看到的是软连接所在的目录

(14)history指令

查看已经执行过历史命令,也可以执行历史指令
基本语法:
history(功能描述:查看已经执行过历史命令)
history 10 //查看最近用的10个指令
history -c //清空历史指令
!num //num表示某个已执行过的指令 !3(执行三号指令)
4、时间日期类

date 指令-显示当前日期

  • date (功能描述:显示当前时间)

  • date +%Y (功能描述:显示当前年份)

  • date +%m(功能描述:显示当前月份)

  • date +%d (功能描述:显示当前是哪一天)

  • date “+%Y-%m-%d %H:%M:%S”(功能描述:显示年月日时分秒)

    在这里插入图片描述

date 指令-设置日期

date -s "2020-5-10 22:55:00"//修改日期
cal //显示当前日历
5、搜索查找类

(1)find指令
find 指令将从指定目录向下递归地遍历其各个子目录,将满足条件的文件或者目录显示在终端。

  • 基本语法:find 【搜索范围】【选项】
  • 选项说明:
    -name :按照指定文件名查找
    -user:查找属于指定用户名的所有文件
    -size:按指定文件大小查找
find /home -name  hello.txt //搜索范围是/home,找名为hello.txt的文件
find /opt -user nobody  ///opt目录下找用户名为nobody的文件
find / -size +20M  //查找整个系统下>20M的文件(+n大于,-n小于,n等于)
find / -name *.txt /// 目录下,所有.txt文件

(2)locate指令

  • locate 指令可以快速定位文件路径
  • locate 指令利用事先建立的系统中所有文件名称及路径的locate 数据库实现快速定位给定的文件
  • Locate 指令无需遍历整个文件系统,查询速度较快。为了保证查询结果的准确度,管理员必须定期更新 locate 时刻
  • 由于 locate 指令基于数据库进行查询,所以第一次运行前,必须使用 updatedb 指令创建 locate 数据库。
updatedb  //先创建locate的数据库
locate hello.txt 

注意:locate用的是模糊查询

(3)grep指令和管道符号 |
grep 过滤查找 , 管道符,“ | ”,表示将前一个命令的处理结果输出传递给后面的命令处理。

  • 基本语法:grep [选项] 查找内容
  • 常用选项: -n 匹配行号 ,-i 忽略字母大小写
cat hello.txt | grep -n yes //查找yes,显示行号
cat hello.txt | grep -ni yes //忽略大小写,如果有Yes也能查出来
6、压缩和解压缩类

(1)gzip/gunzip

gzip 用于压缩文件, gunzip 用于解压的 (压缩后不会保存原文件,不能压缩文件夹)
gzip 文件 (功能描述:压缩文件,只能将文件压缩为*.gz 文件)
gunzip 文件.gz (功能描述:解压缩文件命令)

gzip hello.txt //会压缩成一个hello.txt.gz的文件在同一目录下
gunzip hello.txt.gz //解压缩1

当使用gzip 对文件进行压缩后,不会保留原来的文件。

(2)zip/unzip

zip 用于压缩文件, unzip 用于解压,在项目打包发布中很有用

  • 基本语法
    ①zip [选项] XXX.zip 将要压缩的内容(功能描述:压缩文件和目录的命令)
    ②unzip [选项] XXX.zip (功能描述:解压缩文件)
  • 常用选项
    ① zip -r :递归压缩,即压缩目录
    ②unzip -d :指定解压后文件的存放目录
zip -r mypackage.zip  /home/  ///home下所有文件压缩到mypackage.zip
unzip -d /opt/tmp/  mypackage.zip  //解压到opt/tmp/

(3)tar

tar 指令 是打包指令,最后打包后的文件是 .tar.gz 的文件。 (可以保留原文件,可以压缩文件夹)

  • 基本语法:
    tar [选项] XXX .tar.gz 打包的内容 (功能描述:打包目录,压缩后的文件格式.tar.gz)
  • 选项说明:
    ①-c:产生 .tar打包文件
    ②-v:显示详细信息
    ③-f:指定压缩后的文件名
    ④-z:打包同时压缩
    ⑤-x:解包 .tar文件
一般打包用-zcvf,解包用-zxvf
tar -zcvf file.tar.gz  a1.txt a2.txt //将a1和a2打包成file.tar.gz
tar -zxvf file.tar.gz //解压
tar -zcvf myhome.tar.gz  /home/   ///home的文件夹压缩成myhome.tar.gz文件
tar -zxvf a.tar.gz 将a.tar.gz解压到当前目录下
tar -zxvf myhome.tar.gz -C /opt/tmp2 将myhome.tar.gz解压到/opt/tmp2下(opt/tmp2目录必须事先创建好)

打包:将一堆文件或目录什么的变成一个总的文件。
压缩:将一个大的文件经过某种压缩算法变成一个小文件。

六、组管理和权限管理

在 linux 中的每个用户必须属于一个组,不能独立于组外。在 linux 中每个文件有所有者、所在组、其它组的概念。

1、所有者、所在组、其他组

(1)文件目录所有者
所有者一般为文件的创建者,谁创建了该文件,就自然的成为该文件的所有者。

ls -ahl //查看文件所有者
#实例:创建一个组 police,再创建一个用户 tom,将 tom 放在 police 组 ,然后使用 tom 来创建一个文件 ok.txt
groupadd police
useradd -g police tom
passwd tom
#设置tom的密码......
touch ok.txt
ls -ahl 

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7tl1TKLg-1602676199866)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201007200808361.png)]

ok.txt的所有者是tom

(2)修改文件所有者

#用root创建一个apple.txt,把所有者修改为tom
touch apple.txt
chown tom apple.txt

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-eMXGwGUa-1602676199867)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201007201348269.png)]

(3)文件/目录 所在组

  • 当某个用户创建了一个文件后,默认这个文件的所在组就是该用户所在的组。

  • 查看文件/目录所在组:ls -ahl //a代表all,h是human

  • 修改文件所在的组: chgrp 组名 文件名:chgrp police apple.txt //把apple这个文件放到police组

  • 除文件的所有者和所在组的用户外,系统的其它用户都是文件的其它组。

    改变用户所在组
    >>在添加用户时,可以指定将该用户添加到哪个组中,同样的用 root 的管理权限可以改变某个用户所在的组。可以用 (id 用户)指令查看。
    usermod –g 组名 用户名
    usermod -g bandit tom //把tom从police组放到bandit组
    

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-frvpOD6b-1602676199868)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201007202431601.png)]

2、修改权限

(1)基本介绍

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fAhhRsW8-1602676199869)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201007203757686.png)]

-rw- r-- r-- tom root xxxx apple.txt
arwx --- --- tom police xxxxx tom
0-9 位说明
1)第 0 位确定文件类型(d, - , l , c , b)
【d:目录  -:普通文件  l:软连接   c:字符设备(键盘鼠标)  b:块文件,硬盘】
2)第 1-3 位确定所有者(该文件的所有者)拥有该文件的权限。---User
3)第 4-6 位确定所属组(同用户组的)拥有该文件的权限,---Group
4)第 7-9 位确定其他用户拥有该文件的权限 ---Other

apple.txt文件中

第0位 ‘ - ’表示是个普通文件,

第1-3位rw- 是指文件所有者有读和写的权限,没有可执行权限(否则是rwx)

第4-6是所在组的其他用户只有读权限

第7-9位r- - 是指其他组的用户只有读的权限。

1:如果是文件,表示硬链接的数,如果是目录则表示该目录下子目录的个数

tom:文件的拥有者

police:文件所在的组

0:文件大小,如果是目录则是4096

10月 7 20:12 :文件的最后修改时间

rwx 作用到文件:
(1) [ r ]代表可读(read): 可以读取,查看
(2) [ w ]代表可写(write): 可以修改,但是不代表可以删除该文件,删除一个文件的前提条件是对该文件所在的目录有写权限,才能删除该文件.
(3) [ x ]代表可执行(execute):可以被执行

rwx作用到目录:
(1) [ r ]代表可读(read): 可以读取,ls 查看目录内容
(2) [ w ]代表可写(write): 可以修改,目录内创建+删除+重命名目录
(3) [ x ]代表可执行(execute):可以进入该目录

案例:

ls -l 中显示的内容如下:
-rwxrw-r--1 root root 1213 Feb 2 09:39 abc
10个字符确定不同用户能对文件干什么
第一个字符代表文件类型:文件(-),目录(d),链接(l)
其余字符每3个一组(rwx)(r)(w) 执行(x)
第一组rwx : 文件拥有者的权限是读、写和执行
第二组rw-: 与文件拥有者同一组的用户的权限是读、写但不能执行
第三组r--: 不与文件拥有者同组的其他用户的权限是读不能写和执行
可用数字表示为: r=4,w=2,x=1 因此rwx=4+2+1=7
1文件:硬连接数或目录:子目录数
root 用户
root 组
1213 文件大小(字节),如果是文件夹,显示4096字节
Feb 2 09:39 最后修改日期
abc 文件名

(2)修改权限

  • 方式一:+,-,=权限变更
u:所有者	  g:所有组	o:其他人	  a:所有人(u、g、o 的总和)
1)	chmod	u=rwx,g=rx,o=x	文件目录名
2)	chmod	o+w	文件目录名  //给其他人加上写的权限
3)	chmod	a-x	文件目录名  //所有人减去可执行的权限
#举例:
# 1)给abc文件的所有者读写执行的权限,给所在组读执行权限,给其它组读执行权限
chmod u=rwx,g=rx,o=rx abc
# 2)给 abc 文件的所有者除去执行的权限,增加所在组写的权限
chmod u-x,g+w abc
# 3)给 abc 文件的所有用户添加读的权限
chmod a+r abc
  • 方式二:通过数字
规则:r=4 w=2 x=1,rwx=4+2+1=7 
chmod u=rwx,g=rx,o=x 文件目录名
相当于: chmod 751 文件目录名
#将 /home/abc.txt 文件的权限修改成rwxr-xr-x, 使用数字的方式实现
chmod 755 /home/abc.txt
3、修改文件所有者和所在组

(1)修改所有者

chown newowner file	//改变文件的所有者
chown newowner:newgroup	file	//改变文件的所有者和所有组
-R	如果是目录 则使其下所有子文件或目录递归生效

#举例
chown tom abc.txt ///home/abc.txt 文件的所有者修改成 tom
chown -R tom kkk/    //将kkk目录下的所有文件,包括子目录和子目录表的文件,递归地修改所有者为tom

(2)修改所在组

chgrp newgroup file //改变文件所有组

#举例:
(1)将 /home/abc.txt 文件的所在组修改成 bandit (土匪)
chgrp bandit /home/abc.txt
(2)将 /home/kkk 目录下所有的文件和目录的所在组都修改成 bandit(土匪) 
chgrp -R bandit /home/kkk/

案例

police ,bandit
jack, jerry: 警察
xh, xq: 土匪
(1)创建组
(2)创建用户
(3) jack 创建一个文件,自己可以读写,本组人可以读,其它组没人任何权限
(4)jack 修改该文件,让其它组人可以读, 本组人可以读写
(5)xh 投靠警察,看看是否可以读写.

1)
[root@hadoop1 home]# groupadd police //创建组
[root@hadoop1 home]# groupadd bandit
2)
[root@hadoop1 home]# useradd -g police jack //将用户添加到指定的组
[root@hadoop1 home]# useradd -g police jerry
[root@hadoop1 home]# useradd -g bandit xh
[root@hadoop1 home]# useradd -g bandit xq
3)
[root@hadoop1 home]# passwd jack //为Jack设置密码
[root@hadoop1 home]# passwd xh //为xh设置密码
4)
[jack@hadoop1 ~]$ touch jack.txt //jack创建文件
[jack@hadoop1 ~]$ chmod u=rw,g=r,o-r jack.txt //设置文件的权限
[jack@hadoop1 ~]$ ls -l
-rw-r-----. 1 jack police 0 10月  8 09:05 jack.txt
5)
[jack@hadoop1 ~]$ chmod u=rw,g=wr,o+r jack.txt //修改文件的权限
[jack@hadoop1 ~]$ ls -l
-rw-rw-r--. 1 jack police 0 10月  8 09:05 jack.txt

[root@hadoop1 home]# usermod -g police xh  //修改xh所在组
[root@hadoop1 home]# id xh
uid=505(xh) gid=502(police) 组=502(police)

drwx------. 4 jack     police   4096 10月  8 09:27 jack
[jack@hadoop1 home]$ chmod g=rx jack //jack开放权限给所在组
drwxr-x---. 4 jack     police   4096 10月  8 09:36 jack

xh注销重新登陆进入jack
[xq@hadoop1 home]$ cd jack/
[xq@hadoop1 jack]$ ll
-rw-rw-r--. 1 jack police 81 10月  8 09:37 jack.txt
就可以读写jack.txt文件了
[xq@hadoop1 jack]$ vim jack.txt
[xq@hadoop1 jack]$ cat jack.txt
I am jack 
我是警察
我是小红
我 Jack 又回来了

七、任务调度crond

  • 任务调度:是指系统在某个时间执行的特定的命令或程序。
  • 任务调度分类:
    1.系统工作:有些重要的工作必须周而复始地执行。如病毒扫描等;
    2.个别用户工作:个别用户可能希望执行某些程序,比如对 mysql 数据库的备份。
    crontab 【选项】
    选项:-e 编辑crontab定时任务, -l 查询crontab任务, -r 删除当前用户所有的crontab任务
#每小时的每分钟执行 ls –l /etc/ > /tmp/to.txt 命令
*/1 * * * * ls –l	/etc/ > /tmp/to.txt
项目含义范围
第一个*一小时当中的第几分钟0-59
第二个*一天当中的第几小时0-23
第三个*一个月当中的第几天1-31
第四个*一年当中的第几个月1-12
第五个*一周当中的星期几0-7(0, 7为星期天 )
特殊符号含义
*任何时间,比如第一个*代表一小时中每分钟都执行
代表不连续的时间,比如“0 8,12,16 * * *”代表每天的8点,12点,16点都执行
-连续的时间范围,比如“0 5 * * 1-6”代表周一到周六的五点0分执行
*/n每隔多久执行一次,比如“*/10 * * * * 命令”代表每隔十分钟执行一次

在这里插入图片描述

#例 1:每隔 1 分钟,就将当前的日期信息,追加到/tmp/mydate 文件中
#1)先编写一个shell文件/home/mytask1.sh 
  date >> /tmp/mydate
#2)给 mytask1.sh  一个可以执行权限
  chmod 744 /home/mytask1.sh
3)crontab -e
4)*/1 * * * *	/home/mytask1.sh

#例 2:每隔1分钟,将当前日期和日历都追加到 /home/mycal 文件中
#1)先编写一个文件 /home/mytask2.sh
date >> /tmp/mycal
cal >> /tmp/mycal
#2)给 mytask1.sh 一个可以执行权限
chmod 744 /home/mytask2.sh
3)crontab -e
4)*/1 * * * * /home/mytask2.sh

八、Linux分区和挂载

1、分区基础知识

分区的方式

  1. mbr分区:
    1.最多支持四个主分区
    2.系统只能安装在主分区
    3.扩展分区要占一个主分区
    4.MBR最大只支持2TB,但拥有最好的兼容性
  2. gtp分区:
    1.支持无限多个主分区(但操作系统可能限制,比如windows下最多128个分区)
    2.最大支持18EB的大容量(1EB=1024 PB,1PB=1024 TB )
    3.windows7 64位以后支持gtp
    在这里插入图片描述

Linux分区

原理介绍
1)Linux来说无论有几个分区,分给哪一目录使用,它归根结底就只有一个根目录,一个独立且唯一的文件结构, Linux中每个分区都是用来组成整个文件系统的一部分。
2)Linux采用了一种叫“载入”的处理方法,它的整个文件系统中包含了一整套的文件和目录,且将一个分区和一个目录联系起来。这时要载入的一个分区将使它的存储空间在一个目录下获得。

3)示意图
在这里插入图片描述

硬盘说明
1)Linux硬盘分IDE硬盘和SCSI硬盘,目前基本上是SCSI硬盘
2)对于IDE硬盘,驱动器标识符为“hdx”,其中“hd”表明分区所在设备的类型,这里是指IDE硬盘了。“x”为盘号(a为基本盘,b为基本从属盘,c为辅助主盘,d为辅助从属盘),“”代表分区,前四个分区用数字1到4表示,它们是主分区或扩展分区,从5开始就是逻辑分区。例,hda3表示为第一个IDE硬盘上的第三个主分区或扩展分区,hdb2表示为第二个IDE硬盘上的第二个主分区或扩展分区。
3)对于SCSI硬盘则标识为“sdx~”,SCSI硬盘是用“sd”来表示分区所在设备的类型的,其余则和IDE硬盘的表示方法一样。

查看所有设备挂载情况
命令:lsblk 或者lsblk -f

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uvXbM7n8-1602676199872)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201008170817312.png)]

2、如何增加一块硬盘

1)虚拟机添加硬盘

在【虚拟机】菜单中,选择【设置】,然后设备列表里添加硬盘,然后一路【下一步】,中间只有选择磁盘大小的地方需要修改,至到完成。然后重启系统(才能识别)!

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qNAjQGH9-1602676199873)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201008173239676.png)]

2)分区

分区命令fdisk /dev/sdb
开始对/sdb分区
•m 显示命令列表
•p 显示磁盘分区同fdisk –l
•n 新增分区
•d 删除分区
•w 写入并退出
说明:开始分区后输入n,新增分区,然后选择p ,分区类型为主分区。两次回车默认剩余全部空间。最后输入w写入分区并退出,若不保存退出输入q。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OA3WDjdi-1602676199874)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201008175238653.png)]

3)格式化

格式化磁盘
分区命令:mkfs -t ext4 /dev/sdb1
其中ext4是分区类型

先执行分区命令:mkfs -t ext4 /dev/sdb1

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WeYbWrCg-1602676199875)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201008175953937.png)]
4)挂载

挂载: 将一个分区与一个目录联系起来,
•mount 设备名称挂载目录
•例如:mount /dev/sdb1 /newdisk
•umount设备名称或者挂载目录
•例如:umount/dev/sdb1 或者umount/newdisk
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kpJqXrrJ-1602676199875)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201008180458812.png)]

5)设置可以自动挂载。
永久挂载: 通过修改/etc/fstab实现挂载
添加完成后执行mount –a 即刻生效
•用命令行挂载重启后会失效

[root@hadoop1 newdisk]# vim /etc/fstab
/dev/sdb1      /home/newdisk           ext4    defaults        0 0
3.磁盘情况查询
df -h
du -h /目录
查询指定目录的磁盘占用情况,默认为当前目录
-s指定目录占用大小汇总
-h 带计量单位
-a 含文件
--max-depth=1 子目录深度
-c 列出明细的同时,增加汇总值

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YyBFIXQF-1602676199876)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201008194329994.png)]
案例

查询/opt 目录的磁盘占用情况,深度为1  
[root@hadoop1 ~]# du -ach --max-depth=1/opt
统计/home文件夹下文件的个数
[root@hadoop1 ~]# ls -l /home | grep "^-"| wc -l
统计/home文件夹下目录的个数
[root@hadoop1 ~]# ls -l /home | grep "^d"| wc -l
统计/home文件夹下文件的个数,包括子文件夹里的
[root@hadoop1 ~]# ls -lR /home | grep "^-"| wc -l
统计文件夹下目录的个数,包括子文件夹里的
[root@hadoop1 ~]# ls -lR /home | grep "^d"| wc -l
以树状显示目录结构
[root@hadoop1 ~]# yum install tree //安装tree指令
[root@hadoop1 ~]# tree /home

九、网络配置

1、查看虚拟网络编辑器

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-V62Cstpo-1602676199877)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201008203250525.png)]

在这里插入图片描述

2、查看网关

在这里插入图片描述

查看windows环境的中VMnet8网络配置(ipconfig指令)

ping 目的主机(功能描述:测试当前服务器是否可以连接目的主机)

3、Linux网络环境配置

第一种方法(自动获取):
说明:登陆后,通过界面的来设置自动获取ip

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BEagzPJz-1602676199878)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201009144843009.png)]

特点:linux启动后会自动获取IP,缺点是每次自动获取的ip地址可能不一样。

第二种方法(指定固定的ip):

直接修改配置文件来指定IP,并可以连接到外网(程序员)

vi /etc/sysconfig/network-scripts/ifcfg-eth0

•ifcfg-eth0文件说明
DEVICE=eth0 #接口名(设备,网卡)
HWADDR=00:0C:2x:6x:0x:xx #MAC地址
TYPE=Ethernet #网络类型(通常是Ethemet)
UUID=926a57ba-92c6-4231-bacb-f27e5e6a9f44 #随机id
#系统启动的时候网络接口是否有效(yes/no)
ONBOOT=yes
# IP的配置方法[none|static|bootp|dhcp](引导时不使用协议|静态分配IP|BOOTP协议|DHCP协议)
BOOTPROTO=static
#IP地址
IPADDR=192.168.184.130
#网关
GATEWAY=192.168.184.2
#域名解析器
DNS1=192.168.184.2
•重启网络服务或者重启系统生效
service network restart 、reboot

十、进程管理

1、进程

(1)进程的介绍

1)在 LINUX 中,每个执行的程序(代码)都称为一个进程。每一个进程都分配一个 ID 号。
2)每一个进程,都会对应一个父进程,而这个父进程可以复制多个子进程。例如 www 服务器。
3)每个进程都可能以两种方式存在的。前台与后台,所谓前台进程就是用户目前的屏幕上可以进行操作的。后台进程则是实际在操作,但由于屏幕上无法看到的进程,通常使用后台方式执行。
4)一般系统的服务都是以后台进程的方式存在,而且都会常驻在系统中。直到关机才才结束。

(2)显示进程的命令

ps -a //显示当前终端的所有进程信息
ps -u //以用户的格式显示进程信息
ps -x //显示后台进程运行的参数

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aq5izS4P-1602676199879)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201009152341081.png)]

ps详解

1)指令:ps –aux|grep xxx 
2)指令说明
•System V展示风格
•USER:用户名称
•PID:进程号
•%CPU:进程占用CPU的百分比
•%MEM:进程占用物理内存的百分比
•VSZ:进程占用的虚拟内存大小(单位:KB)
•RSS:进程占用的物理内存大小(单位:KB)
•TT:终端名称,缩写.
•STAT:进程状态,其中S-睡眠,s-表示该进程是会话的先导进程,N-表示进程拥有比普通优先级更低的优先级,R-正在运行,D-短期等待,Z-僵死进程,T-被跟踪或者被停止等等
•STARTED:进程的启动时间
•TIME:CPU时间,即进程使用CPU的总时间
•COMMAND:启动进程所用的命令和参数,如果过长会被截断显示

应用实例

ps -ef | more //以全格式显示当前所有的进程,查看进程的父进程

在这里插入图片描述

ps -ef是以全格式显示当前所有的进程
•-e 显示所有进程。-f 全格式。
•ps -ef|grep xxx
•是BSD风格
•UID:用户ID
•PID:进程ID
•PPID:父进程ID
•C:CPU用于计算执行优先级的因子。数值越大,表明进程是CPU密集型运算,执行优先级会降低;数值越小,表明进程是I/O密集型运算,执行优先级会提高
•STIME:进程启动的时间
•TTY:完整的终端名称
•TIME:CPU时间
•CMD:启动进程所用的命令和参数

查看sshd进程的父进程号是多少
[root@hadoop1 ~]#  ps -ef |grep sshd

(3)终止进程

若是某个进程执行一半需要停止时,或是已消了很大的系统资源时,此时可以考虑停止该进程。使用 kill 命令来完成此项任务。

kill [选项] 进程号 //通过进程号杀死进程
killall 进程名称 //通过进程名称杀死进程,也支持通配符,这在系统因负载过大而变得很慢时很有用

常用选项:-9  表示强迫进程立即停止
kill -9 2701 //杀死进程号为2678的进程
killall gedit //终止多个gedit 编辑器 【killall通过进程名称来终止进程】

(4)查看进程树

pstree [选项] //可以更直观地来看进程信息
常用选项: -p  显示进程的PID
         -u   显示进程所属用户

2、服务管理

服务(service) 本质就是进程,但是是运行在后台的,通常都会监听某个端口,等待其它程序的请求,比如(mysql , sshd 防火墙等),因此我们又称为守护进程,是 Linux 中非常重要的知识点。
在 CentOS7.0 后 不再使用 service ,而是 systemctl。

(1)服务管理指令

service管理指令:

service 服务名[start | stop | restart | reload | status]

查看服务名:
方式1:使用setup -> 系统服务就可以看到。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jK4esvcE-1602676199881)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201010143521079.png)]

方式2: /etc/init.d/服务名称

服务的运行级别(runlevel):

查看或者修改默认级别:vi /etc/inittab
Linux系统有7种运行级别(runlevel):常用的是级别3和5
•运行级别0:系统停机状态,系统默认运行级别不能设为0,否则不能正常启动
•运行级别1:单用户工作状态,root权限,用于系统维护,禁止远程登陆
•运行级别2:多用户状态(没有NFS),不支持网络
•运行级别3:完全的多用户状态(有NFS),登陆后进入控制台命令行模式
•运行级别4:系统未使用,保留
•运行级别5:X11控制台,登陆后进入图形GUI模式
•运行级别6:系统正常关闭并重启,默认运行级别不能设为6,否则不能正常启动

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rAblOdFt-1602676199882)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201010145544980.png)]

chkconfig指令

•介绍
通过chkconfig 命令可以给每个服务的各个运行级别设置自启动/关闭
•基本语法
1) 查看服务chkconfig --list|grep xxx
2) chkconfig 服务名--list
3) chkconfig --level 5 服务名on/off

在这里插入图片描述

3、动态监控进程
top [选项]
选项说明:
		 -d 秒数  指定top命令每隔几秒更新
         -i 不显示任何闲置或僵尸进程
         -p 通过指定监控进程id来仅仅监控某个进程的状态
交互操作说明:
         P 以cpu使用率排序,默认就是此项
         M 以内存使用率排序
         N 以PID排序
         q 退出top123456789
#案例1:监视特定用户
1、输入top命令,回车,查看执行的进程(输入top看到的是不断动态变化的进程)
2、输入u,回车,再输入用户名即可
(输入u后就看到图中which user那行,然后直接输入用户名)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6bFBOTlu-1602676199885)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201010151501268.png)]

#案例2:终止指定的进程
1、输入top,回车
2、输入k,回车,在输入要终止的进程号

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WOOZZ5j5-1602676199886)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201010151800332.png)]

#案例3:指定系统状态更新的时间(每隔10秒自动更新,默认是3秒)
top -d 10
4、查看系统网络情况
  • 基本语法:netstat [选项] netstat -anp
  • 选项说明: -an 按一定顺序排列输出 -p 显示哪个进程在调用

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4AIRd1Xz-1602676199887)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201010152523273.png)]

请查看服务名为sshd 的服务的信息。
netstat -anp |grep sshd

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-AHPcX7QC-1602676199887)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201010152951868.png)]

十一、RPM与YUM

1、RPM

介绍:
一种用于互联网下载包的打包及安装工具,它包含在某些Linux分发版中。它生成具有.RPM扩展名的文件。RPM是RedHat Package Manager(RedHat软件包管理工具)的缩写,类似windows的setup.exe,这一文件格式名称虽然打上了RedHat的标志,但理念是通用的。
Linux的分发版本都有采用(suse,redhat, centos 等等),可以算是公认的行业标准了。

rpm包的简单查询指令:
查询已安装的rpm列表rpm –qa|grep xx
rpm包名基本格式:
一个rpm包名:firefox-45.0.1-1.el6.centos.x86_64.rpm
名称:firefox
版本号:45.0.1-1
适用操作系统: el6.centos.x86_64
表示centos6.x的64位系统
如果是i686、i386表示32位系统,noarch表示通用。

rpm包的其它查询指令:

rpm -qa :查询所安装的所有rpm软件包
rpm -qa | more
rpm -qa | grep X [rpm -qa | grep firefox ]
rpm -q 软件包名:查询软件包是否安装
rpm -q firefox
rpm -qi 软件包名:查询软件包信息
rpm -qi file
rpm -ql 软件包名:查询软件包中的文件
rpm -ql firefox
rpm -qf 文件全路径名查询文件所属的软件包
rpm -qf /etc/passwd
rpm -qf /root/install.log

卸载rpm包:
•基本语法
rpm -e RPM包的名称
•应用案例
1)删除firefox 软件包
•细节讨论

  1. 如果其它软件包依赖于您要卸载的软件包,卸载时则会产生错误信息。
    如:$ rpm -e foo
    removing these packages would break dependencies:foo is needed by bar-1.0-1
  2. 如果我们就是要删除foo这个rpm 包,可以增加参数–nodeps ,就可以强制删除,但是一般不推荐这样做,因为依赖于该软件包的程序可能无法运行
    如:$ rpm -e --nodeps foo

安装rpm包:
•基本语法
rpm -ivh RPM包全路径名称
•参数说明
i=install 安装
v=verbose 提示
h=hash 进度条

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lWC5ksca-1602676199888)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20201010155909052.png)]

2、YUM

Yum 是一个Shell前端软件包管理器。基于RPM包管理,能够从指定
的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并
且一次安装所有依赖的软件包。前提必须有网。

yum的基本指令
•查询yum服务器是否有需要安装的软件
yum list|grep xx软件列表
•安装指定的yum包
yum install xxx 下载安装

十二、JAVAEE环境搭建

1、JDK的安装
0) 先将软件通过xftp5 上传到/opt 下
1) 解压缩到/opt
2) 配置环境变量的配置文件vim /etc/profile
3) JAVA_HOME=/opt/jdk1.7.0_79
4) PATH=/opt/jdk1.7.0_79/bin:$PATH
5) export JAVA_HOME PATH

测试hello world

1.vim hello.java

2.编写

public class hello{
public static void main(String []args){
System.out.println(“hello world”);
}
} 并保存退出

  1. javac hello.java编译
  2. java hello运行
2、TomCat的安装
1)解压缩到/opt
2)启动tomcat   (./startup.sh)
3)开放端口vim /etc/sysconfig/iptables
-A INPUT -m state --state NEW -m tcp -p tcp --dport 8080 -j ACCEPT
4)开启防火墙
测试是否安装成功:
在windows、Linux 下访问http://linuxip:8080
3、Eclipse的安装
  1. 解压缩到/opt
  2. 启动eclipse,配置jre和server

在eclipse.ini文件里加入

-vm
/home/software/jdk1.8.0_221/bin/
  1. 编写jsp 页面,并测试成功!
4、MySQL的安装

具体过程,请自行百度!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值