Session与Cookie、部署redis、redis基本操作、Session共享

news2025/1/11 20:56:02

1 案例1:PHP的本地Session信息

1.1 问题

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

  1. 部署Nginx为前台调度服务器
  2. 调度算法设置为轮询
  3. 后端为两台LNMP服务器
  4. 部署测试页面,查看PHP本地的Session信息

1.2 方案

实验拓扑环境,效果如图-1所示:

使用4台虚拟机,其中一台作为Nginx前端调度器服务器(eth0:192.168.88.5,eth1:192.168.99.5)、两台虚拟机部署为LNMP服务器,分别为Web1服务器(192.168.99.100)和Web2服务器(192.168.99.200),另外一台作为测试用的Linux客户机(192.168.88.10)

1.3 步骤

实现此案例需要按照如下步骤进行。

步骤一:部署后端LNMP服务器相关软件

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

1)使用yum安装基础依赖包

[root@web2 ~]# yum -y install gcc openssl-devel pcre-devel

2)源码安装Nginx

    [root@web2 ~]# tar -xf nginx-1.22.1.tar.gz
    [root@web2 ~]# cd nginx-1.22.1
    [root@web2 nginx-1.22.1]#  ./configure 
    [root@web2 nginx-1.22.1]# make && make install

3)安装MariaDB数据库

    [root@web2 ~]# yum -y install  mariadb  mariadb-server  mariadb-devel

4)安装PHP

    [root@web2 ~]# yum -y install  php  php-mysqlnd
    [root@web2 ~]# yum -y install  php-fpm

5)修改Nginx配置文件(修改默认首页与动静分离)

[root@web2 ~]# vim /usr/local/nginx/conf/nginx.conf
location / {
            root   html;
            index  index.php  index.html   index.htm;
        }
 location  ~  \.php$  {
            root           html;
            fastcgi_pass  unix:/run/php-fpm/www.sock;
            fastcgi_index  index.php;
           # fastcgi_param   SCRIPT_FILENAME  $document_root$fastcgi_script_name;
            include        fastcgi.conf;
        }
[root@web2 ~]# vim /etc/php-fpm.d/www.conf   #打开php-fpm配置文件
[www]
;listen = 127.0.0.1:9000                    #注释或删除该行
listen = /run/php-fpm/www.sock                #socket方式(使用进程通信)
listen.acl_users = apache,nginx,nobody        #添加nobody账户

步骤二:启动LNMP服务器相关的服务

1)启动Nginx服务

这里需要注意的是,如果服务器上已经启动了其他监听80端口的服务软件(如httpd),则需要先关闭该服务,否则会出现冲突。

    [root@web2 ~]# systemctl stop  httpd                #如果该服务存在,则关闭该服务
    [root@web2 ~]# /usr/local/nginx/sbin/nginx
    [root@web2 ~]# ss -utnlp | grep :80      

2)启动MySQL服务

    [root@web2 ~]# systemctl start mariadb
    [root@web2 ~]# systemctl status mariadb

3)启动PHP-FPM服务

    [root@web2 ~]# systemctl start  php-fpm
    [root@web2 ~]# systemctl status php-fpm

