项目部署(Linux)
本文最后更新于34 天前,其中的信息可能已经过时,如有错误请发送邮件到big_fw@foxmail.com

1.安装VMware

在我们的课程资料中提供了VMware的安装程序。找到课程资料中的 Vmware的安装包(exe文件),然后双击下一步下一步的安装即可。

备注:如果之前安装过,就不用安装了。不要卸载!!!! 不要卸载!!!! 不要卸载!!!!

安装步骤:

以上就是VMware在安装时的每一步操作,基本上就是点击 “下一步” 一直进行安装。

2.挂载Linux系统

1). 打开Vmware虚拟机,打开 编辑 -> 虚拟网络编辑器(N)...

选择 NAT模式,然后选择右下角的 更改设置

设置子网IP为 192.168.100.0,然后选择 应用 -> 确定

2). 解压 资料/Linux镜像/CentOS7-1.zip 到一个比较大的磁盘中 (没有中文的目录)。

3). 打开解压目录,双击 .vmx 文件,选择以 Vmware Workstation 打开这个文件。

4). 挂载完毕之后,启动Linux服务器。

启动过程中,如果出现如下界面,选择 我已移动该虚拟机

5). 启动完毕之后,登录服务器。 输入用户名:root,密码:1234(注意:linux系统输入密码是不显示的,输入完毕,回车即可登录)

3.安装SSH连接工具

4.SSH连接工具介绍

Linux已经安装并且配置好了,接下来我们要来学习Linux的基本操作指令。而在学习之前,我们还需要做一件事情,由于我们企业开发时,Linux服务器一般都是在远程的机房部署的,我们要操作服务器,不会每次都跑到远程的机房里面操作,而是会直接通过SSH连接工具进行连接操作。

SSH(Secure Shell),建立在应用层基础上的安全协议。常用的SSH连接工具:

1)FinalShell安装

在课程资料中,提供了finalShell的安装包(“资料/03. 远程连接工具”)。

双击.exe文件,然后进行正常的安装即可。

2)连接Linux

  • 打开FinalShell,选择SSH连接。
  • 连接服务器,输入服务器的信息,IP固定的:192.168.100.128,用户名:root,密码:1234
  • 配置完毕后,双击即可连接服务器。
  1. 目录结构

登录到Linux系统之后,我们需要先来熟悉一下Linux的目录结构。在Linux系统中,也是存在目录的概念的,但是Linux的目录结构和Windows的目录结构是存在比较多的差异的 在Windows目录下,是一个一个的盘符(C盘、D盘、E盘),目录是归属于某一个盘符的。Linux系统中的目录有以下特点:

  • / 是所有目录的顶点
  • 目录结构像一颗倒挂的树

Linux 和 Windows的目录结构对比:

Linux的目录结构,如下:

软件安装

1.软件安装方式

在Linux系统中,安装软件的方式主要有四种,这四种安装方式的特点如下:

  1. 安装JDK

上述我们介绍了Linux系统软件安装的四种形式,接下来我们就通过第一种(二进制发布包)形式来安装JDK。 JDK对应的二进制发布包,在课程资料中已经提供,如下:

JDK具体安装步骤如下:

1). 上传安装包

使用FinalShell自带的上传工具将jdk的二进制发布包上传到Linux

由于上述在进行文件上传时,选择的上传目录 /root,上传完毕后,我们执行指令 cd /root 切换到根目录下,查看上传的安装包。

2). 解压安装包

执行如下指令,将上传上来的压缩包进行解压,并通过-C参数指定解压文件存放目录为 /usr/local。

tar -zxvf jdk-21_linux-x64_bin.tar.gz -C /usr/local/

3). 配置环境变量

使用vim命令修改/etc/profile文件,在文件末尾加入如下配置

export JAVA_HOME=/usr/local/jdk-17.0.10export PATH=$JAVA_HOME/bin:$PATH

具体操作指令如下:

1). 编辑/etc/profile文件,进入命令模式
    vim /etc/profile

2). 在命令模式中,输入指令 G , 切换到文件最后
    G

3). 在命令模式中输入 i/a/o 进入插入模式,然后切换到文件最后一行
    i

4). 将上述的配置拷贝到文件中
    export JAVA_HOME=/usr/local/jdk-17.0.10    export PATH=$JAVA_HOME/bin:$PATH
        
5). 从插入模式,切换到指令模式
    ESC
        
6). 按:进入底行模式,然后输入wq,回车保存
    :wq

4). 重新加载profile文件

为了使更改的配置立即生效,需要重新加载profile文件,执行命令:

source /etc/profile

5). 检查安装是否成功

java -version
  1. MySQL安装

对于MySQL数据库的安装,我们将要使用前面讲解的第一种安装方式进行安装。

1). 准备工作

在安装MySQL数据库之前,我们需要先检查一下当前Linux系统中,是否安装的有MySQL的相关服务(很多linux安装完毕之后,自带了低版本的mysql的依赖包),如果有,先需要卸载掉,然后再进行安装。

A. 通过rpm相关指令,来查询当前系统中是否存在已安装的mysql软件包,执行指令如下:

  • rpm -qa 查询当前系统中安装的所有软件
  • rpm -qa | grep mysql 查询当前系统中安装的名称带mysql的软件
  • rpm -qa | grep mariadb 查询当前系统中安装的名称带mariadb的软件

通过rpm -qa 查询到系统通过rpm安装的所有软件,太多了,不方便查看,所以我们可以通过管道符 | 配合着grep进行过滤查询。

通过查询,我们发现在当前系统中存在mariadb数据库,是CentOS7中自带的,而这个数据库和MySQL数据库是冲突的,所以要想保证MySQL成功安装,需要卸载mariadb数据库。

RPM:全称为 Red-Hat Package Manager,RPM软件包管理器,是红帽Linux用于管理和安装软件的工具。

B. 通过 rpm 相关指令,来卸载对应的组件,执行指令如下:

在rpm中,卸载软件的语法为:rpm -e --nodeps 软件名称

那么,我们就可以通过指令,卸载 mariadb,具体指令为: rpm -e --nodeps mariadb-libs-5.5.60-1.el7_5.x86_64

我们看到执行完毕之后, 再次查询 mariadb,就查不到了,因为已经被成功卸载了。

2). 将资料中提供的MySQL安装包上传到Linux并解压

A. 上传MySQL安装包

在课程资料中,提供的有MySQL的安装包 ,我们需要将该安装包上传到Linux系统的根目录 /root 下面。

B. 解压到 当前目录

执行如下指令:

tar -xvf mysql-8.0.30-linux-glibc2.12-x86_64.tar.xz

C. 将解压后的文件夹移动到 /usr/local 目录下, 并改名为 mysql

mv mysql-8.0.30-linux-glibc2.12-x86_64 /usr/local/mysqlcd /usr/local/mysql

3). 配置系统环境变量

配置MySQL的环境变量, 通过vi编辑器编辑 /etc/profile 文件, 在尾部追加:

export MYSQL_HOME=/usr/local/mysqlexport PATH=$MYSQL_HOME/bin:$PATH

并执行如下指令, 注册MySQL为系统服务:

cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqlchkconfig --add mysql

5). 初始化数据库

#创建一个用户组, 组名就叫mysqlgroupadd mysql#创建一个系统用户 mysql, 并归属于用户组 mysql useradd -r -g mysql -s /bin/false mysql
#初始化mysqlmysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

执行上述指令时, 会输入如下日志,在日志中就输出了MySQL中root用户的一个临时密码【记得复制出来,记录下来】:

  1. 启动MySQL

A. 启动MySQL服务

systemctl start mysql

B. 通过命令, 登录MySQL

#xxxxx 代表上述生成的root的临时密码mysql -uroot -pxxxxx
  1. 配置MySQL

A. 修改root用户的密码

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '1234';

注意: 这个root账号仅仅能够在本机localhost上访问,我们在windows上是无法访问的。如果需要在window上或其他服务器上也能远程访问,需要创建一个账号,用于远程访问的。

B. 创建账号, 并授权远程访问

CREATE USER 'root'@'%' IDENTIFIED BY '1234';

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%';

FLUSH PRIVILEGES;

我们已经开启了MySQL的远程访问的权限,为什么还是连接不上MySQL服务器呢?? 这是因为Linux系统的防火墙,将我们的访问拦截了。

  1. 防火墙操作

Linux系统安装完毕后,系统启动时,防火墙自动启动,防火墙拦截了所有端口的访问。接下来我们就需要学习一下,如何操作防火墙,具体指令如下:

操作指令备注
查看防火墙状态systemctl status firewalld / firewall-cmd –state
暂时关闭防火墙systemctl stop firewalld
永久关闭防火墙(禁用开机自启)systemctl disable firewalld下次启动,才生效
暂时开启防火墙systemctl start firewalld
永久开启防火墙(启用开机自启)systemctl enable 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

注意: 要想在windows上能够访问MySQL,需要开放防火墙的3306端口 或者 直接关闭防火墙 ,执行如下指令:

#开发防火墙的3306端口号firewall-cmd --zone=public --add-port=3306/tcp --permanent#重新加载firewall-cmd --reload#查看开放的端口号firewall-cmd --zone=public --list-ports

或者直接关闭防火墙:

systemctl stop firewalld
  1. 连接测试

关闭掉linux系统的防火墙之后,我们就可以打开windows上的命令行,通过mysql的客户端(命令行/图形化界面)来连接远程linux上安装的MySQL数据库了。

1). 客户端连接

2). 打开DataGrip图形化工具连接

执行资料中提供的SQL脚本 tlias.sql

  1. 安装Nginx
  2. 安装

