0

Goaccess が機能するように Nginx を構成する必要があります。

私の環境は次のとおりです。

  • Ubuntu 18.04 LTS
  • Nginx 1.17.1 [自己構成、パス=/ルート]
  • 暗号化しましょう
  • sshfs
  • goaccess [ --enable-utf8 --enable-geoip=legacy --with-openssl ]

これは自己回答型の Q/A であるため、失敗した試みは含めませんが、代わりに私の解決策を投稿します。自由に編集するか、現在のコードを改善する別の回答を投稿してください。

4

1 に答える 1

3

このソリューション/構成により、400 および 502 エラーが解決されました

nginx conf [ポイント]

upstream goaccess {
    server localhost:7890;
    keepalive 60;
}

server {
    listen 443 ssl; 
    ssl_certificate /etc/letsencrypt/live/test.com/fullchain.pem; 
    ssl_certificate_key /etc/letsencrypt/live/test.com/privkey.pem; 
    include /etc/letsencrypt/options-ssl-nginx.conf; 
    ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem;
    server_name rp.test.com;
    root  /var/www/goaccess;
    index  index.html;
    location / {
            try_files $uri  $uri/ @goaccess;
            alias /var/www/goaccess/;
            index  index.html;
            proxy_set_header Upgrade $http_upgrade;
            proxy_buffering on;            
            proxy_set_header Connection "Upgrade";
            proxy_connect_timeout 600s;
            proxy_send_timeout 600s;
            proxy_read_timeout 600s;
            proxy_temp_path  /var/nginx/proxy_temp;
    }

    location @goaccess{
            proxy_pass http://goaccess;
    }

}

goaccess [ goaccess.sh ]

#!/bin/sh
goaccess  /root/test2_nginx_log/www.test2.com_access.log -o /var/www/goaccess/index.html --real-time-html --origin=https://rp.test.com --addr=0.0.0.0 --port=7890 --ws-url=wss://rp.test.com --ssl-cert=/etc/letsencrypt/live/test.com/fullchain.pem --ssl-key=/etc/letsencrypt/live/test.com/privkey.pem  --time-format=%H:%M:%S --date-format=%d/%b/%Y --log-format=COMBINED

sshfs [run_sshfs.sh]

#!/bin/sh
if [ $(mount | grep 'root@111.111.111.xxx:/data/log/server/nginx' | wc -l) -ne 1 ]
then
    echo 'yourpassword' | sshfs root@111.111.111.xxx:/data/log/server/nginx /root/test2_nginx_log -o password_stdin,allow_other
else
    exit 0
fi

最後に、チェック用のこの sh goaccess が実行されているかどうか、およびマウントがオンラインであるかどうかを確認してから、それを再起動します。

確認して再起動 [ cr.sh ]

#!/bin/bash
if pgrep -x "goaccess" > /dev/null 
then
    clear ;
    echo "goaccess is running!"
    sleep 1
    echo "now cutting down goaccess...please wait"
    sleep 2
    kill `pgrep goaccess`
    echo "cut down done"
    sleep 1
    echo "now check mount test2 nginx log folder..."
    cd /root/ && ./run_sshfs.sh
    sleep 2
    echo "mount done"
    sleep 1
    echo "now restart goaccess..."
    cd /root/ && sudo nohup ./goaccess.sh > goaccess.log 2>&1 &
    sleep 2
    echo "goaccess was restarting success!"
    sleep 1
    echo "now all done!"
    exit 1
else
    clear ;
    echo "goaccess is down!"
    sleep 1
    echo "now check mount test2 nginx log folder..."
    cd /root/ && ./run_sshfs.sh
    sleep 2
    echo "mount done"
    sleep 1
    echo "now start goaccess..."
    cd /root/ && sudo nohup ./goaccess.sh > goaccess.log 2>&1 &
    sleep 2
    echo "goaccess was starting success!"
    sleep 1
    echo "now all done!"
fi

そのすべて。ここで、私の 'rp.test.com' のような URL を開くと、以下のようなものが表示されるはずです (他に特別な条件がない場合)。

ランニング:

goaccess 実行中

注意: これはCROTELの解決策で、最初はquestionに投稿されましたが、その後コミュニティ メンバーによってコミュニティ wiki の回答に移動され、Stack Overflow の Q/A 形式に準拠しています。

于 2019-08-21T10:21:34.940 に答える