0
我想知道当我的应用程序在SQL Server本地运行。这是备份和恢复所必需的。如何通过连接获取SQL Server的IP地址或DNS名称?
我想知道当我的应用程序在SQL Server本地运行。这是备份和恢复所必需的。如何通过连接获取SQL Server的IP地址或DNS名称?
我从Connection.DataSource获取服务器的IP地址(DNS名称)。然后我检查一下,是否有此名称的列表:
localNames = new List<string>()
{
".", "localhost", "(local)", "127.0.0.1", Environment.MachineName.ToLower(),
};
localNames.AddRange(GetIP().Select(a=>a.ToString()));
if (localNames.Contains(GetServer(connection.DataSource).ToLower()))
{
//do something
}
方法:
IEnumerable<IPAddress> GetIP()
{
foreach (var ip in Dns.GetHostEntry(Dns.GetHostName()).AddressList.Where(ip => ip.AddressFamily == AddressFamily.InterNetwork))
{
yield return ip;
}
}
string GetServer(string dataSource)
{
return dataSource.Split('\\').First().Split(',').First().Split(':').Last();
}
数据源可以是: