LANMT架构搭建jspxcms

                LANMT架构搭建jspxcms


前言

上篇文章我们介绍了tomcat的基础使用, 这篇文章我们介绍LANMT架构并用其实现jspxcms 6.0

LANMT是什么?

我们之前了解了LAMP,LNMP, 为什么会出现LANMT的架构呢?

以前我们解决单台LAMP架构不能承受高并发的问题时, 首先想到的不应该将其做成负载均衡集群, 而是先要将其各组件进行分离, 例如:MySQL单独出来,php-fpm运行在单台主机等解决方式. 在生产环境中tomcat一般来说不会直接面向用户, 前端一般会使用NginxApache Httpd进行反向代理, 用户只需要和Nginx或者Apache Httpd保持连接, 可以减缓Tomcat连接器的负担

可能又有朋友会有疑问了, 我们使用一个web服务器进行反代就行了, 为什么要使用NginxApache Httpd一起呢? 
因为
Nginx对静态请求的响应速度是无语伦比的, 我们可以在前端对其进行动静分离, 将图片和CSS等请求通过Nginx响应, 而Apache Httpd因为同属于ASFApache Httpd有很多种反代tomcat的方法, 例如: 我们可以通过proxy_http_module,proxy_ajp_module,proxy_ajp_module等模块反向代理tomcat, 因为ajp协议通过二进制格式传输, 而http协议通过文本格式从传输, 所以效率会更高, 我们可以将Apache HttpdTomcat安装在一台主机上实现整套架构

实验拓扑图

blob.png

实验环境

主机 IP 功用
node1.anyisalin.com 172.16.1.2 Nginx
node2.anyisalin.com 172.16.1.3 Apache, Tomcat, MySQL

实验步骤

Tomcat配置

我们首先配置Tomcat, 安装过程这里不做叙述, 不明白的可以看我上篇博客: tomcat基础进阶

安装Tomcat

[root@node1 ~]# [root@node1 ~]# wget http://mirrors.cnnic.cn/apache/tomcat/tomcat-8/v8.0.33/bin/apache-tomcat-8.0.33.tar.gz
[root@node1 ~]# tar xf apache-tomcat-8.0.33.tar.gz  -C /usr/local/
[root@node1 ~]# cd /usr/local ; ln -sv apache-tomcat-8.0.33 tomcat ; cd ~
[root@node1 ~]# wget http://download.oracle.com/otn-pub/java/jdk/8u77-b03/jdk-8u77-linux-x64.rpm #如果下载出错, 使用浏览器下载
[root@node1 ~]# rpm -ivh jdk-8u77-linux-x64.rpm   #安装JDK

[root@node1 ~]# vim /etc/profile.d/java.sh     #定义JAVA_HOME
export JAVA_HOME=/usr/java/latest
export PATH=$JAVA_HOME/bin
:$PATH

[root@node1 ~]# vim /etc/profile.d/tomcat.sh    #配置tomcat的环境变量
export CATALINA_BASE=/usr/local/tomcat
export PATH=$CATALINA_BASE/bin
:$PATH

[root@node1 ~]# source /etc/profile.d/tomcat.sh
[root@node1 ~]# source /etc/profile.d/java.sh

配置虚拟主机

[root@node2 ~]# vim /usr/local/tomcat/conf/server.xml   

#设置默认虚拟主机为web1.anyisalin.com
<Engine name="Catalina" defaultHost="web1.anyisalin.com" jvmRoute="TomcatA">  

#添加虚拟主机
<Host name="web1.anyisalin.com" appBase="/data/webapps/" unpackWARS="true" autoDeploy="true">
  <Context path="" docBase="/data/webapps/ROOT" reloadable="true" />
    <Valve className="org.apache.catalina.valves.AccessLogValve" directory="/data/logs"
       prefix="web1_access_log." suffix=".txt"
       pattern="%h %l %u %t &quot;%r&quot; %s %b" />
</Host>

[root@node2 ~]# mkdir -PV /data
/webapps/  #创建目录
[root@node2 ~]# cd /data/webapps/
[root@node2 webapps]# wget http://www.jspxcms.com/uploads/jspxcms-6.0.1-release.zip #下载jspxcms
[root@node2 webapps]# unzip jspxcms-6.0.1-release.zip   #解压到当前目录
[root@node2 webapps]# catalina.sh start #启动tomcat

MySQL配置

安装MySQL

[root@node2 webapps]# yum install mysql-server -y
[root@node2 webapps]# service mysqld start

创建数据库和用户

[root@node2 webapps]# mysql

mysql> GRANT ALL ON jspxcms.* TO jsp@'%' IDENTIFIED BY 'passwd';
Query OK, 0 rows affected (0.01 sec)

