Skip to content
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

unable to use postgis_raster extension: GDAL Drivers Disabled #1347

Open
2 tasks done
lookevink opened this issue Dec 1, 2024 · 5 comments
Open
2 tasks done

unable to use postgis_raster extension: GDAL Drivers Disabled #1347

lookevink opened this issue Dec 1, 2024 · 5 comments
Labels
bug Something isn't working

Comments

@lookevink
Copy link

Bug report

  • I confirm this is a bug with Supabase, not with my own application.
  • I confirm I have searched the Docs, GitHub Discussions, and Discord.

Describe the bug

I am working with large climate datasets and need to optimize using PostGIS Raster. Both PostGIS and PostGIS_Raster extensions are enabled, as confirmed by SELECT PostGIS_Full_Version(), which indicates proper versions for PostGIS, GDAL, and Raster. However, when attempting to insert raster data using ST_FromGDALRaster, I encounter the error rt_util_gdal_open: Cannot open file. All GDAL drivers disabled, suggesting that GDAL drivers are not correctly enabled despite proper setup. I'm also unable to enable the extensions w/o superuser permission

To Reproduce

Steps to reproduce the behavior, please provide code snippets or a repository:

Steps to Reproduce

  1. Setup PostgreSQL and PostGIS:
    • Install PostgreSQL 15 and PostGIS 3.3.2.
    • Ensure GDAL (version 3.8.5 or compatible) is installed.
  2. Enable PostGIS and Raster Extensions:
CREATE EXTENSION postgis;
CREATE EXTENSION postgis_raster;
  1. Check PostGIS Version:
    Run the following query to confirm PostGIS and GDAL are properly installed:
SELECT PostGIS_Full_Version();

getting:

POSTGIS="3.3.2" [...] GDAL="GDAL 3.8.5" [...] RASTER

  1. Create a Table for Raster Data:
CREATE TABLE __gpcp_precip (
time TIMESTAMP PRIMARY KEY,
rast RASTER
);
  1. Attempt to Insert Raster Data:
    Use the following query with appropriate values:
INSERT INTO __gpcp_precip (time, rast)
VALUES ('2024-12-01 00:00:00', ST_FromGDALRaster('/path/to/raster.tif'))
ON CONFLICT (time) DO UPDATE
SET rast = EXCLUDED.rast;
  1. Error Encountered:
    The error rt_util_gdal_open: Cannot open file. All GDAL drivers disabled is thrown.

Expected behavior

data is inserted

Additional context

Add any other context about the problem here.

@lookevink lookevink added the bug Something isn't working label Dec 1, 2024
@samrose
Copy link
Contributor

samrose commented Dec 3, 2024

@lookevink thank you for reporting this issue.

I wanted to ask where you experienced this problem? Are you experiencing this issue in a hosted version of supabase, or are you running supabase/postgres server locally on your machine/deployed to a server?

@lookevink
Copy link
Author

@samrose thank you for the prompt response! hosted version

@samrose
Copy link
Contributor

samrose commented Dec 4, 2024

@lookevink when using this query

INSERT INTO __gpcp_precip (time, rast)
VALUES ('2024-12-01 00:00:00', ST_FromGDALRaster('/path/to/raster.tif'))
ON CONFLICT (time) DO UPDATE
SET rast = EXCLUDED.rast;

Where did you upload to the raster.tif file to? Do you have an example raster.tif that I could test this out with?

Testing locally GDAL seems to be working and loading raster files with this query. However, I wanted to test on hosted version following the same approach you are taking and similar file if you don't mind sharing how you uploaded your file, and an example of a file you need to work in this insert? Thank you!

@lookevink
Copy link
Author

@samrose .tif file is in a temp file after being converted from an nc file. I pulled the tif from memory for reference. both are in this folder

spinning up a new postgre locally & storing seems to work fine. can definitely do a fdw but prefer to keep everything in supabase

@justmytwospence
Copy link

I'm also struggling to enable gdal drivers on hosted. I'm not reading from a file, but rather trying to ST_FromGDALRaster on a hex string literal derived from a GeoTiff buffer from an API.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

3 participants