node.js - 如何将 sqlite3 与 docker compose 一起使用

标签 node.js docker sqlite docker-compose sequelize.js

在以下教程之间;

我已经能够将我的 NodeJS 应用程序转换为已启动并运行并连接到服务的 Docker 化微服务。但是,我的应用程序使用 Sqlite/Sequelize,并且在 dockerizing 之前运行得很好。

使用新设置时,我收到错误;

/usr/src/app/node_modules/sequelize/lib/dialects/sqlite/connection-manager.js:31
throw new Error('Please install sqlite3 package manually');
Error: Please install sqlite3 package manually at new ConnectionManager 
(/usr/src/app/node_modules/sequelize/lib/dialects/sqlite/connection-manager.js:31:15)

我的问题是;

  1. 是否可以将 Sqlite3 与 Docker 一起使用
  2. 如果是这样,任何人都可以分享适用于此目的的示例 docker-compose.yml 和 Dockerfile 组合。

我的 docker-compose.yml

version: '3.5'

services:
  user-service:
    container_name: user-service
    build: ./services/user/
    volumes:
      - './services/user:/usr/src/app'
      - './services/user/package.json:/usr/src/package.json'
    ports:
      - '9000:9000' # expose ports - HOST:CONTAINER

  web-service:
    container_name: web-service
    build:
      context: ./services/web
      dockerfile: Dockerfile
    volumes:
      - './services/web:/usr/src/app'
      - '/usr/src/app/node_modules'
    ports:
      - '3000:3000' # expose ports - HOST:CONTAINER
    environment:
      - NODE_ENV=development
    depends_on:
      - user-service

我的用户/Dockerfile

FROM node:latest

# set working directory
RUN mkdir /usr/src/app
WORKDIR /usr/src/app

# add `/usr/src/node_modules/.bin` to $PATH
ENV PATH /usr/src/app/node_modules/.bin:$PATH

# install and cache app dependencies
ADD package.json /usr/src/package.json
RUN npm install

# start app
CMD ["npm", "start"]

我的网站/Dockerfile

FROM node:latest

# set working directory
RUN mkdir /usr/src/app
WORKDIR /usr/src/app

# add `/usr/src/app/node_modules/.bin` to $PATH
ENV PATH /usr/src/app/node_modules/.bin:$PATH

# install and cache app dependencies
COPY package.json /usr/src/app/package.json
RUN npm install
RUN npm install react-scripts@1.1.4
RUN npm install gulp -g

# start app
CMD ["npm", "start"]

非常感谢。

最佳答案

明白了。问题是我的本地 node_modules 被复制到主机容器。因此,在 sqlite3 lib/binding 中,存在 node-v57-darwin-x64,而不是预期的 - node-v57-linux-x64。因此一片困惑。

我更新了 Dockerfiles 和 docker-compose.yml,如下所示:

我的 docker-compose.yml

services:
  user-service:
    container_name: user-service
    build: 
      context: ./services/user/
      dockerfile: Dockerfile
    volumes:
      - './services/user:/usr/src/app'
      - '/usr/src/node_modules'
    ports:
      - '9000:9000' # expose ports - HOST:CONTAINER

  web-service:
    container_name: web-service
    build:
      context: ./services/web/
      dockerfile: Dockerfile
    volumes:
      - './services/web:/usr/src/app'
      - '/usr/src/app/node_modules'
    ports:
      - '3000:3000' # expose ports - HOST:CONTAINER
    environment:
      - NODE_ENV=development
    depends_on:
      - user-service

我的用户/Dockerfile

FROM node:latest

# set working directory
RUN mkdir /usr/src/app
WORKDIR /usr/src/app

# add `/usr/src/node_modules/.bin` to $PATH
ENV PATH /usr/src/node_modules/.bin:$PATH

# install and cache app dependencies
ADD package.json /usr/src/package.json
RUN npm install

# start app
CMD ["npm", "start"]

有用的帖子 Getting npm packages to be installed with docker-compose

关于node.js - 如何将 sqlite3 与 docker compose 一起使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51769034/

相关文章:

javascript - 在 Node.js 中调用一组 http.get 请求完成

share - 如何在构建期间将主机卷挂载到 Dockerfile 中的 docker 容器中

docker - Docker:在镜像创建期间修改文件

java - 应用程序中有大量数据

sql - SQLite-SQL问题101

database - 选择用于存储文件夹系统的数据库模式

node.js - 从 AWS DynamoDB 中的 `ConditionalCheckFailedException` 获取更多详细信息?

node.js - Neo4J 单个查询中的多个匹配语句

javascript - nodeJS 将输入框的 post 请求保存在文件中

azure - 在 azure 管道上拉取并运行 Linux docker 镜像