nginx+php+tomcat

目录

1.源码编译安装php

​2.nginx中使用php-fpm

​3.php添加memcache模块

4.构建nginx高速缓存

5.配置php加载模块openresty

6.tomcat + memcache 实现负载均衡

7.session共享


PHP(PHP: Hypertext Preprocessor)即“超文本预处理器”,是在服务器端执行的脚本语言 

1.源码编译安装php

软件下载:https://www.php.net/

解压php的tar包  tar jxf php-7.4.12.tar.bz2

安装php所需的软件包
yum install -y systemd-devel
yum install -y libxml2-devel
yum install -y sqlite-devel
yum install -y libcurl-devel
yum install -y libpng-devel
yum install -y oniguruma-6.8.2-1.el7.x86_64.rpm
yum install -y oniguruma-devel-6.8.2-1.el7.x86_64.rpm

 --with-MySQL=mysql安装目录,对mysql的支持 ;--with-MySQLi=mysqli文件目录,优化支持
    --enable-inline-optimization --enable-soap --enable-ftp \
    --enable-sockets --enable-mbstring --enable-fpm  \ #--enable-fpm参数即可开启PHP-FPM
    --with-fpm-user=nginx --with-fpm-group=nginx  \ # 编译的时候指定了php的用户是nginx用户,故要建立nginx用户

 进入解压后的目录/root/php-7.4.12,开始编译

安装make && make install 

设置环境变量

拷贝配置文件 php-fpm.conf 

 编辑配置文件php-fpm.conf 

拷贝 www.conf文件

拷贝更改php主配置文件/usr/local/lnmp/php/etc/php.ini,修改时区

php-fpm.service读取服务并开启

拷贝php启动服务至/usr/lib/systemd/system/

此时,netstat -tlnp可以看到php已经启动,默认php服务开启9000端口。

 vim /usr/lib/systemd/system/php-fpm.service

2.nginx中使用php-fpm

修改配置文件

在浏览器中访问172.25.254.1/index.php 可以看到php默认发布页面

3.php添加memcache模块

memcache是一套分布式的高速缓存系统,目前被许多网站使用以提升网站的访问速度,尤其对于一些大型的、需要频繁访问数据库的网站访问速度提升效果十分显著 ,这是一套开放源代码软件,以BSD license授权发布。

通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高了网站访问速度,MemCaChe是一个存储键值对的HashMap,在内存中对任意的数据(比如字符串、对象等)所使用的key-value存储,数据可以来自数据库调用、API调用,或者页面渲染的结果。

osi七层模型每一层都可以加上属于自己的缓存,现在我们给lnmp中的php和nginx可以加上缓存,最后将mysql加上缓存,服务器一般不会把数据直接存储在自己上面,存储有专门的地方,交叉存储可以保证正常运行,数据共享,都会存储一份,本地存储+交叉存储。当服务器和自己的存储设备都坏了,也可以在其他服务器的存储器上找到自己的数据,可以保证客户正常访问。

软件下载:http://pecl.php.net/package/memcache

cd memcache-4.0.5.2

memcache目录中本来没有configure文件,所以没法编译,执行phpize,生成configure文件后就可以编译了

phpize是用来扩展php扩展模块的,通过phpize可以建立php的外挂模块

./configure --debug
make
make install

更改php主配置文件,增加memcache模块 vim php.ini

php -m ##查看模块

4.构建nginx高速缓存

使用memc-nginx模块构建高效透明的缓存机制;如果需要做到高速缓存,nginx可以跳过php直接向memcache存储,但只能做到静态存储,如果需要动态存储,还要调用php,通过php调用到数据后下一次nginx就可以直接从memcache那里取,有效提高效率,因此高速缓存时两种策略同时进行。

 

 安装memcache工具

开启memcache服务,监听端口为11211

拷贝php页面到nginx默认发布目录/usr/local/lnmp/nginx/html/,并修改memcache.php内容 

如果写为OPTIONS='-l 127.0.0.1' 即为只监听本机的11211端口,如果不添加则为所有

define('ADMIN_USERNAME','admin');    ## Admin Username(自定义)
define('ADMIN_PASSWORD','westos');      ## Admin Password(自定义)
$MEMCACHE_SERVERS[] = '172.25.254.1:11211'; // add more as an array
#$MEMCACHE_SERVERS[] = 'mymemcache-server2:11211'; // add more as an array
    ##只留一个主机,memcache没有转发或负载均衡机制,只能一个一个添加(因为本实验只有一个主机,其实可以添加多个)

访问 http://172.25.254.1/memcache.php输入用户名密码,可以查看memcache命中率, 

 再打开一个页面访问http://172.25.254.1/example.php,这个就相当于客户访问nginx(web服务器)的资源

 客户每访问172.25.254.1/example.php一次,172.25.254.1/memcache.php的缓存就会增多

 在真机,压力测试,模拟1000请求量.10个并发;很慢,因为没有缓存,而且failed比较多

很快,因为访问缓存,而且没有failed的 

 其实这两个php文件(index.php、example.php)都相当于放在nginx代理服务器下web资源
客户访问的时候先去问nginx代理服务器;如果请求的是静态资源,nginx会直接将静态缓存的资源返回给客户。如果请求的是动态资源,nginx会通过php去找fsatcgi去加载数据库,再把资源给客户端

