小編給大家分享一下Node使用Sequlize連接Mysql報(bào)錯(cuò)怎么辦,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
10年專(zhuān)注成都網(wǎng)站制作,成都定制網(wǎng)頁(yè)設(shè)計(jì),個(gè)人網(wǎng)站制作服務(wù),為大家分享網(wǎng)站制作知識(shí)、方案,網(wǎng)站設(shè)計(jì)流程、步驟,成功服務(wù)上千家企業(yè)。為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁(yè)設(shè)計(jì)及定制高端網(wǎng)站建設(shè)服務(wù),專(zhuān)注于成都定制網(wǎng)頁(yè)設(shè)計(jì),高端網(wǎng)頁(yè)制作,對(duì)成都?jí)w彩繪等多個(gè)方面,擁有豐富的網(wǎng)站建設(shè)經(jīng)驗(yàn)。前言
最近在工作中遇到問(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ò)誤:訪(fǎng)問(wèn)拒絕,關(guān)鍵是訪(fǎng)問(wèn)拒絕的錯(cuò)誤,說(shuō)明數(shù)據(jù)庫(kù)連接這里有問(wèn)題,數(shù)據(jù)庫(kù)連接訪(fǎng)問(wèn)拒絕,要么是沒(méi)有相應(yīng)的操作權(quán)限,要么是賬號(hào)密碼錯(cuò)誤。
這樣就把問(wèn)題定位在訪(fǎng)問(wèn)權(quán)限以及賬號(hào)密碼錯(cuò)誤兩點(diǎn)上了,千萬(wàn)不要忘其他方面去找問(wèn)題了,那樣只會(huì)是浪費(fèi)時(shí)間。
1. 用戶(hù)權(quán)限的問(wèn)題
權(quán)限問(wèn)題從數(shù)據(jù)庫(kù)著手,確認(rèn)用戶(hù)授權(quán)后,是否刷新的權(quán)限列表。也就是在使用Grant命令授權(quán)用戶(hù)后,應(yīng)該要使用flush privileges命令,這個(gè)是很多人會(huì)忽略的問(wèn)題。
如果用戶(hù)授權(quán)沒(méi)有問(wèn)題,那么嘗試重啟mysql服務(wù)器。使用命令/etc/init.d/mysql restart重啟mysql服務(wù)器,不同Linux版本重啟命令可能不一樣,我這里是Debain系。
如果重啟了問(wèn)題還沒(méi)有解決,那么可能就不是數(shù)據(jù)庫(kù)用戶(hù)權(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ù)的用戶(hù)名密碼是不對(duì)的。
以上是“Node使用Sequlize連接Mysql報(bào)錯(cuò)怎么辦”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線(xiàn),公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性?xún)r(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿(mǎn)足用戶(hù)豐富、多元化的應(yīng)用場(chǎng)景需求。
當(dāng)前題目:Node使用Sequlize連接Mysql報(bào)錯(cuò)怎么辦-創(chuàng)新互聯(lián)
轉(zhuǎn)載注明:http://muchs.cn/article28/dgidjp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)、手機(jī)網(wǎng)站建設(shè)、企業(yè)網(wǎng)站制作、定制網(wǎng)站、全網(wǎng)營(yíng)銷(xiāo)推廣、電子商務(wù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容