Linux 基础
1、Linux简介
1.1、不同应用领域的主流操作系统:
▶️ 桌面操作系统
- Windows(用户数量最多)
- Mac OS(操作体验好)
- Linux(用户数量少)
▶️ 服务器操作系统
- UNIX(安全、稳定、付费)
- Linux(安全、稳定、免费、占有率高)
- Windows Server(付费、占有率低)
▶️ 移动设备操作系统
- Android(基于Linux、开源,主要用于智能手机、平板电脑和智能电视)
- IOS(苹果公司开发、不开源,用于苹果公司产品,例如:iPhone、iPad)
▶️ 嵌入式操作系统
- Linux(机顶盒、路由器、交换机)
1.2、Linux系统历史
- 时间:1991年
- 地点:芬兰赫尔辛基大学
- 人物:Linus Torvalds(21岁)
- 语言:C语言、汇编语言
- logo:企鹅
- 特点:免费、开源、多用户、多任务
1.3、Linux系统版本
Linux系统分为内核版和发行版
- 内核版
- 由 Linus Torvalds及其团队开发、维护
- 免费、开源
- 负责控制硬件
- 发行版
- 基于 Linux 内核版进行扩展
- 由各个 Linux 厂商开发、维护
- 有收费版本和付费版本
1.4、Linux发行版
Linux系统发行版:
- Ubuntu:以桌面端为主
- RedHat:应用最广泛、收费
- CentOS:RedHat的社区版、免费
- openSUSE:对个人完全免费、图形界面华丽
- Fedora:功能完备、快速更新、免费
- 红旗Linux:北京中科红旗软件技术有限公司开发
2、Linux安装
1.1、安装方式
- 物理机安装:直接将操作系统安装到服务器硬件上
- 虚拟机安装:通过虚拟机软件安装
虚拟机(Virtual Machine):
指通过软件模拟的具有完整硬件系统功能、运行在完全隔离环境中的完整计算机系统
常用虚拟机软件:
- VMWare
- VirtualBox
- VMLite WorkStation
- Qemu
- HopeddotVOS
1.2、网卡设置
由于启动服务器时未加载网卡,导致IP地址初始化失败
修改网络初始化配置,设定网卡在系统启动时初始化
步骤 | 说明 |
---|---|
cd / | 进入根目录 |
cd etc | 进入 etc 目录 |
cd sysconfig | 进入 sysconfig 目录 |
cd network-scripts | 进入 network-scripts |
vi ifcfg-ens33 | 编辑 ifcfg-ens33 文件 |
1.3、SSH连接工具
SSH(Secure Shell),建立在应用层基础上的安全协议
常用 SSH 的连接工具
-
putty
-
secureCRT
-
xshell
-
finalshell
1.4、Linux 和 Windows 目录结构对比
Linux 系统中的目录
-
/ 是所有目录的顶点
-
目录结构就像一稞倒挂的树
1.5、Linux 目录介绍
- bin 存放二进制可执行文件
- boot 存放系统引导时使用的各种文件
- dev 存放设备文件
- etc 存放系统配置文件
- home 存放系统用户的文件
- lib 存放程序运行所需的共享库和内核模式
- opt 额外安装的可选应用程序包所放置的文字
- root 超级用户目录
- sbin 存在二进制可执行文件,只有 root 用户才能访问
- tmp 存放零四文件
- usr 存放系统应用程序
- var 存放运行时需要改变数据的文件,例如日志文件
3、Linux常用命令
3.1、Linux命令初体验
命令 | 对应英文 | 作用 |
---|---|---|
ls | list | 查看当前目录下的内容 |
pwd | print work directory | 查看当前所在目录 |
cd [目录名] | change directory | 切换目录 |
touch [文件名] | touch | 如果文件不存在,新建文件 |
mkdir [目录名] | make directory | 创建目录 |
rm [文件名] | remove | 删除指定文件 |
注意:
在执行Linux命令时,提示信息如果显示为乱码,这是由于编码问题导致的,只需要修改Linux的编码即可,命令如下
echo 'LANG="en_US.UTF-8"' >> /etc/profile
source /etc/profile
使用技巧
- Tab 键自动补全
- 连续两次 Tab 键,给出操作提示
- 使用上下箭头快速调出曾经执行的命令
- 使用
clear
命令或者ctrl + l
快捷键实现快速清屏
Linux命令格式
command [-options] [parameter]
说明:
command
:命令[-options]
:选项,可用来对命令进行控制,也可以省略[parameter]
:传给命令的参数,可以是零个,一个或多个
注意:
[]
代表可选命令名、选项、参数之间有空格进行分隔
3.2、文件目录操作命令
1️⃣ ls
作用:显示指定目录下的内容
语法:ls [-al] [dir]
说明:
-a
:显示所有文件及目录(.
开头的隐藏文件也会列出)-l
:除文件名称外,同时将文件状态(d
表示目录,-
表示文件)、权限、拥有者、文件大小等信息详细列出
注意:
由于我们使用
ls
命令时经常需要加入-l
选项,所以 Linux 为ls -l
命令提供了一种简写方式,即ll
2️⃣ cd
作用:用于切换当前工作目录,即进入指定目录
语法:cd [dirName]
特殊说明:
~
:表示用户的 home 目录.
:表示当前所在的目录..
:表示当前目录位置的上级目录
3️⃣ cat
作用:用于显示文件内容
语法:cat [-n] fileName
说明:
-n
:由1开始对所有输出的行数编号
4️⃣ more
作用:以分页的形式显示文件内容
语法:more fileName
操作说明:
- 回车键 向下滚动一行
- 空格键 向下滚动一屏
b
返回上一屏q
或者ctrl + c
退出more
5️⃣ tail
作用:查看文件末尾的内容
语法:tail [-f] fileName
说明:
-f
:动态读取文件末尾内容并显示,通常用于日志文件的内容输出
6️⃣ mkdir
作用:创建目录
语法:mkdir [-p] dirName
说明:
-p
:确保目录名称存在,不在就创建一个。通过此选项,可以实现多层目录同时创建
7️⃣ rmdir
作用:删除空白目录
语法:rmdir [-p] fileName
说明:
-p
:当子目录被删除后使父目录为空目录的话,则一并删除
8️⃣ rm
作用:删除文件或者目录
语法:rm [-rf] name
说明:
-r
:将目录及目录中所有文件(目录)逐一删除,即递归删除-f
:无需确认,直接删除
3.3、拷贝移动命令
1️⃣ cp
作用:用于复制文件或目录
语法:cp [-r] source dest
说明:
-f
:如果复制的是目录需要使用此选项,此时将复制该目录下所有的子目录和文件
2️⃣ mv
作用:为文件或目录改名、或将文件或目录移动到其他位置
语法:mv source dest
3.4、打包压缩命令 - tar
作用:对文件进行打包、解包、压缩、解压
语法:tar [-zcxvf] fileName [files]
包文件后缀为 .tar
表示只是完成了打包,并没有压缩
包文件后缀为 .tar.gz
表示完成了打包同时还进行了压缩
说明:
-z
:z 代表的是gzip
,通过 gzip,通过gzip命令处理文件,gzip可以对文件压缩或者解压-c
:c 代表的是create
,即创建新的包文件-X
:x 代表的是extract
,实现从包文件中还原文件-v
:v 代表的是verbose
,显示命令的执行过程-f
:f 代表的是file
,用于指定包文件的名称
举例:
打包
tar -cvf demo.tar ./*
:将当前目录下所有的文件打包,打包后的文件名为 demo.tartar -zcvf demo.tar.gz ./*
:将当前目录下所有文件打包并压缩,打包后的文件名未 demo.tar.gz
解包
-
tar -xvf demo.tar
:将 demo.tar 文件进行解包,并将解包后的文件放在当前目录 -
tar -zxvf demo.tar.gz
:将 demo.tar.gz 文件进行解压,并将解压后的文件放在当前目录 -
tar -zxvf demo.tar.gz -C /usr/local
:将 demo.tar.gz 文件进行解压,并将解压后的文件放在 /usr/local 目录
3.5、文本编辑 - vi/vim
1️⃣ vi
作用:vi 命令是 Linux 系统提供的一个文本编辑工具,可以对文件内容进行编辑,类似于 Windows 中的记事本
语法:vi fileName
说明:
1、vim 是从 vi 发展来的一个功能更加强大的文本编辑工具,在编辑文件时可以对文本内容进行着色,方便我们对文件进行编辑处理,所以实际工作中 vim 更加常用
2、要使用 vim 命令,需要我们自己完成安装。可以使用下面的命令完成安装:
yum install vim
2️⃣ vim
作用:对文件内容进行编辑,vim其实就是一个文本编辑器
语法:vim fileName
说明:
1、在使用 vim 命令编辑文件时,如果指定的文件存在则直接打开此文件。如果指定的文件不存在则新建文件。
2、vim 在进行文本编辑时共分为三种模式,分别是命令模式(Command mode),插入模式(Inster mode),底行模式(Last line mode)。这三种模式之间可以相互切换。我们在使用 vim 时一定要注意我们当前所处的时哪种模式。
针对 vim 中断三种模式说明如下:
1、命令模式
- 命令模式下可以查看文件内容、移动光标(上下左右箭头、gg、G)
- 通过 vim 命令打开文件后,默认进入命令模式
- 另外两种模式需要首先进入命令模式,才能进入彼此
2、插入模式
- 插入模式下可以对文件内容进行编辑
- 在命令模式下按下 【 i, a, o 】任意一个,可以进入插入模式。进入插入模式后,下方会出现 【inster】字样
- 在插入模式下按下 ESC 键,回到命令模式
3、底行模式
-
底行模式下可以通过命令对文件内容进行查找、显示行号、退出等操作
-
在命令模式下按下【 : , / 】任意一个,可以进入底行模式
-
通过
/
方式进入底行模式后,可以对文件内容进行查找 -
通过
:
方式进入底行模式后,可以输入wq
(退出并保存)、q!
(不保存退出)、set nu
(显示行号)
3.6、查找命令
1️⃣ find
作用:在指定目录下查找文件
语法:find dirName -option fileName
举例:
find . -name "*.java"
在当前目录及其子目录下查找.java
结尾的文件find /demo -name "*.java"
在demo目录及其子目录下查找.java
结尾的文件
2️⃣ grep
作用:从指定文件中查找指定的文本内容
语法:grep word fileName
4、Linux软件安装
4.1、软件安装方式
-
二进制发布包安装
软件已经针对具体平台编译打包发布,只要解压,修改配置即可
-
rpm安装
软件已经安装
redhat
的包安装管理规范进行打包,使用rpm
命令进行安装,不能执行解决库依赖问题 -
yum安装
一种在线软件安装方式,本质上还是
rpm
安装,自动下载安装包并安装,安装过程中自动解决库依赖问题 -
源码编译安装
软件以源码工程的形式发布,需要自己编译打包
4.2、安装JDK
操作步骤:
-
将 JDK 的二进制发布包上传到 Linux
-
解压安装包
tar -zxvf jdk-8u171-linux-x64.tar.gz -C /usr/localta
-
配置环境变量,使用 vim 命令修改
/etc/profile
文件,在文件末尾加入如下配置JAVA_HOME=/usr/local/jdk1.8.0_171 PATH=$JAVA_HOME/bin:$PATH
-
重新加载
profile
文件,使更改的配置立即生效,命令为source /etc/profile
-
检查安装是否成功,命令为
java -version
4.3、安装Tomcat
操作步骤:
-
将 Tomcat 的二进制发布包上传到 Linux
-
解压安装包,命令为
tar -zxvf apache-tomcat-7.0.57.tar.gz -C /usr/local
-
进入 Tomcat 的 bin 安装目录启动服务,命令为
sh startup.sh # 或者 ./startup.sh
验证Tomcat启动是否成功,有多种方式:
-
查看启动日志
more /usr/local/apache-tomcat-7.0.57/logs/catalina.out tail -50 /usr/local/apache-tomcat-7.0.57/logs/catalina.out
-
查看进程
ps -ef|grep tomcat
注意:
ps
命令是Linux下非常强大的进程查看命令,通过ps -ef
可以查看当前运行的所有进程的详细信息- “
|
” 在Linux中称为管道符,可以将前一个命令的输出结果输出给后一个命令作为输入- 使用 ps 命令查看进程时,经常配合管道符和查找命令 grep 一起使用,来查看特定进程
停止Tomcat服务的方式:
-
运行Tomcat的bin目录中提供的停止服务的脚本文件
sh shutdown.sh # 或者 ./shoutdown.sh
-
结束Tomcat进程
查看Tomcat进程,获得进程id
ps -ef | grep tomcat
执行命令结束进程
kill -9 tomcat进程id
注意:
kill
命令是 Linux 提供的用于结束进程的命令,-9
表示强制结束
4.4、安装MySQL
1、检测当前系统中是否安装了MySQL数据库
rpm -qa # 查询当前系统中安装的所有软件
rpm -qa | grep mysql # 查询当前系统中安装的名称带mysql的软件
rpm -qa |grep mariadb # 查询当前系统中安装的名称带mariadb的软件
RPM(Red-Hat Package Manager)RPM软件包管理器,是红帽Linux用于管理和安装软件的工具
注意:
如果当前系统中已经安装有MySQL数据库,安装将失败。CentOS7自带mariadb,与MySQL数据库冲突
2、卸载已经安装的冲突软件
rpm -e --nodeps 软件名称 卸载软件
rpm -e --nodeps mariadb-libs-5.5.60-1.el7_5.x86_64
3、将MySQL安装包上传到Linux并解压
mkdir /usr/local/mysql
tar -zxvf mysql-5.7.25-1.el7.x86.rpm-bundle.tar.gz -C /usr/local/mysql
说明:解压后得到6个rpm的安装包文件
4、按照顺序安装rpm软件包
rpm -ivh mysql-community-community-common-5.7.25-1.el7.x86_64.rpm
rpm -ivh mysql-community-libs-5.7.25-1.el7.x86.rpm
rpm -ivh mysql-community-devel-5.7.25-1.el7.x86_64.rpm
rpm -ivh mysql-community-libs-compat-5.7.25-1.el7.x86_64.rpm
rpm -ivh mysql-community-client-5.7.25-1.el7.x86_64.rpm
yum install net-tools
rpm -ivh mysql-community-server-5.7.25-1.el7.x86_64.rpm
说明1:安装过程中提示缺少net-tools依赖,使用yum安装
说明2:可以通过指令升级现有软件及系统内核
yum update
5、启动MySQL
systemctl status mysqld # 查看mysql服务状态
systemctl start mysqld # 启动mysql服务
说明:可以设置开机时启动mysql服务,避免每次开机启动mysql
systemctl enable mysqld # 开机启动mysql服务
netstat -tunlp # 查看已经启动的服务
netstat -tunlp | grep mysql
ps -ef | grep mysql # 查看mysql进程
6、登录MySQL数据库,查阅临时命令
cat /var/log/mysql.log # 查看文件内容
cat /var/log/mysqld | grep password # 查看文件内容中包含password的行信息
注意事项
冒号后面的是密码,注意空格
7、登录MySQL,修改密码,开发访问权限
mysql -uroot -p # 登录mysql(使用临时密码登录)
# 修改密码
set global validate_password_length=4; # 设置密码长度最低位数
set global validate_password_policy=LOW; # 设置密码安全等级低,便于密码可以修改成root
set password=password('root'); # 设置密码为 root
# 开放访问权限
grant all on *.*to 'root'@'%' identified by 'root';
flush privileges;
4.5、安装lrzsz
操作步骤:
1、搜索 lrzsz
安装包,命令为
yum list lrzsz
2、使用 ym 命令在线安装,命令为
yum install lrzsz.x86_64
注意事项:
Yum(全称为 Yellow dog Updater, Modified)是一个在 Fedora 和 RedHat 以及 CentOS 中的 Shell 前端软件包管理器。基于 RPM 包管理,能够从指定的服务器自动下载 RPM 包并且安装,可以自动处理依赖关系,并且以此安装所有依赖的软件包,无需繁琐地一次次下载、安装。
4.6、Linux防火墙
-
查看防火墙状态
systemctl status firewalld firewall-cmd --state
-
暂时关闭防火墙
systectl stop firewalld
-
永久关闭防火墙
systectl disable firewalld
-
开启防火墙
systectl start firewalld
-
开放指定端口
firewall-cmd --zone=public --add-port=8080/tcp --permanent
-
关闭指定端口
firewall-cmd --zone=public --remove-port=8080/tcp --permanent
-
立即生效
firewall-cmd --reload
-
查看开放的端口
firewall-cmd --zone=public --list-ports
注意:
1、
systemctl
时管理 Linux 中服务的命令,可以对服务进行启动、停止、重启、查看状态等操作2、
firewall-cmd
是 Linux 中专门用于控制防火墙的命令3、为了保证系统安全,服务器的防火墙不建议关闭
5、项目部署
5.1、手工部署项目
1、在IDEA中开发 SpringBoot 项目并打包成 jar 包
2、将 jar 包上传到 Linux 服务器
mkdir /usr/local/app # 创建目录,将项目jar包放到此目录
3、启动 SpringBoot 程序
java -jar jarName.jar # jarName 为项目打包后的jar包名称
4、检查防火墙,确保项目端口对外开放,访问SpringBoot项目
firewall-cmd --zone=public --list-ports # 查看开放的所有端口
5、如果项目端口没有对外开放,则开放指定端口
firewall-cmd --zone=public --add-port=8080/tcp --permanent # 8080为当前项目的访问端口
6、改为后台运行 SpringBoot 程序,并将日志输出到日志文件
目前程序运行的问题:
- 线上程序不会采用控制台霸屏的形式运行程序,二十将程序在后台运行
- 线上程序不会将日志输出到控制台,而是输出到日志文件,方便运维查询信息
nohup 命令: 英文全称 no hang up (不挂起),用于不挂断地运行指定命令,退出终端不会影响程序的运行
语法格式: nohup Command [arg ...] [&]
参数说明:
Commmand: 要执行的命令
Arg: 一些参数,可以指定输出文件
&: 让命令在后台运行
举例:
# 后台运行 java -jar 命令,并将日志输出到 myboot.log 文件
nohup java -jar boot工程.jar &> myboot.log &
7、停止SpringBoot程序
查询SpringBoot项目进程ID
ps -ef | grep 'java -jar'
结束SpringBoot项目进程
kill -9 boot项目进程ID
5.2、通过Shell脚本自动部署项目
操作步骤:
- 在 Linux 中安装 Git
- 在 Linux 中安装 Maven
- 编写 Shell 脚本(拉去代码、编译、打包、启动)
- 为用户授予执行 Shell 脚本的权限
- 执行 Shell 脚本
1、在Linux中安装Git
yum list git # 列出Git安装包
yum install git # 在线安装Git
2、使用Git克隆代码
cd /usr/local/
# 克隆代码
git clone git仓库地址
3、在Linux中安装Maven
将Mavne安装包上传到Linux中,在Linux中安装Maven
tar -zxvf apache-maven-3.5.4-bin.tar.gz -C /usr/local
vim /etc/profile # 修改配置文件,加入以下内容
export MAVEN_HOME=/usr/local/apache-maven-3.5.4
export PATH=$JAVA_HOME/bin:$MAVEN_HOME/bin:$PATH # PATH=$JAVA_HOME/bin:$PATH 要放最后
source /etc/profile
mvn -version # 检查maven是否安装成功
vim /usr/local/apache-maven-3.5.4/conf/settings.xml # 修改配置文件内容如下
<localRepository>/usr/local/repo</localRepository>
4、将Shell脚本复制到Linux服务器
Shell 脚本(shell script)是一种 LInux 系统中的脚本文件
使用Shell脚本编程跟JavaScript、Java编程一样,只要有一个能编写代码的文本编辑器和一个能解释执行的脚本解释器就可以了。
#!/bin/sh
echo =================================
echo 自动化部署脚本启动
echo =================================
echo 停止原来运行中的工程
APP_NAME=helloword
tpid=`ps -ef|grep $APP_NAME|grep -v grep|grep -v kill|awk '{print $2}'`
if [ ${tpid} ]; then
echo 'Stop Process...'
kill -15 $tpid
fi
sleep 2
tpid=`ps -ef|grep $APP_NAME|grep -v grep|grep -v kill|awk '{print $2}'`
if [ ${tpid} ]; then
echo 'Kill Process!'
kill -9 $tpid
else
echo 'Stop Success!'
fi
echo 准备从Git仓库拉取最新代码
cd /usr/local/helloword
echo 开始从Git仓库拉取最新代码
git pull
echo 代码拉取完成
echo 开始打包
output=`mvn clean package -Dmaven.test.skip=true`
cd target
echo 启动项目
nohup java -jar helloword-0.0.1-SNAPSHOT.jar &> helloword.log &
echo 项目启动完成
5、为用户授权
chmod
(英语全拼:change mode )命令时控制用户对文件的权限的命令
Linux 中的权限分为:读(r)、写执行(w)、执行(x)三种权限
Linux 的文件调用者权限分为三级:文件所有者(Owner)、用户组(Group)、其他用户(Other Users)
只有文件的所有者和超级用户可以修改文件或目录的权限
要执行 Shell 脚本需要有对此脚本文件的执行权限,如果没有则不能执行
chmod命令可以使用八进制数来指定权限
# | 权限 | rwx |
---|---|---|
7 | 读 + 写 + 执行 | rwx |
6 | 读 + 写 | rw- |
5 | 读 + 执行 | r-x |
4 | 只读 | r-- |
3 | 写 + 执行 | -wx |
2 | 只写 | -w- |
1 | 只执行 | --x |
0 | 无 | --- |
举例:
chmod 777 bootStart.sh
为所有用户授予读、写、执行权限chmod 755 bootStart.sh
为文件拥有者授予读、写、执行权限,同组用户和其他用户授予读、执行权限chmod 210 bootStart.sh
为文件拥有者授予写权限,同组用户授予执行权限,其他用户没有任何权限
注意:
三位数字分别代表不同用户的权限
- 第一位代表文件拥有者的权限
- 第二位代表同组用户的权限
- 第三位表示其他用户的权限
6、设置静态IP
修改文件 /etc/sysconfig/network-scripts/ifcfg-ens33
,内容如下:
7、重启网络服务
执行以下命令重启网络服务
systemctl restart network
注意:
重启完网络服务后,IP地址以及发生了变化,此时
FinalShell
已经连接不上Linux系统,需要将创建一个行连接才能连接到Linux
脚本需要有对此脚本文件的执行权限,如果没有则不能执行
[外链图片转存中…(img-RUti4OrE-1653558339234)]
chmod命令可以使用八进制数来指定权限
# | 权限 | rwx |
---|---|---|
7 | 读 + 写 + 执行 | rwx |
6 | 读 + 写 | rw- |
5 | 读 + 执行 | r-x |
4 | 只读 | r-- |
3 | 写 + 执行 | -wx |
2 | 只写 | -w- |
1 | 只执行 | --x |
0 | 无 | --- |
举例:
chmod 777 bootStart.sh
为所有用户授予读、写、执行权限chmod 755 bootStart.sh
为文件拥有者授予读、写、执行权限,同组用户和其他用户授予读、执行权限chmod 210 bootStart.sh
为文件拥有者授予写权限,同组用户授予执行权限,其他用户没有任何权限
注意:
三位数字分别代表不同用户的权限
- 第一位代表文件拥有者的权限
- 第二位代表同组用户的权限
- 第三位表示其他用户的权限
6、设置静态IP
修改文件 /etc/sysconfig/network-scripts/ifcfg-ens33
,内容如下:
[外链图片转存中…(img-QeTkZvA3-1653558339235)]
7、重启网络服务
执行以下命令重启网络服务
systemctl restart network
注意:
重启完网络服务后,IP地址以及发生了变化,此时
FinalShell
已经连接不上Linux系统,需要将创建一个行连接才能连接到Linux