如何使用Ubuntu 10.04设置USB-over-IP服务器和客户端
本教程将介绍如何使用Ubuntu 10.04以及USB-over-IP客户端(也运行Ubuntu 10.04)设置USB-over-IP服务器。 USB / IP项目旨在通过IP网络开发一个通用的USB设备共享系统。 要在具有完整功能的计算机之间共享USB设备,USB / IP将“USB I / O消息”封装到TCP / IP有效载荷中,并在计算机之间传输。 USB over IP可以用于虚拟机,例如,无法访问主机系统的硬件 - USB-over-IP允许虚拟机使用远程USB设备。
我不会保证这将为您工作!
1初步说明
本教程基于AliRezaTaleghani的教程如何修改您的Gnu / Linux框以服务于IP over IP Server ,但我已经调整了Ubuntu 10.04(服务器和客户端)。 如果您想使用Windows客户端,请查看AliRezaTaleghani的教程 - 该部分仍然相同。
在本教程中,我使用服务器server1.example.com
,IP地址为192.168.0.100
,客户端client1.example.com
的IP地址为192.168.0.101
,都运行Ubuntu 10.04。 这些设置可能会有所不同,因此您必须在适当的情况下更换它们。
2在服务器上安装和使用USB / IP
server1:
我们可以安装usbip
如下:
aptitude install usbip
之后我们加载usbip
内核模块:
modprobe usbip
modprobe usbip_common_mod
要检查是否真的加载,运行:
lsmod | grep usbip
输出应与此类似:
root@server1:~# lsmod | grep usbip
usbip 15124 0
usbip_common_mod 13605 1 usbip
root@server1:~#
为了确保两个模块在引导系统时自动加载,您可以将它们添加到/ etc / modules中
:
vi /etc/modules
[...] usbip usbip_common_mod |
现在我们可以启动usbip
守护进程:
usbipd -D
root@server1:~# usbipd -D
Bind usbip.ko to a usb device to be exportable!
root@server1:~#
现在附上要导出到服务器的USB设备 - 我在这里使用SanDisk USB闪存驱动器。
执行命令
lsusb
以找到相应的供应商/设备ID,其形式为:
Bus XXX Device YYY: ID VendorID:DeviceID
我的服务器上的输出如下:
root@server1:~# lsusb
Bus 001 Device 002: ID 0781:5151 SanDisk Corp. Cruzer Micro Flash Drive
Bus 001 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
root@server1:~#
我的SanDisk USB闪存驱动器的供应商/设备ID为0781:5151
。
现在跑
usbip_bind_driver --list
我的服务器上的输出如下:
root@server1:~# usbip_bind_driver --list
List USB devices
- busid 1-1 (0781:5151)
1-1:1.0 -> usb-storage
root@server1:~#
如您所见,我的SanDisk USB闪存驱动器的供应商/设备ID( 0781:5151
)对应于BUSID 1-1
。 我们需要这个BUSID将USB设备连接到服务器:
usbip_bind_driver --usbip 1-1
root@server1:~# usbip_bind_driver --usbip 1-1
** (process:765): DEBUG: 1-1:1.0 -> usb-storage
** (process:765): DEBUG: unbinding interface
** (process:765): DEBUG: write "add 1-1" to /sys/bus/usb/drivers/usbip/match_busid
** Message: bind 1-1 to usbip, complete!
root@server1:~#
就这样,我们现在可以在远程usbip
客户端上使用SanDisk USB闪存驱动器。
BTW,如果你运行...
netstat -tap
...你应该看到usbip
守护进程正在监听端口3240,所以请确保该端口没有被防火墙阻止:
root@server1:~# netstat -tap
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 *:ssh *:* LISTEN 537/sshd
tcp 0 0 *:3240 *:* LISTEN 762/usbipd
tcp 0 52 server1.example.com:ssh 192.168.0.199:4024 ESTABLISHED 667/0
tcp6 0 0 [::]:ssh [::]:* LISTEN 537/sshd
root@server1:~#