暗网检测器没有通过输出重定向进行初始化。

问题描述 投票:1回答:1

当我从CLI运行我的脚本时 输出重定向 一切都在工作。

这就是 myscript.py 的样子。

# Load darknet 
sys.path.insert(0, '/var/AI/darknet/')
import darknet
darknet.performDetect(initOnly=True)
print('Beginning API query loop')
while True:
    # Business logic

通过运行我的脚本 py myscript.py这是我在控制台得到的尾部输出。

[yolo] params: iou loss: giou (1), iou_norm: 0.50, cls_norm: 1.00, scale_x_y: 1.00
Total BFLOPS 139.496
avg_outputs = 1103769
 Try to load weights: /var/AI/darknet/weights/yolov3-papersheet_600.weights
Loading weights from /var/AI/darknet/weights/yolov3-papersheet_600.weights...
 seen 64, trained: 76 K-images (1 Kilo-batches_64)
Done! Loaded 107 layers from weights-file
Loaded - names_list: /var/AI/darknet/data/papersheet.names, classes = 1
Initialized detector
Beginning API query loop

所以这个 行得通但如果我运行这个脚本与输出重定向,

nohup python3 myscript.py > /var/log/python/myscript.log 2>&1 & echo $!

停止darknet.performDetect(initOnly=True) 行的脚本,尾部输出如下。

[yolo] params: iou loss: giou (1), iou_norm: 0.50, cls_norm: 1.00, scale_x_y: 1.00
  95 route  91                                     ->   38 x  38 x 256
  96 conv    128       1 x 1/ 1     38 x  38 x 256 ->   38 x  38 x 128 0.095 BF
  97 upsample                 2x    38 x  38 x 128 ->   76 x  76 x 128
  98 route  97 36                                  ->   76 x  76 x 384
  99 conv    128       1 x 1/ 1     76 x  76 x 384 ->   76 x  76 x 128 0.568 BF
 100 conv    256       3 x 3/ 1     76 x  76 x 128 ->   76 x  76 x 256 3.407 BF
 101 conv    128       1 x 1/ 1     76 x  76 x 256 ->   76 x  76 x 128 0.379 BF
 102 conv    256       3 x 3/ 1     76 x  76 x 128 ->   76 x  76 x 256 3.407 BF
 103 conv    128       1 x 1/ 1     76 x  76 x 256 ->   76 x  76 x 128 0.379 BF
 104 conv    256       3 x 3/ 1     76 x  76 x 128 ->   76 x  76 x 256 3.407 BF
 105 conv     18       1 x 1/ 1     76 x  76 x 256 ->   76 x  76 x  18 0.053 BF
 106 yolo
[yolo] params: iou loss: giou (1), iou_norm: 0.50, cls_norm: 1.00, scale_x_y: 1.00
Total BFLOPS 139.496
avg_outputs = 1103769
Loading weights from /var/AI/darknet/weights/yolov3-papersheet_600.weights... Try to load cfg: /var/AI/darknet/cfg/yolov3-papersheet.cfg, weights: /var/AI/darknet/weights/yolov3-papersheet_600.weights, clear = 0
mini_batch = 1, batch = 1, time_steps = 1, train = 0
 Try to load weights: /var/AI/darknet/weights/yolov3-papersheet_600.weights
Done! Loaded 107 layers from weights-file

这个问题会发生在任何输出重定向上,比如:

py script.py > log.py

我使用的是下面这个脚本 暗网库的分叉 我已经开了一个 发出 也有,如果你想检查一下。虽然我认为这 可能 不是图书馆的问题。

有什么想法吗?

python bash nohup darknet
1个回答
0
投票

这个问题是由缓冲引起的。

我通过调用python的 -u 选项。

nohup python3 -u myscript.py

看这个问题

© www.soinside.com 2019 - 2024. All rights reserved.