Connect to multiple SQL database servers and run queries to collect data.
- Your application is single-tenant database.
- You need to poll anonymous information from multiple single-tenant production sql servers.
- Credential to production sql servers is managed by different department.
- Your polling sql statement needs to go through approval process.
https://agilesalt.net/sql-crawler
Configure your own sql server list and sql queries git repository. Then specify them on appsettings.json, which are overridable with environment variables.
Comma-delimited file. *
: required
- ServerId
*
: unique identifier of the server. - ServerName: user-friendly name of the server.
- Scope: see Scope.
- Description.
- UserData1, UserData2: custom info that you can use in your sql as parameter (
@UserData1
) or Handlebars replacement ({{UserData1}}
). For other properties that you can use in your sql, see SqlServerInfoPublic. - ServerDriver:
mssql
(default) orsqlite
. To support more, add class on Drivers. - DataSource
*
, UseIntegratedSecurity, SqlUsername, SqlPassword: connection info consumed by ServerDrivers. See implementation of each driver to find more details.
Files ending with .sql are recognized as queries. If approval process is needed, you may configure your git repo with permission.
SQL queries can be placed inside subfolders in the git repository. Then the path of query file becomes the scope
of the query.
Server List may have optional column Scope
. ServerId must be still unique across entire list.
When you run query, it runs against servers with matching scope or below. For example, a/b/test.sql
's scope is a/b
. It will run on the server with its Scope
values a/b
or a/b/c
, but not on a
nor a server with empty Scope
value.
For more details, check out the demo site.
ServerId must be still unique across different scopes. Same rule is applied to sql query file name, so if you have the same file name in different paths, sql-crawler will raise an error.
n.bat serve
: launch vue on dev mode. Vue code is hot-reloaded.- You must launch back-end from Visual Studio also as IIS Express profile.
run-webapp.ps1
: launch webapp with vue code transpiled in it, on http:5002 and https:5003.build.ps1 -target publish
: create web package that can be used to run under IISbuild.ps1 -target build-docker
: create web package on a linux docker image calledsql-crawler
-
Running on linux container:
docker run -p 5004:80 kennethchoe/sql-crawler
- If you want to have your own sql-credentials attached, attach the folder to
app/data
. Refer to docker-test-data.ps1 for an example.
- If you want to have your own sql-credentials attached, attach the folder to
-
docker-run.ps1
: build, create linux docker image and run it as http:5004.-port 1234
: run it on http:1234.-gitSqlSource https://git-repo-url
: specify sql source. Default value ishttps://github.com/kennethchoe/sql-crawler-sqls.git
.-gitUsername username -gitPassword password
: specify git repo's credential, if needed.-skipRebuild
skips rebuilding docker image.
Because I forget them after a while...
docker ps
: display containers currently runningdocker container prune
: clean up all stopped containersdocker logs -f container-identifier
: show console log until you ctrl+C.docker inspect container-identifier
: show full info about the container, including port, volume mapping, etc.docker exec -it container-identifier bash
: launch interactive bash on the container.exit
to disconnectdocker exec container-identifier ls /app
: tap into the container, display the result ofls /app
and then disconnect immediately