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

official aws lambda layer for @duckdb/node-api #98

Open
cookiejest opened this issue Jan 2, 2025 · 7 comments
Open

official aws lambda layer for @duckdb/node-api #98

cookiejest opened this issue Jan 2, 2025 · 7 comments
Labels
documentation Improvements or additions to documentation

Comments

@cookiejest
Copy link

cookiejest commented Jan 2, 2025

Hey, is there an official aws lambda layer for @duckdb/node-api or we must include as part of our own deployment pipeline?

Currently getting this error on a clean lambda function. I guess most people would also get this:

   "errorType": "Runtime.ImportModuleError",
    "errorMessage": "Error: Cannot find module '@duckdb/node-bindings-linux-x64/duckdb.node'\nRequire stack:\n- /var/task/index.mjs",
    "stack": [
        "Runtime.ImportModuleError: Error: Cannot find module '@duckdb/node-bindings-linux-x64/duckdb.node'",

Many thanks!

@jraymakers
Copy link
Contributor

There is not. The lambda layer for the old Node client isn't "official", either; it's provided by a member of the community.

I'm not very familiar with lambda layers so I don't know what's involved. I don't understand enough about the lambda environment to know why you got the error above, but my guess is there's something different about the Node version or configuration.

I'd welcome any concrete suggestions or PRs to make this work. I have a fair amount of other items on my list right now, so I'm not likely to have time to look into this anytime soon.

@cookiejest cookiejest changed the title offical aws lambda layer for @duckdb/node-api official aws lambda layer for @duckdb/node-api Jan 2, 2025
@cookiejest
Copy link
Author

cookiejest commented Jan 2, 2025

figured it out actually. It was due to lambda function running on a different chip to my local machine and the .node binding dependency not being installed when the function was deployed on aws.

I wouldn't want to use a random lambda layer as abit of a security risk but these are the steps i did to get it working (for others wanting to fix the same issue):

  1. Confirm what lambda run time your using (if nodejs its probably linux64)
  2. Clone your node_modules/@duckdb directory locally and delete the large files you dont need as it needs be below 250mb uncompressed and under 50mb compressed to be uploadable as a lambda layer. (I deleted duckdb-wasm and the binding that was for my local arm machine).
  3. Get the correct binding for the environment the lambda function is running on (can be forced like this):
    npm i @duckdb/node-bindings-linux-x64 --force
    Here was mine:
Screenshot 2025-01-02 at 18 04 31
  1. zip it up and upload as a lambda layer and assign it to the lambda function

Now duckdb will be executable inside a lambda function without using a custom docker image.

@jraymakers
Copy link
Contributor

Nice!

I can confirm that those three packages (@duckdb/node-api, @duckdb/node-bindings, and @duckdb/node-bindings-linux-x64) should be the minimum needed (for Linux x64).

@jraymakers
Copy link
Contributor

Probably worth documenting this and adding it to the README. I'll keep this issue open to track that.

@jraymakers jraymakers added the documentation Improvements or additions to documentation label Jan 2, 2025
@cookiejest
Copy link
Author

good idea! I think this would allow alot more people who are just using front end frameworks like aws amplify to use duckdb in their lambda functions :)

@hannesj
Copy link

hannesj commented Jan 23, 2025

When bundling a lambda function with SST v2, the installation of the native binary can be can be configured as follows:

  new Function(stack, "InvoiceFunction", {
    handler: "functions/invoice.handler",
    nodejs: {
      esbuild: {
        loader: { ".node": "file" },
      },
      install: ["@duckdb/node-bindings-linux-arm64"],
    },
  });

@cookiejest
Copy link
Author

cookiejest commented Jan 23, 2025

That's much better !🤗 (if your using sst)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
documentation Improvements or additions to documentation
Projects
None yet
Development

No branches or pull requests

3 participants