阿士匹灵.sout 2024-03-12 19:11 采纳率: 28.6%
浏览 7
已结题

win上运行ok,在Linux上项目部署运行错误,如何解决?(语言-java)

下载了Ruoyi-ui的前后端分离项目练习在Linux上面打包部署,但结果。。在window可以运行,但是在Linux就报错了

img


img

18:55:14.763 [main] ERROR o.s.b.SpringApplication - [reportFailure,870] - Application run failed
org.springframework.context.ApplicationContextException: Failed to start bean 'webServerStartStop'; nested exception is org.springframework.boot.web.server.WebServerException: Unable to start embedded Tomcat server
    at org.springframework.context.support.DefaultLifecycleProcessor.doStart(DefaultLifecycleProcessor.java:181)
    at org.springframework.context.support.DefaultLifecycleProcessor.access$200(DefaultLifecycleProcessor.java:54)
    at org.springframework.context.support.DefaultLifecycleProcessor$LifecycleGroup.start(DefaultLifecycleProcessor.java:356)
    at java.lang.Iterable.forEach(Iterable.java:75)
    at org.springframework.context.support.DefaultLifecycleProcessor.startBeans(DefaultLifecycleProcessor.java:155)
    at org.springframework.context.support.DefaultLifecycleProcessor.onRefresh(DefaultLifecycleProcessor.java:123)
    at org.springframework.context.support.AbstractApplicationContext.finishRefresh(AbstractApplicationContext.java:937)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:586)
    at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145)
    at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780)
    at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:453)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:343)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:1370)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:1359)
    at com.ruoyi.RuoYiApplication.main(RuoYiApplication.java:18)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.springframework.boot.loader.MainMethodRunner.run(MainMethodRunner.java:49)
    at org.springframework.boot.loader.Launcher.launch(Launcher.java:108)
    at org.springframework.boot.loader.Launcher.launch(Launcher.java:58)
    at org.springframework.boot.loader.JarLauncher.main(JarLauncher.java:88)
Caused by: org.springframework.boot.web.server.WebServerException: Unable to start embedded Tomcat server
    at org.springframework.boot.web.embedded.tomcat.TomcatWebServer.start(TomcatWebServer.java:229)
    at org.springframework.boot.web.servlet.context.WebServerStartStopLifecycle.start(WebServerStartStopLifecycle.java:43)
    at org.springframework.context.support.DefaultLifecycleProcessor.doStart(DefaultLifecycleProcessor.java:178)
    ... 22 common frames omitted
Caused by: java.lang.IllegalArgumentException: standardService.connector.startFailed
    at org.apache.catalina.core.StandardService.addConnector(StandardService.java:235)
    at org.springframework.boot.web.embedded.tomcat.TomcatWebServer.addPreviouslyRemovedConnectors(TomcatWebServer.java:282)
    at org.springframework.boot.web.embedded.tomcat.TomcatWebServer.start(TomcatWebServer.java:213)
    ... 24 common frames omitted
Caused by: org.apache.catalina.LifecycleException: Protocol handler start failed
    at org.apache.catalina.connector.Connector.startInternal(Connector.java:1039)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
    at org.apache.catalina.core.StandardService.addConnector(StandardService.java:232)
    ... 26 common frames omitted
Caused by: java.net.BindException: 地址已在使用
    at sun.nio.ch.Net.bind0(Native Method)
    at sun.nio.ch.Net.bind(Net.java:433)
    at sun.nio.ch.Net.bind(Net.java:425)
    at sun.nio.ch.ServerSocketChannelImpl.bind(ServerSocketChannelImpl.java:223)
    at org.apache.tomcat.util.net.NioEndpoint.initServerSocket(NioEndpoint.java:276)
    at org.apache.tomcat.util.net.NioEndpoint.bind(NioEndpoint.java:231)
    at org.apache.tomcat.util.net.AbstractEndpoint.bindWithCleanup(AbstractEndpoint.java:1302)
    at org.apache.tomcat.util.net.AbstractEndpoint.start(AbstractEndpoint.java:1388)
    at org.apache.coyote.AbstractProtocol.start(AbstractProtocol.java:663)
    at org.apache.catalina.connector.Connector.startInternal(Connector.java:1037)
    ... 28 common frames omitted


什么情况啊这是? 前端和后端分别配置在了两台服务器上后端里面的yml文件也配置了后端的地址,redis和mysql的账号密码也没问题

最重要的是他在window上运行就没问题,到了Linux上就报错,很奇怪

  • 写回答

2条回答 默认 最新

  • 专家-赤兔[在线] 全栈领域优质创作者 2024-03-12 19:12
    关注

    引自免费微信小程序:皆我百晓生

    根据您提供的错误信息,问题出在Linux环境下Tomcat启动时无法绑定到指定的网络端口,具体错误是Caused by: java.net.BindException: 地址已在使用。这意味着您尝试使用的端口已经被其他服务或进程占用。

    解决步骤如下:

    1. 查找占用端口的进程: 首先,需要确定哪个进程占用了您Spring Boot应用配置的端口(默认一般是8080)。在Linux上可以使用以下命令进行查找:

      netstat -tulpn | grep 8080
      

      或者

      lsof -i :8080
      
    2. 停止占用端口的进程: 找到占用端口的进程后,您可以选择停止这个进程,释放端口。例如,如果该进程的PID为pid_number,则可以使用:

      kill -9 pid_number
      
    3. 修改Spring Boot应用端口: 如果您不希望停止占用端口的进程,或者出于安全和管理原因希望Spring Boot应用运行在其他端口,可以在项目的application.yml或application.properties文件中更改服务器端口设置,例如:

      在application.yml中添加或修改:

      server:
        port: 8081 # 更改为未被占用的端口号
      
    4. 重新部署并启动应用: 修改配置后,在Linux上重新打包并部署您的Java应用,然后尝试再次启动它。

    此外,请确保用户运行应用的权限足够以允许其绑定到较低的端口(小于1024的端口可能需要root权限)。

    请按照上述步骤排查并解决问题,如果还有其它环境相关的配置差异,比如Linux系统上的文件读写权限问题等,也需进一步检查和调整。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月21日
  • 已采纳回答 3月13日
  • 创建了问题 3月12日

悬赏问题

  • ¥200 csgo2的viewmatrix值是否还有别的获取方式
  • ¥15 Stable Diffusion,用Ebsynth utility在视频选帧图重绘,第一步报错,蒙版和帧图没法生成,怎么处理啊
  • ¥15 请把下列每一行代码完整地读懂并注释出来
  • ¥15 pycharm运行main文件,显示没有conda环境
  • ¥15 寻找公式识别开发,自动识别整页文档、图像公式的软件
  • ¥15 为什么eclipse不能再下载了?
  • ¥15 编辑cmake lists 明明写了project项目名,但是还是报错怎么回事
  • ¥15 关于#计算机视觉#的问题:求一份高质量桥梁多病害数据集
  • ¥15 特定网页无法访问,已排除网页问题
  • ¥50 如何将脑的图像投影到颅骨上