Node使用Sequlize連接Mysql報錯:Access denied for user ‘xxx’@‘localhost’
前言
最近在工作中遇到問題,問題如下:
Unhandled rejection SequelizeAccessDeniedError: Access denied for user 'lupeng'@'localhost' (using password: YES)
這是Node在使用Sequlize連接Mysql數(shù)據(jù)時報的錯,關(guān)鍵看冒號后面的錯誤:訪問拒絕,關(guān)鍵是訪問拒絕的錯誤,說明數(shù)據(jù)庫連接這里有問題,數(shù)據(jù)庫連接訪問拒絕,要么是沒有相應(yīng)的操作權(quán)限,要么是賬號密碼錯誤。
這樣就把問題定位在訪問權(quán)限以及賬號密碼錯誤兩點上了,千萬不要忘其他方面去找問題了,那樣只會是浪費時間。
1. 用戶權(quán)限的問題
權(quán)限問題從數(shù)據(jù)庫著手,確認用戶授權(quán)后,是否刷新的權(quán)限列表。也就是在使用Grant命令授權(quán)用戶后,應(yīng)該要使用flush privileges命令,這個是很多人會忽略的問題。
如果用戶授權(quán)沒有問題,那么嘗試重啟mysql服務(wù)器。使用命令/etc/init.d/mysql restart重啟mysql服務(wù)器,不同Linux版本重啟命令可能不一樣,我這里是Debain系。
如果重啟了問題還沒有解決,那么可能就不是數(shù)據(jù)庫用戶權(quán)限的問題了。
2. 賬號密碼的問題
賬號密碼錯誤,這個問題聽起來很扯,但是開發(fā)過程中,很多人會忽略掉。為什么這么說?我使用的是config-lite模塊來配置數(shù)據(jù)庫參數(shù),因為會在多個系統(tǒng)環(huán)境中切換開發(fā),使用config-lite模塊可以通過簡單的環(huán)境變量配置,來加載不同的參數(shù)文件。具體用法參照:不同環(huán)境下配置文件使用。
我的問題就出現(xiàn)在這里,打開一個終端運行項目npm run test
,package.json文件里配置著test的運行腳本NODE_ENV=test supervisor --harmony -i views/ ./bin/www
。另打開一個終端,運行數(shù)據(jù)庫同步的命令,同步命令是單獨寫在一個js腳本中,腳本里引用了數(shù)據(jù)連接方法(通用的),連接方法如下:
var Sequelize = require('sequelize'); // 引入數(shù)據(jù)庫配置文件 var sqlConfig = require('config-lite')(__dirname).mysql; var sequelize = new Sequelize(sqlConfig.database, sqlConfig.user, sqlConfig.password, { host: sqlConfig.host, dialect: 'mysql', pool: { max: 10, min: 0, idle: 10000 } }); module.exports = sequelize;
于是在同步數(shù)據(jù)庫的時候,總是如標(biāo)題報錯,然而覺得沒錯啊,最后檢查才發(fā)現(xiàn)問題所在:運行test腳本里的NODE_ENV環(huán)境變量只在當(dāng)前終端下才有效,如果要另開一個終端來同步數(shù)據(jù)庫,那么需要在另開的終端里再設(shè)置一下環(huán)境變量。不然加載的數(shù)據(jù)庫參數(shù)是不一致的,也就是說連接數(shù)據(jù)庫的用戶名密碼是不對的。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
- Node.js調(diào)用fs.renameSync報錯(Error: EXDEV, cross-device link not permitted)
- node.js使用npm 安裝插件時提示install Error: ENOENT報錯的解決方法
- node.js報錯:Cannot find module ''ejs''的解決辦法
- node.js請求HTTPS報錯:UNABLE_TO_VERIFY_LEAF_SIGNATURE\的解決方法
- node.js缺少mysql模塊運行報錯的解決方法
- nodejs提示:cross-device link not permitted, rename錯誤的解決方法
相關(guān)文章
node?gyp安裝canvas原生模塊編譯node?pregyp詳解
這篇文章主要為大家介紹了Nodejs關(guān)于原生模塊編譯node-gyp + node-pre-gyp (以安裝canvas為例)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11node故障定位頂級技巧動態(tài)追蹤Dynamic?Trace詳解
這篇文章主要為大家介紹了node故障定位頂級技巧動態(tài)追蹤Dynamic?Trace詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09