解決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)這個錯誤呢?我明明設置的是 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 !
看到這里,我反應過來了,因為我的數(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)有關屬性。
最后只好發(fā) issue,不久就有 dalao 回答說可以用 dialectOptions 設置 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
}
});
就是這么簡單…
總結
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
node使用mysql獲取數(shù)據(jù)庫數(shù)據(jù)中文亂碼問題的解決
這篇文章主要介紹了node使用mysql獲取數(shù)據(jù)庫數(shù)據(jù)中文亂碼問題的解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-12-12
node.js使用zlib模塊進行數(shù)據(jù)壓縮和解壓操作示例
這篇文章主要介紹了node.js使用zlib模塊進行數(shù)據(jù)壓縮和解壓操作,結合實例形式詳細分析了node.js基于zlib模塊創(chuàng)建數(shù)據(jù)流以及壓縮和解壓縮等相關操作技巧,需要的朋友可以參考下2020-02-02

