質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

SSL

SSL(Secure Sockets Layer)とは、暗号化されたプロトコルで、インターネット上での通信セキュリティを提供しています。

Q&A

解決済

1回答

2143閲覧

Herokuを使ったNode.jsのサンプルファイルのローカル実行 データベース接続

EiAma

総合スコア15

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

SSL

SSL(Secure Sockets Layer)とは、暗号化されたプロトコルで、インターネット上での通信セキュリティを提供しています。

0グッド

0クリップ

投稿2020/04/19 15:20

前提・実現したいこと

herokuで公開されているNode.jsのサンプルプログラムを手順に沿って再現しています。
このサンプルプログラムの最後にあるHeroku postgresqlデータベースとの接続においてSSL connection errorが発生してしまい、解決策が見当たらないためご質問させていただきました。
あまりSSL接続について知識が多くあるわけでも無い初学者です。

発生している問題・エラーメッセージ

username@mbp node-js-getting-started % heroku local [OKAY] Loaded ENV .env File as KEY=VALUE Format 12:02:19 AM web.1 | Listening on 5000 12:02:23 AM web.1 | Error: The server does not support SSL connections 12:02:23 AM web.1 | at Socket.<anonymous> (/Users/username/Desktop/node-js-getting-started/node_modules/pg/lib/connection.js:92:35) 12:02:23 AM web.1 | at Object.onceWrapper (events.js:418:26) 12:02:23 AM web.1 | at Socket.emit (events.js:311:20) 12:02:23 AM web.1 | at addChunk (_stream_readable.js:294:12) 12:02:23 AM web.1 | at readableAddChunk (_stream_readable.js:275:11) 12:02:23 AM web.1 | at Socket.Readable.push (_stream_readable.js:209:10) 12:02:23 AM web.1 | at TCP.onStreamRead (internal/stream_base_commons.js:186:23)

該当のソースコード

app.js

1const { Pool } = require('pg'); 2 3const pool = new Pool({ 4 connectionString: "postgres://username:user@localhost:5432/mylocal", 5 ssl: true 6}); 7 8const cool = require('cool-ascii-faces') 9const express = require('express') 10const path = require('path') 11const PORT = process.env.PORT || 5000 12 13express() 14 .use(express.static(path.join(__dirname, 'public'))) 15 .set('views', path.join(__dirname, 'views')) 16 .set('view engine', 'ejs') 17 .get('/', (req, res) => res.render('pages/index')) 18 .get('/db', async (req, res) => { 19 try { 20 const client = await pool.connect() 21 const result = await client.query('SELECT * FROM test_table'); 22 const results = { 'results': (result) ? result.rows : null}; 23 res.render('pages/db', results ); 24 client.release(); 25 } catch (err) { 26 console.error(err); 27 res.send("Error " + err); 28 } 29 }) 30 .get('/cool', (req, res) => res.send(cool())) 31 .get('/times', (req, res)=> res.send(showTimes())) 32 33 .listen(PORT, () => console.log(`Listening on ${ PORT }`))

試したこと

https://devcenter.heroku.com/articles/heroku-postgresql#connecting-in-node-js
こちらのページで指摘されているsslについて
heroku pg:credentials:url
のコマンドで調べましたがドキュメントで求められているようにsslmode=requireになっていることは確認できました。

参考URL
https://devcenter.heroku.com/articles/getting-started-with-nodejs#provision-a-database

補足情報(FW/ツールのバージョンなど)

postgresqlはherokuのドキュメントにある
https://postgresapp.com/
こちらのアプリケーションを使用して、heroku postgres上のデータベースからpullしてローカルのデータベースに納めています。
psql --version
=> psql(PostgreSQL) 12.1

heroku --version
=>heroku/7.39.3 darwin-x64 node-v12.16.2

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2020/04/19 15:41

ゲストからホストはローカルではないですよ?
EiAma

2020/04/19 16:32

asahina1979さん、ありがとうございます。 すみません。もう少し詳しく教えていただけないでしょうか。
hoshi-takanori

2020/04/20 11:08

heroku 用のサンプルを、heroku を使わずにローカルで実行したい、ということであればローカルですね。
EiAma

2020/04/20 12:41 編集

hoshi -takanoriさんありがとうございます。 実行コマンドがheroku localではなくでnode appなどにするべきということでしょうか?
EiAma

2020/04/20 12:48

herokuのサンプルとして載っているプログラムにおいてデータベースをheroku上のものからlocalのものに置き換えることはできないのでしょうか。
hoshi-takanori

2020/04/21 10:12

ローカルの postgresql サーバーに繋ぐ場合は、普通は ssl を有効にしてないと思いますので、ssl: true をコメントアウトすればいいと思います。 ローカルの node.js から heroku の postgresql に繋ぐ場合は、環境変数 DATABASE_URL を設定して、以下のコードでいけると思います。 const pool = new Pool({ connectionString: process.env.DATABASE_URL, ssl: true });
EiAma

2020/04/21 11:41

hoshi-takanoriさん、詳しくご説明くださりありがとうございます。 上記の方法にて問題を解決することができました。 ローカルのpostgresqlへ接続する際にsslが働いているものだと思い込みずっとssl: trueの設定にて頑張っておりました。。。 本当にありがとうございます。
EiAma

2020/04/21 11:48

hoshi-takanoriさん、コメントいただいた内容をベストアンサーとさせていただきたいので、回答欄に回答願えますでしょうか。
guest

回答1

0

ベストアンサー

ローカルの postgresql サーバーに繋ぐ場合は、普通は ssl を有効にしてないと思いますので、ssl: true をコメントアウトすればいいと思います。

js

1const pool = new Pool({ 2 connectionString: "postgres://username:user@localhost:5432/mylocal", 3 //ssl: true 4});

ローカルの node.js から heroku の postgresql に繋ぐ場合は、環境変数 DATABASE_URL を設定して、以下のコードでいけると思います。

js

1const pool = new Pool({ 2 connectionString: process.env.DATABASE_URL, 3 ssl: true 4});

投稿2020/04/21 12:09

hoshi-takanori

総合スコア7901

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問