大家好,上一篇我们学习了如何《购买一台云服务器》,本篇文章在上一篇文章的基础上我们来学习Linux,主要是要熟练掌握Linux基础命令
和windows操作系统类似,Linux是一套开源性能稳定的多用户网络操作系统,是一种免费使用和自由传播的[类UNIX]操作系统,其内核由林纳斯·本纳第克特·托瓦兹于1991年10月5日首次发布,它主要受到Minix和Unix思想的启发,是一个基于POSIX的多用户、多任务、支持多线程和多CPU的操作系统。
在企业中我们通常在Window系统中使用IDEA开发项目,然后使用Linux部署项目。Linux相对于Windows更可靠,安全性、稳定性能其安全性相比其他系统也要安全很多
由于Linux开源所以很多组织基于开源的Linux衍生出很多的分支版本
(使用Red Hat(红帽子)的软件库管理系统):
(package manager for Debian):
Debian 很多公司在用,基于ubuntu(乌班图);
Ubuntu 基于debian的发行版,比较最受欢迎的免费操作系统,界面强大。比较适合个人用户;
Pear os 基于Ubuntu,仿macos;
红旗Linux,真正的国产linux系统,2014年公司解散后被收购

我们上一章节采购的云服务器的操作系统就是选择的centos7系列。后续也会使用centos给大家讲解项目的部署。
linux的目录跟window有所区别,windows中有盘符的概念,c盘,d盘等,而在linux中是以目录存储文件而且只有一个根目录
在Linux有个基本思想:一切都是文件。就是系统中的所有都可以归结为一个文件,包括命令、硬件和软件设备、操作系统、进程等等对于操作系统内核而言,都被视为拥有各自特性或类型的文件。而这些文件是以一定的结构组织的;
linux系统的目录结构是一个以/(根目录)为根节点的树形结构:
这里我百度了一张centos目录结构图(偷个懒~)

大家可以挑几个比较重要的目录去记一下,下面这几个常用
执行命令 : cd / , 然后执行 ls 查看根目录内容:


cd 目录名 :进入指定目录
cd .. :退回上一级
cd ~ : 切到用户 home目录

ls –a :列出所有文件和文件夹,包含隐藏文件
ls -al :以详细信息方式列出所有文件信息,包含隐藏文件
ls -l :以详细信息方式列出文件信息 , 可以简写成: ll , 如下:

第一个字母表示文件类型
| 第一个字母 | 所代表的权限字母 |
|---|---|
| ”-” | 普通文件 |
| ”d” | 目录,字母”d”,是dirtectory(目录)的缩写 |
| “l” | 符号链接。请注意,一个目录或者说一个文件夹是一个特殊文件,这个特殊文件存放的是其他文件和文件夹的相关信息 |
| “b” | 块设备文件 |
| “c” | 字符设备文件 |
第一个栏位,表示文件的属性。Linux的文件基本上分为三个属性:
| 字母 | 文件属性 |
|---|---|
| r | 可读 |
| w | 可写 |
| x | 可执行 |
紧接着的3*3个字符分3组,各指示此文件的读、写、执行权限,对于owner、group、others而言。
find / --name "文件名"
whereis java 
相对路径和绝对路径
/ 代表根目录,凡是最左边是一个 /代表绝对路径,即从根目录开始
./ 代表当前目录
../ 表示上一级目录
mkdir -p /a/b/c
强制删除文件或者目录 ,该命令慎用,切记乱删除东西。


将dir1复制一份到dir2目录(包含目录内容一起复制) : cp -rf dir1 dir2
直接复制内容(非常重要) : cp -rf dir1/* dir2



参数
-c 创建一个新的tar文件
-t 参看压缩文件内容
-v 显示运行过程信息
-j 调用bzip2压缩命令执行压缩
-f 指定文件名称
-C 指定需要解压到的目录
-z 调用gzip压缩命令执行压缩
-x 解开tar文件



编辑一个文本:vi a.txt -> 按 i 进入insert模式 -> 编辑内容 -> esc 退出编辑 -> :wq -> 保存退出/ :q! 强制退出。

:w //保存文件
:w vpser.net //保存至vpser.net文件
:q //退出编辑器,如果文件已修改请使用下面的命令 ,q(quit)
:q! //退出编辑器,且不保存
:wq //退出编辑器,且保存文件
注意:按i(insert)进入编辑,按Ctrl + C 强制退出编辑,退出编辑并保存输入按 :wq
Linux系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。
用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另一方面也可以帮助用户组织文件,并为用户提供安全性保护。
添加新的用户账号使用useradd命令,其语法 : useradd 选项 用户名 ,参数说明
-c comment 指定一段注释性描述。
-d 目录 指定用户主目录,如果此目录不存在,则同时使用-m选项,可以创建主目录。
-g 用户组 指定用户所属的用户组。
-G 用户组,用户组 指定用户所属的附加组。
-s Shell文件 指定用户的登录Shell。
-u 用户号 指定用户的用户号,如果同时有-o选项,则可以重复使用其他用户的标识号。
添加用户
useradd –d /home/sam -m sam
此命令创建了一个用户sam,其中-d和-m选项用来为登录名sam产生一个主目录 /home/sam(/home为默认的用户主目录所在的父目录)。
删除帐号 : userdel 选项 用户名 , 常用的选项是 -r,它的作用是把用户的主目录一起删除。例如:
# userdel -r sam
此命令删除用户sam在系统文件中(主要是/etc/passwd, /etc/shadow, /etc/group等)的记录,同时删除用户的主目录。
每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux 系统对用户组的规定有所不同,如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。
用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。
增加一个新的用户组使用groupadd命令。其格式如下 : groupadd 选项 用户组 ,可以使用的选项有:
groupadd group1
此命令向系统中增加了一个新组group1,新组的组标识号是在当前已有的最大组标识号的基础上加1。
如果要删除一个已有的用户组,使用groupdel命令 : groupdel 用户组
groupdel group1
此命令从系统中删除组group1。
Linux系统中的每个文件和目录都有访问许可权限,用他来确定谁能通过何种方式对文件和目录进行访问和操作。 我们通过 ll 命令可以查看目录下的文件权限,如下

从上面图中可以看到,权限部分有10位,可以分为4段来解读
注:u表示所有者(user);g表示所属组(group);o表示其他人(other);a便是所有人(all)

修改权限可以使用 字母和数字的方式,通过 chmod 来修改, 格式:chmod u/g/o/a +/-/= rwx 文件
| [ u/g/o/a ] | 含义 |
|---|---|
| u | user 表示该文件的所有者 |
| g | group 表示与该文件的所有者属于同一组( group )者,即用户组 |
| o | other 表示其他以外的人 |
| a | all 表示这三者皆是 |
| [ ±= ] | 含义 |
|---|---|
| + | 增加权限 |
| - | 撤销权限 |
| = | 设定权限 |
| rwx | 含义 |
|---|---|
| r | read 表示可读取,对于一个目录,如果没有r权限,那么就意味着不能通过ls查看这个目录的内容。 |
| w | write 表示可写入,对于一个目录,如果没有w权限,那么就意味着不能在目录下创建新的文件。 |
| x | excute 表示可执行,对于一个目录,如果没有x权限,那么就意味着不能通过cd进入这个目录。 |
数字法:“rwx” 这些权限也可以用数字来代替
| 字母 | 说明 |
|---|---|
| r | 读取权限,数字代号为 “4” |
| w | 写入权限,数字代号为 “2” |
| x | 执行权限,数字代号为 “1” |
| - | 不具任何权限,数字代号为 “0” |
| 7 | 读 + 写 + 执行 | rwx | 111 |
|---|---|---|---|
| 6 | 读 + 写 | rw- | 110 |
| 5 | 读 + 执行 | r-x | 101 |
| 4 | 只读 | r– | 100 |
| 3 | 写 + 执行 | -wx | 011 |
| 2 | 只写 | -w- | 010 |
| 1 | 只执行 | –x | 001 |
| 0 | 无 | — | 000 |
例如, 765 将这样解释:
如执行:chmod u=rwx,g=rx,o=r filename 就等同于:chmod u=7,g=5,o=4 filename
案例:修改/test下的aaa.txt的权限为 属主 有全部权限,属主所在的 组 有读写权限,
chmod u=rwx,g=rw,o=r aaa.txt
案例:将文件 file1.txt 设为所有人皆可读取 :
chmod ugo+r file1.txt
案例:将文件 file1.txt 设为所有人皆可读取 :
chmod a+r file1.txt
案例:将文件 file1.txt 与 file2.txt 设为该文件拥有者,与其所属同一个群体者可写入,但其他以外的人则不可写入 :
chmod ug+w,o-w file1.txt file2.txt
案例:为 ex1.py 文件拥有者增加可执行权限:
chmod u+x ex1.py
案例:将目前目录下的所有文件与子目录皆设为任何人可读取 :
chmod -R a+r *
案例:此外chmod也可以用数字来表示权限如 :
chmod 777 file
防火墙具备一些有效的隔离功能,能够对经过防火墙的网络包按照一定的规则进行检查,从而控制网络包的进入进出,以达到限制网络访问的一些目的。
当centos中安装了有端口的软件,如果外网需要访问该端就需要做防火墙的端口放行。
systemctl stop firewalld.service
firewall-cmd --zone=public --add-port=1935/tcp --permanent
firewall-cmd --zone=public --remove-port=5672/tcp --permanent
这种方式拿到的是软件的源码包,需要自行 make 进行编译,然后 install 安装。同时make命令需要有gcc的环境。
先安装环境,以Redis为例:https://my.oschina.net/liuyuantao/blog/915785
特点:这种安装方式,软件包会自动配置jdk的环境变量,不用手动配置。也是最方便快捷的一种方式
命令:
rpm -qa 软件名称 :查询软件是否被安装
rpm -ivh 软件包路径 需要安装的包文件 : rpm –ivh xxx.rpm
rpm -e --nodeps 需要卸载的软件包 : 卸载软件(–nodeps 忽略依赖关系并继续操作)
rpm -qa | grep 查询名称 :利用管道模糊查询软件安装情况:
例如: rpm -qa | grep java 检测系统自带的jdk安装包
参数说明:rpm [选项] [参数]
-a:查询所有软件包
-e:删除指定的软件包
-f<文件>:查询拥有指定文件的套件;
-h或-–hash:显示进度信息 ,以#显示进度
-i:显示包的详细信息
-i<软件包>或-–install<软件包>:安装指定的软件包
-l:显示包的文件列表
-p:查询指定的RPM包
-q:使用询问模式
-U<软件包>或-–upgrade<软件包>:升级指定的程序包
-v:显示指令执行详细过程
-vv:详细显示指令执行过程,便于排错
以Java为例,第一步下载Java :https://www.oracle.com/java/technologies/downloads/

然后通过ftp工具上传下载号的安装包到linux

最后使用rpm 安装java
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Bw3tHAG8-1666709883023)(课件图片/1635998829923.png)]](https://1000bd.com/contentImg/2024/05/23/4a0491b9552eebf8.png)
这种方式是在线安装,自动下载需要安装的软件,同时自动安装软件所依赖的其他软件,如果yum仓库中没有要安装的软件需要更换或者添加 “yum仓库" 。
特点:将所有软件包放到官方服务器上,当进行yum在线安装时,可以自动解决依赖性问题;
缺点:安装过程中,rpm包依赖性太强;
比如要安装Git,只需要执行 yum install git
yum命令:
yum list --查询所有可用软件包列表
yum search 关键字 --搜索服务器上所有和关键字相关的包
yum -y install 包名 (-y 自动回答yes)
yum安装只写包名即可! eg:yum -y install gcc --c语言编译器
升级:yum -y update 包名 : -y自动回答yes
卸载:yum -y remove 包名
文章就写到这里把,如果对你有帮助请给个好评~~~