-
Notifications
You must be signed in to change notification settings - Fork 60
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[ADAP-979] [Bug] Database Error: Only user perm tables supported in producer views #656
Comments
Thanks for detailed write-up @alison985 ! I'm wondering if we can reproduce the essence of your experience outside of dbt Cloud. Are the following files a reasonable representation of the setup and experience you are describing? Files
sandcastle-redshift:
target: connection_a
outputs:
connection_a:
type: redshift
dbname: A
ra3_node: true
# ...
connection_b:
type: redshift
dbname: B
ra3_node: true
# ...
name: "my_project"
version: "1.0.0"
config-version: 2
profile: "sandcastle-redshift"
models:
my_project:
+database: B
select 1 as id CommandsThis works? dbt run -s my_model --target connection_b But this doesn't? dbt run -s my_model --target connection_a |
Hi @dbeatty10 ! That file setup is correct for what I had except for the I have been using dbt-core locally with this Redshift cluster for weeks, so I can do the outside dbt Cloud test. Yes, it works fine with Yes, it doesn't work with 04:16:43 Encountered an error:
ERROR: Cross-db references allowed only in RA3.* node. (sources vs data_platform_development) When I add Runtime Error
Database Error in model clean_table_coconut (models/upstream_prepared/sqlserverdbname_dbo/clean_table_coconut.sql)
Only user perm tables supported in producer views When I keep FWIW, locally I'm on dbt-core v1.4.8 and dbt-redshift v1.4.0. The |
Nice research @alison985 I haven't seen this error before and didn't have much luck with Google either, so we might need to ask some folks from AWS what it means:
In the meantime, could you try installing dbt-redshift 1.7.0 and setup a brand new standalone project like this and see if you get that same error? |
@dbeatty10 , I can't upgrade the code base to 1.7 because then I would lose the ability to function against SQL Server. |
Could you help me understand how SQL Server and Redshift are related to each other in this case? Is there some way by which you are connecting to a SQL Server database from within a single dbt project that uses the dbt-redshift adapter? Or do you have both the dbt-redshift adapter and the dbt-sqlserver adapter installed at the same time with a shared version of dbt-core? And you have totally different dbt projects that use each of those adapters separately? Virtual environment for dbt-redshift 1.7Assuming that you have a separate dbt project that only uses Redshift (and doesn't use SQL Server at all), could you try to install 1.7 within a virtual enviornment like this? The details will vary based on your operating system and shell. If you let me know your operating system, I can try coming up with custom instructions for you. These are the instructions for macOS using python3 -m venv redshift_1.7
source redshift_1.7/bin/activate
python3 -m pip install --upgrade pip
python3 -m pip install --upgrade --pre dbt-redshift~=1.7.0.dev0 dbt-postgres~=1.7.0.dev0 dbt-core~=1.7.0.dev0
source redshift_1.7/bin/activate
dbt --version 👉 Then could you try setting up a brand new standalone project like #656 (comment) and see if you get that same error? When you are all done using this virtual environment, you can get out of it by running:
Determining your python commandYou can run the following to find your python command that points to Python 3 (rather than Python 2):
If both of them say something like |
dbt-sqlserver shouldn't have anything to do with it. I was trying to say I can't upgrade my dbt-core version until dbt-sqlserver supports dbt-core versions > 1.4.8. Or at least, I'm not going to attempt adding it to the complexity of the project. I have 1 dbt code repo(and Whether using the Redshift adapter and Redshift development endpoint on a) dbt-core v1.4.8 locally and/or b) dbt Cloud v1.5 with 1 dbt Cloud project, dbt can not handle reading across databases on RA3 nodes for at least some operations(e.g. compile).
I don't. I was already setup to do the outside-dbt-Cloud test you requested and I was happy to do it. Unfortunately, I won't have time to create the separate project test you're describing. I can report that dbt Cloud works now that the database name in the connection string is changed to the database name I'll be working in and the dbt Cloud generated public key is installed on our side. |
Hi @alison985 , looks like you're trying to run a dbt project with models on a database while the connection is made to another database. Is that correct? You're right that RA3 nodes support |
@jiezhen-chen thanks for jumping in with your expertise here! 🧠 In this case, it sounds like @alison985 is only doing a
From the logs that @alison985 shared, it looks like it may be this query that is triggering the error: SELECT *
FROM sources.information_schema.tables
WHERE table_name = 'clean_table_coconut' and table_schema = 'dbt_developer_transforms' Do you know what this error message means and what might be causing it? |
Ah, thanks for the clarification @dbeatty10 . I did an experiment querying on a ra3 cluster using redshift query editor. I ran the following snippet while connected to cluster_b and got the same "perm tables" error.
This may be a redshift limitation with cross-database querying information_schema, guessing that it is not accessible from another database. An alternative would be to use svv_redshift_tables. Try the following:
The query above should return a list of all tables in cluster_a. |
Thanks for that insight @jiezhen-chen ! Potential fixSearching through the source code, the fix might be updating here (and maybe here too) to use I'm not sure one way or the other if there are other queries against Acceptance criteria
Test case detailsFiles
sandcastle-redshift:
target: connection_a
outputs:
connection_a:
type: redshift
dbname: database_a
ra3_node: true
# ...
connection_b:
type: redshift
dbname: database_b
ra3_node: true
# ...
name: "my_project"
version: "1.0.0"
config-version: 2
profile: "sandcastle-redshift"
models:
my_project:
+database: database_b
{{ config(materialized="table") }}
select 1 as id
{{ config(materialized="view") }}
select 1 as id
{{ config(materialized="materialized_view") }}
select 1 as id
{{ config(materialized="ephemeral") }}
select 1 as id CommandsThis is expected to break until a fix is in place: dbt run --target connection_a This is expected to work just fine both with and without a fix: dbt run --target connection_b Note I didn't actually try reproducing this error report myself. |
Will likely be addressed as a part of #555 |
Lacking some context as I am not a DBT user but from what I can tell Redshift does not support cross DB queries on some system level tables...This might be able to be bypassed with some really really broad permission scopes and maybe thats okay depending on your user but AWS support was unable to help me on this one |
Please note, in redshift we can't use the three-part notation or external schemas to query cross-database metadata tables or views under information_schema and pg_catalog. Noted here: https://docs.aws.amazon.com/redshift/latest/dg/cross-database_usage.html To get metadata across databases, we can only use SVV_ALL* and SVV_REDSHIFT* metadata views like SVV_ALL_TABLES. |
Is this a new bug in dbt-redshift?
Current Behavior
When the dbt Cloud connection is set to database "development" and your
dbt_project.yml
file states all model nodes occur in databasesources
thendbt compile
anddbt build
will not work.Expected Behavior
The database specified in
dbt_project.yml
for a model is used as specified. At the least, when using RA3 nodes and a database user that has permissions, dbt should be able to rundbt compile
successfully regardless of the database specified in the Connection.Steps To Reproduce
dbt_project.yml
file that specifies+database: B
.dbt compile
.Relevant log output
Environment
Additional Context
Why can't I just change the database name in the dbt Cloud Connection to be correct? Because that will generate a new ssh key set which means the public_key has to get PRed by DevOps into the right place which will take an unspecified amount of time. (So yes, I'm going to go through that process, but also it would be great for this to be fixed so someone else doesn't have to deal with it. Also, supporting RA3 nodes in general.)
Why? Well it's not any of these:
A) user permissions. The
Only user perm tables supported in producer views
in the error message implies it's a permission issue. So I explicitly permissioned the user account for allllll the things -usage
,select
,all
alter default privileges
ontables
,schema
and added it to groups with at leastSELECT
permissions on the same. No go. This database user also created and owns the database it's referencing and all the objects it's trying to read information about. In addition, the database user in my dbt Cloud profile settings is a superuser. (Technically, it doesn't own this particular schema.)B) It occurred to me that the dbt-redshift adapter should be doing something like
USE DATABASE sources
but a) Redshift doesn't seem to have theUSE
keyword from a web search and b) dbt is correctly writing the database namesources
in the query it runs against theinformation_schema
.C) Maybe it was that Redshift doesn't support cross-database work - unless you use RA3 nodes and then it supports
SELECT
s. These are RA3 nodes, so it should be able to run aSELECT
on thesources
databaseinformation_schema
schema.D) The database connection just doesn't work. Incorrect. i)
dbt seed
runs fine and creates 3 tables, albeit in the wrong place - database apple. This is expected - RA3 nodes don't support writes. (Specifying database B for seed writes also results, as expected, in an error.) ii)There's a SUCCESS message for the connection in the log.E) Fluke one off. No, this happened multiple times.
G) Something about whether an object exists or not. I received the error whether the object I was trying to refresh already existed or didn't(deleted manually outside of dbt).
You can possibly argue what the bug is/bugs are, but something doesn't work correctly. Possible interpretations of this bug are:
The text was updated successfully, but these errors were encountered: