日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

nodejs mysql access denied_Node使用Sequlize连接Mysql报错:Access denied for user ‘xxx’@‘localhost’...

發(fā)布時(shí)間:2025/3/8 数据库 15 豆豆
生活随笔 收集整理的這篇文章主要介紹了 nodejs mysql access denied_Node使用Sequlize连接Mysql报错:Access denied for user ‘xxx’@‘localhost’... 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

前言

最近在工作中遇到問(wèn)題,問(wèn)題如下:

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ò)誤:訪問(wèn)拒絕,關(guān)鍵是訪問(wèn)拒絕的錯(cuò)誤,說(shuō)明數(shù)據(jù)庫(kù)連接這里有問(wèn)題,數(shù)據(jù)庫(kù)連接訪問(wèn)拒絕,要么是沒(méi)有相應(yīng)的操作權(quán)限,要么是賬號(hào)密碼錯(cuò)誤。

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

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

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

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

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

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

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

我的問(wèn)題就出現(xiàn)在這里,打開(kāi)一個(gè)終端運(yùn)行項(xiàng)目npm run test,package.json文件里配置著test的運(yùn)行腳本NODE_ENV=test supervisor --harmony -i views/ ./bin/www。另打開(kāi)一個(gè)終端,運(yùn)行數(shù)據(jù)庫(kù)同步的命令,同步命令是單獨(dú)寫(xiě)在一個(gè)js腳本中,腳本里引用了數(shù)據(jù)連接方法(通用的),連接方法如下:

var Sequelize = require('sequelize');

// 引入數(shù)據(jù)庫(kù)配置文件

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ù)庫(kù)的時(shí)候,總是如標(biāo)題報(bào)錯(cuò),然而覺(jué)得沒(méi)錯(cuò)啊,最后檢查才發(fā)現(xiàn)問(wèn)題所在:運(yùn)行test腳本里的NODE_ENV環(huán)境變量只在當(dāng)前終端下才有效,如果要另開(kāi)一個(gè)終端來(lái)同步數(shù)據(jù)庫(kù),那么需要在另開(kāi)的終端里再設(shè)置一下環(huán)境變量。不然加載的數(shù)據(jù)庫(kù)參數(shù)是不一致的,也就是說(shuō)連接數(shù)據(jù)庫(kù)的用戶名密碼是不對(duì)的。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

總結(jié)

以上是生活随笔為你收集整理的nodejs mysql access denied_Node使用Sequlize连接Mysql报错:Access denied for user ‘xxx’@‘localhost’...的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。