mysql> CREATE DATABASE jspxcms;
Query OK, 1 row affected (0.00 sec)

mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.00 sec)

jspxcms安装

安装步骤

访问172.16.1.2:8080 安装jspxcms

blob.png

blob.png

blob.png

重启tomcat并测试

[root@node2 webapps]# catalina.sh stop 
[root@node2 webapps]# catalina.sh start

再次访问172.16.1.3:8080 , 第一次访问可能有点慢

blob.png

Apache Httpd配置并测试

安装httpd

[root@node2 ~]# yum install httpd -y

配置httpd

[root@node2 ~]# cd /etc/httpd/conf.d/
[root@node2 ~]# vim virt.conf
<VirtualHost *:80>
 ServerName www.anyisalin.com
 ProxyRequests Off
ProxyPass / ajp://172.16.1.3:8009/
ProxyPassReverse / ajp://172.16.1.3:8009/
</VirtualHost>

[root@node2 ~] service httpd start

测试反向代理

我们直接通过80端口访问httpd, 能够显示jspxcms页面

blob.png

Nginx配置并测试

安装nginx

在node1上安装配置
[root@node1 ~]# yum install nginx -y  #确保有epel源

配置nginx

[root@node1 ~]# vim /etc/nginx/conf.d/default.conf  #修改以下字段
    location / {
        proxy_pass http://172.16.1.3;
    }

[root@node1 ~]# service nginx start  #启动nginx

测试nginx

我们通过访问nginx就能够访问隐藏在后端的Tomcat中的jspxcms

blob.png

总结

我们这样就实现了一个LANMT架构的jspxcms站点, 是不是很Easy呢? 我们实现了一个LANMT架构, 按照我们以前的套路, 下篇我们应该实现后端多个Tomcat实例负载均衡了~,~

作者水平很低, 如果有错误及时指出, 如果你觉得本文写的好请点一波赞~(≧▽≦)/~ 
作者: AnyISaIln QQ: 1449472454 
感谢: MageEdu

原创文章,作者:Net18-AnyISalIn,如若转载,请注明出处:http://www.178linux.com/15197

(0)
Net18-AnyISalInNet18-AnyISalIn
上一篇 2016-04-22
下一篇 2016-04-22

相关推荐

  • vim编辑器的使用

    vim          vim是一个类似于vi的文本编辑器,不过在vi的基础上增加了很多功能,在早起vim和Emacs编辑器打的很火热,在1999年被linuxwork文本编辑分类的优胜者,而vim屈居第二,但2000年vim赢得了salashdot beanie的最佳开放源代…

    系统运维 2016-08-09
  • Linux下软件包安装(rpm,yum)

    Linux下软件包安装(rpm,yum,源代码) 1)    Rpm包管理安装 2)    Yum包程序管理器 3)    本地Yum仓库建制 ======================================= 1) …

    Linux干货 2016-06-22
  • varnish详解

      第一章    http缓存的基础概念 1、程序运行时具有局部性特征 时间局部性缓存的数据往往被打有时间缀,具有定期失效的特征,过期后会从源服务器检验请求验证是否需要重新拉取数据,某数据被访问后,该数据往往会再次在短时间内被访问到。 空间局部性被访问数据的周边数据被访问的概率会比其它常规数据访问大很多,所以这些访问数…

    Linux干货 2016-11-15
  • 简单的文本处理工具和正则表达式

    一、文本工具     在linux中,有很多优秀且功能强大的文本处理工具,对文件内容进行查找、替换、删除、排序等操作,是linux进行文本处理变得特别方便。日常工作中,经常会用文本处理进行日志分析,文本抽取等,所以掌握文本处理,将会对我们的工作起到极大的作用。 cat:查看文件    &n…

    Linux干货 2016-08-10
  • 2016-08-10作业

    1、编写脚本/root/bin/systeminfo.sh, 显示当前主机系统信息,包括主机名,IPv4 地址,操作系统版本,内核版本,CPU 型号,内存大小,硬盘大小。 #!/bin/bash echo "hostname is `hostname`" echo "IPv4 is `ifconfig | sed -n &#03…

    Linux干货 2016-08-15
  • 笔记整理:权限管理2-特殊权限(sst)和隐藏属性

    特殊权限 进程访问文件时的权限,取决于进程的发起者和其所在的属组。还有其他权限,包括SST(Suid【可以更改进程发起者】,Sgid【可以更改进程发起者属组】,Sticky) 查询SUID/SGID文件   find / -perm +6000 SUID 使用特点 SUID只能作用在二进制文件上。 执行者需要对该文件具有可执行权限 只在程序运行过程…

    Linux干货 2016-08-05