lnmp需要搭建支持redis会话保存的应用
脑图:
各软件版本:
linux:centos7.9 ;ngnix:nginx-1.23.3 ;
Mysql5.7; PHP:5.6;Redis:redis-6.2.2
实验环境
web服务器:
centos 7.9.2 IP地址:10.0.0.132
redis服务器:
centos 7.9.3 IP地址:10.0.0.133
centos 7.9.2部署LNMP(三种方法)
yum安装(略)
编译安装(略)
脚本编译安装:
#!/bin/bash
#指定脚本运行环境
#源码编译安装mysql数据库
install_mysql(){
systemctl disable --now firewalld
setenforce 0
sed -i "7c SELINUX=disabled" /etc/sysconfig/selinux
cd /opt
#安装环境依赖包
yum -y install gcc gcc-c++ ncurses ncurses-devel bison cmake expect
tar xf /opt/mysql-boost-5.7.20.tar.gz -C /opt/
useradd -M -s /sbin/nologin mysql
cd /opt/mysql-5.7.20
cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DSYSCONFDIR=/etc \
-DSYSTEMD_PID_DIR=/usr/local/mysql \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_EXTRA_CHARSETS=all \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DWITH_BOOST=boost \
-DWITH_SYSTEMD=1
make -j 4 && make install
cat > /etc/my.cnf <<EOF
[client]
port = 3306
socket = /usr/local/mysql/mysql.sock
[mysql]
port = 3306
socket = /usr/local/mysql/mysql.sock
auto-rehash
[mysqld]
user = mysql
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
port = 3306
character-set-server=utf8
pid-file = /usr/local/mysql/mysqld.pid
socket=/usr/local/mysql/mysql.sock
bind-address = 0.0.0.0
skip-name-resolve
max_connections=2048
default-storage-engine=INNODB
max_allowed_packet=16M
server-id = 1
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES
EOF
chown -R mysql:mysql /usr/local/mysql/
chown mysql:mysql /etc/my.cnf
cat >> /etc/profile <<EOF
export PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH
EOF
source /etc/profile
cd /usr/local/mysql/bin/
./mysqld \
--initialize-insecure \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data
cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/
systemctl daemon-reload
systemctl enable --now mysqld
/usr/bin/expect <<EOF
spawn mysqladmin -u root -p password "abc123"
expect "Enter password" {send "\r"}
expect eof
EOF
/usr/bin/expect <<EOF
spawn mysql -u root -p
expect "Enter password" {send "abc123\r"}
expect "mysql" {send "grant all privileges on *.* to 'root'@'%' identified by 'abc123';\r"}
expect "mysql" {send "quit\r"}
expect eof
EOF
/usr/bin/expect <<EOF
spawn mysql -u root -p
expect "Enter password" {send "abc123\r"}
expect "mysql" {send "CREATE DATABASE bbs;\r"}
expect "mysql" {send "GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY 'admin123';\r"}
expect "mysql" {send "flush privileges;\r"}
expect "mysql" {send "quit\r"}
expect eof
EOF
}
#源码编译安装Nginx服务
install_nginx(){
yum -y install pcre-devel zlib-devel make
useradd -M -s /sbin/nologin nginx
tar xf /opt/nginx-1.12.0.tar.gz -C /opt/
cd /opt/nginx-1.12.0/
./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module
make -j 4 && make install
ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
cat > /lib/systemd/system/nginx.service <<EOF
[Unit]
Description=nginx
After=network.target
[Service]
Type=forking
PIDFile=/usr/local/nginx/logs/nginx.pid
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target
EOF
chmod 754 /lib/systemd/system/nginx.service
systemctl enable --now nginx.service
}
#源码编译安装php服务
install_php(){
yum -y install gd \
libjpeg libjpeg-devel \
libpng libpng-devel \
freetype freetype-devel \
libxml2 libxml2-devel \
zlib zlib-devel \
curl curl-devel \
openssl openssl-devel
tar xf /opt/php-7.1.10.tar.bz2 -C /opt/
cd /opt/php-7.1.10
./configure \
--prefix=/usr/local/php \
--with-mysql-sock=/usr/local/mysql/mysql.sock \
--with-mysqli \
--with-zlib \
--with-curl \
--with-gd \
--with-jpeg-dir \
--with-png-dir \
--with-freetype-dir \
--with-openssl \
--enable-fpm \
--enable-mbstring \
--enable-xml \
--enable-session \
--enable-ftp \
--enable-pdo \
--enable-tokenizer \
--enable-zip
make -j 4 && make install
ln -s /usr/local/php/bin/* /usr/local/bin/
ln -s /usr/local/php/sbin/* /usr/local/sbin/
cp /opt/php-7.1.10/php.ini-development /usr/local/php/lib/php.ini
sed -i "1170c mysqli.default_socket = /usr/local/mysql/mysql.sock" /usr/local/php/lib/php.ini
sed -i "939c date.timezone = Asia/Shanghai" /usr/local/php/lib/php.ini
cd /usr/local/php/etc/
cp php-fpm.conf.default php-fpm.conf
sed -i "17c pid = run/php-fpm.pid" /usr/local/php/etc/php-fpm.conf
cd /usr/local/php/etc/php-fpm.d/
cp www.conf.default www.conf
/usr/local/php/sbin/php-fpm -c /usr/local/php/lib/php.ini
cp /opt/php-7.1.10/sapi/fpm/php-fpm.service /usr/lib/systemd/system/php-fpm.service
systemctl restart php-fpm.service
sed -i "65,68 s/^.*#//" /usr/local/nginx/conf/nginx.conf
sed -i '69c fastcgi_param SCRIPT_FILENAME /usr/local/nginx/html$fastcgi_script_name;' /usr/local/nginx/conf/nginx.conf
sed -i "70,71 s/^.*#//" /usr/local/nginx/conf/nginx.conf
systemctl restart nginx.service
cat >/usr/local/nginx/html/index.php<<EOF
<?php
phpinfo();
?>
EOF
unzip /opt/Discuz_X3.4_SC_UTF8.zip -d /opt/dis
cd /opt/dis/dir_SC_UTF8/
cp -r upload/ /usr/local/nginx/html/bbs
cd /usr/local/nginx/html/bbs
chown -R daemon ./config
chown -R daemon ./data
chown -R daemon ./uc_client
chown -R daemon ./uc_server/data
chmod -R 777 ./config
chmod -R 777 ./data
chmod -R 777 ./uc_client
chmod -R 777 ./uc_server
}
#####脚本主体#####
#调用安装mysql函数
install_mysql
#调用安装Nginx函数
install_nginx
验证并配置ngnx服务配置文件:
[root@10 ~]# php -v
PHP 5.6.40 (cli) (built: Feb 10 2023 20:52:08)
Copyright (c) 1997-2016 The PHP Group
全系统查找nginx.conf
[root@10 ~]# find / -name nginx.conf
/root/oneinstack/config/nginx.conf
/usr/local/nginx/conf/nginx.conf
vim +100 /usr/local/nginx/conf/nginx.conf #配置100行
配置结果:
测试:
/usr/local/nginx/sbin/nginx -t
成功,重启验证端口:
[root@10 ~]# systemctl restart nginx
重启,查看端口:
[root@10 ~]# netstat -utnlp | grep :80
打开php-fpm并配置
[root@10 ~]# systemctl start php-fpm
开机运行,验证:
[root@10 ~]# systemctl enable php-fpm
[root@10 ~]# netstat -utnlp | grep :9000
[root@10 ~]# vim /usr/local/nginx/html/test.php
<?php
$i=99;
echo $i;
?>
命令行访问:
[root@10 ~]# curl http://127.0.0.1/test.php
配置php支持redis:
下载工具到根目录
wget https://pecl.php.net/get/redis-5.3.7.tgz
检查依赖并安装
[root@10 ~]# rpm -q php
package php is not installed
[root@10 ~]# rpm -q php-devel
package php-devel is not installed
[root@10 ~]# rpm -q autoconf
autoconf-2.69-11.el7.noarch
[root@10 ~]# rpm -q automake
automake-1.13.4-3.el7.noarch
[root@10 ~]#
1.安装依赖:
[root@10 ~]# yum install php php-devel -y
解压工具
tar zxvf redis-5.3.7.tgz
生成配置文件
[root@10 ~]# cd redis-5.3.7
生成配置文件php-config及configure命令
[root@10 phpredis-2.2.4]# phpize #生成config
启动
./configure --with-php-config=/usr/bin/php-config --enable-redis
编译安装
make & make install
/usr/lib64/php/modules/
修改php的主配置文件,让它去加载redis模块
vim /etc/php.ini
改728行左右,728/730行
重启php-fpm服务
systemctl restart php-fpm
查看是否支持redis
php -m |grep -i redis
编写php脚本从redis服务器读取会话数据
$redis->auth("redis");
$redis->set("yang","88888");
//var_dump($a);
$data=$redis->keys("*");
var_dump($data);
//$redis->set('yang'=>170);
?>
OK了,刷新运行php程序
查看redis库:在Redis上验证会话已经保存
加上一句:取值:
echo $redis->get("yang");
浏览器验证:输出redis服务器key的值
Lnmp+redis:可读可写应用保存的会话数据完成
如果觉得对您有用,请点个赞哦♪(^∀^●) ↓↓↓