如何搭建ipv6网络

网上有通过mac电脑安装ipv6网络的(这种方式的教程请访问:http://www.tuicool.com/articles/InIjMzn),发现只能承受住很少的手机在线,如果想承担起大量的用户访问,请使用以下教程:
一、搭建ipv6单台主机环境
1 IPv6网络环境总图

Paste_Image.png

2 操作系统的安装
建议安装服务器为Mandrake8.2,或redhat7.2操作系统。在安装时,不要忘记选择Kernel Source这个内核源码的包。

3 编译配置IPv6协议
3.1 编译一个支持IPv6协议的新内核。

  1.     以root身份登陆,进入源码所在的目录:cd /usr/src/linux
    
  2.     运行 make clean,清除一些可能过期的中间代码。
    
  3.     然后配置内核选项:make menuconfig 或者 make xmenuconfig
    

运行make menuconfig后,将表1列出的选项选上,而其他内核选项请根据自己系统的具体情况作出符合自己系统的选择。
表1内核编译选项
内核编译主选项

内核编译子选项

选择

Code maturity level options

Prompt for development and/or incomplete code/drivers

Yes

Loadable module support

Enable loadable module support

No

General setup

Video mode selection support

Yes

Networking options

Packet socket

Yes

 

Unix domain sockets

Yes

 

TCP/IP networking

Yes

 

The IPv6 protocol

Yes

 

IPv6: enable EUI-64 token format

Yes

 

IPv6: disable provider based address

Yes

File systems

/proc filesystem support

Yes

Kernel hacking

Magic sysrq key

Yes

然后运行make dep; make clean; make bzImage

  1.                    如果没有错误,你现在已经编译成功了支持IPv6协议的内核了。cp arch/i386/boot/zImage /boot/vmlinuz-ipv6
    
  2.                    编辑你的lilo.conf使新的kernel成为boot的选择。
    
  3.     重起系统: reboot
    

3.2 编译iputils(ping6,tracepath6,traceroute6,等)
此工具替代了原先的Inet6-applications。
Mandrake8.2自带此安装包,配置好IPv6协议后,其自动安装。
3.3 编译iproute(测试IPv6的工具,比下面的net-tools新)
Mandrake8.2 也自带了此安装包,配置好IPv6协议后,其自动安装。
3.4 Net-Tools(包括hostname,netstat,arp,ifconfig,rarp,route)。
当前最新版本是Net-Tools1.54(http://www.tazenda.demon.co.uk/phil/net-tools/)。
安装步骤:

  1.     进入源码目录:cd /usr/src
    
  2.     解压源程序:tar xzf your-path/net-tools-version.tar.gz –C /usr/src
    
  3.     重新命名新目录:mv net-tools net-tools-version
    
  4.     建立符号链接:ln –sf /usr/src/net-tools-version /usr/src/net-tools
    
  5.     进入安装目录:cd /usr/src/net-tools
    
  6.     配置编译选项:make clean;make config
    

Net-tools 选项

子选项

选择

GNU gettext

 

Yes(如果使用glibc-2)

Protocol families

Unix protocol family

Yes

 

INET(tcp-ip)protocol family

Yes

 

INET(ipv6)protocol family

Yes

Device hardware types

SIT (IPv6-inIPv4) support

Yes

  1.     开始编译:make
    
  2.     安装:make install
    

4 配置网络
4.1 打开或关闭接口
4.1.1 使用“ip”
用法:

ip link set dev <interface> up

ip link set dev <interface> down

例子:

ip link set dev eth0 up

ip link set dev eth0 down

4.1.2 使用“ifconfig”
用法:

/sbin/ifconfig <interface> up

/sbin/ifconfig <interface> down

例子:

/sbin/ifconfig eth0 up

/sbin/ifconfig eth0 down

4.2 配置IPv6地址
4.2.1 显示现有IPv6地址
(1)使用“ip”
用法:

/sbin/ip -6 addr show dev <interface>

(2)使用“ifconfig”
用法:

/sbin/ifconfig <interface>

4.2.2 添加或删除一个IPv6地址
(1)使用“ip”
用法:

/sbin/ip -6 addr <add/del> <ipv6address>/<prefixlength> dev <interface>

例子:

/sbin/ip -6 addr add 3ffe:ffff:0:f101::1/64 dev eth0

(2)使用“ifconfig”
用法:

/sbin/ifconfig <interface> inet6 [add/del] <ipv6address>/<prefixlength>

例子:

/sbin/ifconfig eth0 inet6 add 3ffe:ffff:0:f101::1/64

4.3 配置IPv6路由
4.3.1 显示现有路由
(1)使用“ip”
用法:

/sbin/ip -6 route show [dev <device>]

例子:

/sbin/ip -6 route show dev eth0

3ffe:ffff:0:f101::/64 proto kernel metric 256 mtu 1500 advmss 1440
fe80::/10 proto kernel metric 256 mtu 1500 advmss 1440
ff00::/8 proto kernel metric 256 mtu 1500 advmss 1440
default proto kernel metric 256 mtu 1500 advmss 1440
(2)使用“route”
用法:

/sbin/route -A inet6

例子:

/sbin/route -A inet6 |grep -w "eth0"

3ffe:ffff:0:f101 ::/64 :: UA 256 0 0 eth0 <- Interface route for global address
fe80::/10 :: UA 256 0 0 eth0 <- Interface route for link-local address
ff00::/8 :: UA 256 0 0 eth0 <- Interface route for all multicast addresses
::/0 :: UDA 256 0 0 eth0 <- Automatic default route
4.3.2 增加或删除到一个网关的路由
(1)使用“ip”
用法:

/sbin/ip -6 route <add/del> <ipv6network>/<prefixlength> via <ipv6address> [dev <device>]

例子:

/sbin/ip -6 route <add/del> 2000::/3 via 3ffe:ffff:0:f101::1

(2)使用“route”
用法:

/sbin/route -A inet6 add <ipv6network>/<prefixlength> gw <ipv6address> [dev <device>]

如果网关的IPv6地址是一个链路地址,则需要加上dev <device>参数。
4.4 配置IPv6-in-IPv4隧道
4.4.1 隧道类型
(1)静态的点到点隧道:6bone
点到点的隧道是一个终端(endpoint)的专用隧道。配置这样的隧道需要知道:
Ø 你的本地隧道终端的IPv4地址必须是静态、全球唯一,并且外部隧道终端可以到达的地址。
Ø 分配给你的全球IPv6前缀
Ø 外部隧道终端能够将你的IPv6前缀路由到你的本地隧道终端
(2)自动隧道
自动产生的隧道,这发生在本节点和另外一个具有IPv4地址的节点有直接的链接时。
(3)6to4隧道

4.4.2 显示现有隧道
(1)使用“ip”
用法:

/sbin/ip -6 tunnel show [<device>]

例子:

/sbin/ip -6 tunnel show

sit0: ipv6/ip remote any local any ttl 64 nopmtudisc
sit1: ipv6/ip remote 195.226.187.50 local any ttl 64
(2)使用“route”
用法:

/sbin/route -A inet6

例子:

/sbin/route -A inet6 | grep "\Wsit0\W*$"

::/96 :: U 256 2 0 sit0
2002::/16 :: UA 256 0 0 sit0
2000::/3 ::193.113.58.75 UG 1 0 0 sit0
fe80::/10 :: UA 256 0 0 sit0
ff00::/8 :: UA 256 0 0 sit0
4.4.3 建立点到点隧道
共有3种可能的方法增加或删除点到点隧道的方法。
u 增加点到点隧道
(1)使用“ip”和“route”
建立少量隧道的通用方法。
建立一个隧道设备的用法(此后要让配置立刻生效,同时由于TTL的默认值为0,我们还要指定TTL的值):

/sbin/ip tunnel add <device> mode sit ttl <ttldefault> remote <ipv4addressofforeigntunnel> local <ipv4addresslocal>

三个通用的例子:

/sbin/ip tunnel add sit1 mode sit ttl <ttldefault> remote <ipv4addressofforeigntunnel1> local <ipv4addresslocal>

/sbin/ifconfig sit1 up

/sbin/route -A inet6 add <prefixtoroute1> dev sit1

/sbin/ip tunnel add sit2 mode sit ttl <ttldefault> <ipv4addressofforeigntunnel2> local <ipv4addresslocal>

/sbin/ifconfig sit2 up

/sbin/route -A inet6 add <prefixtoroute2> dev sit2

/sbin/ip tunnel add sit3 mode sit ttl <ttldefault> <ipv4addressofforeigntunnel3> local <ipv4addresslocal>

/sbin/ifconfig sit3 up

/sbin/route -A inet6 add <prefixtoroute3> dev sit3

(2)使用“ifconfig”和“route”(不推荐使用)
在只增加一个隧道时,没有任何问题,但当你建立多个隧道时,问题便出现了。这时,你不能够轻松的关闭前一个隧道,而同时让其它的隧道运行。
用法:(三个隧道的通用例子)

/sbin/ifconfig sit0 up

/sbin/ifconfig sit0 tunnel <ipv4addressofforeigntunnel1>

/sbin/ifconfig sit1 up

/sbin/route -A inet6 add <prefixtoroute1> dev sit1

/sbin/ifconfig sit0 tunnel <ipv4addressofforeigntunnel2>

/sbin/ifconfig sit2 up

/sbin/route -A inet6 add <prefixtoroute2> dev sit2

/sbin/ifconfig sit0 tunnel <ipv4addressofforeigntunnel3>

/sbin/ifconfig sit3 up

/sbin/route -A inet6 add <prefixtoroute3> dev sit3

(3)只使用“route”
用法:(3个通用的例子)

/sbin/ifconfig sit0 up

/sbin/route -A inet6 add <prefixtoroute1> gw ::<ipv4addressofforeigntunnel1> dev sit0

/sbin/route -A inet6 add <prefixtoroute2> gw ::<ipv4addressofforeigntunnel2> dev sit0

/sbin/route -A inet6 add <prefixtoroute3> gw ::<ipv4addressofforeigntunnel3> dev sit0

u 删除点到点的隧道
(1)使用“ip”和“route”
用法:

/sbin/ip tunnel del <device>

举三个通用的用法:

/sbin/route -A inet6 del <prefixtoroute1> dev sit1

/sbin/ifconfig sit1 down

/sbin/ip tunnel del sit1

/sbin/route -A inet6 del <prefixtoroute2> dev sit2

/sbin/ifconfig sit2 down

/sbin/ip tunnel del sit2

/sbin/route -A inet6 del <prefixtoroute3> dev sit3

/sbin/ifconfig sit3 down

/sbin/ip tunnel del sit3

(2)使用“ifconfig”和“route”(现在不推荐使用)
和创建隧道的命令一样,删除隧道的方式也令人很费解。最后创建的隧道必须最先删除。
用法:(3个常用例子)

/sbin/route -A inet6 del <prefixtoroute3> dev sit3

/sbin/ifconfig sit3 down

/sbin/route -A inet6 del <prefixtoroute2> dev sit2

/sbin/ifconfig sit2 down

/sbin/route -A inet6 add <prefixtoroute1> dev sit1

/sbin/ifconfig sit1 down

/sbin/ifconfig sit0 down

(3)使用“route”
这有点像删除通常的IPv6路由。
用法:(3个常用例子)

/sbin/route -A inet6 del <prefixtoroute1> gw ::<ipv4addressofforeigntunnel1> dev sit0

/sbin/route -A inet6 del <prefixtoroute2> gw ::<ipv4addressofforeigntunnel2> dev sit0

/sbin/route -A inet6 del <prefixtoroute3> gw ::<ipv4addressofforeigntunnel3> dev sit0

/sbin/ifconfig sit0 down

4.4.4 建立6to4隧道
u 增加6to4隧道
(1)使用“ip”和一个专用的隧道设备(推荐采用方式)
建立一个新的隧道设备:

/sbin/ip tunnel add tun6to4 mode sit remote any local <localipv4address>

激活此隧道接口:

/sbin/ip link set dev tun6to4 up

给隧道接口增加本地6to4地址

/sbin/ip -6 addr add <local6to4address>/16 dev tun6to4

使用全6to4路由器IPv4任播地址向全球IPv6网络增加一个(默认的)路由器:

/sbin/ip -6 route add 2000::/3 via ::192.88.99.1 dev tun6to4 metric 1

(2)使用“ifconfig”和“route”以及通常的(generic)隧道设备“sit0”(不推荐使用)
缺点:使用“sit0”不允许每个设备的特定的过滤。
激活通常隧道接口“sit0”:

/sbin/ifconfig sit0 up

给接口增加本地6to4地址:

/sbin/ifconfig sit0 add <local6to4address>/16

使用全6to4路由器IPv4任播地址向全球IPv6网络增加一个(默认的)路由器:

/sbin/route -A inet6 add 2000::/3 gw ::192.88.99.1 dev sit0

u 删除6to4隧道
(1)使用“ip”和一个专用隧道设备
删除到专用隧道设备的所有路由:

/sbin/ip -6 route flush dev tun6to4

关闭接口:

/sbin/ip link set dev tun6to4 down

删除建立的隧道设备:

/sbin/ip tunnel del tun6to4

(2)使用“ifconfig”和“route”和通常隧道设备“sit0”(不推荐使用)
删除默认到6to4隧道接口的路由:

/sbin/route -A inet6 del 2000::/3 gw ::192.88.99.1 dev sit0

删除到接口的本地6to4地址:

/sbin/ifconfig sit0 del <local6to4address>/16

关闭“sit0”:(此步骤要注意,因为sit0有可能还在使用)

/sbin/ifconfig sit0 down

至此ipv6单机环境搭建完毕

二、搭建ipv6网络环境
有了单机环境之后将单机的ipv6网络分享出去就ok了,下一步需要使用支持ipv6网络的软路由。

对于软路由可以使用海蜘蛛,建议通过虚拟机进行安装,安装后配置ipv6的dhcp,之后将网关指向第一步的ipv6主机即可,具体教程网上很多,请参考操作。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,491评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,856评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,745评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,196评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,073评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,112评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,531评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,215评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,485评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,578评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,356评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,215评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,583评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,898评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,497评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,697评论 2 335

推荐阅读更多精彩内容