ModuleNotFoundError: No module named 'sqlglot' error across many containers
Bug description
Working on a 2023 Macbook Air M2
I followed the steps per wiki here https://superset.apache.org/docs/installation/installing-superset-using-docker-compose/ (which I believe needs updating) and I am unable to have stable build for many containers under the main superset container.
- Cannot reach
http://localhost:8088/. Page is blank. - Error I am getting below.
Skipping local overrides
Starting web app (using development server)...
Skipping local overrides
Starting web app (using development server)...
Skipping local overrides
Starting web app (using development server)...
<jemalloc>: MADV_DONTNEED does not work (memset will be used instead)
<jemalloc>: (This is the expected behaviour if you are running under QEMU)
Usage: flask run [OPTIONS]
Try 'flask run --help' for help.
Error: While importing 'superset.app', an ImportError was raised:
Traceback (most recent call last):
File "/usr/local/lib/python3.9/site-packages/flask/cli.py", line 218, in locate_app
__import__(module_name)
File "/app/superset/__init__.py", line 21, in <module>
from superset.app import create_app
File "/app/superset/app.py", line 24, in <module>
from superset.initialization import SupersetAppInitializer
File "/app/superset/initialization/__init__.py", line 35, in <module>
from superset.extensions import (
File "/app/superset/extensions/__init__.py", line 30, in <module>
from superset.async_events.async_query_manager import AsyncQueryManager
File "/app/superset/async_events/async_query_manager.py", line 26, in <module>
from superset.utils.core import get_user_id
File "/app/superset/utils/core.py", line 90, in <module>
from superset.sql_parse import sanitize_clause
File "/app/superset/sql_parse.py", line 29, in <module>
from sqlglot import exp, parse, parse_one
ModuleNotFoundError: No module named 'sqlglot'
This error above is looping endlessly
How to reproduce the bug
- git clone https://github.com/apache/superset.git
- cd superset
open docker-compose.yml- paste
platform: linux/x86_64/v8under each superset container - Please include in your wiki for arm64 users, as this will save folks a lot of time.
Eg
superset:
platform: linux/x86_64/v8
...
superset-websocket:
platform: linux/amd64
...
superset-init:
platform: linux/x86_64/v8
...
superset-node:
platform: linux/x86_64/v8
...
superset-worker:
platform: linux/x86_64/v8
...
superset-worker-beat:
platform: linux/x86_64/v8
...
superset-tests-worker:
platform: linux/x86_64/v8
- run
docker compose up --build -d - Notice the
ModuleNotFoundError
Screenshots/recordings
Superset version
master / latest-dev
Python version
3.9
Node version
18 or greater
Browser
Chrome
Additional context
No response
Checklist
- [x] I have searched Superset docs and Slack and didn't find a solution to my problem.
- [x] I have searched the GitHub issue tracker and didn't find a similar bug report.
- [x] I have checked Superset's logs for errors and if I found a relevant Python stacktrace, I included it here as text in the "additional context" section.
+1 having the same exact issue.
- 1 also having the same problem
Same
@michael-s-molina is there any version you would recommend back rolling superset so that arm64 machines are able to build superset fully in docker? FWIW, we are all building superset in development and not production
Same goes for me and I have done exactly the same steps. Trying to push this in my company but is hard when the local thing just doesn't works ...
I have the exact same issue after trying everything to solve the compatibility error with M1
same issue on Amazon x86-64 EC2 instance with Ubuntu
Virtualization: amazon
Operating System: Ubuntu 22.04.3 LTS
Kernel: Linux 6.2.0-1018-aws
Architecture: x86-64
Hardware Vendor: Amazon EC2
Hardware Model: t3.large
Pinging @betodealmeida and @john-bodley since it sounds related to their recent consolidation efforts.
+1, is there any rollback branch or commit we can use for now?
I resolved the issues by checking out the latest stable release
My system:
Ubuntu 22.04.3 LTS (GNU/Linux 5.15.0-92-generic x86_64)
Steps
git clone https://github.com/apache/superset.git
git checkout tags/3.1.0
docker compose up
If all runs smoothly
docker compose up -d
@SbstnErhrdt Thanks for your reply. You did not specify what machine you are using.
- Even if this is the case, did you had to specify
platform: linux/x86_64/v8in the docker file of each container? - What are your logs for
superset-websocketnow? - I also had to create a
superset_config.pyfile and export its path to mysupersetdir so that the app reads it and override the secret key that is weak by default. - If I checkout the
tag_3.1.0, I get a new log error forsuperset-websocketthat says its looking for aconfig.jsonfile now?? when its clearly usingconfig.pyfor configuration
[email protected] start node dist/index.js start config.json file not found {"date":"Wed Feb 07 2024 16:00:22 GMT+0000 (Coordinated Universal Time)","error":{},"exception":true,"level":"error","message":"uncaughtException: Please provide a JWT secret at least 32 bytes long\nError: Please provide a JWT secret at least 32 bytes long\n at Object.
(/home/superset-websocket/dist/index.js:76:11)\n at Module._compile (node:internal/modules/cjs/loader:1198:14)\n at Object.Module._extensions..js (node:internal/modules/cjs/loader:1252:10)\n at Module.load (node:internal/modules/cjs/loader:1076:32)\n at Function.Module._load (node:internal/modules/cjs/loader:911:12)\n at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:81:12)\n at node:internal/main/run_main_module:22:47","os":{"loadavg":[29.07,19.59,13.16],"uptime":87469.63},"process":{"argv":["/usr/local/bin/node","/home/superset-websocket/dist/index.js","start"],"cwd":"/home/superset-websocket","execPath":"/usr/local/bin/node","gid":1000,"memoryUsage":{"arrayBuffers":74962,"external":948746,"heapTotal":18386944,"heapUsed":15244176,"rss":0},"pid":22,"uid":1000,"version":"v16.20.2"},"stack":"Error: Please provide a JWT secret at least 32 bytes long\n at Object. (/home/superset-websocket/dist/index.js:76:11)\n at Module._compile (node:internal/modules/cjs/loader:1198:14)\n at Object.Module._extensions..js (node:internal/modules/cjs/loader:1252:10)\n at Module.load (node:internal/modules/cjs/loader:1076:32)\n at Function.Module._load (node:internal/modules/cjs/loader:911:12)\n at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:81:12)\n at node:internal/main/run_main_module:22:47","trace":[{"column":11,"file":"/home/superset-websocket/dist/index.js","function":null,"line":76,"method":null,"native":false},{"column":14,"file":"node:internal/modules/cjs/loader","function":"Module._compile","line":1198,"method":"_compile","native":false},{"column":10,"file":"node:internal/modules/cjs/loader","function":"Module._extensions..js","line":1252,"method":".js","native":false},{"column":32,"file":"node:internal/modules/cjs/loader","function":"Module.load","line":1076,"method":"load","native":false},{"column":12,"file":"node:internal/modules/cjs/loader","function":"Module._load","line":911,"method":"_load","native":false},{"column":12,"file":"node:internal/modules/run_main","function":"Function.executeUserEntryPoint [as runMain]","line":81,"method":"executeUserEntryPoint [as runMain]","native":false},{"column":47,"file":"node:internal/main/run_main_module","function":null,"line":22,"method":null,"native":false}]}
Same problem here
not resolved yet ! what [SbstnErhrdt] said does not work for me.
Are we looking for any update soon on this.
Still Issue Persist. Superset team really need to sort it out, as everyone clone's from master only.
@SbstnErhrdt tags/3.1.0 didn't work for me.
Distributor ID: Ubuntu Description: Ubuntu 20.04.6 LTS Release: 20.04 Codename: focal
@yashagv @andrekef @vikramwalia
my system is
Ubuntu 22.04.3 LTS (GNU/Linux 5.15.0-92-generic x86_64)
The config.json file issue with WebSocket is in the master also. It's not just related to tags/3.1.0.
The solution for ModuleNotFoundError, for now, is to create a requirements-local.txt in ./docker path and put this sqlglot==20.8.0. Then if you run docker-compose again, you will not find this error.
@yashagv @vikramwalia @ricokali96 @andrekef
@rusackas We are missing the dependency in the docker-image being used by the docker-compose. The image seems to be old and does not have the additional changes of base.txt. This needs to be fixed.
Thanks @akshayjain3450 Resolved 'sqlglot' error after adding sqlglot==20.8.0.
All containers are up, but "http://localhost:8088/superset/welcome/" is continuously loading. When I did port forwarding, it shows me favicon icon. http://localhost:8089/static/assets/images/favicon.png Also not able to connect 5432 database.
Are you able to run, Can you suggest something?
Thanks @akshayjain3450
Resolved 'sqlglot' error after adding sqlglot==20.8.0.
All containers are up, but "http://localhost:8088/superset/welcome/" is continuously loading.
When I did port forwarding, it shows me favicon icon. http://localhost:8089/static/assets/images/favicon.png
Also not able to connect 5432 database.
Are you able to run, Can you suggest something?
I found one more error with postgres container where it is looking for a test table which does not exist. What I did is added CREATE DATABASE test command in ./docker/examples-init.sh. And tried again. I am still in the process to confirm if the UI opens up or not.
My two containers are down even after the module fix:
- superset_websocket with error: config.json file not found
- superset_tests_worker with error:
2024-02-08 16:45:28 2024-02-08 11:15:28,136:ERROR:flask_appbuilder.security.sqla.manager:DB Creation and initialization failed: (psycopg2.OperationalError) connection to server at "localhost" (::1), port 5432 failed: Connection refused 2024-02-08 16:45:28 Is the server running on that host and accepting TCP/IP connections? 2024-02-08 16:45:28 connection to server at "localhost" (127.0.0.1), port 5432 failed: FATAL: database "test" does not existAlso, I am not able to login with username: admin and password: admin
Need help to make this working.
I'm not familiar with how we're building the Docker images, nor with Snarf — does it just mirror an image from Dockerhub?
I was able to repro, and the solution proposed by @akshayjain3450 worked for me, so that seems like an easy workaround for now.
@rusackas do you know how to build and publish a new docker image?
I think @mistercrunch has the most relevant docker-fu here.
Regarding Scarf (Gateway), if that's what you mean, it's just a proxy, more so than a mirror. It just passes the request through directly to dockerhub and clicks a counter along the way ;)
This should help at least with the confusion around having to change image targets for local arm64 development work on newer Apple silicon -> https://github.com/apache/superset/pull/27055
is this the same solution for windows 10 user?
Can't recreate, can someone who had the issue confirmed it's fixed by now?
I tried:
docker-compose pull
docker-compose up
Also
docker compose -f docker-compose-non-dev.yml pull
docker compose -f docker-compose-non-dev.yml up
And also
git checkout 3.0.0
TAG=3.0.0 docker compose -f docker-compose-non-dev.yml pull
TAG=3.0.0 docker compose -f docker-compose-non-dev.yml up
All seemed to work on a recent Macbook M2. I hit localhost:8088 and things were snappy
Still running into issues, it is not even getting to a point where the containers are created. I am following documentation for a 2 min setup. I am going to test this out by creating an .env file at the location below and testing. This is x86 / Ubuntu 22.04.
docker compose up WARN[0000] The "SCARF_ANALYTICS" variable is not set. Defaulting to a blank string. WARN[0000] The "CYPRESS_CONFIG" variable is not set. Defaulting to a blank string. WARN[0000] The "CYPRESS_CONFIG" variable is not set. Defaulting to a blank string. env file /home/superset/docker/.env not found: stat /home/superset/docker/.env: no such file or directory
the only error I am facing is mysqlglot error in a loop.
From: Maxime Beauchemin @.> Sent: 13 February 2024 02:29 To: apache/superset @.> Cc: Rajdeep Sarkar @.>; Comment @.> Subject: Re: [apache/superset] ModuleNotFoundError: No module named 'sqlglot' error across many containers (Issue #26997)
Screenshot.2024-02-12.at.6.21.56.PM.png (view on web)https://github.com/apache/superset/assets/487433/21c8b8bb-80e9-4ae2-b0fe-40ad0de2383c
Can't recreate, can someone who had the issue confirmed it's fixed by now?
I tried:
docker-compose pull docker-compose up
Also
docker compose -f docker-compose-non-dev.yml pull docker compose -f docker-compose-non-dev.yml up
And also
git checkout 3.0.0 TAG=3.0.0 docker compose -f docker-compose-non-dev.yml pull TAG=3.0.0 docker compose -f docker-compose-non-dev.yml up
All seemed to work on a recent Macbook M2. I hit localhost:8088 and things were snappy
— Reply to this email directly, view it on GitHubhttps://github.com/apache/superset/issues/26997#issuecomment-1940296342, or unsubscribehttps://github.com/notifications/unsubscribe-auth/A7QFMXN3L2TXL5FZWQ3VQJTYTLFY5AVCNFSM6AAAAABCXDMIUOVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTSNBQGI4TMMZUGI. You are receiving this because you commented.Message ID: @.***>
@rajdeepUWE follow the answer from @akshayjain3450 about creating a requirements-local with the sqlglot.
@rajdeepUWE follow the answer from @akshayjain3450 about creating a requirements-local with the sqlglot.
I tried this. Let me get it, i need to make a .txt file name it requirements-local and write sqlglot==20.8.0 and save it in .docker/ or in the Docker directory inside superset (superset/Docker/)? I tried both, I am facing the same issue
mmmh, wondering why I can't recreate here on my local... Are you all on latest master?
sqlglot is properly referenced here -> https://github.com/apache/superset/blob/master/requirements/base.txt#L345 and this file is mounted/referenced in the Dockerfile -> https://github.com/apache/superset/blob/master/Dockerfile#L84-L86
There's a bit of a jumparoo here where requirements files point to one another, the chaing goes requirements/local.txt -> requirements/development.txt -> requirements/base.txt (where sqlglot is referenced)
Wondering if docker caching could be an issue here, where say base.txt changed, but the layer is cached because doesn't think the file has changed. But from my understanding of how docker cache works, if any of the mounted file changed, it's part of the cache key and will invalidate the cache.