手把手教你实现:将后端SpringBoot项目部署到华为云服务器上

前言

前提:有一个后端项目,项目能够运行在本地,可以通过本地访问(localhost)
如果没有可以看这篇:一个基于SpringBoot的后端项目

注册华为云账号

华为云官网

购买云服务器

产品 -> 华为云耀云服务器L实例 或者 ESC弹性云服务器-> 购买
有免费试用的,也有包年的,也有三个月的,具体容量、带宽参数根据自己的需求(挑最便宜的)来定。

配置服务器环境

其实所谓的服务器就是 一台 远程的电脑主机,当你购买后,会给你一个账号和密码,让你通过远程登录去操作这台主机。
我们需要在这台主机上配置好项目运行的基本环境,如 JDK、Mysql数据库等。
然后只需要将项目编译打包成jar文件,并上传布置到 这台主机,运行启动即可。

登录服务器

根据购买提供的账号远程登录云主机。

登录后,你就可以看到一个黑乎乎的屏幕:

配置JAVA SDK 21

先查看云服务器的主机类型,一般来说是购买的云主机都是 Linux操作系统
入口为华为云官网: 控制台 -> 我的资源 ->云服务器

下载Java Sdk 21:
Java JDK 官网
找到和你云主机类型符合的包,比如这个:
在这里插入图片描述
下载后,在云主机上找到,opt文件夹,新建一个文件夹叫jdk, 然后将 下载的JDK上传到这个目录。

解压JDK

输入命令:
进入这个目录

# cd /opt/jdk

查看目录的文件

# ls

解压

# tar -zxvf jdk-21_linux-x64_bin.tar.gz

配置java home路径

# cd /
# vim /etc/profile

按下 键盘 “i” 键, 在后面新增以下内容:
(注意这个 JAVA_HOME是否和你JDK解压路径一致)

export JAVA_HOME=/opt/jdk/jdk-21export PATH=$JAVA_HOME/bin:$PATHexport CLASSPATH=.:$JAVAHOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar

按下 键盘 “ESC” 键,然后输入 :wq 回车。

:wq

输入 java -version 看是否配置成功

# source /etc/profile
# java -version

在这里插入图片描述

配置Mysql

配置mysql会遇到很多坑,先打个预防针,各种数据库问题都可能遇到,同时Mysql 8.0的sql语法也有所变化。

下载Mysql

Mysql 官网

根据你所购买的云主机,选择合适的型号:

上传到指定目录 /opt/mysql

在opt文件夹中,单击右键新建文件夹 mysql, 然后上传刚下载的mysql包。

解压 mysql

# cd /opt/mysql
# ls
# tar -xf mysql-server_8.1.0-1ubuntu22.04_amd64.deb-bundle.tar

安装libmecab2包

这个包有些云主机会没有导致,mysql安装失败。

# cd /
# sudo apt-get update
# sudo apt-get install libmecab2

安装 Mysql 包

# cd /opt/mysql
# ls

你可以看到解压后的mysql有很多个 .deb类型的包。
我们需要安装以下4个包:

libmysqlclient22_8.1.0-1ubuntu22.04_amd64.deb
mysql-common_8.1.0-1ubuntu22.04_amd64.deb
mysql-server_8.1.0-1ubuntu22.04_amd64.deb
mysql-client_8.1.0-1ubuntu22.04_amd64.deb

但是,由于这4个包还会有依赖包,所以安装上面几个包时,他会提示你要先安装依赖包
所以以下依赖包也是需要安装的。

mysql-community-client_8.1.0-1ubuntu22.04_amd64.deb
mysql-community-client-core_8.1.0-1ubuntu22.04_amd64.deb
mysql-community-client-plugins_8.1.0-1ubuntu22.04_amd64.debmysql-community-server_8.1.0-1ubuntu22.04_amd64.deb
mysql-community-server-core_8.1.0-1ubuntu22.04_amd64.deb

安装命令

# sudo dpkg -i 文件名.deb

输入命令,回车后,它会有安装是否成功提示,如果出现依赖缺少,它是会提示你的,那你请先安装它所提示的包。
所有包都安装成功后,查看是否可以工作。

# mysql -V

在这里插入图片描述

修改mysql端口号

# cd /etc/mysql/mysql.conf.d
# vim mysqld.cnf

按下 键盘 “i” 键, 在[mysqld]标签下面新增以下内容:

port = 3308

在这里插入图片描述

按下 键盘“ESC” ,输入 :wq退出

:wq

端口号未必就要3308,可以自己定义,主要目的是为了避免mysql默认端口号3306被占用导致mysql访问不了的问题。

启动mysql

# cd /
# service mysqld start
# service mysqld status

如果你看到这个,说明你的Mysql启动成功了。
在这里插入图片描述

创建新用户

# mysql -u root -p
# 在输入密码地方,直接回车

在这里插入图片描述
sql语句不区分大小写,用大写还是小写看你个人习惯。

> CREATE USER '用户名'@'%' IDENTIFIED BY '密码';

查看目前所有的mysql用户账号

> SELECT user,host FROM mysql.user;

在这里插入图片描述

授予新用户远程访问的权限

