溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Node使用Sequlize連接Mysql報(bào)錯(cuò)怎么辦

發(fā)布時(shí)間:2021-06-18 09:59:15 來源:億速云 閱讀:118 作者:小新 欄目:web開發(fā)

小編給大家分享一下Node使用Sequlize連接Mysql報(bào)錯(cuò)怎么辦,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

前言

最近在工作中遇到問題,問題如下:

Unhandled rejection SequelizeAccessDeniedError: Access denied for user 'lupeng'@'localhost' (using password: YES)

這是Node在使用Sequlize連接Mysql數(shù)據(jù)時(shí)報(bào)的錯(cuò),關(guān)鍵看冒號(hào)后面的錯(cuò)誤:訪問拒絕,關(guān)鍵是訪問拒絕的錯(cuò)誤,說明數(shù)據(jù)庫連接這里有問題,數(shù)據(jù)庫連接訪問拒絕,要么是沒有相應(yīng)的操作權(quán)限,要么是賬號(hào)密碼錯(cuò)誤。

這樣就把問題定位在訪問權(quán)限以及賬號(hào)密碼錯(cuò)誤兩點(diǎn)上了,千萬不要忘其他方面去找問題了,那樣只會(huì)是浪費(fèi)時(shí)間。

1. 用戶權(quán)限的問題

權(quán)限問題從數(shù)據(jù)庫著手,確認(rèn)用戶授權(quán)后,是否刷新的權(quán)限列表。也就是在使用Grant命令授權(quán)用戶后,應(yīng)該要使用flush privileges命令,這個(gè)是很多人會(huì)忽略的問題。

如果用戶授權(quán)沒有問題,那么嘗試重啟mysql服務(wù)器。使用命令/etc/init.d/mysql restart重啟mysql服務(wù)器,不同Linux版本重啟命令可能不一樣,我這里是Debain系。

如果重啟了問題還沒有解決,那么可能就不是數(shù)據(jù)庫用戶權(quán)限的問題了。

2. 賬號(hào)密碼的問題

賬號(hào)密碼錯(cuò)誤,這個(gè)問題聽起來很扯,但是開發(fā)過程中,很多人會(huì)忽略掉。為什么這么說?我使用的是config-lite模塊來配置數(shù)據(jù)庫參數(shù),因?yàn)闀?huì)在多個(gè)系統(tǒng)環(huán)境中切換開發(fā),使用config-lite模塊可以通過簡單的環(huán)境變量配置,來加載不同的參數(shù)文件。具體用法參照:不同環(huán)境下配置文件使用。

我的問題就出現(xiàn)在這里,打開一個(gè)終端運(yùn)行項(xiàng)目npm run test,package.json文件里配置著test的運(yùn)行腳本NODE_ENV=test supervisor --harmony -i views/ ./bin/www。另打開一個(gè)終端,運(yùn)行數(shù)據(jù)庫同步的命令,同步命令是單獨(dú)寫在一個(gè)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ù)庫的時(shí)候,總是如標(biāo)題報(bào)錯(cuò),然而覺得沒錯(cuò)啊,最后檢查才發(fā)現(xiàn)問題所在:運(yùn)行test腳本里的NODE_ENV環(huán)境變量只在當(dāng)前終端下才有效,如果要另開一個(gè)終端來同步數(shù)據(jù)庫,那么需要在另開的終端里再設(shè)置一下環(huán)境變量。不然加載的數(shù)據(jù)庫參數(shù)是不一致的,也就是說連接數(shù)據(jù)庫的用戶名密碼是不對(duì)的。

以上是“Node使用Sequlize連接Mysql報(bào)錯(cuò)怎么辦”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI