gpt4 book ai didi

javascript - 如何使用 JavaScript 从 Azure Functions 连接到 Microsoft SQL Server?

转载 作者:行者123 更新时间:2023-12-02 06:55:27 27 4
gpt4 key购买 nike

我们正在使用无服务器框架使用 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 后面的虚拟机上?

如果是这样,您将需要将 Function App 与该虚拟网络集成。请参阅Microsoft guide .

关于javascript - 如何使用 JavaScript 从 Azure Functions 连接到 Microsoft SQL Server?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/72326522/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com