仅允许指定的机器连接SQL Server服务器
创始人
2024-07-23 21:50:41
0

问题:希望仅仅允许某个指定IP的计算机连接到SQL Server服务器,但不允许其他的客户端进行连接。

解决方法如下:

  你可以直接在防火墙中做限制,只允许与指定的IP地址建立1433的通讯。(注:从安全的角度来考虑,应该把1433端口改成其他的端口。)

其他的解决方法:

  一、限从指定IP接入的客户端:

  如果使用SQL Server 2005,还可以通过端点限制的方法来实现,此方法要求一块专门的网卡,所有可以连接SQL Server的客户端均通过此网卡接入(假设此网卡的IP是192.168.1.1):

  1.在“SQL Server 配置管理器”的“SQL Server 2005网络配置中”,禁止除TCP/IP之外的所有协议;

  2.使用如下的T-SQL禁止默认的TCP端点

  ALTER ENDPOINT [TSQL Default TCP]
  STATE = STOPPED

  3.使用如下的T-SQL建立新的TCP端点和授权

  USE master
  GO
  -- 建立一个新的端点
  CREATE ENDPOINT [TSQL User TCP]
  STATE = STARTED
  AS TCP(
  LISTENER_PORT = 1433,
  LISTENER_IP = (192.168.1.1) -- 侦听的网络地址
  )
  FOR TSQL()
  GO

  -- 授予所有登录(或者指定登录)使用此端点的连接权限

  GRANT CONNECT ON ENDPOINT::[TSQL User TCP]
  TO [public]

  完成以上的配置之后,只有通过网络地址配置为192.168.1.1的网卡接入的客户端才能访问SQL Server;此外,假如只授予指定登录对端点的连接权限,则只有指定的登录才能接入SQL Server实例。

  二、限指定IP的客户端接入

  当SQL Server 2005升级到SP2或者更高的版本的时候,你还可以通过新增的触发器来实现控制。

  执行一下的T-SQL后,IP地址为192.168.1.1以外的客户端连接将会出现失败的现象。

  USE master
  GO
  CREATE TRIGGER tr_LoginCheck
  ON ALL SERVER
  FOR LOGON
  AS
  IF EVENTDATA().value('(/EVENT_INSTANCE/ClientHost)[1]', 'varchar(15)') <> '192.168.1.1'
  ROLLBACK TRAN
  GO

通过上文中介绍的方法就能实现让只有允许了的机器才能连接到SQL Server服务器,这里只是介绍了这几种方法,并不是很全面,可能还有一些更好的方法,以后我还会继续为大家介绍这方面的内容。

【编辑推荐】

  1. 多台SQL Server服务器管理
  2. 远程登录sql server服务器的实现方法
  3. 浅谈如何优化SQL Server服务器

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
各种千兆交换机的数据接口类型详... 千兆交换机有很多值得学习的地方,这里我们主要介绍各种千兆交换机的数据接口类型,作为局域网的主要连接设...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
规避非法攻击 用好路由器远程管... 单位在市区不同位置设立了科技服务点,每一个服务点的员工都通过宽带路由器进行共享上网,和单位网络保持联...
范例解读VB.NET获取环境变... VB.NET编程语言的使用范围非常广泛,可以帮助开发人员处理各种程序中的需求,而且还能对移动设备进行...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...