实验查看PHP本地的Session信息

通过Nginx调度器负载后端两台Web服务器,实现以下目标:

- 部署Nginx为前台调度服务器

- 调度算法设置为轮询

- 后端为两台LNMP服务器

- 部署测试页面,查看PHP本地的Session信息

概念:Session:存储在服务器端,保存用户名、登陆状态等信息。Cookies:由服务器下发给客户端,保存在客户端的一个文件里。保存的内容主要包括:SessionID

拓扑环境:使用4台RHEL7虚拟机,其中一台作为Nginx前端调度器服务器(eth0:192.168.4.5,eth1:192.168.2.5)、两台虚拟机部署为LNMP服务器,分别为Web1服务器(192.168.2.100)和Web2服务器(192.168.2.200),另外一台作为测试用的Linux客户机(192.168.4.10)

拓扑图:

步骤:

一, 部署后端LNMP服务器相关软件

注意:以下部署LNMP服务器的操作,需要在两台后端服务器做相同的操作,下面以Web2服务器(192.168.2.200)为例,对Web1服务器执行相同操作即可。

[[email protected] ~]# yum -y install gcc openssl-devel pcre-devel   #yum安装基础依赖包

[[email protected] ~]# tar -xf nginx-1.12.2.tar.gz

[[email protected] ~]# cd nginx-1.12.2

[[email protected] nginx-1.12.2]# ./configure \      #源码安装Nginx

> --with-http_ssl_module

[[email protected] nginx-1.12.2]# make && make install

[[email protected] ~]# yum -y install mariadb mariadb-server mariadb-devel     #安装MariaDB数据库

[[email protected] ~]# yum -y install php php-mysql php-fpm     #安装PHP

[[email protected] ~]# vim /usr/local/nginx/conf/nginx.conf       #修改Nginx配置文件的默认首页与动静分离)

location / {

root html;

index index.php index.html index.htm;

}

location ~ \.php$ {               #启用动态页面

root html;

fastcgi_pass 127.0.0.1:9000;

fastcgi_index index.php;

# fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

include fastcgi.conf;      #修改默认文件为fastcgi.conf

}

二, 启动LNMP服务器相关的服务

[[email protected] ~]# systemctl stop httpd      #如果该服务存在,则关闭,以避免端口冲突

[[email protected] ~]# systemctl start mariadb    #启动MySQL服务

[[email protected] ~]# systemctl status mariadb

[[email protected] ~]# systemctl start php-fpm     #启动PHP-FPM服务

[[email protected] ~]# systemctl status php-fpm

三, 修改Nginx配置文件,实现代理服务器

- 通过upstream定义后端服务器地址池,默认调度策略为轮询,使用proxy_pass调用upstream定义的服务器地址池

[[email protected] ~]# vim /usr/local/nginx/conf/nginx.conf

...

http{

upstream webs {

server 192.168.2.100:80;

server 192.168.2.200:80;

}

server {

listen 80;

server_name localhost;

location / {

proxy_pass http://webs;

root html;

index index.php index.html index.htm;

}

...

[[email protected] ~]# /usr/local/nginx/sbin/nginx -s reload    #重新加载配置文件

[[email protected] ~]# curl http://192.168.4.5/index.html    #浏览器访问,查看默认页面加载是否成功

四, 部署web1与web2的测试页面

1. 部署 web1 的测试页面

[[email protected] ~]# tar -xf php-memcached-demo.tar.gz    //找一个php的测试页面

[[email protected] php_scripts]# cd php-memcached-demo

[[email protected] php-memcached-demo]# ls
home.php  images  index.php  login.php  README.md  style.css

[[email protected] php-memcached-demo]# cp -r * /usr/local/nginx/html/      #拷贝php页面到Nginx的网页目录下

[[email protected] php-memcached-demo]# vim home.php

<body bgcolor=blue>    #定义home.php的页面颜色为blue, 以便于区分后端两台不同的web服务器

[[email protected] php-memcached-demo]# vim index.php

<body bgcolor=red>    #定义index.php的页面颜色为red,以便于区分后端两台不同的web服务器

1.1 浏览器访问后端服务器 web1 的测试页面

[[email protected] ~]# firefox http://192.168.2.100       #在web1网站上注册用户,密码

[[email protected] ~]# cd /var/lib/php/session/

[[email protected] ~]# ls     #查看服务器本地生成的Session信息

sess_ahilcq9bguot0vqsjtd84k7244       #Session信息是随机分配的

2. 部署 web2 的测试页面

[[email protected] ~]# tar -xf php-memcached-demo.tar.gz    //找一个php的测试页面

[[email protected] php_scripts]# cd php-memcached-demo

[[email protected] php-memcached-demo]# ls
home.php  images  index.php  login.php  README.md  style.css

[[email protected] php-memcached-demo]# cp -r * /usr/local/nginx/html/      #拷贝php页面到Nginx的网页目录下

[[email protected] php-memcached-demo]# vim home.php

<body bgcolor=blue>    #定义home.php的页面颜色为blue, 以便于区分后端两台不同的web服务器

[[email protected] php-memcached-demo]# vim index.php

<body bgcolor=red>    #定义index.php的页面颜色为red,以便于区分后端两台不同的web服务器

2.1 浏览器访问后端服务器 web2 的测试页面

[[email protected] ~]# firefox http://192.168.2.200       #在web2网站上注册用户,密码

[[email protected] ~]# cd /var/lib/php/session/

[[email protected] ~]# ls     #查看服务器本地生成的Session信息

sess_qqek1tmel07br8f63d6v9ch401    #Session信息是随机分配的

五, 浏览器访问前端调度器Nginx,查看页面

[email protected] ~]# google-chrome http://192.168.4.5

-  填写注册信息后,刷新,还需要再次注册,说明两台计算机使用的是本地Session.

- 因为,第二台主机并不知道你在第一台主机已经登录,第一台主机的登录信息也没有传递给第二台主机.

- 也就是当前存在的问题: 不同后端web服务器的Session不一致,即没有实现Session的共享.

- 如何实现Session共享,在后面的随笔再介绍.

结束.

原文地址:https://www.cnblogs.com/liusingbon/p/11143158.html

时间: 2024-07-30 00:48:14

实验查看PHP本地的Session信息的相关文章

PHP的本地Session信息

通过Nginx调度器负载后端两台Web服务器,实现以下目标: 部署Nginx为前台调度服务器 调度算法设置为轮询 后端为两台LNMP服务器 部署测试页面,查看PHP本地的Session信息 方案使用4台RHEL7虚拟机,其中一台作为Nginx前端调度器服务器(eth0:192.168.4.5,eth1:192.168.2.5).两台虚拟机部署为LNMP服务器,分别为Web1服务器(192.168.2.100)和Web2服务器(192.168.2.200),另外一台作为测试用的Linux客户机(1

16_构建memcached服务、LNMP+memcached、PHP的本地Session信息、PHP实现session共享

proxy   10.10.11.10client  10.10.11.11web1    10.10.11.12web2    10.10.11.13 proxy:1.构建memcached服务]# yum -y install memcached]# cat /etc/sysconfig/memcachedPORT="11211"USER="memcached"MAXCONN="1024"CACHESIZE="64"OPT

如何查看oracle当前session信息

如何查看oracle当前session信息 怎样查看Oracle当前的连接数呢?只需要用下面的SQL语句查询一下就可以了. #查看当前不为空的连接select * from v$session where username is not null #查看不同用户的连接数 select username,count(username) from v$session where username is not null group by username #连接数 select count(*) f

查看锁定的session信息脚本

查看当前被阻塞的对象和锁信息SELECT DISTINCT       s1.inst_id BlockingInst,       s1.sid BlockingSid,       s1.serial# BlockingSerial,       s2.inst_id BlockedInst,       s2.sid BlockedSid,       s2.username BlockedUser,       s2.seconds_in_wait BlockedWaitTimeFROM

查看历史会话等待事件对应的session信息

此处以enq: TX - row lock contention等待时间为例. 如果在此回话发生在awr快照信息默认的保存天数以内.可以通过如下sql查询到相关的session信息.select * from DBA_HIST_ACTIVE_SESS_HISTORY where event like '%enq: TX - row lock contention%' DBA_HIST_ACTIVE_SESS_HISTORY 中的blocking_session字段关联DBA_HIST_ACTIV

PHP使用memcached储存session信息

文档信息: 文档作者:amun 文档版本:Version 1.1 修改记录:2017-05-15 系统环境:CentOS 6.5 64 bit 需求: 环境                                       ip                                      软件 Centos6.5_x64_64                   192.168.200.101               memcached libmemcached Ap

apache+PHP使用memcached储存session信息

需求: Apache使用php支持memcached储存session信息 **以下apache.php.memcached均使用yum方式安装,如有特殊需求使用源码包安装时,配置方式与此不同 关闭防火墙和SElinux安全机制 service iptables stop setenforce 0 1.安装部署apache 使用系统自带的apache即可 修改apache配置文件以支持php vim /etc/httpd/conf/httpd.conf 402 DirectoryIndexind

(apache+tomcat集群+memcached番外篇)单台tomcat的session信息的2种持久化方式

为什么要实现搭建tomcat集群环境呢?主要因为单个tomcat无论从吞吐量和并发数上,会达到一定的极限.如果访问量超过单个tomcat的承受能力的话,tomcat一般要么拒绝提供服务,要么直接宕掉.所以,必须要依靠tomcat集群技术.举个最简单的例子,拿"送快件"比喻,如果一个人,5分钟送一件,一小时之内,送10个,一个人完全能胜任这项工作.假设现在到了双十一,要求1小时,送100个, 那怎么办?只能安排更多的人加入"送快件"这项工作中来.这其实和集群一个道理.

查看登陆系统用户的信息的三种方法详解

查看登陆系统用户的信息的三种方法详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.who这个命令显示可以谁在登陆,但是这个有很多的花式玩法,这个命令超简单 语法:who [OPTION]... [ FILE | ARG1 ARG2 ] 1.参数:-u,显示闲置时间,若该用户在前一分钟之内有进行任何动作,将标示成"."号,如果该用户已超过24小时没有任何动作,则标示出"old"字符串. 例如: 2.参数:-m,此参数的效果和指定"a