解决Spring Boot 在localhost域奇怪的404问题(Mac book pro)

网友投稿 900 2023-04-09


解决Spring Boot 在localhost域奇怪的404问题(Mac book pro)

在mac系统中,明明url是对的,浏览器也可以打开,一个简单的代码调用就是404,你有没有遇到过?

情景再现

普通的一个controller,返回一个常量。

@GetMapping("/project_metadata/spring-boot")

public String getMetadata(){

return "{\"data\":1234}";//这个不重要

}

调用接口的方式:

content = new jsONObject(restTemplate.getForObject(url, String.class));

大部分情况下,返回如下错误,偶尔成功。

2017-08-31 14:35:38.867 INFO 3450 --- [nio-8080-exec-1] .i.w.s.DefaultInitializrMetadataProvider : Fetching boot metadata from http://localhost:8080/project_metadata/spring-boot

2017-08-31 14:35:38.872 WARN 3450 --- [nio-8080-exec-1] .i.w.s.DefaultInitializrMetadataProvider : Fhttp://ailed to fetch spring boot metadata

org.springframework.web.client.HttpClientErrorException: 404 Not Found

at org.springframework.web.client.DefaultResponseErrorHandler.handleError(DefaultResponseErrorHandler.java:63) ~[spring-web-4.3.10.RELEASE.jar:4.3.10.RELEASE]

at org.springframework.web.client.RestTemplate.handleResponse(RestTemplate.java:700) ~[spring-web-4.3.10.RELEASE.jar:4.3.10.RELEASE]

at org.springframework.web.client.RestTemplate.doExecute(RestTemplate.java:653) ~[spring-web-4.3.10.RELEASE.jar:4.3.10.RELEASE]

at org.springframework.web.client.RestTemplate.execute(RestTemplate.java:613) ~[spring-web-4.3.10.RELEASE.jar:4.3.10.RELEASE]

at org.springframework.web.client.RestTemplate.getForObject(RestTemplate.java:287) ~[spring-web-4.3.10.RELEASE.jar:4.3.10.RELEASE]

排查

浏览器访问是正常的。

把localhost 改为一个私网IP,页面空白,不报错。

到 bash中查看:

curl -I http://10.2.10.203:8080/project_metadata/spring-boot

HTTP/1.1 404 Not Found

server: ecstatic-1.4.1

Date: Thu, 31 Aug 2017 07:06:39 GMT

Connection: keep-alive

什么情况?

再次检查localhost:

curl -I http://localhost:8080/project_metadata/spring-boot

HTTP/1.1 200

Content-Type: application/jshttp://on;charset=UTF-8

Content-Length: 2683

Date: Thu, 31 Aug 2017 07:07:28 GMT

查看端口:

lsof -i:8080

COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME

node 1045 pollyduan 13u IPv4 0x992085ef857b1d07 0t0 TCP *:http-alt (LISTEN)

java 3995 pollyduan 65u IPv6 0x992085ef905d994f 0t0 TCP *:http-alt (LISTEN)

什么鬼?

杀掉node,恢复清明了。

坑在哪里?

有两个进程都在监听8080,但ip错乱。

Mac osx 一手造成了坑。ubuntu 测试无坑,启动http-server的情况下,tomcat根本起不来:

Caused by: java.net.BindException: Address already in use

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 sun.nio.ch.ServerSocketAdaptor.bind(ServerSocketAdaptor.java:74)

at org.apache.tomcat.util.net.NioEndpoint.bind(NioEndpoint.java:340)

at org.apache.tomcat.util.net.AbstractEndpoint.init(AbstractEndpoint.java:742)

at org.apache.coyote.AbstractProtocol.init(AbstractProtocol.java:458)

at org.apache.coyote.http11.AbstractHttp11JsseProtocol.init(AbstractHttp11JsseProtocol.java:120)

at org.apache.catalina.connector.Connector.initInternal(Connector.java:960)

... 13 more

小结:

完整的坑是这样的,我用node起了一个127.0.0.1:8080 调js,完了没关。

现在用springboot起8080,竟然成功,但这个坑就这么挖好了。

有两个进程都使用的8080,spring boot 是localhost:8080 ,他会精神错乱。因为localhost也是127.0.0.1。

奇了怪的是,既然错乱,启动的时候居然不报端口占用。

那么我们现在要明确,localhost指向127.0.0.1,但二者还是不一样,localhost可以看做一个域名。

为了避免入坑,如果可能尽量不使用localhost,直接使用IP。

Tomcat 启动同样的问题。

浏览器一切正常,restTemplate错乱。

总结

以上所述是给大家介绍的解决Spring Boot 在localhost域奇怪的404问题(Mac book pro),希望对大家有所帮助,如果大家有任何疑问请给我留言,会及时回复大家的。在此也非常感谢大家对我们网站的支持!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:java中volatile不能保证线程安全(实例讲解)
下一篇:mybatis实现增删改查_动力节点Java学院整理
相关文章

 发表评论

暂时没有评论,来抢沙发吧~