《2022年lvs安装手册域名服务器教程.docx》由会员分享,可在线阅读,更多相关《2022年lvs安装手册域名服务器教程.docx(12页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、2022年lvs安装手册域名服务器教程摘要:lvs安装手册lvs安装手册RedHat 8.0/9.0 LVS安裝手冊来源:linuxaid作者:apile(apilecheng.tw)完成日期:2022/08/04附注:欢迎传阅转寄,并希望可以保留原作者名字1、前言:RedHat在 9.0以后,就将ipvsadm这些套件去除,因此假如想运用LVS(Linux Virtual Server),就得自己重新编译核心(kernel),而编译核心是一件穷极无聊的事情,不管是make menuconfig、make xconfig、make config,触目所及都是一堆不是很懂的驱动程序,本文利用一些
2、技巧,将compile kernel变得比较简洁,但是假如你有一些不常见的硬设备,请自己想方法Compile,或者利用linux的load module功能自行将该硬件的驱动程序加载进kernel。Redhat 8.0选择完整安装时,预设已经会支持ipvs,但是他却不支持-NOARP这个网络卡设定选项,因为没有这个-NOARP选项,则LVS无法在同一个网段内设定LVS/DR与LVS/IP Tunnel,会遭受ARP Problem,所以只好重新编译核心,顺便将kernel更新至比较新的版本,另外RedHat 8.0上比较新的核心,预设不支持ipvs。首先简洁介绍一下LVS究竟是什么东西,其实他
3、是一种丛集(Cluster)的技术,透过支持IPVS的kernel,来达到LVS/Direct Routing (DR)、LVS/IP Tunnel、LVS/NAT的功能,具体内容请看LVS官方网站。而这些技术有什么用呢?其实就是拿来当成High Availability软件,Unix大厂SUN、HP、IBM、SCO等等都有供应这类的软件,但是都要许多钱,而我们没什么钱,只好用Open Source,而Open Source的好处,就是可以达到类似的功能,但不须要花钱。?以下安装内容主要参考下述网页,特别感谢这些供应基本学问的人,假如你不清晰LVS是什么,看看下面文章,可以有个头绪顺便练练基本
4、的功夫,以免后面的内容你完全不晓得我再写什么。http:/linux.vbird.idv.tw/ 鸟哥的Linux私房菜(Linux基本常识)http:/www.adj.idv.tw/server/linux_lvs.php 在RedHat 7.3上架设LVShttp:/www.linuxvirtualserver.org/ LVS的官方网站 LinuxAid说明(上) LinuxAid说明(下) Alex的网站,重要的patch都从这儿抓取附带一提:假如你参考Linux Virtual Server的官方网站上的作法,我在REDHAT 8上编译了十多次的kernel也作不出来,后来发觉是因为
5、RedHat在kernel-2.4.20-19.8的source中将ipvs的程序代码拿掉,且CIPE版本也不对。目前最适合拿来当Linux Virtual Server的RedHat版本为7.3,其它的都不是很stable,有爱好可以用google查查看。下列方法适用于2.4的kernel,主要在Redhat 8.0上运用,但是RedHat 9.0应当也差不多。PART I :编译核心1、首先安装RedHat 8.0选择全部安装。关闭一些不用的Service与并将vsftp激活。即着手进行kernel的重新编译,此时的kernel版本为2.4.18-18.4。2、下载oprofile首先上g
6、oogle找寻oprofile版本要大于0.4的,因为在安装kernel 2.4.20-18.8.rpm的时候会须要这个rpm,假如找不到rpm,就搜寻oprofile-0.4-xx.src.rpm。2.1、安装oprofile# rpm -ivh oprofile-0.4-44.8.1.src.rpm# cd /usr/src/redhat/SPECS# vi oprofile.spec 将(BuildPreReq: kernel-source >=2.4.20)用# mark起来# rpmbuild -bb oprofile.spec# cd /usr/src/redhat/RPMS
7、/i386/# rpm -ivh oprofile-0.4-44.8.1.i386.rpm(安装oprofile)3、安装内核安装kernel 2.4.20-18.8的kernel,上http:/ftp.nsysu.edu.tw/Linux/RedHat/updates/抓取kernel-2.4.20-18.8的rpm核心,因为我测试环境有三部,一部是我的notebook (P4 CPU、512MB RAM),一部是有4GB RAM与两颗CPU(PIII 700)的机器,一部是有1GB RAM与两颗有hyper threading P4 CPU的计算机。所以我总共抓了三个RPM,分别是kern
8、el-2.4.20-18.8.i686.rpm 02-Jun-2022 23:34 13.3Mkernel-bigmem-2.4.20-18.8.i686.rpm 02-Jun-2022 23:34 13.9Mkernel-smp-2.4.20-18.8.i686.rpm 02-Jun-2022 23:34 13.9M然后在各部机器上先安装上述RPM:若不清晰倒底要用那个,可以用uname -r2.4.20-18.8bigmem (就用bigmem的版本)#rpm -ivh kernel-2.4.20-18.8.i686.rpm检查grub(/boot/grub/grub.conf)或lilo
9、(/etc/lilo.conf)的设定是不是正确?假如正确,就重新激活机器(shutdown -i 6 now),用2.4.20-18.8开机,检查有无错误。4、安装内核源码然后上 抓取kernel-source-2.4.20-19.8.i386.rpm这个kernel的核心。利用# rpm -ivh kernel-source-2.4.20-19.8.i386.rpm安装,他会建立两个书目:/usr/src/linux-2.4.20-19.8 (directory)/usr/src/linux-2.4->/usr/src/linux-2.4.20-19.8 (Symbolic Link
10、)但是我们还要另外建立一个symbolic link#ln -s ./linux-2.4.20-19.8 ./linux因为等会要上ipvs patch的时候,他肯定会link到/usr/src/linux这个书目,所以要另外建立这个Soft Link。5、因为我们从前有安装过2.4.20-18.8的rpm文件,所以在/boot书目下,可以找到-rw-r-r- 1 root root 44764 5月 29 19:49 config-2.4.20-18.8这个档案,将这个档案copy至/usr/src/linux/.config# cp /boot/config-2.4.20-18.8 /us
11、r/src/linux/.config因为等会我要利用make oldconfig去作他default会去读取/usr/src/linux/.config这个file留意:这就是我所说的技巧,因为我从前用make config、make menuconfig选取那些modules,但是因为数量实在太多,看得眼花撩乱,而且选完不知道为什么总有一两地方有问题无法compile胜利,无意间被我发觉2.4.20-18.8的config档案与2.4.20-19.8的config档案一模一样,加上kernel的README中又有写make oldconfig会去读取,.config这个档案,所以我才会想到
12、用这个方法或许可行,因为2.4.20-18.8都可以正常激活机器了,不行能用相同的config 档案,2.4.20-19.8就无法激活。其它版本,应当也差不多,先安装一个差不多版本的kernel,再用他的config去重新compile支持ipvs的kernel。6、给kernel的source file上Patch:6.1、运用LVS的内核补丁上Linux Virtual Server的网页抓取kernel-2.4.0-20的PATCH档案下来,我是抓下面这个档案:The IPVS Netfilter module for kernel 2.4 - Version 1.0.9 - May 2
13、1, 2022 (http:/www.linuxvirtualserver.org/software/kernel-2.4/ipvs-1.0.9.tar.gz)取得ipvs-1.0.9.tar.gz 这个档案我试过抓linux-2.4.20-ipvs-1.0.9.patch.gz 这个档案,但是从来没有compile胜利过,所以放弃。6.2、将ipvs-1.09.tar.gz解开,放在/usr/src/source/ipvs-1.0.9这个书目下,然后在这个书目下,输入# make patchkernel# make installsource将IPVS的Patch加载到kernel的sour
14、ce中6.3、加载 hidden的patch可以到 这个书目中抓取(hidden-2.4.20pre10-1.diff)这个patch档案,放在/usr/src/linux书目下,利用:# cat hidden-2.4.20pre10-1.diff | patch -p1对Kernel进行patch,特别感谢Alex供应上述Patch。留意:为什么这里要对kernel进行hidden的patch,因为在运用LVS中的DR与IP Tunnel的时候,会须要有一块网络卡要设定两个IP的情形,但是Linux在2.2.14之后,就将eth0:1的-NOARP这个FLAG关闭。也就是说在kernel 2
15、.2.14以后,eth0:1就视为eth0的别名,任何对eth0:1的设定也同样作用在eth0,换句话说,我对eth0:1下-NOARP,同样也会对eth0有作用,这样会使得整张网络卡收不到封包。在上述两种模式下,因为我全部的机器都放在同一个网段,当该网段的Router接收到客户端(Client)对虚拟IP(Virtual IP)的TCP connection要求时,会先在网段中利用Arp request询问谁有VIP的地址,而包含Director与RealServers上全部的interface(不管Primary还是Subinterface),只要他有那个ip,都会发送arp reply回去,造成网段内全部拥有Virtual IP的interface都会reply给Router,最终结果就是看谁的速度快,Router就将该封包送给谁,如此会造成LVS的Server并无法发挥其效果,因此须要利用hidden这个pattch,将Subinterface上的Virtual IP给隐藏起来,如此他就不会对Arp Request进行Reply,如此就可以解决ARP的问题,而这个NOARP的问题,kerne