程序使用 Node 編寫,后端數(shù)據(jù)庫為 MySQL,提供 APP 后端 API 及 socket 連接服務。目前單實例部署,實例內(nèi)使用一個 MySQL 連接。服務初期工作一切正常,隨著服務時間變長(一天到一周不等),某個時間點,一個 API 調(diào)用會發(fā)生失敗,發(fā)生該錯誤之后,后續(xù)的所有數(shù)據(jù)庫讀寫操作都會失敗。API 服務代碼出錯的原因是:向 MySQL 插入一條記錄失敗,我在關鍵代碼處插入了一些代碼:
self.conn.query(sql, function(err, res, fields){
if(err){
callback && callback(ERRCODE.MYSQL.code, err);
}else{
if (!res.insertId) {
logger.error('activity.insertActivitySpeaker: insertId undefined');
} else {
logger.info('success: activity.insertActivitySpeaker: insertId %s', res.insertId);
}
callback && callback(0, res);
}
});
比較難理解的是,插入操作失敗時,代碼
logger.info('success: activity.insertActivitySpeaker: insertId %s', res.insertId);
仍被執(zhí)行,且打印了一個正常的 id(自增),但是 MySQL binlog 中并無相應的操作日志,且最終數(shù)據(jù)庫里也查不到 id 對應的那條記錄。目前猜測是服務長時間運行或代碼邏輯漏洞導致 MySQL 連接異常:向 MySQL 嘗試寫入時,可以獲得一個寫入 id,但最終的寫入操作未執(zhí)行成功,而從數(shù)據(jù)庫讀取的操作,返回的數(shù)據(jù)都是空。不知朋友們有沒有遇到過類似問題,給些排查建議,萬分感謝。
問題原因是使用事務時,缺少 rollback 或 commit,使用以下代碼可穩(wěn)定復現(xiàn)這個錯誤:
let mysql = require("mysql");
function createConn() {
return mysql.createConnection({
host : '192.168.1.100',
user : 'yangqiang',
password : '123456',
database : 'node_mysql_demo'
});
}
function transactionWithoutCommit(conn) {
conn.beginTransaction(function (err) {
if (err) {
throw err;
}
conn.query('SELECT * from user where name="jonny"', function (error, results, fields) {
if (error) {
return conn.rollback(function () {
throw error;
})
} else {
// 缺少 commit,引發(fā)錯誤
}
});
});
}
function transactionWithCommit(conn) {
conn.beginTransaction(function (err) {
if (err) {
throw err;
}
conn.query('SELECT * from user where name="jonny"', function (error, results, fields) {
if (error) {
return conn.rollback(function () {
throw error;
})
} else {
conn.commit(function (err) {
if (err) {
return conn.rollback(function(){ throw err;})
} else {
console.log('transaction committed');
}
});
}
});
});
}
function write(conn) {
conn.query('INSERT INTO user (name) VALUES ("Mei");', function (error, results, fields) {
if (error) throw error;
console.log(JSON.stringify(results));
});
}
var connection = createConn();
connection.connect();
transactionWithoutCommit(connection); // 引發(fā)錯誤
// transactionWithCommit(connection); // 正確的方法
write(connection);
北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學院和江蘇省首批服務外包人才培訓基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術與教育服務機構,發(fā)展為教育服務業(yè)的綜合性企業(yè)集團,成為集合面授教學培訓、網(wǎng)
達內(nèi)教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構,是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
浪潮集團項目經(jīng)理。精通Java與.NET 技術, 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務負責iOS教學及管理工作。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術顧問,美國Dachieve 系統(tǒng)架構師,美國AngelEngineers Inc. 系統(tǒng)架構師。