前言

“觊觎”Nginx其实已经很久了,但是之前一直忙着准备找实习啊,各种考试啊什么的,也没有时间。恰好最近空了出来,就浅浅的学了一点关于Nginx的知识,顺便搭建了一个模拟的负载均衡,反向代理环境。在此做下笔记,以备不时之需。

Nginx搭建结果展示


准备篇

在正式开始搭建环境之前,还是需要 多多少少的具备一点Linux相关的知识,因为以后服务器大部分还是要跑在Linux系统上的。

我这里就简单的使用Ubuntu14.04LTS来做测试了。因此需要安装一些编译软件需要的东西,如下:

sudo apt-get install build-essential
sudo apt-get install libtool

如果您的电脑上没有makegcc、g++, 还是需要手动安装一下的。因为Ubuntu自带了,所以我这里就不再重复安装。

然后是对于一些开源软件的安装的方式的使用,其实无外乎一下三个步骤:

cd targetdir
./configure
sudo make
sudo make install

这样的话,就差不多了。

搭建篇

现在正式开始搭建这个环境吧。总的来说需要安装的东西还是挺多的。不管怎么样,一点点来吧。

安装虚拟机

我本人手里只有一台Linux服务器,所以肯定是不够的。于是我选择了使用虚拟机来创建多个Linux服务器的方式。

  • VMware 12 pro 破解版。
  • Ubuntu14.04 LTS

VMware虚拟机一般来说只有30天的试用期,对于环境搭建的学习应该是足够的了。但是如果想长期使用,就需要破解一下,免得整天弹出购买窗口,烦人。关于破解码的问题,网上一搜就有答案了。或者在博客下面留下您的邮箱,我私信发过去也行。

安装完虚拟机之后装一下Ubuntu系统就可以啦。我这边完成安装后的效果如下。
虚拟机安装完成图

其实ServerA 和ServerB是从Nginx安装完成之后直接克隆出来的,这样省事而且也不容易出错。

安装Nginx

重头戏来了,安装Nginx之前还需要安装其他的三个文件,分别是:

  • pcre: 为了rewrite的重写,方便对URL做自定义。

  • zlib: 为了gzip压缩的支持,服务器上一般必备。

  • OpenSSL: 为了建立更加安全的链接。

下面分别介绍一下它们的安装步骤:

pcre安装
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
zlib安装
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
openssl安装
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了。

安装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

为了模拟现实中的场景,前台使用Nginx,后面连着一大群Apache服务器。我这里还需要在另外的两台服务器上安装一下Apache服务器。

sudo apt-get install apache2

这样就可以了。然后为了加以区分,我手动的修改了一下两台服务器的默认的index.html文件的内容。

比如对于ServerA服务器,可以作如下修改。
ServerA 默认的index.html文件修改

效果呢,当然还是在浏览器上来验证最合适了。参照下图。

ServerA修改效果

然后对于ServerB中也做下类似的修改就可以了。

配置

现在万事俱备了,只需要修改一下Nginx的相关的配置文件就可以了。
修改Nginx配置文件

修改完成之后重启Nginx服务器即可。

cd /usr/local/nginx/sbin
sudo ./nginx -s reload

出现下图所示即可。
重启Nginx服务

验证篇

Nginx

在Nginx的conf配置文件中未打开

proxy_pass http://backup.com

这条注释之前,应该仅仅显示Nginx自己的信息。如下图
Nginx未启用反向代理之前

ServerA

ServerA仅仅开启了一个Apache服务器,我本人修改了其默认的显示文件内容。如下
ServerA Apache服务

ServerB

同样,ServerB也是如此。但是为了区分,也修改了一下页面现实的内容。
ServerB Apache服务

Nginx配置之后

也就是说打开了上面的proxy_pass注释句,开启了Nginx的反向代理功能。

Nginx搭建结果展示

总结

最后来总结一下。

给我的感觉就是Nginx确实很好用,作为一个“大管家”来分配请求任务真的是再合适不过了。今天也就是玩了点皮毛,深层次的东西基本上就没接触到。

最后看了人家的源码,还是感觉C语言的伟大啊。叹服!!!

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