使用【宝塔+docker】在云服务器上部署基于SpringBoot 和 Dubbo RPC 的项目:踩坑记录

待部署的项目包括:前端front,服务提供者backend,服务消费者gateway,注册中心nacos
服务器信息:腾讯云入门级服务器2核2G(后续有对服务器进行升级)
部署工具:前端使用宝塔部署,消费者和服务者使用打包jar的方式部署,其他后端项目使用docker部署
基于rpc框架项目的部署相对于只有一个后端程序的项目部署会要复杂很多,博主在这里踩了很多坑,耗费了很多时间,本篇博客记录下一些大大小小的坑,希望对读者有所帮助~

nacos部署

  • 在部署nacos之前需要先部署java jdk 和 maven环境
  • 先把服务器上自带的javaopenjdk全部删除
  • 按照本地环境的jdk版本下载linux的jdk,并且配置好java的环境变量
  • 直接把linux版本的nacos解压到服务器上即可,注意版本要和项目中的版本一致
  • sh startup.sh -m standalone 单机运行nacos,此时只会显示正在starting,但是不会本地一样打印出详细的启动信息,具体的启动信息在nacos/logs/start.out里面

在这里插入图片描述

  • 如果报内存不够无法启动的错误,可以调整startup.sh里面的jvm内存,具体看自己的服务器调小一点:JAVA_OPT=“${JAVA_OPT} -Xms512m -Xmx512m -Xmn256m”
  • 如果是报其他错误,可以指定一下startup.sh里面的 JAVA_HOME为刚刚装的jdk(因为宝塔在添加站点的时候会要求再装一个Tomcat和jdk)
  • 如果日志里面显示正常启动,但是无法在自己的电脑上访问nacos主页,需要检查一下application.yml里面配置的address: nacos://ip:8848是不是外网的ip,然后按照外网ip访问主页:http://外网ip:8848/nacos/。如果是顺利启动会很快访问到主页,如果一直在nacos页面上转圈加载说明肯定启动有问题,检查日志中是不是有错误

在这里插入图片描述

  • 如果显示无法访问,检查防火墙是不是开放了端口,注意有两层防火墙,一个是直接在腾讯云设置的防火墙规则,一个是服务器自己的防火墙服务。端口要开齐,9848 9849,8848等

在这里插入图片描述

提供者部署(backend)

  • 注意把application.yml中的数据库信息和nacos地址修改为服务器的外网信息
  • 把client-sdk项目中的网关地址改外外网地址,重新打包client-sdk和backend
  • 把打包好的backend jar包传到服务器上直接java -jar运行 (先确保nacos能正确启动再运行backend项目)
  • 如果有问题的话注意观察日志

在这里插入图片描述

消费者部署(gateway)

  • 修改gateway中的白名单以及interface_host,打包成jar之后传到服务器

  • 先启动naocs,再启动backend,确保正确之后启动gateway

  • 此时发现gateway一直启动错误,日志显示客户端无法连接,dubbo实例创建失败(在这一步上花了很多时间!)
    在这里插入图片描述

  • 启动gateway失败之后,我尝试关闭nacos,先ps -ef | grep nacos查看nacos的运行状态,此时显示有一条nacos项目,我便判断nacos是正常运行的,然后使用sh shutdown.sh关闭nacos,但是却显示目前没有正在运行的nacos

  • 此时我恍然大悟,重新开启nacos,再启动backend,检查到此时是可以运行sh shutdown.sh成功,说明backend启动之后nacos正常,随后启动gateway,发现此时使用sh shutdown.sh已经会提示没有运行的nacos了,说明在启动gateway的过程中,nacos挂掉了。

  • 回到宝塔面板主页,显示内存已经爆红了。我再一次尝试调整startup.sh里面的jvm内存,不过调小了之后连backend都启动不了,显然问题出在了硬件上

  • 我实在是太贫穷了,贪小便宜买了2G的服务器,加了200块钱升到了4G,里面就启动成功了

  • 果然,钱能解决大部分问题!

前端部署

  • 安装工作:
    • 在服务器上安装宝塔
    • 在宝塔上安装Tomcat(为了装java),Nginx, Mysql,docker
    • 安装完毕之后停止tomcat,在服务器防火墙中放行8888(宝塔),8080(后端项目),和 3306(数据库)
  • 宝塔部署前端:添加网站,PHP项目添加站点,在根目录下上传前端npm build 后dist目录中的所有内容
  • docker部署除了消费者和提供者之外的其他后端项目:本地maven package生成jar包,将项目传到服务器上,根据Dockerfile build后端镜像,并启动该镜像
  • 数据库准备:创建一个mysql超级用户(允许远程访问,并赋予所有权限),创建数据库和用户表
  • 域名配置:由于域名注册和备案需要一段时间,暂时用ip访问
  • 跨域配置:在站点配置文件中设置允许跨域

DockerFile

# Docker 镜像构建
FROM maven:3.5-jdk-8-alpine as builder
# Copy local code to the container image. # test
WORKDIR /app
COPY pom.xml .
COPY src ./src# Build a release artifact.
RUN mvn package -DskipTests# Run the web service on container startup.
CMD ["java","-jar","/app/target/user-center-0.0.1-SNAPSHOT.jar","--spring.profiles.active=prod"]