如果上面👆 root账号的 host 为 localhost, 你需要先执行

> update user set host='%' where user='root';

授予远程权限

> GRANT ALL PRIVILEGES ON *.* TO '新用户名'@'%' WITH GRANT OPTION;
> flush privileges;

根据你的后端项目建立数据库、建立表、测试

建立数据库

> create DATABASE 数据库名;
> use 数据库名;

建立表
【字段名 类型 不为空 默认值 】按照这个顺序
【PRIVARY KEY】修饰的字段为key
【UNIQUE KEY】修饰的字段为key且为唯一的key。

> create TABLE 表名(uid INT NOT NULL auto_increment,字段名 CHAR(10) NOT NULL,字段名 VARCHAR(50) NOT NULL,字段名 INT DEFAULT 0,UNIQUE KEY (uid)
)ENGINE = INNODB;

往表中添加数据以及查询数据:

> insert into 表名(字段名,字段名....) values(字段值,字段值,字段值);
> select * from 表名;

远程连接mysql

退出数据库操作模式

> exit;

修改mysql配置文件

# cd /etc/mysql/mysql.conf.d
# vim mysqld.cnf

按下 键盘 “i” 键, 在[mysqld]标签下面新增以下内容:

bind-address    = xx.xx.xx.xx(华为云服务器分配的公网IP地址)

在这里插入图片描述
输入完成后,按“ESC”键,输入 :wq 保存退出。

华为云服务器分配的公网IP地址入口在:
华为云控制台 -> 我的资源 -> 云服务器

开放远程端口

华为云控制台 -> 我的资源 -> 云服务器 -> 安全组 -> 入方向规则 ->添加规则

  1. 添加 8080端口(你Sprig Boot项目启动时的端口,如果Spring Boot项目没有设置,默认是8080)
  2. 添加 3308端口 (你Mysql 刚才设置的端口,默认是 3306)
    在这里插入图片描述

测试远程连接是否成功

下载 Mysql WorkBench, 官网地址
安装完成应用后,打开应用
新建连接 -> 输入Mysql数据库远程地址、端口号、用户名、密码

如果连接成功,继续往下走,否则需要去看一下连接不上的原因,查看mysql配置文件是否开放了远程连接,远程连接地址是否正确,以及华为云安全组是否开放了 端口号。

修改Spring Boot项目关于Mysql的连接配置

在这里插入图片描述

编译后端项目为jar文件

如果你的后端项目使用Gradle管理的,编译方法如下:
gradle 打包 springboot项目
如果你的后端项目使用maven管理的,编译方法如下:
maven 打包 springboot项目

上传项目jar文件到云服务器

在根目录新建一个文件夹,命名为projects, 然后单击右键上传文件。
上传成功后,运行项目。

# cd /
# cd /projects
# nohup java -jar 项目编译.jar > spring.log &

运行日志,你就可以在 /projects/spring.log 双击文件中看到了
在这里插入图片描述

最后

最后就是你正常访问你的后端项目API了。
比如我的:

接口域名:http://124.71.83.237:8080
接口路径:/register
请求方式:POST
请求体参数:
{"name": "xxxxx","phoneNumber": "1858346xxxx""password": "xxxxxx"
}
返回结构:
{"code": 200,"message": "操作成功","data": []
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/142224.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python+requests+unittest+excel实现接口自动化测试框架

一、框架结构: 工程目录 二、Case文件设计 三、基础包 base 3.1 封装get/post请求(runmethon.py) 1 import requests2 import json3 class RunMethod:4 def post_main(self,url,data,headerNone):5 res None6 if heade…

paddle2.3-基于联邦学习实现FedAVg算法

目录 1. 联邦学习介绍 2. 实验流程 3. 数据加载 4. 模型构建 5. 数据采样函数 6. 模型训练 1. 联邦学习介绍 联邦学习是一种分布式机器学习方法,中心节点为server(服务器),各分支节点为本地的client(设备&#…

【乳腺超声、乳腺钼靶、宫颈癌】等项目数据调研,及相关参考内容整理汇总

一、乳腺超声内容整理 1.1、数据集 Breast Ultrasound Images Dataset;下载地址2STU-Hospital处理和训练参考文档:https://blog.csdn.net/weixin_51511389/article/details/127594654 1.2、可以参考的论文 AAU-net: An Adaptive Attention U-net for Breast Lesions Segmen…

京东获得JD商品详情 API 返回值说明

京东商品详情API接口可以获得JD商品详情原数据。 这个API接口有两种参数,公共参数和请求参数。 公共参数有以下几个: apikey:这是您自己的API密钥,可以在京东开发者中心获取。 请求参数有以下几个: num_iid&#…

LeetCode01

LeetCode01 两数之和 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和 为目标值 target 的那两个整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。 你…

【神印王座】悲啸洞穴之物揭晓,圣采儿差点被骗,幸好龙皓晨聪明

Hello,小伙伴们,我是小郑继续为大家深度解析神印王座。 神印王座动漫现阶段已经出到龙皓晨等人接取新任务深入魔族地界的阶段,而龙皓晨等人接取的任务想必现在大家都知道了,那就是探索魔族地界中的悲啸洞穴。但是大家知道悲啸洞穴里面藏着什么…

软件测试:全链路追踪工具 Zipkin导入、安装(Windows版本)

1.0全链路追踪技术出现的原因 公司内部一个功能的实现,底层可能调用多个应用系统 在调用这个功能的同时,可能会出现多种情况,比如访问较慢,出现错误,可能需要进行定位 所以,我们需要快速定位服务错误点 大…

基于SSM的办公用品管理系统设计与实现

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:采用JSP技术开发 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目&#x…

Docker(三)、Dockerfile探究

Dockerfile探究 一、镜像层概念1、通过执行命令显化docker的机制 二、Dockerfile基础命令1、FROM 基于基准镜像【即构建镜像的时候,依托原有镜像做拓展】2、LABEL & MAINTAINER -说明信息3、WORKDIR 设置工作目录4、ADD & COPY 复制文件5、ENV 设置环境常量…

Ceph存储部署

这里写自定义目录标题 一、Ceph概述二、Ceph的组件三、架构四、安装步骤一、环境部署二、修改ssh配置三、hosts文件修改四、ssh免密配置五、时间同步六、格式化磁盘七、后续的操作暂时都在centos1执行 五、成功将ceph配置完成 前言:后续配置的解释可能标题不是很清晰…

【前端】零基础快速搞定JavaScript核心知识点

文章目录 1.初识JavaScript1.1.JavaScript语言简介1.2.JavaScript引入方式和注释1.3.Javascript变量声明详解1.4.JavaScript变量提升详解 2.JavaScript基础数据类型2.1.JavaScript基础数据类型简介2.2.基础类型数据-Number2.3.基础类型数据-String2.4.基础类型数据-Boolean2.5.…

HarmonyOS 4.0 实况窗上线!支付宝实现医疗场景智能提醒

本文转载自支付宝体验科技,作者是蚂蚁集团客户端工程师博欢,介绍了支付宝如何基于 HarmonyOS 4.0 实况窗实现医疗场景履约智能提醒。 1.话题背景 8 月 4 日,华为在 HDC(华为 2023 开发者大会)上推出了新版本操作系统…

一文教你学会ArcGIS Pro地图设计与制图系列全流程(2)

ArcGIS Pro做的成果图及系列文章目录: 系列文章全集: 《一文教你学会ArcGIS Pro地图设计与制图系列全流程(1)》《一文教你学会ArcGIS Pro地图设计与制图系列全流程(2)》《一文教你学会ArcGIS Pro地图设计与…

jupyterlab开发环境最佳构建方式

文章目录 背景jupyterlab环境构建运行虚拟环境构建以及kernel映射验证总结 背景 从jupyter notebook切换到了jupyter lab. 这里记录一下本地环境的最佳构建方式. jupyter lab 安装在jupyterlab-local的anaconda 虚拟环境中.建立多个其他虚拟环境安装各种python包实现环境隔离,…

【实战详解】如何快速搭建接口自动化测试框架?Python + Requests

摘要: 本文主要介绍如何使用Python语言和Requests库进行接口自动化测试,并提供详细的代码示例和操作步骤。希望能对读者有所启发和帮助。 前言 随着移动互联网的快速发展,越来越多的应用程序采用Web API(也称为RESTful API&…

python 探索分形世界|曼德布洛特|np.frompyfunc()

文章目录 分形的重要特征曼德布洛特集合曼德布洛特集合有一个以证明的结论:图像展示np.ogrid[]np.frompyfunc()集合转图像 julia集合 无边的奇迹源自简单规则的无限重复 ---- 分形之父Benoit B.Mandelbrot 分形的重要特征 自相似性无标度性非线性 曼德布洛特集合…

8+单基因+细胞凋亡+WGCNA+单细胞+实验验证

今天给同学们分享一篇单基因细胞凋亡WGCNA实验验证的生信文章“RASGRP2 is a potential immune-related biomarker and regulates mitochondrial-dependent apoptosis in lung adenocarcinoma”,这篇文章于2023年2月3日发表在Front Immunol期刊上,影响因…

订阅《复现SCI文章系列教程》

写在前面 《小杜生信笔记》准备开启新的订阅专栏**《复现期刊文章系列教程》,本专栏小杜会寻找一些自己感兴趣的文章进行复现(不说百分之百的复现,但是也会百分之八十进行复现)。本期刊的教程代码会全部进行公开(通过订…

孙哥Spring源码第26集

第26集、AnnotationAwareAspectJAutoProxyCreator源码 【视频来源于:B站up主孙帅suns Spring源码视频】【微信号:suns45】 26.1、postProcessAfterInitialization分析 26.2、wrapIfNecessary分析 26.3、createProxy分析 26.4、getProxy 26.5、BeanPost…

Deep Span Representations for Named Entity Recognition

原文链接: https://aclanthology.org/2023.findings-acl.672.pdf ACL 2023 介绍 问题 作者认为,一个好的span表征对于NER任务是非常重要的,而之前的工作都是将第一个或最后一个的表征简单的进行组合后,没有进行充分的交互就送入到…