Why have a Linux virtual server cluster
The idea is simple:- The user looks up your website.
- The user is connected to the LVS load-balancing computer.
- The connection is forwarded one of the real servers on the local area network.
- A service like the Apache web server or a FTP client on the real server handles the request.
- The user is presented the requested content quickly even though the site is heavily used.
- ???
- Profit !!!
What you need
The Linux Virtual Server Project modules where added to version 2.4.28 of the Linux kernel. It is also available in the 2.6.x kernel, but there are many problems reported with using LVS on 2.6 kernels. LVS is known to be rock solid stable on 2.4.x kernels. Patches are available for previous versions of the 2.4.x kernel from the official LVS website.2.1. Needed kernel configuration
You can configure your kernel by running ''make menuconfig''. Go to theNetworking options
sub-menu and then the sub-menu IP: Virtual
Server Configuration
. 2.4.2x Linux Virtual Server kernel configuration |
Networking options -> IP: Virtual Server Configuration |
[Y] virtual server support (EXPERIMENTAL) |
[ ] IP virtual server debugging |
(16) IPVS connection table size (the Nth power of 2) |
--- IPVS scheduler x |
[M] round-robin scheduling |
[M] weighted round-robin scheduling |
[M] least-connection scheduling |
[M] weighted least-connection scheduling |
[M] locality-based least-connection scheduling |
[M] locality-based least-connection with replication scheduling |
[M] destination hashing scheduling |
[M] source hashing scheduling |
[M] shortest expected delay scheduling |
[M] never queue scheduling |
--- IPVS application helper |
[M] FTP protocol helper |
make dep && make clean && make bzImage && make
modules && make modules_install
Update your boot manager and your LVS kernel is ready to be used.
2.2. Software: ipvsadm and iptables
Gentoo:emerge ipvsadm iptables
You must turn on IP forwarding on to use the LVS modules. You must turn it on by adding
net.ipv4.ip_forward = 1
to your
/etc/sysctl.conf
. You are now ready to start iptables.
- Fedora users:
service iptables start
- Gentoo users:
/etc/init.d/iptables start
If your eth0 is connected to the Real Internet and eth1 is connected to your local area network then you can turn on masquerading with the following commands:
iptables -t nat -P POSTROUTING DROP
iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE
/etc/init.d/iptables save
) so they are applied the next time
iptables is started. Create a server cluster and choose algorytm module
The most common choices are thewlc
(weighted least-connection)
and wrr
(weighted round robin) scheduling algorithms. This is how simple it is to create a virtual server using weighted least-connection for HTTP port number 80 (replace 66.199.240.50 with the IP you want the virtual server on):
ipvsadm -A -t 66.199.240.50:80 -s wlc
Redirect the incoming traffic
You can explain to the LVS where to send the incoming requests withipvsadm -a -t Real-IP:port -r Internal-IP:port -m
. You can set the
server weight (load) with the -w switch. The default is 1, 2 would mean the
server gets twice the normal load. Examples: ipvsadm -a -t 66.199.240.50:80 -r 10.0.0.100:80 -m |
ipvsadm -a -t 66.199.240.50:80 -r 10.0.0.101:80 -m -w
2 |
The single point of failure
Your LVS will be a single point of failure. You can setup multiple A (ipv4) and AAAA (ipv6) records for your domain. This is a good and simple way of doing basic load-balancing. If you have real amounts of traffic then you may want two or three virtual servers load balanced by the DNS records, all connected to different clusters.Not as easy as it sounds..?
Congratulations, you have the knowledge needed to make a cluster.Here are some important things you must consider: All the real servers connected to the virtual server must present the content you have created to drive the the visiting consumers into profit-generating behavior. If you have a web forum or a wiki then you are required to setup database clusters and so on to ensure the consumers are driven into purchasing behavior.
If you are mostly serving static files for example to serve an anonymous ftp site with Linux files then it is very easy to synchronize the servers using rsync. It is simple to setup a virtual ftp service with weighted round robin scheduling with the boxes on internal IPs 10.0.0.100, 10.0.0.101 and 10.0.0.102:
RealIp=66.199.240.50 ipvsadm -A -t $RealIp:21 -s wlc ipvsadm -a -t $RealIp:21 -r 10.0.0.100:21 -m -w 2 ipvsadm -a -t $RealIp:21 -r 10.0.0.101:21 -m ipvsadm -a -t $RealIp:21 -r 10.0.0.102:21 -m
what is linux web server and how to working all the points are get it from through this blog.Most of the small and large business people prefer to like this kind of valuable tips.hosting server
ReplyDeleteEmailOcean is a brand new platform to cater to your email marketing needs.
ReplyDeleteIt provides promotional emailing at an amazingly low rate of $0.10 per 1000 emails. The customer only pay for what is utilised. The brilliance of EmailOcean lies in it making the process easier and faster for the customer,as compared to Amazon and Sendgrid, EmailOcean has a beautiful Web-app which makes creating and sending the campaign a lot more easier. Using this web-app one can also send and track their campaigns.
As of now,the registrations are open by invitation but register yourself with the website and keep self updated as to when they are open to all or for your surprise invitation code.
www.emailocean.com