QEMU KVM Libvirt手册(6):Network Block Device

本文深入探讨NBD网络块设备的工作原理,介绍如何通过NBDServer导出虚拟块设备,实现远程访问。涵盖qemu-nbd的使用,包括设置socket连接、参数配置如--share、--snapshot、--read-only等,以及如何处理LVM和多分区映像。

网络块设备是通过NBD Server将虚拟块设备通过TCP/IP export出来,可以远程访问。

NBD Server通常是qemu-nbd

可以提供unix socket

qemu-nbd -t -k /home/cliu8/images/ubuntutest-nbd ubuntutest.img

打开另一个窗口,可以连接这个unix socket

qemu-system-x86_64 -enable-kvm -name ubuntutest  -m 2048 -hda nbd:unix:/home/cliu8/images/ubuntutest-nbd -vnc :19 -net nic,model=virtio -net tap,ifname=tap0,script=no,downscript=n

可以提供普通的socket连接

qemu-nbd -t -p 1088 ubuntutest.img

打开另一个窗口,可以连接这个port

qemu-system-x86_64 -enable-kvm -name ubuntutest  -m 2048 -hda nbd:localhost:1088 -vnc :19 -net nic,model=virtio -net tap,ifname=tap0,script=no,downscript=n

参数--share=num,可以多个客户端同时访问这个server

参数--snapshot,说明任何修改都放在临时文件中

参数—read-only,则只读模式export这个设备

如果有参数—connect = dev,则可以直接将image付给一个network block device,并且可以mount它

qemu-nbd -c /dev/nbd0 ubuntutest.img

这时候我们ls,发现

# ls /dev/nbd0*
/dev/nbd0  /dev/nbd0p1  /dev/nbd0p2  /dev/nbd0p5

其实ubuntutest.img中有至少三个partition

# fdisk -l /dev/nbd0

Disk /dev/nbd0: 5368 MB, 5368709120 bytes
255 heads, 63 sectors/track, 652 cylinders, total 10485760 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x00077a7b

     Device Boot      Start         End      Blocks   Id  System
/dev/nbd0p1   *        2048     6291455     3144704   83  Linux
/dev/nbd0p2         6293502    10483711     2095105    5  Extended
/dev/nbd0p5         6293504    10483711     2095104   82  Linux swap / Solaris

通过fdisk验证,的确是这样的

我们可以mount其中的一个

mkdir ubuntutestp1

mount /dev/nbd0p1 ubuntutestp1/

# cd ubuntutestp1/
# ls
bin   dev  home        lib    lost+found  mnt  proc  run   srv  tmp  var
boot  etc  initrd.img  lib64  media       opt  root  sbin  sys  usr  vmlinuz

这个时候我们可以对里面的文件修改,就修改了image了。

修改完毕后,我们umount

# umount ubuntutestp1
# qemu-nbd -d /dev/nbd0
/dev/nbd0 disconnected

其实并不是所有的都这么简单

# qemu-nbd -c /dev/nbd0 centos-5.8.new.qcow2 
# fdisk -l /dev/nbd0

Disk /dev/nbd0: 10.7 GB, 10737418240 bytes
255 heads, 63 sectors/track, 1305 cylinders, total 20971520 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x000f117e

     Device Boot      Start         End      Blocks   Id  System
/dev/nbd0p1   *          63      208844      104391   83  Linux
/dev/nbd0p2          208845    20964824    10377990   8e  Linux LVM

我们发现里面有LVM,当然LVM不能作为整体访问,因为里面有Logic volume,都是单独成文件系统的

# lvscan
  inactive          '/dev/VolGroup00/LogVol00' [5.97 GiB] inherit
  inactive          '/dev/VolGroup00/LogVol01' [3.91 GiB] inherit
# vgscan
  Reading all physical volumes.  This may take a while...
  Found volume group "VolGroup00" using metadata type lvm2
# pvscan
  PV /dev/nbd0p2   VG VolGroup00            lvm2 [9.88 GiB / 0    free]

由于logical volume处于inactive的状态

# vgimport VolGroup00
  Volume group "VolGroup00" is not exported

# vgchange -ay VolGroup00
  2 logical volume(s) in volume group "VolGroup00" now active

这下可以分别mount两个LV了

