升级到了最新版本的 solo,访问一直出现 8080

今天试用 docker 升级了 solo 的最新版本,后面每次访问点击文章跳转的链接都会带上 8080 端口!

博客网站:www.javadaily.cn

image.png

赞助商 我要投放

30 回帖
请输入回帖内容 ...
  • 88250

    请参考 Solo 用户指南配置 NGINX 反代

    2 回复
  • jianzh5

    没有试用 https 也需要配置吗?

  • jianzh5

    原来都正常的!

    1 回复
  • 88250

    改一下反代配置应该就好了

    1 回复
  • jianzh5
    conf
    
    upstream backend {
        server localhost:8080; # Solo 监听端口
    }
    
    server {
        listen       80;
        server_name  javadaily.cn;
    
        #charset koi8-r;
        access_log  off;
    
        location / {  
    	proxy_pass http://backend$request_uri;
    	proxy_set_header  Host $http_host;
    	proxy_set_header  X-Real-IP $remote_addr;
    	client_max_body_size  10m;
        }
    ...
    

    已经根据文档配置了,现在 nginx 访问出现 404

  • 88250

    看下 nginx error log 还有 Solo 的日志

    1 回复
  • jianzh5

    image.png

  • 88250
    • 带 www 和不带 www 是两个域名,只能选其一,另一个配置 302 重定向
    • 上游的 Solo 服务没有监听 8080 端口么
    1 回复
  • jianzh5
    • 上游的是监听了的,直接访问 javadaily.cn:8080 是可以访问的
  • 88250

    那应该还是 NGINX 配置有问题,仔细检查一下。

    1 回复
  • jianzh5
    conf
    upstream backend {
        server localhost:8080;
    }
    
    server {
        listen       80;
        server_name  javadaily.cn;
    	rewrite ^(.*)$ http://www.javadaily.cn$1 redirect;
    
        #charset koi8-r;
        access_log  off;
    
        location / {      
    	proxy_pass			http://backend$request_uri;
    	proxy_set_header	Host $http_host;
    	proxy_set_header	X-Real-IP $remote_addr;
    	client_max_body_size  10m;
        }
    
        #error_page  404              /404.html;
    
        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   /usr/share/nginx/html;
        }
    
        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}
    
        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}
    
        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }
    

    可以帮我看一下吗?

    1 回复
  • 88250

    rewrite 那里不对,需要单独配置一个 server,大概这样:

    server {
        server_name www.javadaily.cn;
        listen 80;
        rewrite ^(.*)$  http://javadaily.cn$1 permanent;
    }
    
    
    1 回复
  • jianzh5
    conf
    upstream backend {
        server localhost:8080;
    }
    
    server {
        listen			80;
        server_name		javadaily.cn;
    
    
        #charset koi8-r;
        access_log  off;
    
        location / {
    		proxy_pass			http://backend$request_uri;
    		proxy_set_header	Host $http_host;
    		proxy_set_header	X-Real-IP $remote_addr;
    		client_max_body_size  10m;
        }
    
        #error_page  404              /404.html;
    
        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   /usr/share/nginx/html;
        }
    }
    
    
    server {
        server_name		www.javadaily.cn;
        listen			80;
        rewrite ^(.*)$  http://javadaily.cn$1 permanent;
    }
    
    

    这是我的完整配置,现在访问 javadaily.cn 还是报错

    image.png

    快急哭了!

  • 88250

    贴一下 Docker Solo 的启动命令

    1 回复
  • jianzh5
    shell
     docker run --detach --name solo --network=host -v /dockerData/solo/skins:/opt/solo/skins --env RUNTIME_DB="MYSQL" --env JDBC_USERNAME="root" --env JDBC_PASSWORD="xxxxxx" --env JDBC_DRIVER="com.mysql.cj.jdbc.Driver" --env JDBC_URL="jdbc:mysql://127.0.0.1:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC"    b3log/solo --listen_port=8080 --server_scheme=http --server_host=www.javadaily.cn
    
    1 回复
  • 88250

    server_host 改成不带 www 的,另外,docker logs solo 看下有无报错日志。

    1 回复
  • jianzh5
    1. 已经去掉 server_host 后面的 www
    2. docker logs solo 无错误,www.javadaily.cn:8080 端口正常访问
    3. 配置了反代后还是 404。

    image.png

    conf
    upstream backend {
        server localhost:8080;
    }
    
    server {
        listen			80;
        server_name		javadaily.cn;
    
    
        #charset koi8-r;
        access_log  off;
    
        location / {
    		proxy_pass			http://backend$request_uri;
    		proxy_set_header	Host $http_host;
    		proxy_set_header	X-Real-IP $remote_addr;
    		client_max_body_size  10m;
        }
    
        #error_page  404              /404.html;
    
        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   /usr/share/nginx/html;
        }
    }
    
    
    server {
        server_name		javadaily.cn;
    	listen			80;
        rewrite ^/(.*)$  http://www.javadaily.cn/$1 redirect;
    }
    
    
    1 回复
  • 88250

    最终你是想用带 www 还是不带?我之前给你的配置建议是不带 www 的,但是你现在帖这个里面又是重定向到 www 的,这里有冲突。

    1 回复
  • jianzh5

    我是一直在尝试各种解决方法,换成了你这样的还是不行。可以麻烦提供下 QQ 或者其他联系方式吗?这个问题折腾好久了

    我的 QQ:476938977

    1 回复
  • 88250

    之前有群我都解散了,就是为了方便在社区交流问题呢。

    建议仔细参考一下用户指南检查配置,还有那篇 Latke 配置剖析的帖子。

    1 回复
  • jianzh5

    重新看了一下,都一样的!
    现在把启动命令的 server_host 都改成了 localhost 还是不行!

    1 回复
  • 88250

    你还没回复我之前的问题,你到底是要用 www 还是不用呢?

    1 回复
  • jianzh5

    不用呀,我只想用 javadaily.cn

    1 回复
  • 88250

    好的,确定后就按照这个步骤排查:

    1. 检查 NGINX 配置重定向 server 和反代 server
    2. 检查 Solo 启动命令 server_host 参数

    改完记得重启。如果还不能解决问题,请贴一下你当前的配置我帮你再看看。

    1 回复
  • jianzh5

    ok,排查完发现还是不行。
    nginx 的错误日志如下:

    image.png

    • solo 启动命令如下
    bash
     docker run --detach --name solo --network=host -v /dockerData/solo/skins:/opt/solo/skins --env RUNTIME_DB="MYSQL" --env JDBC_USERNAME="xxx" --env JDBC_PASSWORD="xxx" --env JDBC_DRIVER="com.mysql.cj.jdbc.Driver" --env JDBC_URL="jdbc:mysql://127.0.0.1:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC"    b3log/solo --listen_port=8080 --server_scheme=http --server_host=javadaily.cn
    
    • nginx 的配置如下
    upstream backend {
        server localhost:8080;
    }
    
    server {
        listen			80;
        server_name		javadaily.cn;
    
    
        #charset koi8-r;
        access_log  off;
    
        location / {
    		proxy_pass			http://backend$request_uri;
    		proxy_set_header	Host $http_host;
    		proxy_set_header	X-Real-IP $remote_addr;
    		client_max_body_size  10m;
        }
    
        #error_page  404              /404.html;
    
        # redirect server error pages to the static page /50x.html
        #
        error_page   502 503 504  /50x.html;
    
        location = /50x.html {
            root   /usr/share/nginx/html;
        }
    }
    
    
    server {
        server_name		www.javadaily.cn;
    	listen			80;
        rewrite ^(.*)$  http://javadaily.cn$1 redirect;
    }
    
    

    麻烦您了,万分感谢!

    1 回复
  • 88250

    这次配置应该没问题了,从 NGINX 报错日志上看可能是因为 Solo 进程没启动,docker ps 看下进程还活着没,然后 docker logs solo 看下日志。

    1 回复
  • jianzh5

    image.png

    docker logs solo 正常
    docker ps 正常
    直接带端口访问正常:http://www.javadaily.cn:8080/

    1 回复
  • 88250

    你的 NGINX 也是 docker 启的啊,那得看下 docker 的网络配置是否和 Solo 的网络想通了,按照之前你提供的配置,Solo 启动用的是宿主机 host 网络,那 NGINX 呢?

    2 回复
  • jianzh5

    好 ,我来下载个安装包,使用本地 nginx 安装一下

  • jianzh5

    好了,果然是这个问题。我用本地安装的可以了!
    奇怪就是我在没升级之前是有用的,配置方向代理都生效!网站都运行大半年了!

    而且也是参照一篇手册使用的 nginx 容器部署!
    升级后就不行了~

    感谢感谢!!我去打个赏!

请输入回帖内容 ...