在mac系统中,明明url是对的,浏览器也可以打开,一个简单的代码调用就是404,你有没有遇到过?
情景再现
普通的一个controller,返回一个常量。
1
2
3
4
|
@GetMapping ( "/project_metadata/spring-boot" )
public String getMetadata(){
return "{\"data\":1234}" ; //这个不重要
}
|
调用接口的方式:
1
|
content = new JSONObject(restTemplate.getForObject(url, String. class ));
|
大部分情况下,返回如下错误,偶尔成功。
1
2
3
4
5
6
7
8
|
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 : Failed 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中查看:
1
2
3
4
5
|
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:
1
2
3
4
5
|
curl -I http: //localhost:8080/project_metadata/spring-boot
HTTP/ 1.1 200
Content-Type: application/json;charset=UTF- 8
Content-Length: 2683
Date: Thu, 31 Aug 2017 07 : 07 : 28 GMT
|
查看端口:
1
2
3
4
|
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根本起不来:
1
2
3
4
5
6
7
8
9
10
11
12
|
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),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:https://my.oschina.net/polly/blog/1527030