smartscenes / sstk

SSTK: SmartScenes ToolKit
MIT License
116 stars 41 forks source link

Error: Database access denied #16

Closed jb892 closed 4 years ago

jb892 commented 4 years ago
OS: Ubuntu 16.04
nodejs version: v10.21.0
npm version: 6.14.4
MySQL version: 14.14 Distrib 5.7.30
SSTK: head -> dev

Hi,

I'm trying to setup SSTK server on my pc. However, I'm running into this error:

(node:13358) [DEP0096] DeprecationWarning: timers.unenroll() is deprecated. Please use clearTimeout instead.
error: Error querying database code=ER_ACCESS_DENIED_ERROR, errno=1045, sqlMessage=Access denied for user 'DBUSERNAME'@'localhost' (using password: YES), sqlState=28000, fatal=true, name=SQLQuerier

Could anyone help?

jb892 commented 4 years ago

Hi @msavva and @angelxuanchang

After some research, I have managed to set up a MySQL server by doing the following steps:

  1. puting correct user and password info in the file sstk/server/config.index.js in this line config.annDb = { host: 'localhost', user: 'USER', password: 'PASSWORD', database: 'scannet' };
  2. Create a database called 'scannet' in MySQL server.
  3. Change line 4 in file sstk/server/proj/scannet/tasks/segment_annotation/default.config.yml to scansToAnnotate: '../../../../static/data/nyuv2/nyuv2.example.csv' # up to server directory

Current status and problems:

I can access to the example annotation model now: scannet_annotation

But, I'm unable to fetch and save the annotation in MySQL since I don't know how to create the data table with the correct attribute fields.

Could you please tell me how to set up the database correctly? Thx in advance!

Additional info: Error and logs

error

audited 517 packages in 2.474s

2 packages are looking for funding
  run `npm fund` for details

found 81 vulnerabilities (25 low, 18 moderate, 35 high, 3 critical)
  run `npm audit fix` to fix them, or `npm audit` for details

> sstk-server@0.5.3 start /media/jake/DATA/Documents/SceneAnnotationTool/sstk/server
> node app/

