作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们正在使用无服务器框架使用 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/
我正在开发一个 voip 调用应用程序。我需要做的是在接到来电时将 Activity 带到前台。我在应用程序中使用 Twilio,并在收到推送消息时开始调用。 问题是我试图在接到任何电话时显示 Act
我是一名优秀的程序员,十分优秀!