解決Node.js使用MySQL出現(xiàn)connect ECONNREFUSED 127.0.0.1:3306的問題
前言
最近用 Node 寫一個小玩意,需要用到 MySQL 數(shù)據(jù)庫,現(xiàn)在用得最廣泛的是 mysql 這個庫。然后呢,現(xiàn)在 ORM 這么火,干脆也上 ORM 吧,正好我也不會可以學習一下,于是找到了 Sequelize.js 這個 ORM 庫。
發(fā)現(xiàn)問題
看看 Sequelize 的文檔,so easy,兩分鐘搞定~
import Sequelize from 'sequelize';
let sequelize = new Sequelize('database', 'username', 'password', {
host: 'localhost',
port: 3306,
dialect: 'mysql',
pool: {
max: 5,
min: 0,
idle: 10000
}
});
// ...后面還有一堆懶得貼了
運行一下
SequelizeConnectionRefusedError: connect ECONNREFUSED 127.0.0.1:3306
什么鬼,為什么會出現(xiàn)這個錯誤呢?我明明設(shè)置的是 localhost,為什么會變成 127.0.0.1?
解決問題
照例先谷歌,確實發(fā)現(xiàn)了很多人也遇到了這個問題,解決方法大概有這么幾種:
1、你丫以為不用裝 MySQL 就能跑了么?快去裝數(shù)據(jù)庫!
2、你數(shù)據(jù)庫運行了么你?趕緊 /etc/init.d/mysqld start 運行起來
3、端口寫錯了
4、你是不是開啟了 skip-networking 這個選項?Remove it !
看到這里,我反應(yīng)過來了,因為我的數(shù)據(jù)庫不涉及到遠程訪問,只要使用 Unix socket 通信就夠了,于是就啟用了 skip-networking 讓 MySQL 不監(jiān)聽指定端口。
先科普一下 skip-networking 是什么
Do not listen for TCP/IP connections at all. All interaction with mysqld must be made using named pipes or shared memory (on Windows) or Unix socket files (on Unix). This option is highly recommended for systems where only local clients are permitted.
翻譯一下就是:
不要監(jiān)聽 TCP/IP 連接。所有與 mysqld 的交互必須使用命名管道或共享內(nèi)存(在 Windows 上)或 Unix socket 文件(在 Unix 上)。強烈建議對只允許本地客戶端的系統(tǒng)使用此選項。
但是為了安全性,我并不想把這個選擇給移除,難道只好忍痛不用 ORM 了嗎?
因為看了文檔,mysql 這個連接庫是可以使用 socketPath 這個屬性指定 Unix 套接字文件,但是 Sequelize.js 沒發(fā)現(xiàn)有關(guān)屬性。
最后只好發(fā) issue,不久就有 dalao 回答說可以用 dialectOptions 設(shè)置 mysql 的屬性。
下面是測試成功的代碼:
import Sequelize from 'sequelize';
let sequelize = new Sequelize('database', 'username', 'password', {
host: 'localhost',
port: 3306,
dialect: 'mysql',
dialectOptions: {
socketPath: '/tmp/mysql.sock' // 指定套接字文件路徑
}
pool: {
max: 5,
min: 0,
idle: 10000
}
});
就是這么簡單…
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
node.js如何自定義實現(xiàn)一個EventEmitter
我們了解到,Node采用了事件驅(qū)動機制,而EventEmitter就是Node實現(xiàn)事件驅(qū)動的基礎(chǔ),本文主要介紹了node.js自定義實現(xiàn)EventEmitter,感興趣的可以了解一下2021-07-07
node實現(xiàn)生成帶參數(shù)的小程序二維碼并保存到本地功能示例
這篇文章主要介紹了node實現(xiàn)生成帶參數(shù)的小程序二維碼并保存到本地功能,涉及nodejs模塊引用、接口調(diào)用、編碼轉(zhuǎn)換、圖片生成等相關(guān)操作技巧,需要的朋友可以參考下2018-12-12
實例詳解Nodejs 保存 payload 發(fā)送過來的文件
這篇文章主要介紹了實例詳解Nodejs 保存 payload 發(fā)送過來的文件 的相關(guān)資料,需要的朋友可以參考下2016-01-01
node.js中的fs.readlinkSync方法使用說明
這篇文章主要介紹了node.js中的fs.readlinkSync方法使用說明,本文介紹了fs.readlinkSync方法說明、語法、接收參數(shù)、使用實例和實現(xiàn)源碼,需要的朋友可以參考下2014-12-12

