小白准备网络同步复制系统--实验理解为成功

Web、Mail、Ftp、DNS、Proxy、VPN、Samba、LDAP 等基础网络服务
回复
头像
eexpress
帖子: 58428
注册时间: 2005-08-14 21:55
来自: 长沙

小白准备网络同步复制系统--实验理解为成功

#1

帖子 eexpress » 2006-03-23 15:50

2006-3-23 周四, 下午3:47
晚上整理一下。

本记录思想是通过以太网络,配合简单的3个命令,实现把配置好了的完整系统复制到其他机器。以便于局域网上的快速安装,并减少单台机器系统配置的过程。

使用了3个命令:nc,dump,restore。

代码: 全选

netcat 简称 nc. Netcat 是一把非常简单易用的基于 TCP/IP 协议(C/S模型的)的“[color=red]瑞士军刀[/color]”(man里面,第一句就是这样说的),它能允许我们通过网络创建管道(pipe)。

dump 和 restore 是用于备份和恢复系统的常用命令。位于dump包中。可以apt-get install dump。
实验的目的:我们将源机器的根分区,通过 dump/restore 和 nc 来传送到目标机器的指定分区。 先实验将源机器的/var/cache/apt/archives/复制到目标机器。

1:在接收端(目标电脑),创建一个 netcat 的监听例程(-l),这个监听例程将管道输出到 restore。 把接受到的数据写到目标机器。
nc -l -p 2000 -q 1 | restore -r -f -

这里-p是建立一个端口。-q 选项是让 nc 在到达文件结束(EOF)时延时n秒后,自动停止运行。

2:在 源电脑, 创建另一个 netcat 的例程,这个例程将它从管道里得到的输入(也就是dump备份的数据)发给目标电脑。
dump -0 -f - /dir | nc <target-ip> 2000

这里 target-IP 是目标电脑的 IP 地址。 2000是端口号。

以下是man里面的原版说明,可以参考。

代码: 全选

restore说明: 
 -f file 
    Read  the  backup  from  file; file may be a special device file like /dev/st0 (a tape drive), /dev/sda1 (a disk drive), an ordinary file, or - (the standard input). If the name of the file isof the form host:file or user@host:file, restore reads from  the named file on the remote host using rmt(8). 

 -r     Restore (rebuild) a file system. The target file  system  should be made pristine with mke2fs(8), mounted, and the user cd’d into the pristine file system before starting the restoration of  the initial  level  0  backup. If the level 0 restores successfully, the -r flag may be used to  restore  any  necessary  incremental backups on top of the level 0. The -r flag precludes an interac‐tive file extraction and can be detrimental to one’s health (not to mention the disk) if not used carefully. An example: 

                     mke2fs /dev/sda1 
                     mount /dev/sda1 /mnt 
                     cd /mnt 
                     restore rf /dev/st0 

   Note  that  restore  leaves  a  file restoresymtable in the root directory  to  pass  information  between  incremental   restore passes.   This  file should be removed when the last incremental has been restored. 

代码: 全选

dump说明: 
-f file 
    Write the backup to file; file may be a special device file like /dev/st0 (a tape drive), /dev/rsd1c (a floppy  disk  drive),  an ordinary  file,  or - (the standard output). Multiple file names may be given as a single argument separated by commas. Each file will  be  used  for  one dump volume in the order listed; if the dump requires more volumes than the number of names  given,  the last file name will used for all remaining volumes after prompt‐ing for media changes. If the name of the file is  of  the  form host:file or user@host:file dump writes to the named file on the remote host (which should already exist, dump doesn’t  create  a new  remote  file)  using  rmt(8).  The default path name of the remote rmt(8) program is /etc/rmt; this can be overridden by the environment variable RMT. 