STK running on localhost:9010
Reverse proxy running on localhost:8010
*** Done booting server. Access through localhost:8010 ***
(node:12333) [DEP0095] DeprecationWarning: timers.enroll() is deprecated. Please use setTimeout instead.
(node:12333) [DEP0096] DeprecationWarning: timers.unenroll() is deprecated. Please use clearTimeout instead.
info: query filters 0=ann.task, 1=scan-model-align, 2=ann.itemId, 3=ann.condition, 4=ann.status, 5=ann.status, name=SQLQuerier
info: query SELECT * FROM annotations AS ann where `ann`.`task` = 'scan-model-align' AND `ann`.`itemId` REGEXP 'nyuv2[.].*' AND `ann`.`condition` IN ('manual') AND (`ann`.`status` <> 'rejected' OR `ann`.`status` IS NULL) ORDER BY created_at DESC name=SQLQuerier
error: Error querying database code=ER_NO_SUCH_TABLE, errno=1146, sqlMessage=Table 'scannet.annotations' doesn't exist, sqlState=42S02, index=0, sql=SELECT * FROM annotations AS ann where `ann`.`task` = 'scan-model-align' AND `ann`.`itemId` REGEXP 'nyuv2[.].*' AND `ann`.`condition` IN ('manual') AND (`ann`.`status` <> 'rejected' OR `ann`.`status` IS NULL) ORDER BY created_at DESC, name=SQLQuerier
info: query filters 0=ann.type, 1=segment, 2=ann.itemId, 3=ann.condition, 4=ann.status, 5=ann.status, name=SQLQuerier
info: query SELECT GROUP_CONCAT(`label`) as `label`,COUNT(DISTINCT(label)) as `nlabels`,COUNT(label) as `ninstances`,`ann`.`id` FROM annotations AS ann JOIN segment_annotations AS parts ON parts.annId = ann.id  where `ann`.`type` = 'segment' AND `ann`.`itemId` REGEXP 'nyuv2[.].*' AND `ann`.`condition` IN ('manual') AND (`ann`.`status` <> 'rejected' OR `ann`.`status` IS NULL) GROUP BY `ann`.`id` ORDER BY ann.created_at DESC name=SQLQuerier
error: Error querying database code=ER_NO_SUCH_TABLE, errno=1146, sqlMessage=Table 'scannet.annotations' doesn't exist, sqlState=42S02, index=0, sql=SELECT GROUP_CONCAT(`label`) as `label`,COUNT(DISTINCT(label)) as `nlabels`,COUNT(label) as `ninstances`,`ann`.`id` FROM annotations AS ann JOIN segment_annotations AS parts ON parts.annId = ann.id  where `ann`.`type` = 'segment' AND `ann`.`itemId` REGEXP 'nyuv2[.].*' AND `ann`.`condition` IN ('manual') AND (`ann`.`status` <> 'rejected' OR `ann`.`status` IS NULL) GROUP BY `ann`.`id` ORDER BY ann.created_at DESC, name=SQLQuerier
warn: Unknown task: manual, using default task configuration name=SegmentAnnotatorServer
info: loading task config ./default.config.yml name=SegmentAnnotatorServer
info: loading file /media/jake/DATA/Documents/SceneAnnotationTool/sstk/server/proj/scannet/tasks/segment_annotation/default.config.yml name=SegmentAnnotatorServer
info: loading file /media/jake/DATA/Documents/SceneAnnotationTool/sstk/server/static/data/nyuv2/nyuv2.example.csv name=SegmentAnnotatorServer
info: loading file /media/jake/DATA/Documents/SceneAnnotationTool/sstk/server/proj/scannet/tasks/segment_annotation/annotation-checks.yml name=SegmentAnnotatorServer
info: loading file /media/jake/DATA/Documents/SceneAnnotationTool/sstk/server/proj/scannet/tasks/segment_annotation/segment-labels.json name=SegmentAnnotatorServer
info: loading file /media/jake/DATA/Documents/SceneAnnotationTool/sstk/server/proj/scannet/tasks/segment_annotation/survey.json name=SegmentAnnotatorServer
info: loading file /media/jake/DATA/Documents/SceneAnnotationTool/sstk/server/proj/scannet/tasks/segment_annotation/category-parts.json name=SegmentAnnotatorServer
info: query filters 0=ann.status, 1=ann.status, name=SQLQuerier
info: query SELECT `itemId`,COUNT(DISTINCT(`id`)) as `id`,COUNT(DISTINCT(`created_at`)) as `created_at` FROM annotations AS ann where (`ann`.`status` <> 'rejected' OR `ann`.`status` IS NULL) GROUP BY `itemId` ORDER BY created_at DESC name=SQLQuerier
error: Error querying SQL for existing annotations code=ER_NO_SUCH_TABLE, errno=1146, sqlMessage=Table 'scannet.annotations' doesn't exist, sqlState=42S02, index=0, sql=SELECT `itemId`,COUNT(DISTINCT(`id`)) as `id`,COUNT(DISTINCT(`created_at`)) as `created_at` FROM annotations AS ann where (`ann`.`status` <> 'rejected' OR `ann`.`status` IS NULL) GROUP BY `itemId` ORDER BY created_at DESC, name=SegmentAnnotatorServer
info: SegmentAnnotatorServer annotateSingle processing user USER@::ffff:127.0.0.1 name=SegmentAnnotatorServer
info: passing to client mId=nyuv2.bedroom_0114 name=SegmentAnnotatorServer
info: query filters 0=ann.taskMode, 1=fixup, 2=ann.itemId, 3=nyuv2.bedroom_0114, name=SQLQuerier
info: query SELECT `id` FROM annotations AS ann where `ann`.`taskMode` = 'fixup' AND `ann`.`itemId` = 'nyuv2.bedroom_0114' ORDER BY created_at DESC LIMIT 1 name=SQLQuerier
error: Error querying database code=ER_NO_SUCH_TABLE, errno=1146, sqlMessage=Table 'scannet.annotations' doesn't exist, sqlState=42S02, index=0, sql=SELECT `id` FROM annotations AS ann where `ann`.`taskMode` = 'fixup' AND `ann`.`itemId` = 'nyuv2.bedroom_0114' ORDER BY created_at DESC LIMIT 1, name=SQLQuerier
info: query filters 0=ann.type, 1=segment, 2=ann.itemId, 3=nyuv2.bedroom_0114, name=SQLQuerier
info: query SELECT GROUP_CONCAT(`label`) as `label`,COUNT(DISTINCT(label)) as `nlabels`,COUNT(label) as `ninstances`,`ann`.`id` FROM annotations AS ann JOIN segment_annotations AS parts ON parts.annId = ann.id  where `ann`.`type` = 'segment' AND `ann`.`itemId` = 'nyuv2.bedroom_0114' GROUP BY `ann`.`id` ORDER BY ann.created_at DESC name=SQLQuerier
error: Error querying database code=ER_NO_SUCH_TABLE, errno=1146, sqlMessage=Table 'scannet.annotations' doesn't exist, sqlState=42S02, index=0, sql=SELECT GROUP_CONCAT(`label`) as `label`,COUNT(DISTINCT(label)) as `nlabels`,COUNT(label) as `ninstances`,`ann`.`id` FROM annotations AS ann JOIN segment_annotations AS parts ON parts.annId = ann.id  where `ann`.`type` = 'segment' AND `ann`.`itemId` = 'nyuv2.bedroom_0114' GROUP BY `ann`.`id` ORDER BY ann.created_at DESC, name=SQLQuerier
warn: Unknown task: undefined, using default task configuration name=SegmentAnnotatorServer
info: query filters 0=ann.status, 1=ann.status, name=SQLQuerier
info: query SELECT `itemId`,COUNT(DISTINCT(`id`)) as `id`,COUNT(DISTINCT(`created_at`)) as `created_at` FROM annotations AS ann where (`ann`.`status` <> 'rejected' OR `ann`.`status` IS NULL) GROUP BY `itemId` ORDER BY created_at DESC name=SQLQuerier
error: Error querying SQL for existing annotations code=ER_NO_SUCH_TABLE, errno=1146, sqlMessage=Table 'scannet.annotations' doesn't exist, sqlState=42S02, index=0, sql=SELECT `itemId`,COUNT(DISTINCT(`id`)) as `id`,COUNT(DISTINCT(`created_at`)) as `created_at` FROM annotations AS ann where (`ann`.`status` <> 'rejected' OR `ann`.`status` IS NULL) GROUP BY `itemId` ORDER BY created_at DESC, name=SegmentAnnotatorServer
info: Got annotation for nyuv2.bedroom_0114, user jake name=SQLAnnotationDb
error: Error querying database code=ER_NO_SUCH_TABLE, errno=1146, sqlMessage=Table 'scannet.annotations' doesn't exist, sqlState=42S02, index=0, sql=INSERT INTO annotations (type, task, taskMode, appId, sessionId, workerId, itemId, `condition`, data, preview_data) VALUES ('segment', '', 'fixup', 'SegmentAnnotator.v5', 'local-session', 'jake', 'nyuv2.bedroom_0114', 'manual', '{\"stats\":{\"initial\":{\"annotatedVertices\":19544,\"unannotatedVertices\":47677,\"annotatedSegments\":59,\"unannotatedSegments\":383,\"totalSegments\":442,\"totalVertices\":67221,\"percentComplete\":29.074247630948662},\"delta\":{\"annotatedVertices\":33775,\"unannotatedVertices\":-33775,\"annotatedSegments\":180,\"unannotatedSegments\":-180,\"totalSegments\":0,\"totalVertices\":0,\"percentComplete\":50.2447151931688},\"total\":{\"annotatedVertices\":53319,\"unannotatedVertices\":13902,\"annotatedSegments\":239,\"unannotatedSegments\":203,\"totalSegments\":442,\"totalVertices\":67221,\"percentComplete\":79.31896282411746}},\"timings\":{\"times\":{\"initial\":1594027333438,\"modelLoad\":{\"start\":1594027335060,\"end\":1594027336158,\"duration\":1098},\"annotatorReady\":1594027337237,\"annotationSubmit\":1594028256206},\"durations\":{\"modelLoad\":1098,\"annotatorReady\":3799,\"annotationSubmit\":922768}},\"metadata\":{\"segmentType\":\"surfaces\",\"startFrom\":\"latest\",\"startAnnotations\":\"aggr\"}}', ''), name=SQLQuerier
warn: Unknown task: undefined, using default task configuration name=SegmentAnnotatorServer
info: Got annotation for nyuv2.bedroom_0114, user jake name=SQLAnnotationDb
...
jb892 commented 4 years ago

After contact with the author Manolis, I found the MySQL setup script inside SSTK/scripts/db folder.