客户通过php访问后端资源慢,客户通过php的memcache缓存直接访问缓存在内存中的数据很快
类似于在php服务上面加了memcache服务,就可以缓存数据,使的数据的访问更快(也可以说是备份)memcache.php只是一个管理员的页面而已

5.配置php加载模块openresty

OpenResty是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。 通过汇聚各种设计精良的 Nginx 模块(主要由 OpenResty 团队自主开发),从而将 Nginx 有效地变成一个强大的通用 Web 应用平台。这样,Web 开发人员和系统工程师可以使用 Lua 脚本语言调动 Nginx 支持的各种 C 以及 Lua 模块,快速构造出足以胜任 10K 乃至 1000K 以上单机并发连接的高性能 Web 应用系统。 OpenResty的目标是让web服务直接运行在Nginx服务内部,利用Ngnix的非阻塞IO模型,对HTTP客户端请求和后端DB进行一致的高性能响应。

 

Nginx 采用的是 master-worker 模型,一个 master 进程管理多个 worker 进程

    woker负责基本事件的处理
    master 负责一些全局初始化,以及对 worker 的管理

在OpenResty中,每个 woker 使用一个 LuaVM,当请求被分配到 woker 时,将在这个 LuaVM 里创建一个 coroutine(协程)协程之间数据隔离,每个协程具有独立的全局变量_G

下载openresty的包到虚拟机,并解压

编译

之后gmake install

 编辑openresty的nginx配置文件/usr/local/openresty/nginx/conf/nginx.conf

 #upstream属于handler,只是他不产生自己的内容,而是通过请求后端服务器得到内容,所以才称为upstream(上游)。请求并取得响应内容的整个过程已经被封装到nginx内部,所以upstream模块只需要开发若干回调函数,完成构造请求和解析响应等具体的工作。
  # nginx将memcache缓存前移,客户端请求到来,先查看memcache缓存

 location /memc {
                 internal;   # 只接收内部访问,不接受外部http访问。比较安全
                 memc_connect_timeout 100ms;
                 memc_send_timeout 100ms;  # 后端服务器数据回传时间
                 memc_read_timeout 100ms;  # 连接成功后,后端服务器响应时间
                 set $memc_key $query_string;  # 键值对的形式存储
                 set $memc_exptime 300;
                memc_pass memcache;
         }

location ~ \.php$ {
            set $key $uri$args;  # http的GET方法表示get、PUT方法表示set
             srcache_fetch GET /memc $key;
             srcache_store PUT /memc $key;
				# 这两个配置的作用是:请求php页面时,先会去memcache中找,如果没有,正常访问;访问结束后将结果存到memcache,下次访问时直接从缓存中
             root           html;
             fastcgi_pass   127.0.0.1:9000;
             fastcgi_index  index.php;
         #   fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
             include        fastcgi.conf;
         }

拷贝之前example.phpindex.php到默认发布目录准备测试 

访问速度有了明显的提高 ,因为php是没有缓存的 

发现访问index.php没有失败,而且访问时间都比给php添加memcache短 

6.tomcat + memcache 实现负载均衡

nginx作为反向代理服务器,转发多个tomcat服务器,实现负载均衡

 安装解压

在server2上,创建软链接

开启tomcat

发送安装包给server3,安装解压

 开启tomcat

查看8080端口开启

在server 1中关闭openresty中的nginx,重启nginx

编辑nginx配置文件

在server2和server3的/usr/local/tomcat/webapps/ROOT 中添加test.jsp

 

在浏览器访问测试页http://172.25.254.1/test.jsp 

 关闭server2的tomcat

继续输入数据,nginx的将康检测会快速切换到server3,不会影响输入数据,但是刚刚在网页上输入的数据丢失

可查询日志

7.session共享

Session是指会话控制,是保存在服务器上一种机制,当客户端访问服务器的时候,服务器会把信息以某种形式记录在服务器上,恰恰和Cookie相反。

Session经常用于会话过程中保证一定状态的信息,比如,用户在登录的时候,需要浏览web应用程序,并且存储是在页面重新被加载的时候,Session始终保持着任何时间都可以在设备上进行访问,但是随着用户的增多,Session的服务器内存也要不断加大,Session也会使用持久方法的限制。

nginx通过负载调度算法将请求调度至某一后端服务器;tomcat 把会话通过组播的方式复制到集群各节点;所有节点共享会话;

当服务开启时:

server2中的tomcat将数据保存到server3的session中;server3中的tomcat将数据保存到server2的session中

当server2的tomcat关闭时,server3将数据保存在server3的session中;当server3的tomcat关闭时,server2将数据保存在server2的session中

打开server1的nginx

编辑配置文件context.xml ;xml常用于数据存储和传输,

在server2上,安装memcahce,并开启服务。 

下载jar包放到erver2/usr/local/tomcat/lib目录下

如果tomcat之前是开启的,要先关闭,在开启。 

配置server3:

下载jar包放到server3/usr/local/tomcat/lib目录下 

安装memcahce,并开启服务。 

 

 cat catalina.out

 测试:访问测试页http://172.25.254.1/test.jsp

 在server2中写入数据

 此时宕掉server2,再次访问测试页面,还可以看到数据

 可以监控日志,查看到数据

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值