4) 配置好lnmp之后,拷贝带登录效果的测试页面

    cd  ~/lnmp_soft/php_scripts/
    tar -xf php-session-demo.tar.gz    #释放带登录功能的网页
    cp -r php-session-demo/* /usr/local/nginx/html/   #拷贝页面到nginx中使用火狐浏览器访问http://192.168.99.200/index.php  可以看到有登录界面的网页

注:这里index.php是登录前页面 ,home.php是登录后才能看的页面

步骤三:在proxy部署前端Nginx调度服务器

1)使用源码安装nginx软件(如果Nginx软件包已安装可以忽略此步骤)

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

    [root@proxy ~]# vim /usr/local/nginx/conf/nginx.conf
    .. ..
    upstream webs  {
            server 192.168.99.100:80;
            server 192.168.99.200:80;
      }
     server  {
              listen       80;
              server_name  localhost;
              location  /  {
                  proxy_pass http://webs;
                root   html;
                index  index.php index.html index.htm;
              }
    }

3)重新加载配置文件

    [root@proxy ~]# /usr/local/nginx/sbin/nginx -s reload
    #请先确保nginx是启动状态,否则运行该命令会报错,报错信息如下:
    [error] open() "/usr/local/nginx/logs/nginx.pid" failed (2: No such file or directory)

注意!proxy主机不要配置动静分离

步骤四:测试环境是否配置成功

浏览器访问测试192.168.99.5的登录页面,但两个集群主机一样,可用修改index.php文件的内容,以区别后端两台不同的服务器

了解概念

Session:存储在服务器端,保存用户名、登陆状态等信息。

Cookies:由服务器下发给客户端,保存在客户端的一个文件里。

保存的内容主要包括:SessionID。

目前环境搭建好之后可以按以下步骤测试:

    rm  -rf  /var/lib/php/session/*        #删除web1与web2的session文件,再删除火狐浏览器的历史记录(主要是cookies文件)
    http://192.168.99.5/index.php            #登录2次才能成功,目前登录2次是正常现象!!

2 案例2:构建redis服务

2.1 问题

上述实验由于web1与web2都是在各自的/var/lib/php/session目录中存储session,所以造成客户需要重复登录,为了统一session存储的位置(该存储方式通常被称为session共享),需要安装专门的数据库工具

本案例要求先快速搭建好一台redis服务器,并对redis进行简单的增、删、改、查操作:

  • 安装redis软件,并启动服务
  • 测试redis服务
  • 对redis进行增、删、改、查等操作

2.2 方案

使用1台虚拟机作为redis服务器(192.168.99.5)。

2.3 步骤

实现此案例需要按照如下步骤进行。

步骤一:构建redis服务

1)使用yum安装软件包redis

    [root@proxy ~]# yum -y  install   redis
    [root@proxy ~]# systemctl start redis
    [root@proxy ~]# ss -ntulp | grep redis
    tcp   LISTEN 0      128          0.0.0.0:6379      0.0.0.0:* 

2) redis配置文件

[root@proxy ~]#vim  /etc/redis.conf
...
#bind 127.0.0.1                    #加注释
...
protected-mode no                    #保护模式关闭
...

步骤二:测试redis服务器

1)测试包括增、删、改、查等操作。

[root@proxy ~]#redis-cli            #进入redis命令行
set abc 456         #创建变量abc,里面的值是456
get abc            #查看变量abc的值
keys  *            #查看当前库中所有key
del  abc            #删除变量abc
flushall            #删除所有数据
quit                #退出

3 案例3:PHP实现session共享

3.1 问题

沿用练习三,通过修改PHP-FPM配置文件,实现session会话共享:

  • 配置PHP使用redis服务器共享Session信息
  • 客户端访问两台不同的后端Web服务器时,Session 信息一致

3.2 方案

Nginx服务器除了承担调度器外,还需要担任redis数据库的角色,并在两台后端LNMP服务器上实现PHP的session会话共享

3.3 步骤

实现此案例需要按照如下步骤进行。

步骤一:为Web服务器安装PHP扩展

1)为web1主机的PHP添加redis扩展

    [root@web1 ~]# cd ~/lnmp_soft/php_scripts/
    [root@web1 php_scripts]# yum -y install phpredis-5.1.0-1.x86_64.rpm

2)为web2主机的PHP添加redis扩展

    [root@web2 ~]# cd ~/lnmp_soft/php_scripts/
    [root@web2 php_scripts]# yum -y install phpredis-5.1.0-1.x86_64.rpm

步骤二:在后端LNMP服务器上部署Session共享

注意:这些操作在两台后端Web服务器上均需要执行

1)修改PHP-FPM配置文件,并重启服务

注意,因为后端两台web服务器(web1,web2)都需要修改配置文件(下面也web1为例)。

    [root@web1 ~]# vim  /etc/php-fpm.d/www.conf            #修改该配置文件的两个参数
    最后一页的部分内容,修改前效果如下:
    php_value[session.save_handler] = files
    php_value[session.save_path] = /var/lib/php/session
    修改后效果如下:
    php_value[session.save_handler] = redis
    php_value[session.save_path] = "tcp://192.168.99.5:6379"
    [root@web1 ~]# systemctl  restart  php-fpm

所有主机关闭防火墙和selinux

步骤三:客户端测试

客户端使用浏览器访问proxy

最后清空浏览器的历史记录,再访问http://192.168.99.5/index.php仅仅登录一次即可成功

4 案例4:Nginx实现跨域

4.1 问题

网站中通过脚本调用不同端口、域名、协议的数据时被浏览器阻拦:

  • 比如一个80端口的网站,无法访问同网站下8080端口的数据

4.2 方案

默认情况下,浏览器根据同源策略,会拦截非本网站端口、域名、协议的数据,通过配置Nginx跨域指令即可解决

4.3 步骤

实现此案例需要按照如下步骤进行。

创建2个虚拟主机,一个80端口(这个用默认配置即可),一个8080端口

1)为proxy主机的添加8080虚拟主机

    [root@proxy nginx]# vim conf/nginx.conf
    server {
    listen 8080;
    charset utf8;
    location / {
    root html;
    index index.html;
    }
    }
    [root@proxy nginx]# sbin/nginx -s reload

2)创建2个测试页面

    [root@proxy nginx]# cat html/80.html
    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <title>API-test</title>
        <script>
            var xhr = new XMLHttpRequest();
            xhr.open('GET', 'http://192.168.99.5:8080/api.html',true);
            xhr.send();
            function change(){
                if(xhr.readyState==4 && xhr.status==200){
                    alert(xhr.responseText);
                }
            }
        </script>
    </head>
    <body>
    <input  id="button" type="button" value="测试" onclick="change();">
    </body>
    [root@proxy nginx]# cat html/api.html
    8080虚拟主机测试页面

3)打开浏览器,访问http://192.168.99.5/80.html,点击按钮无反应,此时在8080虚拟主机中添加即可允许从任意地址请求8080的数据

    [root@proxy nginx]# vim conf/nginx.conf
    server {
    listen 8080;
    charset utf8;
    location / {
    add_header 'Access-Control-Allow-Origin' '*';  #服务器响应数据中添加允许跨域访问
    root html;
    index index.html;
    }
    }
    [root@proxy nginx]# sbin/nginx -s reload

再次访问http://192.168.99.5/80.html,点击按钮即可看到8080端口的页面

4)修改具体允许请求的地址,增加安全

    [root@proxy nginx]# vim conf/nginx.conf
    server {
    listen 8080;
    charset utf8;
    location / {
    add_header 'Access-Control-Allow-Origin' 'http://192.168.99.5';
    root html;
    index index.html;
    }
    }
    [root@proxy nginx]# sbin/nginx -s reload

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1429708.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

亚马逊新店铺视频怎么上传?视频验证失败怎么办?——站斧浏览器

亚马逊新店铺视频怎么上传&#xff1f; 登录亚马逊卖家中心&#xff1a;首先&#xff0c;卖家需要登录亚马逊卖家中心。在登录后&#xff0c;可以点击左侧导航栏上的“库存”选项&#xff0c;然后选择“新增或管理商品”。 选择商品&#xff1a;接下来&#xff0c;在“新增或…

如何部署Node.js服务并实现无公网ip远程访问本地项目【内网穿透】

文章目录 前言1.安装Node.js环境2.创建node.js服务3. 访问node.js 服务4.内网穿透4.1 安装配置cpolar内网穿透4.2 创建隧道映射本地端口 5.固定公网地址 前言 Node.js 是能够在服务器端运行 JavaScript 的开放源代码、跨平台运行环境。Node.js 由 OpenJS Foundation&#xff0…

YOLOv8进阶 | 如何用yolov8训练自己的数据集(以安全帽佩戴检测举例)

前言&#xff1a;Hello大家好&#xff0c;我是小哥谈。YOLOv8是一种目标检测算法&#xff0c;它是YOLO&#xff08;You Only Look Once&#xff09;系列算法的最新版本。本节课就带领大家如何基于YOLOv8来训练自己的目标检测模型&#xff0c;本次作者就以安全帽佩戴检测为案例进…

二叉树的最小深度

给定一个二叉树&#xff0c;找出其最小深度。 最小深度是从根节点到最近叶子节点的最短路径上的节点数量。 说明&#xff1a;叶子节点是指没有子节点的节点。 示例 1&#xff1a; 输入&#xff1a;root [3,9,20,null,null,15,7] 输出&#xff1a;2示例 2&#xff1a; 输入&…

postgres:锁申请

什么是弱锁&#xff0c;强锁&#xff1f; 为了提高并发控制&#xff0c;PG通过将锁信息在本地缓存&#xff08;**LOCALLOCK**&#xff09;和快速处理常见锁&#xff08;fastpath&#xff09;&#xff0c;减少了对共享内存的访问&#xff0c;提高性能。从而出现了弱锁和强锁的概…

如何在win系统部署开源云图床Qchan并无公网ip访问本地存储图片

文章目录 前言1. Qchan网站搭建1.1 Qchan下载和安装1.2 Qchan网页测试1.3 cpolar的安装和注册 2. 本地网页发布2.1 Cpolar云端设置2.2 Cpolar本地设置 3. 公网访问测试总结 前言 图床作为云存储的一项重要应用场景&#xff0c;在大量开发人员的努力下&#xff0c;已经开发出大…

【自然语言处理】P2 PyTorch 基础 - 张量

目录 安装 PyTorch张量创建张量操作张量索引、切片、联合操作 CUDA张量 本系列博文我们将使用 PyTorch 来实现深度学习模型等。PyTorch 是一个开源的、社区驱动的深度学习框架。拥有强大的工具和库生态系统&#xff0c;包含 TorchVision&#xff08;用于图像处理&#xff09;、…

后端软件三层架构

一、三层架构简介 三层架构是软件开发中广泛采用的一种经典架构模式&#xff0c;其核心价值在于通过清晰的任务划分来提高代码的可维护性和重用性。具体来说&#xff0c;三层架构主要包括以下三个层次&#xff1a; 持久层&#xff08;DAO层&#xff09;&#xff1a;这一层主要…

和鲸科技与智谱AI达成合作,共建大模型生态基座

近日&#xff0c;上海和今信息科技有限公司&#xff08;简称“和鲸科技”&#xff09;与北京智谱华章科技有限公司&#xff08;简称“智谱AI”&#xff09;签订合作协议&#xff0c;双方将携手推动国产通用大模型的广泛应用与行业渗透&#xff0c;并积极赋能行业伙伴探索领域大…

10:00进去,10:06就出来了,面试问的问题真难。。。

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 关注公众号【互联网杂货铺】&#xff0c;回复 1 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 刚从小厂出来&#xff0c;没想到在另一家公司我又寄了。 在这家…

在线JSON转CSV工具

在线JSON转CSV - BTool在线工具软件&#xff0c;为开发者提供方便。本工具可以在浏览器本地将JSON转换成CSV文件,并下载转换后的CSV文件。https://www.btool.cn/json-to-csv 在大数据时代&#xff0c;数据处理与交换已经成为日常工作生活中的常态。而JSON和CSV作为两种广…

Go语言的100个错误使用场景(21-29)|数据类型

前言 大家好&#xff0c;这里是白泽。 《Go语言的100个错误以及如何避免》 是最近朋友推荐我阅读的书籍&#xff0c;我初步浏览之后&#xff0c;大为惊喜。就像这书中第一章的标题说到的&#xff1a;“Go: Simple to learn but hard to master”&#xff0c;整本书通过分析100…

Flutter向 开发人员需要了解的和颜色有关的知识

前言 构建应用前台的开发人员常常需要和颜色打交道&#xff0c;即使很多时候&#xff0c;前台人员不用自己设计颜色&#xff0c;而是由设计师给出颜色&#xff0c;不过经常和颜色打交道&#xff0c;整理和颜色有关的知识还是开卷有益的 flutter中指定颜色的常用方式 Color.f…

海外IP代理:解锁网络边界的实战利器

文章目录 引言&#xff1a;正文&#xff1a;一、Roxlabs全球IP代理服务概览特点&#xff1a;覆盖范围&#xff1a;住宅IP真实性&#xff1a;性价比&#xff1a;在网络数据采集中的重要性&#xff1a; 二、实战应用案例一&#xff1a;跨境电商竞品分析步骤介绍&#xff1a;代码示…

vscode的ssh忽然连不上服务器:远程主机可能不符合glibc和libstdc++ VS Code服务器的先决条件

vscode自动更新了一下就发现连不上服务器了&#xff0c;我寻思估计一大堆人都寄了&#xff0c;一搜&#xff0c;果然哈哈哈哈 然后我直接搜一天内新发布的博客&#xff0c;还真给我搜到了这个问题&#xff0c;按照这个问题里面的回答&#xff08;vscode1.86无法远程连接waitin…

Notion 开源替代品:兼容 Miro 绘图 | 开源日报 No.162

toeverything/AFFiNE Stars: 25.6k License: NOASSERTION AFFiNE 是下一代知识库&#xff0c;将规划、排序和创建集于一身。它是一个注重隐私、开源、可定制且即插即用的替代方案&#xff0c;可以与 Notion 和 Miro 相媲美。主要功能和优势包括&#xff1a; 超融合&#xff1…

深入理解网络编程之BIO和NIO

目录 原生JDK网络编程BIO BIO通信模型服务端代码 BIO通信模型客户端代码 伪异步模型服务端代码&#xff08;客户端跟之前一致&#xff09; 原生JDK网络编程NIO 什么是NIO&#xff1f; NIO和BIO的主要区别 阻塞与非阻塞IO NIO之Reactor模式 NIO中Reactor模式的基本组成…

Vue 上门取件时间组件

本文使用vue2.0elementui 制作一个上门取件时间组件&#xff0c;类似顺丰&#xff0c;样式如下&#xff1a; 大概功能&#xff1a;点击期望上门时间&#xff0c;下面出现一个弹框可以选择时间&#xff1a; 首先我们定义一些需要的数据&#xff1a; data() {return {isDropdown…

Github处理clone慢的解决方案

Github设置代理clone依然慢的解决方案 1、前提&#xff1a;科学上网 注意&#xff1a; 必须要有科学上网&#xff01;必须要有科学上网&#xff01;必须要有科学上网&#xff01;重要的事情说三遍&#xff1b; 2、http/https方案&#xff08;git clone时使用http&#xff09…

【git指南】git 本地代码版本控制

文章目录 git 本地代码版本控制1 设置全局 Git 用户名和邮箱2 初始化仓库3 提交文件4 文件修改5 版本对比6 版本回退7 版本分支8 版本合并 git 本地代码版本控制 ​ 下面介绍在 vscode 中如何利用 git 对本地代码进行版本控制。可以查看官网介绍来获得更详细的内容。 1 设置全…