解决弹簧引导在localhost域奇怪的404问题(Mac pro)

  

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

  

  

普通的一个控制器,返回一个常量。

        @GetMapping (“/project_metadata/spring-boot”)   公共字符串getMetadata () {   返回“{\“数据\”:1234}”;//这个不重要   }      

调用接口的方式:

        内容=new JSONObject(创建restTemplate。String.class getForObject (url));      

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

        3450 14:35:38.867信息2017-08-31 - - - - - - [nio - 8080 - exec - 1] .i.w.s。DefaultInitializrMetadataProvider:获取启动元数据从http://localhost: 8080/project_metadata/spring-boot   3450 14:35:38.872警告2017-08-31 - - - - - - [nio - 8080 - exec - 1] .i.w.s。DefaultInitializrMetadataProvider:未能获取弹簧引导的元数据   org.springframework.web.client。HttpClientErrorException: 404没有找到   在org.springframework.web.client.DefaultResponseErrorHandler.handleError (DefaultResponseErrorHandler.java: 63) ~ (spring-web-4.3.10.RELEASE.jar 4.3.10.RELEASE):   在org.springframework.web.client.RestTemplate.handleResponse (RestTemplate.java: 700) ~ (spring-web-4.3.10.RELEASE.jar 4.3.10.RELEASE):   在org.springframework.web.client.RestTemplate.doExecute (RestTemplate.java: 653) ~ (spring-web-4.3.10.RELEASE.jar 4.3.10.RELEASE):   在org.springframework.web.client.RestTemplate.execute (RestTemplate.java: 613) ~ (spring-web-4.3.10.RELEASE.jar 4.3.10.RELEASE):   在org.springframework.web.client.RestTemplate.getForObject (RestTemplate.java: 287) ~ (spring-web-4.3.10.RELEASE.jar 4.3.10.RELEASE):      

  

浏览器访问是正常的。

  

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

  

到bash中查看:

        curl - http://10.2.10.203:8080 project_metadata/spring-boot   HTTP/1.1 404 Not Found   服务器:ecstatic-1.4.1   时间:星期四,2017年8月31日07:06:39格林尼治时间   连接:维生      

什么情况?

  

再次检查localhost:

        curl - http://localhost: 8080/project_metadata/spring-boot   HTTP/1.1 200   内容类型:application/json; charset=utf - 8   内容长度:2683   时间:星期四,2017年8月31日格林尼治时间07:07:28      

查看端口:

        lsof我:8080   命令PID用户FD类型设备大?节点名   节点1045 pollyduan 13 u IPv4 x992085ef857b1d07 0 t0 TCP *: http-alt(听)   3995年java pollyduan 65 u IPv6 x992085ef905d994f 0 t0 TCP *: http-alt(听)      

什么鬼?

  

杀掉节点,恢复清明了。

  

坑在哪里?

  

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

  

Mac osx一手造成了坑.ubuntu测试无坑,启动http服务器的情况下,tomcat根本起不来:

        引起的:java.net.BindException:地址已经在使用   在sun.nio.ch.Net上。bind0(本地方法)   sun.nio.ch.Net.bind (Net.java: 433)   sun.nio.ch.Net.bind (Net.java: 425)   sun.nio.ch.ServerSocketChannelImpl.bind (ServerSocketChannelImpl.java: 223)   sun.nio.ch.ServerSocketAdaptor.bind (ServerSocketAdaptor.java: 74)   org.apache.tomcat.util.net.NioEndpoint.bind (NioEndpoint.java: 340)   org.apache.tomcat.util.net.AbstractEndpoint.init (AbstractEndpoint.java: 742)   org.apache.coyote.AbstractProtocol.init (AbstractProtocol.java: 458)   org.apache.coyote.http11.AbstractHttp11JsseProtocol.init (AbstractHttp11JsseProtocol.java: 120)   org.apache.catalina.connector.Connector.initInternal (Connector.java: 960)   …13      

  

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

  8080年

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

  

有两个进程都使用的8080年春季引导是localhost: 8080年,他会精神错乱。因为localhost也是127.0.0.1。

  

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

  

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

  

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

  

Tomcat启动同样的问题。

  

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

  

  

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

解决弹簧引导在localhost域奇怪的404问题(Mac pro)