我们正在使用无服务器框架在JavaScript中开发一个函数应用程序,并将其部署到Azure。
我们从Microsoft SQL Server 2014数据库中提取数据,当使用无服务器离线插件和VPN在本地环境中测试功能时,一切都很顺利。下面是建立连接的代码:
const mssql = require("mssql");
const sqlConfig = {
user: process.env["DB_USER"],
password: process.env["DB_PWD"],
database: process.env["DB_NAME"],
server: process.env["DB_HOST"],
pool: {
max: 10,
min: 0,
idleTimeoutMillis: 30000,
},
options: {
encrypt: true, // for azure
trustServerCertificate: false, // change to true for local dev / self-signed certs
},
};
// pool-manager.js
const pools = new Map();
module.exports = {
get: (name) => {
if (!pools.has(name)) {
const pool = new mssql.ConnectionPool(sqlConfig);
// automatically remove the pool from the cache if `pool.close()` is called
const close = pool.close.bind(pool);
pool.close = (...args) => {
pools.delete(name);
return close(...args);
};
pools.set(name, pool.connect());
}
return pools.get(name);
},
closeAll: () =>
Promise.all(
Array.from(pools.values()).map((connect) => {
return connect.then((pool) => pool.close());
})
),
};
我们也在使用Key Vault的引用,这些都正常工作。
问题是在部署功能时,从未建立到数据库的连接。这是我得到的错误:
{
"code": "ESOCKET",
"originalError": {
"code": "ESOCKET"
},
"name": "ConnectionError"
}
所以,我的问题是:在Azure中必须做什么,或者在我们的代码中必须改变什么才能允许这个连接?
感谢您的MS SQL 2014服务器是否在VNET后面的本地/虚拟机上托管?
如果是这样,你需要将你的功能应用程序与虚拟网络集成。