Linux是多用户、多任务的操作系统,具有可移植性、强大的网络功能和良好的编程环境。在Linux的发行版中已经附带了多套服务器软件,无论是架设网页服务器、邮件服务器,还是FTP服务器,都可以轻而易举地实现。本文以Red Hat Linux 9.0为基础,向你全面讲述Linux环境下服务器架设的方法与技巧。
一、动态域名的实现
1.动态域名基础
搭建Linux服务器是一个系统工程,涉及到硬件购置、软件安装、域名申请、网络服务提供等。这里的前提就是域名的申请,因为对于虚拟拨号上网的用户而言,使用的都是动态IP地址,别人根本无法和你联系。
解决的办法就是采用动态域名解析工具,通过运行一个专门的客户端程序,一旦拨号用户上线,就会把当前的动态IP地址发送到专门的动态域名解析服务器,然后该动态域名解析服务器就可以及时更新自己的数据库,把某个“固定”域名指向该临时IP地址。这样,不管现在的IP地址是多少,总是可以通过一个固定的域名来访问我们的Linux服务器。
需要注意的是,计算机所拥有的IP地址应该是公网IP地址,也就是Internet所采用的IP地址,而非内网(局域网)IP地址。
2.动态域名解析
(1)注册动态域名
我们可以到科迈网http://www.comexe.cn/register.php注册一个用户账户。然后在“域名管理”页面中单击“申请科迈公网免费二级域名”链接,注册一个合适的名称(例如myname),即会得到一个myname.kmip.net的二级域名,然后单击“提交”按钮,如果该域名没有被别人注册,则可以立即生效。
注意:本文假设用户已经完全安装Red Hat Linux 9.0,并使用KDE桌面系统。
(2)安装动态域名解析工具
注册成功以后,我们可以到http://www.comexe.cn/client/linux_i.tar.gz中下载动态域名解析工具(如,版本号“公网Ver 2.00 Build 104”)。下载得到的是一个压缩文件,在系统里建立一个目录,如/usr/local/comexe,把下载的文件解压到这个目录即可。
[root@ahpeng root]# cd /tmp
[root@ahpeng tmp]# tar -xvzf linux_i.tar.gz
[root@ahpeng tmp]# cp pipclient /usr/local/comexe/pipclient
(3)配置客户端
解压后得到一个执行文件pipclient。在终端命令窗口切换到该目录并运行以下命令:
[root@ahpeng comexe]# ./ pipclient
第一次运行pipclient,会要求输入配置信息:
[root@ahpeng comexe]# ./ pipclient
Usage: pipclient -h -c -w /home/pipclient
-h: help message.
-c: do configuration.
-w <dir>: set work directory.
Do configuration now.
Input User name:
这里按照屏幕提示输入以下配置信息:
Input User name: //在科迈网注册的用户名
Input Password: //科迈网用户密码
Input Domain: //域名
Input Offline URL or Offline IP(Enter for none): //域名离线URL。如果没有请直接按回车键。这里要注意离线功能对科迈的二级域名(如abc.dns0755.net、abc.kmip.net)无效
Has another domain?(Y/N): //如果要解析多个域名,请按“Y”,逐个输入域名及其离线URL
配置完毕后应该出现以下提示信息:
030827 155904:MESG:
COMEXE DDNS (Public IP) Ver 2.00a Build 102
Copyright 2003 Shenzhen COMEXE Communication Technology Co. Ltd.
All Rights Reserved.
http://www.comexe.cn
030827 155904:MESG:服务启动.
030827 155904:INFConnected t210.22.12.54:9994
030827 155904:INFConnected t210.22.12.54:9993
030827 155904:MESG:登录成功! 出口IP是: xxx.xxx.xxx.xxx
030827 155904:INFxxx.xxx.xxx.xxx N 20
现在可以按Ctrl+C组合键退出。如果以后要修改配置,可以在终端命令窗口运行以下命令:
[root@ahpeng comexe]#./pipclient -c
3.内网映射
所谓内网(局域网),就是只有一台主机(可能是代理服务器或路由器)连接到Internet,具有公网地址,假设为A1。别的计算机通过它与Internet连接,假设为A2,只有内网地址,外网计算机显然无法直接访问A2。
要让外网用户可以访问Linux服务器,通常有三种解决思路:
(1)如果A1是Windows主机
如果A1是Windows主机,可以考虑安装端口映射工具,如PortTunnel,把外网计算机对A1特定端口的访问,转驳到对A2特定端口的访问。
(2)如果你采用路由器
如果你采用路由器,或具有路由功能的ADSL Modem,可以直接在路由器上进行设置。这里以AboveCable无线路由器为例进行介绍:
首先在浏览器地址栏中输入“192.168.100.100”,回车进入路由器设置界面,输入密码即可进入管理界面。展开页面左侧的“重定向规则→虚拟主机”链接,然后在右侧页面中依次填上服务端口、服务器IP地址,这样外网对路由器的特定端口访问,都会被转驳到指定服务器的端口。
(3)下载客户端程序
登录到http://www.comexe.cn/helptruehost.php下载一个特殊的客户端程序,不过这需要支付一定的费用、并且带宽受到限制(通过专门的服务器中转),它可以实现内网用户对外提供服务。
4.内置防火墙的配置
在搭建Linux网站时,还有一个很容易疏忽的问题,即是没有正确配置系统内置的防火墙,这可能会导致“客户”无法访问我们的Linux服务器,所以必须对防火墙进行配置。单击“主菜单→系统设置→安全级别”菜单项,即可打开“安全级别配置”对话框,如图1所示。选中“定制”选项,然后选择所需启用的服务,例如WWW、FTP、邮件(SMTP)等,最后单击“确定”按钮即可。
二、架设Web服务器
Apache是使用范围最广的Web服务器工具套件,这里我们将详细介绍如何在Red Hat Linux 9.0环境里安装、启动和配置Apache服务器。
1.安装Apache服务器
在安装Red Hat Linux 9.0时,会提示是否安装Apache服务器。如果不能确定是否已经安装,可以在终端命令窗口输入以下命令:
[root@ahpeng root] rpm -qa | grep httpd
如果结果显示为“httpd-2.0.40-21”,则说明系统已经安装Apache服务器。
如果安装Red Hat Linux 9.0时没有选择Apache服务器,则可以在图形环境下单击“主菜单→系统设置→添加删除应用程序”菜单项,在出现的“软件包管理”对话框里确保选中“万维网服务器”选项,然后单击“更新”按钮,按照屏幕提示插入安装光盘即可开始安装。
另外,你也可以直接插入第1张安装光盘,定位到/RedHat/RPMS下的httpd-2.0.40-21.i386.rpm安装包,然后在终端命令窗口运行以下命令即可开始安装进程:
[root@ahpeng RPMS] rpm -ivh httpd-2.0.40-21.i386.rpm
安装好Apache服务器,可以在终端命令窗口运行以下命令来启动Apache服务:
[root@ahpeng root] /etc/rc.d/init.d/httpd start
重新启动Apache服务:
[root@ahpeng root] /etc/rc.d/init.d/httpd restart
关闭Apache服务:
[root@ahpeng root] /etc/rc.d/init.d/httpd stop
确认Apache服务已经启动后,我们可以在Web浏览器里输入以下地址,如果可以看到默认的Apache首页,则说明Apache服务器工作正常。
Htpp://WebServerAddress
此处的WebServerAddress指代Web服务器的IP地址或者域名。即是说WebServerAddress应该用实际的Web服务器的IP地址或者域名来代替。
2.配置httpd.conf文件
在早期Apache服务器版本里,其配置内容分散在httpd.conf、srm.conf、access.conf三个文件里。而新版本的Apache服务器,则统一在httpd.conf里进行配置。对于默认安装的Red Hat Linux来说,该配置文件位于/etc/httpd/conf目录下,如果安装的是tar.gz版本,则该文件位于/usr/local/apache/conf目录。
利用httpd.conf,我们可以对Apache服务器进行全局配置、主要或预设服务器的参数定义、虚拟主机的设置。httpd.conf是一个文本文件,我们可以用Vi、Kate等文本编辑工具进行修改。通过分析该httpd.conf配置文件,我们不难发现:
该配置文件分为若干个小节,例如Section 1: Global Environment(第一小节:全局环境);Section 2: 'Main' server configuration(第二小节:主服务器配置)等。
每个小节都有若干个配置参数,其表达形式为“配置参数名称 具体值”,每个配置参数都有详尽的英文解释(用#号引导每一个注释行)。
为了帮助大家理解,这里给出httpd.conf的最常用配置参数:
(1)DocumentRoot
该参数指定Apache服务器存放网页的路径,默认所有要求提供HTTP服务的连接,都以这个目录为主目录。以下为Apache的默认值:
DocumentRoot "/var/www/html"
|
|