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

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

ただいまの
回答率

90.49%

  • MySQL

    5990questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

  • Linux

    3888questions

    Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

  • SQL

    2464questions

    SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

  • Node.js

    1931questions

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

  • Express

    250questions

    ExpressはNode.jsのWebアプリケーションフレームワークです。 マルチページを構築するための機能セットおよびハイブリッドのWebアプリケーションを提供します。

mysqlがport3306で起動してるのでexpressで接続することができません - node.js

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 228

keys

score 185

追記

var server = app.listen(8888, function(){
    console.log("Node.js is listening to PORT:" + server.address().port);
});

として

const connection = mysql.createConnection(
{
  host: '127.0.0.1',
  user: 'root',
  password: 'pass',
  database: "express_test",
  port: 8888,

});

connection.connect(function(err) {
  if (err) throw err;
  console.log("Connected!");
});


とすると、エラーは出なくなりましたが、全く接続までされません。console.log("Connected!");が出ません。調べて見ると、mysqlのポートは3306で動いていました。このポートは閉じても良いのかどうなのか。まだよくわかりませんm

 質問

express+node.jsでウェブアプリを開発しています。mysqlを接続するところで問題が発生しました。node appでexpressアプリを起動する際、下記のようにウェブサーバーのポートを3306で起動すると

var server = app.listen(3306, function(){
    console.log("Node.js is listening to PORT:" + server.address().port);
});

ローカルでは問題なかったのですが、本番環境(aws lightsail)ではポート3306はmysqlでしようしているようです。

$ sudo lsof -i :3306
COMMAND    PID  USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
mysqld.bi 3287 mysql   12u  IPv4  17789      0t0  TCP localhost:mysql (LISTEN)

なので、node appでexpressアプリを起動する際のポート番号を3308にしました。

var server = app.listen(3308, function(){
    console.log("Node.js is listening to PORT:" + server.address().port);
});


そうすると、なぜかexpressからmysqlに接続する際、下記のようなエラーが出ます。

undefined:50
  if (err) throw err;
           ^

Error: ER_ACCESS_DENIED_ERROR: Access denied for user 'root'@'127.0.0.1' (using password: YES)


expressからmysqlに接続するところは下記のように設定しています

const connection = mysql.createConnection(
{
  host: 'localhost',
  user: 'root',
  port : 3306,
  password: 'pass',
  database: 'express_test'
});

どうすれば、expressからmysqlに接続できますか?

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • mix-peach

    2018/06/19 15:11

    mysqlに接続のところ、host: 'localhost' ではなく、 host: '127.0.0.1' でもダメでしたか?

    キャンセル

  • keys

    2018/06/20 07:23

    ダメです。

    キャンセル

  • mts10806

    2018/06/20 09:37 編集

    (2回目)こちらの質問は解決したのでしょうか。https://teratail.com/questions/131800

    キャンセル

回答 1

0

rootユーザーが拒否されています。

expressからではなくコンソールから下記のように確認できると思います。

mysql -u root -p
パスワードを聞かれるので pass 

// ログインできたら

mysql > SHOW DATABASES;  でexpress_testが存在するか確認

ログインができない場合はパスワードが間違っている。
ログインができてshow databasesにexpress_testが存在しない場合はexpress_testデータベースを作成する

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 90.49%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 受付中

    EJS Expressを用いたテンプレートを用いた、サーバー側ファイルの取り扱い方について  

    Node.jsを用い、サーバー側にPDFファイル(sample.pdf)を格納しております。 クライアント側からの接続により、このファイルにアクセスする場合には、どのようにリンク

  • 解決済

    Node.jsでMySQL接続がしたい

    前提・実現したいこと プログラミング初学者です。 Node.jsを使ってMySQLのデータベース上から値を表示したいのですが コマンドラインにundifinedが表示されてし

  • 解決済

    Node.jsでMySQLに接続し、データをブラウザ上で表示したい

    前提・実現したいこと プログラミング初心者です。 Node.js、Expressを使い、http://localhost:3000/にアクセスするとMySQL上のデータを表示で

  • 解決済

    node.jsのmodule.exportsで循環参照

    あるwebアプリを作っててそこではexpressとsocketioを使用しています。 expressのインスタンスの処理等とルーティングを分けようと思って app.js

  • 解決済

    四則演算の結果を返すプログラム

    四則演算の結果を返すプログラムを作成する課題を与えられています。 ※結果をcurlコマンドで確認したいためjavascriptなどは使用できません。 以下のようにアクセスす

  • 解決済

    EC2上でのシンタックスエラーについて

    EC2にSSH接続して、Node.jsを起動するために「sudo npm start」のコマンドを走らせると下記のようなエラーが出てしまい原因がわからず困っています。 間違えって

  • 解決済

    Mysqlの外部サーバーへの接続

    アプリケーションから、外部のMysqlサーバーへのデータの読み書きを行いたいため、 ローカルのMysqlクライアント?から、AWS上に作成したMysqlへの接続を試しています。

  • 解決済

    JavascriptでQueryを呼び出すには

    手さぐりでMysqlを勉強しているのですが、Node.js内でクエリを実行するにはどうすればいいのでしょうか・・ 調べてはみたのですが、人によってはmudule.export

同じタグがついた質問を見る

  • MySQL

    5990questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

  • Linux

    3888questions

    Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

  • SQL

    2464questions

    SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

  • Node.js

    1931questions

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

  • Express

    250questions

    ExpressはNode.jsのWebアプリケーションフレームワークです。 マルチページを構築するための機能セットおよびハイブリッドのWebアプリケーションを提供します。