[-level#] 

代码: 全选

nc - TCP/IP swiss army knife说明: 
       -l           listen mode, for inbound connects 
       -n           numeric-only IP addresses, no DNS 
       -o file      hex dump of traffic 
       -p port      local port number  (port  numbers  can  be  individual  or ranges: lo-hi [inclusive]) 
       -q seconds   after  EOF  is detected, wait the specified number of seconds and then quit. 
-------------------------
实验结果,数据送传可以,只是目标路径有些偏差。2边执行了

代码: 全选

sudo dump -0 -f - /var/cache/apt/archives/ | nc 10.23.1.100 2000 
[color=blue][b][size=150]~[/size][/b][/color]$ nc -l -p 2000 -q 1 | restore -r -f - 
结果数据全部传送到了~/var/cache/apt/archives/。
当时考虑失误,安装目标机器系统时,图简单,安装时选了格式全盘,安装的server,然后安装了dump包。结果搞得没有空闲分区测试。直接根目录对根目录传送,提示失败,被中断。想来也想得到。挂载了并且在运行中的根目录怎么会让你覆盖哦。

总体来说,实验还是成功的。数据传送正常。以后就只要找个带了nc/dump/restore命令的live cd。就可以在裸机或者其他任何有空间的机器上,复制其他机器上配置好了的linux系统了。我想以太网络的速度应该比usb硬盘之类的要好得多。 :lol: 省去了独立安装系统时,系统检测,解包,下载包,配置软件的时间,这些也是占用很长的时间的。

忘记了,复制以后,需要按照机器设置,修改/etc/fstab(分区结构), /etc/network/interfaces(网络ip,dhcp的就可以不要修改), /boot/grub/menu.lst(多数不要修改,除开目标机器有其他不同的系统), 然后就是显卡和声卡(这个我以前写过),硬件的驱动。
:lol:
● 鸣学
头像
firehare
帖子: 2625
注册时间: 2005-04-10 16:54
来自: 温州大学
联系:

#2

帖子 firehare » 2006-03-23 23:00

兄弟厉害,居然想到用黑客工具来做网络复制,佩服佩服!

不过照你的说法,目标机是否已经运行了Linux?如果是这样的话,用ssh直接网络对拷或直接用同步软件同步也是可以的!
我心无畏,源自于我心无知。
图片
头像
eexpress
帖子: 58428
注册时间: 2005-08-14 21:55
来自: 长沙

#3

帖子 eexpress » 2006-03-23 23:06

ssh,我看了显得罗嗦一些。我喜欢nc的这种管道操作。很灵活的。
目标机器,我准备下步找个合适的live cd试试。这样安装就容易了。
● 鸣学
头像
firehare
帖子: 2625
注册时间: 2005-04-10 16:54
来自: 温州大学
联系:

#4

帖子 firehare » 2006-03-24 13:30

ssh还好了,你可以用scp来做,用法除了需要加另一台机器的用户名和机器IP外,同cp命令一样!
我心无畏,源自于我心无知。
图片
头像
eexpress
帖子: 58428
注册时间: 2005-08-14 21:55
来自: 长沙

#5

帖子 eexpress » 2006-03-24 19:08

ssh也可以直接使用密码方式。不用ssh-keygen。scp也可以。只是一直认为cp对于管道,套接字这些特殊文件的复制好像有问题。不知道是不是。

我在撺掇fanx加dump,restore和nc的组合。 :lol:
● 鸣学
血色眼泪
帖子: 335
注册时间: 2005-12-27 21:15
联系:

#6

帖子 血色眼泪 » 2006-03-24 20:34

firehare 写了:兄弟厉害,居然想到用黑客工具来做网络复制,佩服佩服!

不过照你的说法,目标机是否已经运行了Linux?如果是这样的话,用ssh直接网络对拷或直接用同步软件同步也是可以的!
cn的功能很强大

以前我们还用他聊过天
头像
eexpress
帖子: 58428
注册时间: 2005-08-14 21:55
来自: 长沙

#7

帖子 eexpress » 2006-03-24 20:44

哈,有一个赞成的了。我喜欢自己开端口的方式。
● 鸣学
头像
firehare
帖子: 2625
注册时间: 2005-04-10 16:54
来自: 温州大学
联系:

#8

帖子 firehare » 2006-03-24 23:35

nc当然牛了
这可以真正的网络利器
瑞士军刀之称名符其实
可以用做各种用途
一般黑客都用它!
我心无畏,源自于我心无知。
图片
networker
帖子: 419
注册时间: 2006-02-06 21:06
来自: Shanghai,China
联系:

#9

帖子 networker » 2006-03-25 23:12

佩服。
头像
bones7456
帖子: 8495
注册时间: 2006-04-12 20:05
来自: 杭州
联系:

#10

帖子 bones7456 » 2006-04-24 20:51

厉害!光想法就令人佩服!
回复