内容简介:使用Nginx和Tomcat搭建Web集群环境
一直以来对于web服务器对tomcat还是很熟悉了,但是很对于nginx还是有些陌生,一看到nginx的配置就让人有一种莫名的排斥,这就是对于陌生的恐惧,我们今天玩个有意思的,我从不了解nginx,到nginx和tomcat搭建集群,大概在不到一个小时内完成。
看看我这一个小时的学习成果,说不上对你有帮助。
首先nginx是出自俄罗斯的一款轻量级web服务器,开源免费,而且至简。
它的网站是这个:http://nginx.org/en/download.html
下载的版本目前有三类,比较容易理解,一个是目前的开发版本(Mainline version),第二类是稳定的最新版,比如目前最新的是1.12.2的版本,有源码包和windows版本。第三类算是怀旧稳定版,不一定线上的环境都是最新的,也考虑了兼容性,算是比较贴心吧。
说nginx至简,一个原因就是这个安装包确实够小,压缩版本不到1M,而解压后的版本也大概在7M左右。
[root@localhost nginx]# ll
total 960
-rw-r--r--. 1 root root 981687 Oct 18 13:14 nginx-1.12.2.tar.gz
安装nginx还是比较简便的,configure,make ,make install,需要注意的是安装是需要几个依赖包的,比如zlib,PCRE的库,可以提前检查下。
# rpm -qa|grep zlib
zlib-1.2.3-29.el6.x86_64
zlib-devel-1.2.3-29.el6.x86_64
PCRE的库需要的是pcre-devel,配置了yum源使用yum -y install pcre-devel即可搞定。
# rpm -qa|grep pcre
pcre-devel-7.8-7.el6.x86_64
pcre-7.8-7.el6.x86_64
小结下安装的三个步骤:
-
./configure --prefix=/usr/local/nginx
-
make
-
make install
如果需要编辑ssl额外加个选项。
nginx的启动确实很简单,直接使用nginx命令即可启动,默认是使用80端口,很快就能看到一个欢迎页面。
当然我们可以通过fuser来检验80端口的情况,或者检测80端口是否被占用:
# fuser -n tcp 80
80/tcp: 21412 21413
或者是:
# netstat -pan | grep -w 80
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 21412/nginx
tcp 0 0 127.0.0.1:80 127.0.0.1:49593 TIME_WAIT -
tcp 0 0 192.168.253.219:57492 23.32.3.248:80 ESTABLISHED 21590/clock-applet
tcp 0 0 192.168.253.219:51678 60.221.218.180:80 TIME_WAIT -
tcp 1 0 ::ffff:192.168.253.21:39646 ::ffff:104.25.106.17:80 CLOSE_WAIT 12329/java
tcp 1 0 ::ffff:192.168.253.21:37445 ::ffff:104.25.107.17:80 CLOSE_WAIT 12329/java
如果查看nginx相关的进程,会发现有个master,有个worker的进程。
# ps -ef|grep nginx
root 21412 1 0 22:39 ? 00:00:00 nginx: master process ./nginx
nobody 21413 21412 0 22:39 ? 00:00:00 nginx: worker process
root 21719 15134 0 22:43 pts/3 00:00:00 grep nginx
这个部分怎么理解,可以通过nginx的配置文件就能容易理解了。在nginx.conf文件中,开头就是如下的两行。可以很明显看出worker进程有1个,配置了nobody,所以你看到的worker进程的属主就是nobody
#user nobody;
worker_processes 1;
这个是nginx的架构。他是使用epoll的方式。
nginx的命令几乎都不需要你重新去学习,直接使用-h就得到了帮助命令。所以我们很容易就会发现:./nginx -s stop 是停止的命令,启用配置文件使用-c选项。
在nginx所在的sbin目录下,一个完整的启动命令即为:
./nginx -c /usr/local/nginx/conf/nginx.conf
然后我们看看和tomcat怎么结合,nginx常用来做http服务器,反向代理,邮件服务器等。也是做负载均衡的一种很自然的方案。我们来简单模拟一下。
比如当前后端的服务器是tomcat,如果要实现负载均衡,通过nginx来转发就是一件很自然的事情,如果其中的一个tomcat出现问题,那也可以很方便的满足容错性。
为此我们需要配置若干个tomcat服务来模拟一下,比如我们使用3个tomcat。
drwxr-xr-x. 9 root root 4096 Jan 3 23:14 tomcat1
drwxr-xr-x. 9 root root 4096 Jan 3 23:14 tomcat2
drwxr-xr-x. 9 root root 4096 Jan 3 23:14 tomcat3
默认端口为8080,我们简单包装,三个tomcat的端口即为:
18080
28080
38080
修改tomcat的配置文件server.xml就需要注意以下几个地方的端口设置,分别为:
tomcat1:
<Server port="18005" shutdown="SHUTDOWN">
<Connector port="18080" protocol="HTTP/1.1"
<Connector port="18009" protocol="AJP/1.3" redirectPort="8443" />
tomcat2:
<Server port="28005" shutdown="SHUTDOWN">
<Connector port="28080" protocol="HTTP/1.1"
<Connector port="28009" protocol="AJP/1.3" redirectPort="8443" />
tomcat3:
<Server port="38005" shutdown="SHUTDOWN">
<Connector port="38080" protocol="HTTP/1.1"
<Connector port="38009" protocol="AJP/1.3" redirectPort="8443" />
然后启动做简单的验证:能看到小猫即可。
为了区别起见,我们可以在webapps/ROOT/index.jsp里面分别表示tomcat1,tomcat2,tomcat3这样后面做转发就知道是到达了哪个tomcat了。
此时的tomcat是可以了,我们配置Nginx.
nginx的配置核心就是nginx.conf了。
注意红色的部分配置:
#gzip on;
upstream jeanron100.com {
server 127.0.0.1:18080 weight=1;
server 127.0.0.1:28080 weight=2;
server 127.0.0.1:38080 weight=3;
}
server {
listen 80;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
#location / {
# root html;
# index index.html index.htm;
#}
location / {
proxy_pass http://jeanron100.com;
proxy_redirect default;
}
然后启动nginx,使用命令:
./nginx -c /usr/local/nginx/conf/nginx.conf
然后在浏览器中输入IP和页面的名字。可以看到这个时候已经开始做了转发,现在调到了tomcat2上。
继续刷新,现在跳到了tomcat3上面。
不断的刷新,tomcat和nginx是映射起来了。
下面关于 Nginx 的文章您也可能喜欢,不妨参考下:
Nginx 403 forbidden的解决办法 http://www.linuxidc.com/Linux/2017-08/146084.htm
CentOS 7下Nginx服务器的安装配置 http://www.linuxidc.com/Linux/2017-04/142986.htm
CentOS上安装Nginx服务器实现虚拟主机和域名重定向 http://www.linuxidc.com/Linux/2017-04/142642.htm
CentOS 6.8 安装LNMP环境(Linux+Nginx+MySQL+PHP) http://www.linuxidc.com/Linux/2017-04/142880.htm
Linux下安装 PHP 环境并配置Nginx支持php-fpm模块 http://www.linuxidc.com/Linux/2017-05/144333.htm
Nginx服务的SSL认证和htpasswd认证 http://www.linuxidc.com/Linux/2017-04/142478.htm
Ubuntu 16.04上启用加密安全的Nginx Web服务器 http://www.linuxidc.com/Linux/2017-07/145522.htm
Linux中安装配置Nginx及参数详解 http://www.linuxidc.com/Linux/2017-05/143853.htm
Nginx日志过滤 使用ngx_log_if不记录特定日志 http://www.linuxidc.com/Linux/2014-07/104686.htm
CentOS 7.2下Nginx+PHP+MySQL+Memcache缓存服务器安装配置 http://www.linuxidc.com/Linux/2017-03/142168.htm
CentOS6.9编译安装Nginx1.4.7 http://www.linuxidc.com/Linux/2017-06/144473.htm
Nginx 的详细介绍 : 请点这里
Nginx 的下载地址 : 请点这里
本文永久更新链接地址 : http://www.linuxidc.com/Linux/2018-01/150306.htm
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- Elasticsearch 集群搭建和集群原理
- Zookeeper学习系列【二】Zookeeper 集群章节之集群搭建
- Spark集群环境搭建
- Zookeeper搭建集群
- FastDFS集群搭建
- Zookeeper集群环境搭建
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
计算机程序设计艺术(第2卷)
高德纳 / 机械工业出版社 / 2008-1 / 109.00元
《计算机程序设计艺术:半数值算法(第2卷)(英文版)(第3版)》主要内容:关于算法分析的这多卷论著已经长期被公认为经典计算机科学的定义性描述。迄今已出版的完整的三卷已经组成了程序设计理论和实践的惟一的珍贵资源,无数读者都赞扬Knuth的著作对个人的深远影响,科学家们为他的分析的美丽和优雅所惊叹,而从事实践的程序员已经成功地将他的“菜谱式”的解应用到日常问题上,所有人都由于Knuth在书中表现出的博......一起来看看 《计算机程序设计艺术(第2卷)》 这本书的介绍吧!