# mount  /dev/VolGroup00/LogVol00 ubuntutestp1/       
# cd ubuntutestp1/
# ls
bin  boot  dev  etc  home  lib  lib64  lost+found  media  misc  mnt  opt  proc  root  sbin  selinux  srv  sys  tmp  usr  var

完毕后

umount ubuntutestp1

# vgchange -an VolGroup00
  0 logical volume(s) in volume group "VolGroup00" now active

# vgexport VolGroup00
  Volume group "VolGroup00" successfully exported

# qemu-nbd -d /dev/nbd0
/dev/nbd0 disconnected

在linux下,一个更高效的network block device是nbd-server,另有nbd-client连接server,形成一个/dev/ndb0

转载于:https://www.cnblogs.com/Ansing/p/5844414.html

<think>嗯,用户问如何回退Git远程提交记录。我需要仔细思考这个问题,确保给出正确的步骤和注意事项。首先,用户可能已经将一些提交推送到远程仓库,但后来发现有问题,想要撤销这些提交。这时候,回退远程提交就需要用到Git的一些命令,比如git reset或者git revert,但要注意不同的方法有不同的影响。 首先,我应该考虑本地回退和强制推送到远程的情况。通常的做法是在本地回退到某个提交,然后使用git push --force来覆盖远程分支。但这样做有风险,尤其是当其他人也在同一个分支上工作时,可能会导致他们的提交丢失。需要提醒用户注意这一点。 接着,可能需要具体步骤。例如,用户需要先使用git log找到要回退到的提交的哈希值,然后用git reset --hard <commit-hash>来回退本地分支。之后,强制推送到远程仓库。但必须强调,只有在确定没有其他人依赖该分支的情况下才能这么做。 另外,git revert也是一个安全的选择,因为它会创建新的提交撤销之前的更改,而不会重写历史。这对于团队合作的项目更安全,因为不会影响其他人的工作流程。但用户的问题明确是回退远程提交,可能他们希望彻底删除某些提交,而不仅仅是撤销更改。 还有,可能需要提到其他相关命令,比如git push --force-with-lease,它比--force更安全,因为它会检查远程分支的当前状态是否与本地预期一致,避免覆盖其他人的提交。 还需要考虑分支保护的情况,比如在GitHub或GitLab上,默认分支可能被保护,不允许强制推送。这时候用户可能需要暂时解除保护,或者在临时分支上操作,然后通过合并请求来回退。 此外,提醒用户在操作前备份当前状态,比如创建一个临时分支,以防万一操作出错可以恢复。同时,强调在执行强制推送后,其他协作者需要同步他们的本地仓库,避免出现不一致的情况。 总结一下,回答的结构应该是先说明风险,再给出不同的方法(reset + force push,revert),比较它们的适用场景,然后分步骤说明操作流程,最后给出注意事项和建议。需要确保用户理解每种方法的后果,并根据实际情况选择合适的方式。</think>要回退Git远程提交记录,需谨慎操作以避免影响团队协作。以下是具体操作步骤及注意事项: --- ### 一、操作原理 Git远程提交记录本质是修改分支指针位置,通过本地回退后强制推送(force push)覆盖远程分支。⚠️ 此操作会重写历史记录,可能影响其他协作者。 --- ### 二、具体步骤 #### 方法1:使用 `git reset`(彻底删除提交) 1. **定位目标提交** ```bash git log --oneline # 找到要回退到的提交哈希值(如 abc123) ``` 2. **本地回退** ```bash git reset --hard abc123 # 将本地分支回退到目标提交 ``` 3. **强制推送到远程** ```bash git push --force origin 分支名 # 覆盖远程分支 # 更安全的替代命令: git push --force-with-lease origin 分支名 # 检查远程状态是否与本地预期一致 ``` #### 方法2:使用 `git revert`(安全撤销,保留历史) 1. **撤销指定提交** ```bash git revert 要撤销提交哈希值 # 生成一个反向提交 ``` 2. **推送新提交** ```bash git push origin 分支名 # 无需强制推送 ``` --- ### 三、关键对比 | 方法 | 适用场景 | 优点 | 缺点 | |------------|------------------------------|---------------------|-----------------------| | `git reset`| 个人分支/需要彻底
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值