在云服务器上部署SpringBoot分布式项目

在云服务器上部署SpringBoot分布式项目

IDEA安装Alibaba Cloud Toolkit插件
在这里插入图片描述

在工具栏点击alibaba cloud,选择deploy to host

在这里插入图片描述

添加主机,主机列表填写自己购买的云服务器公网ip,端口号默认22

在这里插入图片描述

项目父模块pom.xml设置打包方式为pom,子模块打包方式为jar

同时在子模块的pom.xml文件中指定main class

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <version>2.4.3</version>
            <configuration>
                <fork>true</fork>
                <addResources>true</addResources>
                <!-- 指定该Main Class为全局的唯一入口 -->
                <mainClass></mainClass>
            </configuration>
            <executions>
                <execution>
                    <!--可以把依赖的包都打包到生成的Jar包中-->
                    <goals>
                        <goal>repackage</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

在云服务器上新建一个目录存放上传的jar包,我这里放在/home/xxx下,

然后再点击deploy to host,添加target host,填写target directory

在这里插入图片描述

然后下滑到before launch,点击+,选择run maven goal,第一次选择父模块,填写命令:clean install,第二次添加你要部署的子模块,命令是clean package。如下图所示:

在这里插入图片描述

在这里插入图片描述

点击run,等待打包完成。

如果在打包过程中遇到如下问题:

在这里插入图片描述

我们在子模块的pom.xml设置跳过测试即可:

在这里插入图片描述

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-surefire-plugin</artifactId>
    <configuration>
        <skipTests>true</skipTests>
    </configuration>
</plugin>

打包完毕后,我们可以用Xshell工具连接云服务器,或者直接在IDEA内连接终端:
在这里插入图片描述

在这里插入图片描述

切换到/home/xxx目录下,可以看到上传成功的jar,我这里已经上传了两次,你有多少个微服务,就需要上传多少次。然后输入命令nohup java -jar xxxx.jar & ,让jar包跑起来,并且一直运行。如果你不想项目一直运行,关闭了连接就关闭了服务的话,就直接java -jar xxx.jar 即可。

在这里插入图片描述

在阿里云或腾讯云控制面板放行相关的端口号,这样就可以把你之前在本地运行项目时地址中的localhost替换成云服务器的公网ip地址了,然后访问你部署的项目。

如果我们需要停止运行的微服务,执行ps auxwww | grep xxx.jar通过查找进程关键字找到进程pid,然后执行kill pid命令即可。

如果你已经有域名,想通过域名访问项目,那么可以接着往下看。

在这里默认你已经在云服务器安装了宝塔面板,并且会使用。

在阿里云域名控制面板里添加一条记录,记录值是你的ip地址。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在宝塔面板中,新建一个站点,填写你的域名,

在这里插入图片描述

申请SSL证书,

在这里插入图片描述

开启https

在这里插入图片描述

在配置文件中配置反向代理

在这里插入图片描述

在这里插入图片描述

添加和修改的内容如下:

upstream yhy {
    server ip:端口;
}


location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
    {
        proxy_pass http://yhy;
        expires      30d;
        error_log /dev/null;
        access_log /dev/null;
    }

    location ~ .*\.(js|css)?$
    {
        proxy_pass http://yhy;
        expires      12h;
        error_log /dev/null;
        access_log /dev/null;
    }
    location / {
        proxy_set_header HOST $host;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_pass http://yhy;
    }

然后在软件商店->已安装,找到nginx,重载配置,这样就可以通过域名访问分布式项目了。

  • 1
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
智慧校园管理系统是一种基于分布式架构的项目,采用了Spring Boot和Vue两个主流的技术框架进行开发。 Spring Boot是一种轻量级的Java开发框架,它简化了企业级应用的开发过程。Spring Boot提供了许多开箱即用的功能和组件,如自动配置、快速开发、无需部署等。在智慧校园管理系统中,我们可以使用Spring Boot来构建后端的业务逻辑和接口。 Vue是一种流行的JavaScript框架,用于构建用户界面。它具有响应式数据绑定和组件化的特性,使得前端开发更加简单和高效。在智慧校园管理系统中,我们可以使用Vue来构建用户界面和处理前端的交互逻辑。 由于智慧校园管理系统是一个分布式项目,我们可以将系统的不同模块部署在不同的服务器上,实现系统的水平扩展和负载均衡。使用Spring Boot和Vue的组合可以使得系统具有良好的可伸缩性和稳定性。 在系统的架构设计上,可以使用Spring Boot的微服务架构来实现各个功能模块的独立部署和独立开发。同时,使用Vue可以实现前后端分离的开发模式,将前端和后端的开发过程并行进行,提高开发效率和协作性。 总之,通过结合Spring Boot和Vue,可以实现智慧校园管理系统的分布式开发和部署,同时还能够带来良好的用户体验和开发效率。这样的架构设计可以为校园管理带来更多的智能化和便利性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值