在配置nginx反向代理后端服务时,遇到前端不能访问后端的情况,查看日志发现有一句错误信息:The character [_] is never valid in a domain name,下面来记录下排查过程。
通过第一个红框中内容中的xxx_back_server 反应到nginx的配置文件中有写过这个名字,大概意识时这个名字的地址解析不到对应的主机;再看第二个红框中的“_”字符不识别。
upstream test_back_server { server 127.0.0.1:8088; } server { …… location /api/ { proxy_pass http://test_back_server/; } …… }
tomcat8及以上的版本不支持upstream中带有“_”字符,我的是springboot项目内嵌的tomcat版本是9.0.29,所以也不好使了。
因为正好测试docker环境部署,所以最初怀疑是docker的问题,然后是nginx的版本问题,最后看到日志发现是tomcat的问题,遇到问题还是要冷静啊;
把“test_back_server ”中的下划线去掉就好了。
https://blog.51cto.com/u_15127589/3937865
https://stackoverflow.com/questions/60467824/java-lang-illegalargumentexception-the-character-is-never-valid-in-a-domain
遇到问题保持脑袋清晰!解决了这个问题,又可以开心的遇见下一个奇奇怪怪的问题了。