“觊觎”Nginx其实已经很久了,但是之前一直忙着准备找实习啊,各种考试啊什么的,也没有时间。恰好最近空了出来,就浅浅的学了一点关于Nginx的知识,顺便搭建了一个模拟的负载均衡,反向代理环境。在此做下笔记,以备不时之需。
在正式开始搭建环境之前,还是需要 多多少少的具备一点Linux相关的知识,因为以后服务器大部分还是要跑在Linux系统上的。
我这里就简单的使用Ubuntu14.04LTS来做测试了。因此需要安装一些编译软件需要的东西,如下:
sudo apt-get install build-essential
sudo apt-get install libtool
如果您的电脑上没有make
和gcc、g++
, 还是需要手动安装一下的。因为Ubuntu自带了,所以我这里就不再重复安装。
然后是对于一些开源软件的安装的方式的使用,其实无外乎一下三个步骤:
cd targetdir
./configure
sudo make
sudo make install
这样的话,就差不多了。
现在正式开始搭建这个环境吧。总的来说需要安装的东西还是挺多的。不管怎么样,一点点来吧。
我本人手里只有一台Linux服务器,所以肯定是不够的。于是我选择了使用虚拟机来创建多个Linux服务器的方式。
VMware虚拟机一般来说只有30天的试用期,对于环境搭建的学习应该是足够的了。但是如果想长期使用,就需要破解一下,免得整天弹出购买窗口,烦人。关于破解码的问题,网上一搜就有答案了。或者在博客下面留下您的邮箱,我私信发过去也行。
安装完虚拟机之后装一下Ubuntu系统就可以啦。我这边完成安装后的效果如下。
其实ServerA 和ServerB是从Nginx安装完成之后直接克隆出来的,这样省事而且也不容易出错。
重头戏来了,安装Nginx之前还需要安装其他的三个文件,分别是:
pcre: 为了rewrite的重写,方便对URL做自定义。
zlib: 为了gzip压缩的支持,服务器上一般必备。
OpenSSL: 为了建立更加安全的链接。
下面分别介绍一下它们的安装步骤:
cd /usr/local/src
wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.gz
tar -zxvf pcre-8.34.tar.gz
cd pcre-8.34
./configure
sudo make
sudo make install
cd /usr/local/src
wget http://zlib.net/zlib-1.2.10.tar.gz
tar -zxvf zlib-1.2.10.tar.gz
cd zlib-1.2.10
./configure
sudo make
sudo make install
wget http://www.openssl.org/source/openssl-1.0.1t.tar.gz
tar -zxvf openssl-1.0.1c.tar.gz
./config --prefix=/usr/local --openssldir=/usr/local/openssl
sudo make depend
sudo make
sudo make install
//若要生成libssl.so动态库文件 需要如下make
make clean
./config shared --prefix=/usr/local --openssldir=/usr/local/openssl
sudo make depend
sudo make
sudo make install
成功安装完成这三个之后就可以安装Nginx了。
cd /usr/local/src
wget http://nginx.org/download/nginx-1.10.1.tar.gz
tar -zxvf nginx-1.10.1.tar.gz
cd nginx-1.10.1
# 下面这几行是可选项,其实可以默认不进行指定
./configure --sbin-path=/usr/local/nginx/nginx
--conf-path=/usr/local/nginx/nginx.conf --pid-path=/usr/local/nginx/nginx.pid --with-http_ssl_module --with-pcre=/usr/local/src/pcre-8.39 --with-zlib=/usr/local/src/zlib-1.2.8 --with-openssl=/usr/local/openssl
sudo make
sudo make install
安装的过程比较缓慢,一方面是我电脑的问题,另一方面是它真的很慢。。。
不管怎么说,最后成功安装好了Nginx的话,/usr/local
下的文件大概就是这个样子的了。
为了模拟现实中的场景,前台使用Nginx,后面连着一大群Apache服务器。我这里还需要在另外的两台服务器上安装一下Apache服务器。
sudo apt-get install apache2
这样就可以了。然后为了加以区分,我手动的修改了一下两台服务器的默认的index.html
文件的内容。
比如对于ServerA服务器,可以作如下修改。
效果呢,当然还是在浏览器上来验证最合适了。参照下图。
然后对于ServerB中也做下类似的修改就可以了。
现在万事俱备了,只需要修改一下Nginx的相关的配置文件就可以了。
修改完成之后重启Nginx服务器即可。
cd /usr/local/nginx/sbin
sudo ./nginx -s reload
出现下图所示即可。
在Nginx的conf配置文件中未打开
proxy_pass http://backup.com
这条注释之前,应该仅仅显示Nginx自己的信息。如下图
ServerA仅仅开启了一个Apache服务器,我本人修改了其默认的显示文件内容。如下
同样,ServerB也是如此。但是为了区分,也修改了一下页面现实的内容。
也就是说打开了上面的proxy_pass注释句,开启了Nginx的反向代理功能。
最后来总结一下。
给我的感觉就是Nginx确实很好用,作为一个“大管家”来分配请求任务真的是再合适不过了。今天也就是玩了点皮毛,深层次的东西基本上就没接触到。
最后看了人家的源码,还是感觉C语言的伟大啊。叹服!!!