2017-02-28 81 views
1

我正在使用bigquery.go库。Bigquery.go导出作业比WebGUI慢很多

在调查一些性能时,我发现从客户端启动的导出(.csv到GCS)作业(仅导出作业)平均需要大约60秒,而从WebGUI启动的相同作业需要大约20秒。这可能是什么原因?

的代码如下:

time1 := time.Now() 
job_extract, err := extractor.Run(ctx) 
if err != nil { 
    return err 
} 

status, err = job_extract.Wait(ctx) 
if err != nil { 
    return err 
} 

if status.Err() != nil { 
    log.Fatalf("Job failed with error %v", status.Err()) 
    return status.Err() 
} 

time2 := time.Since(time1) 

回答

3

的WEB UI通常有一个轮询机制来检查时,工作已经完成,所以你可能会看到更长的时间。通常,导出到GCS的文件比在WebUI中实际完成的作业更早出现。

为了确保看到的确切时间,请使用cli tool获得最新的岗位:

bq ls -j -a --max_results=15 

运行,这将显示一个表,作业ID和相应的时序。

   jobId    Job Type State  Start Time  Duration 
--------------------------------- ---------- --------- ----------------- ---------- 
    bquijob_1864e679_15a84d8878a  query  SUCCESS 28 Feb 07:11:06 0:00:04 
    bquijob_770b512_15a84d8122c  query  FAILURE 28 Feb 07:10:35 0:00:00 
    bquijob_de0df03_15a84d6a4fa  query  FAILURE 28 Feb 07:09:02 0:00:00 
    bquijob_52c4f7d7_15a84d660e6  query  FAILURE 28 Feb 07:08:44 0:00:00 
    bquijob_76a2c1be_15a84d5e769  query  FAILURE 28 Feb 07:08:13 0:00:00 
    bquijob_7f51dde5_15a84d55afb  query  SUCCESS 28 Feb 07:07:41 0:00:08 
    bquijob_34f25864_15a84d50503  query  SUCCESS 28 Feb 07:07:18 0:00:08 
    job_Ca0cuRTAjY7MEHAs7vTJMxtVYTs query  SUCCESS 28 Feb 07:00:47 0:00:09 
    job_hHfmcdwyBsPsYF5dDvvOdR1Rmd0 load  SUCCESS 28 Feb 07:00:26 0:00:20 
    job_mkiLf_mFHLKSplGJOtg-XDKzvv4 load  SUCCESS 28 Feb 02:52:50 0:00:02 
    job_3RsPvttxWwv3SzVoOI9Cv_2yWtA query  SUCCESS 27 Feb 21:18:40 0:00:08 
    job_JLsqJO0NEIlKNac6jkDWbwneGMg extract SUCCESS 27 Feb 11:35:04 0:00:17 
    job_KOS7vKX4aX0FNbK6dibE7cxzcQA query  SUCCESS 27 Feb 11:33:44 0:00:37 
    bquijob_44046bec_15a802f703a  query  SUCCESS 27 Feb 09:27:48 0:00:07 
    job_2qQ6YSWeXaP2y2doONQJsIoga3c query  SUCCESS 27 Feb 08:53:20 0:00:06 

你可以通过这种方式来检查提取作业的DURATION。如果您确实确实存在问题,请将问题表发回问题,以便Google工程师尽快检查。但没有适当的细节,我们可以假设你的测量是错误的。

+0

你是对的,当我用cli工具运行它时,持续时间很长,比我计算的短得多,所以我期望它连接到wait()调用或类似的地方。 – Zanndorin