nginx七层负载—会话共享
会话保持相关信息存储
cookie
- 前端开发人员将用户登录的信息保存到浏览器中(开发者工具->Application->Cookies)
- 如果仅将用户的登录信息记录在Cookie中,随时可以在浏览器中篡改
session
- 后端开发人员,将用户登录信息记录在服务器上(共享存储,某一个文件夹下的某个文件、数据库中、缓存数据库中...)session是对COOkie做的加密,保存在服务器中
部署phpMyadmin
环境准备
主机名 | wanIP | LanIP | 角色 | 应用 |
---|---|---|---|---|
lb01 | 10.0.0.5 | 172.16.1.5 | 负载均衡 | nginx |
web01 | 10.0.0.7 | 172.16.1.7 | phpmyadmin网站 | nginx、php |
web02 | 10.0.0.8 | 172.16.1.8 | phpmyadmin网站 | nginx、php |
db01 | 10.0.0.51 | 172.16.1.51 | 数据库 | MariaDB |
部署
# 1.下载phpmyadmin代码
[root@web01 lb]# wget http://test.driverzeng.com/Nginx_Code/phpMyAdmin-4.9.0.1-all- languages.zip
# 2.解压代码
[root@web01 lb]# unzip phpMyAdmin-4.9.0.1-all-languages
# 3.添加虚拟主机配置文件
[root@web01 lb]# vim /etc/nginx/conf.d/lb.zh.com.conf
server{
listen 80;
server_name php.zls.com;
root /code/lb/phpMyAdmin-4.9.0.1-all-languages;
index index.php index.html;
location ~ /.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name
;
include fastcgi_params;
}
}
[root@web02 ~]# vim /etc/nginx/conf.d/lb.zh.com.conf
server{
listen 80;
server_name php.zls.com;
root /code/lb/phpMyAdmin-4.9.0.1-all-languages;
index index.php index.html;
location ~ /.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name
;
include fastcgi_params;
}
}
# 4.修改代码连接数据库的配置文件
将站点目录下的案例配置文件改名
[root@web01 phpMyAdmin-4.9.0.1-all-languages]# cp config.sample.inc.php config.inc.php
[root@web01 phpMyAdmin-4.9.0.1-all-languages]# vim config.inc.php
将第31行的localhost改成自己的数据库的ip地址
[root@web01 phpMyAdmin-4.9.0.1-all-languages]# vim config.inc.php
# 5.将web01上的代码发送到web02的站点目录下
[root@web01 phpMyAdmin-4.9.0.1-all-languages]# scp -r /code/lb/phpMyAdmin-4.9.0.1-all-languages 172.16.1.8:/code/lb/
# 6.修改存放session的目录文件的属组和属主
[root@web01 phpMyAdmin-4.9.0.1-all-languages]# chown www.www /var/lib/php/sessi 1-all-languages 172.16.1.8:/code/lb/
on -R
[root@web02 ~]# chown www.www /var/lib/php/session -R
# 7.启动nginx
[root@web02 ~]# systemctl reload nginx
[root@web01 phpMyAdmin-4.9.0.1-all-languages]# systemctl reload nginx
# 8.连接数据库
[root@db01 ~]# mysql -uroot -p123
# 9.创建一个数据库的用户
MariaDB [(none)]> grant all on *.* to wp@'172.16.1.%' identified by '123';
登录的用户名:wp
密码:123
添加phpmyadmin的负载均衡
# 1.在负载均衡上添加nginx配置文件
[root@ib01 ~]# vim /etc/nginx/conf.d/lb.zh.com.conf
upstream lb.zh.com {
server 172.16.1.7:80 max_fails=3 fail_timeout=10s max_conns=100;
server 172.16.1.8:80 max_fails=3 fail_timeout=10s;
}
server{
listen 80;
server_name lb.zh.com;
location /{
proxy_pass http://lb.zh.com;
}
}
# 2.域名解析
10.0.0.5 lb.zh.com
制作session共享
# redis端口:6379
# 1.在db01上安装redis数据库
[root@db01 ~]# yum install -y redis
# 2.修改redis配置文件
[root@db01 ~]# vim /etc/redis.conf
将61行bind后面IP地址改为0.0.0.0
bind 0.0.0.0
# 3.启动服务
[root@db01 ~]# systemctl start redis
# 4.修改php程序配置文件
[root@web01 phpMyAdmin-4.9.0.1-all-languages]# vim /etc/php.ini
将1231的内容修改为以下
session.save_handler = redis
在1265行添加以下内容
session.save_path = "tcp://172.16.1.51:6379"
将1295行内容修改为以下
session.auto_start = 1
# 5.修改php启动程序配置文件
[root@web01 phpMyAdmin-4.9.0.1-all-languages]# vim /etc/php-fpm.d/www.conf
将以下内容加上注释(最后几行)
395 ;php_value[session.save_handler] = files
396 ;php_value[session.save_path] = /var/lib/php/session
# 6.重启PHP
[root@web01 phpMyAdmin-4.9.0.1-all-languages]# systemctl restart php-fpm
# 7.将改好的文件拷贝到web02
[root@web01 phpMyAdmin-4.9.0.1-all-languages]# scp /etc/php.ini 172.16.1.8:/etc
/
[root@web01 phpMyAdmin-4.9.0.1-all-languages]# scp /etc/php-fpm.d/www.conf 172.
16.1.8:/etc/php-fpm.d/
# 8.重启web02上的php
原创文章,作者:wdmbts,如若转载,请注明出处:https://blog.ytso.com/268271.html