docker相关命令:

# 创建镜像
docker build -t user-center-frontend:v0.0.1 .  
# 显示已经安装的镜像
docker images
# 前端启动镜像
docker run -p 80:80 -d user-center-frontend:v0.0.1
# 后端启动镜像
docker run -p 8080:8080 user-center-backend:v0.0.1

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

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

相关文章

计算机网络的故事——HTTP报文内的HTTP信息

HTTP报文内的HTTP信息 文章目录 HTTP报文内的HTTP信息一、HTTP 报文二、请求报文及响应报文的结构三、编码提升传输速率 一、HTTP 报文 HTTP报文是由多行(CRLF作换行符)数据构成的字符串文本,HTTP报文可以分为报文首部和报文主体两部分&…

【C++】拷贝对象时,编译器的偷偷优化

你知道吗?对于连续的”构造拷贝构造“,编译器其实是会默默做出优化的。👻 如果你不知道这个知识点的话,那下面这道笔试题就要失分了😵。 本篇分享一个关于编译器优化的小知识,看完本篇,你就能…

面试题 ⑤

1、TCP与UDP的区别 UDPTCP是否连接无连接,即刻传输面向连接,三次握手是否可靠不可靠传输,网络波动拥堵也不会减缓传输可靠传输,使用流量控制和拥塞控制连接对象个数支持一对一,一对多,多对一和多对多交互通…

【kubernetes】Argo Rollouts -- k8s下的自动化蓝绿部署

蓝绿(Blue-Green)部署简介 在现代软件开发和交付中,确保应用程序的平稳更新和发布对于用户体验和业务连续性至关重要。蓝绿部署是一种备受推崇的部署策略,它允许开发团队在不影响用户的情况下,将新版本的应用程序引入生产环境。 蓝绿部署的核心思想在于维护两个独立的环…

【算法与数据结构】700、LeetCode二叉搜索树中的搜索

文章目录 一、题目二、解法三、完整代码 所有的LeetCode题解索引&#xff0c;可以看这篇文章——【算法和数据结构】LeetCode题解。 一、题目 二、解法 思路分析&#xff1a;二叉搜索树的性质&#xff1a;左节点键值 < 中间节点键值 < 右节点键值。那么我们根据此性质&am…

文件上传漏洞-upload靶场5-12关

文件上传漏洞-upload靶场5-12关通关笔记&#xff08;windows环境漏洞&#xff09; 简介 ​ 在前两篇文章中&#xff0c;已经说了分析上传漏的思路&#xff0c;在本篇文章中&#xff0c;将带领大家熟悉winodws系统存在的一些上传漏洞。 upload 第五关 &#xff08;大小写绕过…

微服务主流框架概览

微服务主流框架概览 目录概述需求&#xff1a; 设计思路实现思路分析1.HSF2.Dubbo 3.Spring Cloud5.gRPC Service mesh 参考资料和推荐阅读 Survive by day and develop by night. talk for import biz , show your perfect code,full busy&#xff0c;skip hardness,make a be…

无涯教程-Android - List fragments函数

框架的ListFragment的静态库支持版本&#xff0c;用于编写在Android 3.0之前的平台上运行的应用程序&#xff0c;在Android 3.0或更高版本上运行时,仍使用此实现。 List fragment 的基本实现是用于创建fragment中的项目列表 List in Fragments 示例 本示例将向您说明如何基于…

地图投影——1 投影目录

地图投影示例说明亚当斯方形 II该投影以方形显示世界。该投影为等角投影&#xff0c;但方形的四个角除外。埃托夫该折衷改进的方位投影采用椭圆的形式。该投影主要用于世界地图。阿尔伯斯该等积圆锥投影最适合用于中纬度东西方向分布的大陆板块。方位自适应圆柱该折衷的地图投影…

【Yellowbrick】特征可视化分析

Yellowbrick特征可视化分析 ⭐Yellowbrick⭐特征分析可视化⭐Rank1D⭐Rank2D ⭐Yellowbrick Yellowbrick是一个用于可视化机器学习模型和评估性能的Python库。它提供了一系列高级可视化工具&#xff0c;帮助数据科学家和机器学习从业者更好地理解、调试和优化他们的模型。 它在…

JVM性能优化 —— 类加载器,手动实现类的热加载

一、类加载的机制的层次结构 每个编写的”.java”拓展名类文件都存储着需要执行的程序逻辑&#xff0c;这些”.java”文件经过Java编译器编译成拓展名为”.class”的文件&#xff0c;”.class”文件中保存着Java代码经转换后的虚拟机指令&#xff0c;当需要使用某个类时&#…

react利用wangEditor写评论和@功能

先引入wangeditor写评论功能 import React, { useEffect, useState, useRef, forwardRef, useImperativeHandle } from react; import wangeditor/editor/dist/css/style.css; import { Editor, Toolbar } from wangeditor/editor-for-react; import { Button, Card, Col, For…