手机
当前位置:查字典教程网 >操作系统 >unix linux >管理用SSH远程登录Linux服务器的用户的权限
管理用SSH远程登录Linux服务器的用户的权限
摘要:为了满足“breakqiang”的需要,在国外的Linux主机上(比如DreamHost)上建个可ssh登录的用户,...

为了满足“break qiang”的需要,在国外的Linux主机上(比如 DreamHost )上建个可 ssh登录的用户,使用 ssh 的 Tunnel 来作代理是十分常见的方法。

但是主人往往又想最小化用户权限,以避免对系统造成影响。最简单的办法就是,禁止用户登录。

其实 ssh 可以连接到 sshd 但是不执行远程命令(默认是启动用户设定的 shell ),使用 -N 参数即可。

在服务器上建一个 username :

添加用户:useradd -s /bin/false username,将用户的shell设置成/bin/false。这样用户就无法与系统进行交互。

设置密码:passwd username

当然对已有的用户也可以更改用户权限为只能tcp转发:

usermod -s /bin/false USERNAME

也可以使用 /usr/bin/passwd 作为用户的 shell ,这样用户就可以通过登录而来自主修改密码。需要注意的是,需要将 /usr/bin/passwd 这一行写进 /etc/shells文件。

sshd 认证通后之后,会检查设定的 shell 是否登记在 /etc/shells 文件中,若已经登记,则fork自己,然后fork出来的子进程再exec 设定的 shell 。而 ssh 的 -N 参数,则是告诉 sshd 不需要执行 shell。

建立Tunnel:

ssh -D 1080 -qfnN username@hostname

输入密码即可使用(也可以用key认证)。

Windows的话,可以使用plink.exe或者MyEnTunnel(MyEnTunnel 本质上也是使用plink.exe来建立Tunnel)。

此时账号username 可以通过sshd的认证使用 TcpForwarding ,但是不能运行 shell,不能与系统交互。刚好可以用来为朋友提供国外的代理break qiang。

参数详解:

-D 1080 建立动态Tunnel,监听在本地1080端口。

-q 安静模式。

-f ssh在后台运行,即认证之后,ssh退居后台。

-n 将 stdio 重定向到 /dev/null,与-f配合使用。

-N 不运行远程程序。即通知 sshd 不运行设定的 shell。

【管理用SSH远程登录Linux服务器的用户的权限】相关文章:

Linux上最常用的用户名和密码 有的快改

Linux下DNS服务器架设攻略 3

Linux服务器安全小技巧

linux w命令参数及用法详解(linux查看在线用户命令)

suse 10配置SSH无密码登录的步骤

使用 WinSCP 管理 Linux VPS/服务器上的文件 图文教程

Linux下Web服务器架设攻略

用root安全登录VPS 的方法

Linux下DNS服务器架设攻略

配置Sendmail服务器以防治垃圾邮件

精品推荐
分类导航