Nginx的安装包,从官方下载下来的是c语言的源码包,我们需要自己编译安装。具体操作步骤如下:

1). 安装Nginx运行时需要的依赖

yum install -y pcre pcre-devel zlib zlib-devel openssl openssl-devel

安装C语言的编译环境.

yum install gcc-c++

2). 上传Nginx的源码包

3). 解压源码包到当前目录

tar -zxvf nginx-1.20.2.tar.gz

4). 进入到解压目录后,执行指令

#进入解压目录cd nginx-1.20.2#执行命令配置, 生成Makefile文件./configure --prefix=/usr/local/nginx

5). 执行命令进行编译和安装

#编译make#编译安装make install
  1. 启动Nginx

进入到nginx安装目录/usr/local/nginx,启动nginx服务

cd /usr/local/nginx/sbin/nginx

启动完毕之后,我们可以通过 ps 指令查询当前系统中的nginx进程,从而确认nginx是否启动 。

然后,我们就可以打开浏览器,访问服务器上的nginx 。

  1. 项目部署
  2. 前端项目部署

1). 将nginx的安装目录的html中的静态资源文件先删除掉。

2). 将资料中提供的 “资料/06. 项目部署/前端/页面资源” 目录下的静态资源文件,全部上传到nginx安装目录下的 html 目录中.

3). 修改资料中提供的 nginx.conf 配置文件,将其上传到nginx安装目录下的 conf 目录中.

4). 重新加载nginx服务的配置文件

#重新加载配置文件sbin/nginx -s reload

5). 再次访问nginx (可能会存在浏览器缓存, 可以按Ctrl+F5, 强制刷新清理缓存)

nginx服务常见操作指令:

  • 启动: sbin/nginx
  • 重载: sbin/nginx -s reload
  • 停止: sbin/nginx -s stop
  1. 后端项目部署

之前我们讲解Linux操作系统时,就提到,我们服务端开发工程师学习Linux系统的目的就是将来我们开发的项目绝大部分情况下都需要部署在Linux系统中。

  1. 环境准备

那现在,项目要上线了,要部署到linux服务器上了,我们也需要使用linux服务器上所安装的mysql数据库。

那此时,我们就可以再准备一份文件 application.yml 将里面的配置的mysql的ip地址及相关配置信息修改一下(配置Linux上安装的MySQL的信息):

#配置数据库连接信息
spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://192.168.100.128:3306/tlias
    username: root
    password: 1234
  servlet:
    multipart:
      max-file-size: 10MB #单个文件最大大小限制10MBmax-request-size: 100MB #单个请求最大大小限制100MB#配置mybatis的日志输出到控制台
mybatis:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
    #配置mybatis的驼峰命名的映射开关map-underscore-to-camel-case: true
#查看事务管理的日志
logging:
  level:
    org.springframework.jdbc.support.JdbcTransactionManager: debug

#阿里云oss配置
aliyun:
  oss:
    endpoint: https://oss-cn-beijing.aliyuncs.com
    bucketName: java422-web-ai

改造完毕之后,可以在本地的idea中先启动当前项目,然后访问一下,看看工程是否正常访问。

  1. 打包部署

1). 执行 package 指令,进行打包操作,将当前的springboot项目,打成一个jar包。 (跳过测试)

2). 在Linux服务器上创建一个目录,将jar包上传到服务器 。

mkdir -p /usr/local/app

3). 通过java命令,启动项目

#进入目录/usr/local/app cd /usr/local/app#运行jar包java -jar tlias-web-management-0.0.1-SNAPSHOT.jar

项目启动起来之后,就可以打开浏览器测试啦。

  1. 阿里云OSS秘钥配置

由于在开发的时候,我们将访问阿里云OSS的AccessKeyId,AccessKeySecret都配置在了系统的环境变量中了。那现在项目部署到了Linux服务器中,调用阿里云OSS进行文件上传时,程序就会获取Linux系统中的环境变量。所以此时,我们需要将AccessKeyId,AccessKeySecret配置为Linux系统的环境变量。

1). 查看Windows系统之前配置的环境变量

echo %OSS_ACCESS_KEY_ID%echo %OSS_ACCESS_KEY_SECRET%

我们将上述自己的 AccessKeyId 与 AccessKeySecret 复制出来,然后在linux系统中配置环境变量。

2). 执行如下指令:

nohup命令说明:

  • nohup命令:英文全称 no hang up(不挂起),用于不挂断地运行指定命令,退出终端不会影响程序的运行
  • 语法格式:nohup command [ args … ] [&]
  • 参数说明:
    • command:要执行的命令
    • args:一些参数,可以指定输出文件
    • &:让命令在后台运行
  • 举例:
    • nohup java -jar boot工程.jar &> hello.log &

上述指令的含义为: 后台运行 java -jar 命令,并将日志输出到hello.log文件

文末附加内容
暂无评论

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