Linux之lnmp

######lnmp######

mysql

1)解压安装mysql
tar zxf mysql-boost-5.7.17.tar.gz

2)安装cmake(相当于configure),用来编译mysql
yum install -y cmake-2.8.12.2-4.el6.x86_64.rpm 同时解决依赖性

3)cmake -DCMAKE_INSTALL_PREFIX=/usr/local/lnmp/mysql \ #安装目录
-DMYSQL_DATADIR=/usr/local/lnmp/mysql/data \ #数据库存放目录
-DMYSQL_UNIX_ADDR=/usr/local/lnmp/mysql/data/mysql.sock \ #Unix socket 文件路径
-DWITH_MYISAM_STORAGE_ENGINE=1 \ #安装 myisam 存储引擎
-DWITH_INNOBASE_STORAGE_ENGINE=1 \ #安装 innodb 存储引擎
-DDEFAULT_CHARSET=utf8 \ #使用 utf8 字符
-DDEFAULT_COLLATION=utf8_general_ci \ #校验字符
-DEXTRA_CHARSETS=all #安装所有扩展字符集

4)根据提示解决依赖性问题
需要安装包:yum install -y gcc gcc-c++ ncurses-devel

##报错##
CMake Error at cmake/boost.cmake:81 (MESSAGE):
You can download it with -DDOWNLOAD_BOOST=1 -DWITH_BOOST=

This CMake script will look for boost in . If it is not there,
it will download and unpack it (in that directory) for you.

If you are inside a firewall, you may need to use an http proxy:

export http_proxy=http://example.com:80

‘重新编译时,需要清除原来的对象文件和缓存信息’
‘make clean;rm -fr CmakeCache.txt’

##解决##
缺少 -DWITH_BOOST= 参数 -DWITH_BOOST=boost/boost_1_59_0/ (可Tab补齐)

后面编译会有一个warning:
CMake Warning at cmake/bison.cmake:20 (MESSAGE):
Bison executable not found in PATH
Call Stack (most recent call first):
sql/CMakeLists.txt:514 (INCLUDE)

##解决##
yum install -y bison

5)make && make install (过程较长) ##如果make还有问题,删除原来的目录,重新解压编译

6)复制启动脚本到/etc/init.d/
[root@server5 support-files]# pwd
/root/mysql-5.7.17/support-files
[root@server5 support-files]# cp mysql.server /etc/init.d/mysqld

7)将原来的/etc/my.cnf备份,重新拷贝安装包里的过去
[root@server5 etc]# cp my.cnf my.cnf.bak
[root@server5 support-files]# cp my-default.cnf /etc/my.cnf

修改配置:
basedir = /usr/local/lnmp/mysql
datadir = /usr/local/lnmp/mysql/data
socket = /usr/local/lnmp/mysql/data/mysql.sock

8)添加用户和组:
groupadd -g 27 mysql
useradd -u 27 -g 27 mysql (id=27是因为rpm默认安装时mysql用户的id为27,并非强制)

chown mysql.mysql /usr/local/lnmp/mysql -R (修改mysql目录的权限,使其对mysql用户可写)

9)将mysql命令添加到环境变量
vim ~/.bash_profile
添加:PATH= P A T H : PATH: PATH:HOME/bin:/usr/local/lnmp/mysql/bin
生效:source ~/.bash_profile

初始化mysql:
mysqld --user=mysql --initialize(以mysql用户身份初始化)
初始化会生成一个临时密码,用于登录mysql(要记住此密码)
#如:‘2019-01-03T09:06:09.448851Z 1 [Note] A temporary password is generated for root@localhost: r#9VqAoA/au:’

10)为了安全,再将mysql目录的所有者改为root
chown root /usr/local/lnmp/mysql -R
chown mysql /usr/local/lnmp/mysql/data -R ##数据目录所有者必须是mysql,不然mysql用户不能写

11)启动mysql:/etc/init.d/mysqld start

12)进入mysql:mysql -uroot -pr#9VqAoA/au: #使用刚才的临时密码
执行:show databases; 会报错
需要执行:mysql_secure_installation,然后会提示是否启用密码检测插件,直接回车不启用,否则会要求密码有大小写和特殊字符等要求
剩余全部选 y

mysql安装配置完成

php

1)解压:tar jxf php-5.6.35.tar.bz2
yum -y install bzip2
2)进入解压后的目录,开始编译

./configure --prefix=/usr/local/lnmp/php --with-config-file-path=/usr/local/lnmp/php/etc --with-openssl --with-snmp --with-gd --with-zlib --with-curl --with-libxml-dir --with-png-dir --with-jpeg-dir --with-freetype-dir --with-gmp --with-gettext --with-pear --enable-mysqlnd --with-mysql=mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd --enable-inline-optimization --enable-soap --enable-ftp --enable-sockets --enable-mbstring --enable-fpm --with-fpm-user=nginx --with-fpm-group=nginx --with-mcrypt --with-mhash

–with-config-file-path=/etc 指定php.ini位置
–with-MySQL=mysql安装目录,对mysql的支持
–with-MySQLi=mysqli文件目录,优化支持
–enable-fpm
PHP-FPM是一个PHP FastCGI管理器,是只用于PHP的,它其实是PHP源代码的一个补丁,旨在将Fast-CGI进程管理整合进PHP包中。必须将它patch到你的PHP源代码中,在编译安装PHP后才可以使用。新版的PHP已经集成了php-fpm,在./configure的时候带 –enable-fpm参数即可开启PHP-FPM
#以上为php需要编译的模块,把刚才编译mysql的参数要加进来,添加mysqlnd(这是mysql的驱动,php开发的)
–with-freetype-dir 打开对freetype字体库的支持
–with-zlib 打开zlib库支

#编译时遇到的报错就安装:yum install -y libxml2-devel libcurl-devel
#没有jpeglib.h文件:yum whatprovides */jpeglib.h
#yum install -y libjpeg-turbo-devel-1.2.1-1.el6.x86_64
#yum install -y libpng-devel-1.2.49-1.el6_2.x86_64
#yum install -y freetype freetype-devel
#yum install -y net-snmp net-snmp-devel

3)编译报错,逐步解决依赖性(rhel7可以向下兼容6的包)
yum install -y re2c-0.13.5-1.el6.x86_64.rpm libmcrypt-2.5.8-9.el6.x86_64.rpm libmcrypt-devel-2.5.8-9.el6.x86_64.rpm (系统镜像没有的3个包)

4)make && make install

5)编译时添加了–with-fpm-user=nginx --with-fpm-group=nginx 参数
所以添加 nginx 用户

6)拷贝更改配置文件
[root@server5 etc]# pwd
/usr/local/lnmp/php/etc
[root@server5 etc]# cp php-fpm.conf.default php-fpm.conf
查看配置文件中以下几项是否开启:
user = nginx
group = nginx
pid = run/php-fpm.pid

7)拷贝更改php主配置文件
[root@server5 php-5.6.35]# cp php.ini-production /usr/local/lnmp/php/etc/php.ini
修改时区:date.timezone = Asia/Shanghai

8)拷贝php启动脚本至/etc/init.d/
[root@server5 fpm]# pwd
/root/lnmp/php-5.6.35/sapi/fpm
[root@server5 fpm]# cp init.d.php-fpm /etc/init.d/php-fpm
添加执行权限:chmod +x /etc/init.d/php-fpm

9)启动php:/etc/init.d/php-fpm start

nginx

1)解压nginx:tar zxf nginx-1.14.0.tar.gz

2)进入nginx解压包:
vim src/core/nginx.h
修改:#define NGINX_VER “nginx/”(将此行末尾显示nginx版本号的配置删除)

vim auto/cc/gcc
修改:

debug

#CFLAGS="$CFLAGS -g" (将这2行注释调,关闭debug)

3)编译安装nginx:
./configure --prefix=/usr/local/lnmp/nginx --with-http_ssl_module --with-http_stub_status_module --with-threads --with-file-aio --user=nginx --group=nginx

根据提示解决依赖性 ##此处应该还需要安装pcre-devel

4)make && make install

5)修改nginx配置文件,开启php模块
vim

43 location / {
44 root html;
45 index index.php index.html index.htm; (添加php页面)
46 }

65 location ~ .php$ {
66 root html;
67 fastcgi_pass 127.0.0.1:9000;
68 fastcgi_index index.php;
69 #fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
70 include fastcgi.conf;
71 }

6)将nginx启动脚本链接到/usr/local/sbin/
ln -s /usr/local/lnmp/nginx/sbin/nginx /usr/local/sbin/
[root@server5 ~]# nginx -t ##检测语法
[root@server5 ~]# nginx ##开启nginx

7)尝试访问:http://172.25.0.1 ##是nginx默认页面
在nginx默认发布目录添加 index.php
vim /usr/local/lnmp/nginx/html/index.php

<?php phpinfo() ?>

#可以看到php的默认页面

8)启动nginx并访问:http://172.25.0.1

nginx安装配置完成

Discuz论坛搭建

1)解压 Discuz_X3.2_SC_UTF8.zip

unzip Discuz_X3.2_SC_UTF8.zip -d /usr/local/lnmp/nginx/html/
#没有unzip命令的话需要安装:yum install -y unzip

2)将解压后的upload目录改名为bbs,便于访问
mv upload bbs

3)浏览器访问:http://172.25.0.1/bbs

4)点击同意后会出现很多目录不存在和不可写的报错

##解决##
[root@server1 bbs]# pwd
/usr/local/lnmp/nginx/html/bbs

chmod 777 config/ -R
chmod 777 data/ -R
chmod 777 uc_server/ uc_client/ -R
给以上目录增加权限,再刷新就可以了

5)选择全新安装—>填写数据库名(任意) 数据库用户名:root 数据库密码:自己设定的数据库root用户密码
管理员帐号:admin 密码:westos

6)下面会报数据库连接错误:No such file or directory

##解决##
编辑php主配置文件:vim /usr/local/lnmp/php/etc/php.ini
修改以下配置:
pdo_mysql.default_socket= /usr/local/lnmp/mysql/data/mysql.sock
mysql.default_socket = /usr/local/lnmp/mysql/data/mysql.sock
mysqli.default_socket = /usr/local/lnmp/mysql/data/mysql.sock
以上路径为mysql安装的目录,根据自己的路径填写

重新加载php
/etc/init.d/php-fpm reload

7)再次刷新页面,还是报错:Permission denied

##解决##
由于 nginx用户 对于 /usr/local/lnmp/mysql/data 目录没有权限
所以:chmod 755 data/

再次刷新,成功安装

8)点击页面中“管理中心”,会出现报错:Please delete install/index.php via FTP!

##解决##
[root@server5 bbs]# pwd
/usr/local/lnmp/nginx/html/bbs/install
[root@server5 install]# rm -fr index.php

再刷新页面,成功
‘如果把nginx配置文件中php模块注释掉,再刷新页面,会让你下载,这就是打开php模块的原因’

php增加memcache模块
##将phpize加入环境变量
1)将php的bin目录路径增加到 ~/.bash_profile中,为了方便调用
PATH= P A T H : PATH: PATH:HOME/bin:/usr/local/lnmp/mysql/bin:/usr/local/lnmp/php/bin
source ~/.bash_profile
2)memcache目录中本来没有configure文件,所以没法编译
yum install autoconf
先执行命令:phpize
#########################################################################
phpize是用来扩展php扩展模块的,通过phpize可以建立php的外挂模块,比如你想在原来编译好的php中加入memcached或者ImageMagick等扩展模块,可以使用phpize。或者说,phpize的作用可以这样理解:侦测环境(phpize工具是在php安装目录下,基于这点phpize对应了当时的php环境,所以是要根据该php的配置情况生成对应的configure文件),建立一个configure文件。必须在一个目录下去运行phpize。那么phpize就知道你的的环境是哪个目录,并且configure文件建立在该目录下
#########################################################################
会生成configure文件

3)编译安装memcacheng
##编译
./configure
##安装
make && make install

4)修改php主配置文件,增加memcache模块
vim /usr/local/lnmp/php/etc/php.ini
873 extension=memcache.so

5)重新加载php
/etc/init.d/php-fpm reload

6)php -m | grep memcache 可以查看是否加载成功
php -m | grep mysql

7)安装memcached
yum install -y memcached

8)查看memcached的配置文件
[root@server5 sbin]# cat /etc/sysconfig/memcached
PORT=“11211”
USER=“memcached”
MAXCONN=“1024” ##最大链接数1024
CACHESIZE=“64”
OPTIONS="" (如果写为OPTIONS="-l 127.0.0.1" 即为只监听本机的11211端口)

9)启动memcached
/etc/init.d/memcached start

10)telnet测试 ##没有的话:yum install -y telnet
telnet localhost 11211
stats(查看状态)
set name 0 0 6 (0编号 0缓存时间(此处0代表不限制时间) 6限制字符数) key:name;编号:0;缓存时间:0(永久)valuce值:6位
westosawd
CLIENT_ERROR bad data chunk
ERROR
westos
STORED
get name
VALUE name 0 6
westos
END
delete name
DELETED
set name 0 5 6 ##设置缓存5s,过5s再获取name,为空
westos
STORED
get name
END

quit #退出

11)拷贝php页面到nginx默认发布目录
memcache.php监控页面;example.php测memcache命中率
[root@server1 memcache-2.2.5]# cp memcache.php example.php /usr/local/lnmp/nginx/html/

修改内容
define(‘ADMIN_USERNAME’,‘memcache’); ## Admin Username(自定义)
define(‘ADMIN_PASSWORD’,‘westos’); ## Admin Password(自定义)

KaTeX parse error: Expected 'EOF', got '#' at position 68: …re as an array #̲MEMCACHE_SERVERS[] = ‘mymemcache-server2:11211’; // add more as an array
只留一个主机,memcache没有转发或负载均衡机制,只能一个一个添加(因为本实验只有一个主机,其实可以添加多个)

12)访问http://172.25.230.5/memcache.php
输入用户名密码,可以查看memcache命中率,使用http://172.25.230.5/example.php不停刷新来测试

13)在物理机上分别对两个页面进行压测
[root@localhost ~]# ab -c 10 -n 5000 http://172.25.230.5/index.php #很慢,因为没有缓存,而且failed比较多 10个并发,5000个请求
[root@localhost ~]# ab -c 10 -n 5000 http://172.25.230.5/example.php #很快,因为访问缓存,而且没有failed的

观察时间和命中率

nginx添加memcache模块*****
1.什么是OpenResty?

OpenResty(又称:ngx_openresty) 是一个基于 NGINX 的可伸缩的 Web平台,由中国人章亦春发起,提供了很多高质量的第三方模块。
OpenResty 是一个强大的 Web 应用服务器,Web 开发人员可以使用 Lua 脚本语言调动 Nginx 支持的各种 C 以及Lua 模块,更主要的是在性能方面,OpenResty可以 快速构造出足以胜任 10K 以上并发连接响应的超高性能 Web 应用系统。
360,UPYUN,阿里云,新浪,腾讯网,去哪儿网,酷狗音乐等都是 OpenResty 的深度用户。

OpenResty 的目标是让你的 Web 服务直接跑在 Nginx 服务内部,充分利用 Nginx 的非阻塞 I/O 模型,不仅仅对 HTTP 客户端请求,甚至于对远程后端诸如 MySQL,PostgreSQL,~Memcaches 以及 ~Redis 等都进行一致的高性能响应。
所以对于一些高性能的服务来说,可以直接使用 OpenResty 访问 Mysql或Redis等,而不需要通过第三方语言(PHP、Python、Ruby)等来访问数据库再返回,这大大提高了应用的性能。
参考openresty中文官网 http://openresty.org/cn/

原nginx不支持memcache
1)给nginx添加memc和sr cache模块,让nginx直接访问memcache来提高速度
先关闭原来的nginx,因为下面安装的openresty-1.13.6.1.tar.gz也是nginx

nginx -s stop

源码编译安装openresty-1.13.6.1.tar.gz(不需要加参数,使用默认)
./configure --prefix=/usr/local/openresty
gmake && gmake install

拷贝之前example.php和index.php到默认发布目录准备测试
/usr/local/openresty/nginx/html
[root@server5 html]# cp /usr/local/lnmp/nginx/html/index.php .
[root@server5 html]# cp /usr/local/lnmp/nginx/html/example.php .

修改nginx配置文件:vim /usr/local/openresty/nginx/conf/nginx.conf
添加:
upstream memcache {
server localhost:11211;
keepalive 512;
}

    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;(这两个配置的作用是:请求php页面时,先会去memcache中找,如果没有,正常访问;
        srcache_store PUT /memc $key; 访问结束后将结果存到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;
    }

再次进行压测,速度会比之前只加了php的缓存更快

###重点说明一下对index.php页面的访问
访问速度有了明显的差别 因为php是没有缓存的
tomcat

1)安装jdk和tomcat
tar zxf jdk-7u79-linux-x64.tar.gz -C /usr/local/
tar zxf apache-tomcat-7.0.37.tar.gz -C /usr/local/

2)做好软连接便于访问
cd /usr/local
ln -s jdk1.7.0_79/ java
ln -s apache-tomcat-7.0.37/ tomcat

3)配置环境变量
vim /etc/profile
export JAVA_HOME=/usr/local/java
export CLASSPATH=.: J A V A H O M E / l i b : JAVA_HOME/lib: JAVAHOME/lib:JAVA_HOME/jre/lib
export PATH= P A T H : PATH: PATH:JAVA_HOME/bin
source /etc/profile
#####################################################################################
[root@server1 local]# echo $PATH
/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin:/usr/local/lnmp/mysql/bin:/usr/local/lnmp/php/bin:/usr/local/java/bin
[root@server1 local]# echo $CLASSPATH
.:/usr/local/java/lib:/usr/local/java/jre/lib
[root@server1 local]# echo $JAVA_HOME
/usr/local/java
[root@server1 local]# which java
/usr/local/java/bin/java
[root@server1 local]# which javac
/usr/local/java/bin/javac

vim test.java
public class test
{
public static void main(String[] args)
{
System.out.println(“Hello World1”);
}
}
javac test.java
java test
cd /usr/local/tomcat
bin/startup.sh
网页访问:172.25.0.1:8080
网页访问:172.25.0.2:8080
编写页面测试:
cd /usr/local/tomcat/webapps/ROOT/
vim test.jsp
server1-The time is: <%=new java.util.Date() %>

测试nginx对tomcat的负载均衡
vim nginx.conf
upstream tomcat {
server 172.25.0.1:8080;
server 172.25.0.2:8080;

}
location / {
root /usr/local/tomcat/webapps/ROOT;
index index.html index.htm;
}
location ~ .jsp$ {
proxy_pass http://tomcat;
}

http://172.25.0.101/test.jsp
#####################################################################################
4)增加测试页面:vim /usr/local/apache-tomcat-7.0.37/webapps/ROOT/test.jsp
<%@ page contentType=“text/html; charset=GBK” %>
<%@ page import=“java.util.*” %>

Cluster App Test Server Info: <% out.println(request.getLocalAddr() + " : " + request.getLocalPort()+"
");%> <% out.println("
ID " + session.getId()+"
"); String dataName = request.getParameter("dataName"); if (dataName != null && dataName.length() > 0) { String dataValue = request.getParameter("dataValue"); session.setAttribute(dataName, dataValue); } out.print(" Session list"); Enumeration e = session.getAttributeNames(); while (e.hasMoreElements()) { String name = (String)e.nextElement(); String value = session.getAttribute(name).toString(); out.println( name + " = " + value+"
"); System.out.println( name + " = " + value); } %> name:
key:

5)在nginx配置文件中增加tomcat模块,为了实现session共享,需要支持sticky(粘滞)模块,nginx-1.14不支持sticky,所以使用nginx-1.10版本,重新编译nginx
###注意:将/usr/local/lnmp/nginx 目录全部删除 再次编译
tar zxf nginx-sticky-module-ng.tar.gz -C /usr/local/
cd nginx-1.10.3
./configure --prefix=/usr/local/lnmp/nginx --with-http_ssl_module --with-http_stub_status_module --with-threads --with-file-aio --add-module=/usr/local/nginx-sticky-module-ng
make && make install
ln -s /usr/local/lnmp/nginx/sbin/nginx /sbin/
vim /usr/local/lnmp/nginx/conf/nginx.conf
upstream tomcat {
sticky;
server 172.25.0.1:8080;
server 172.25.0.2:8080;

}
gzip on; #开启gzip
location / {
root /usr/local/tomcat/webapps/ROOT;
index index.html index.htm;
}
location ~ .jsp$ {
proxy_pass http://tomcat;
}
nginx
再次刷新页面,访问的ID号不会变,实现了sticky

接下来实现session共享:

1)进入/usr/local/tomcat/lib目录(server1,2都做)
将以下jar包拷贝到该目录:
asm-3.2.jar
kryo-1.04.jar
kryo-serializers-0.10.jar
memcached-session-manager-1.6.3.jar
memcached-session-manager-tc7-1.6.3.jar(最重要)
minlog-1.2.jar
msm-kryo-serializer-1.6.3.jar
reflectasm-1.01.jar
spymemcached-2.7.3.jar

2)编辑/usr/local/tomcat/conf/context.xml文件,加入session共享配置
context.xml 该文件的作用是配置各种数据库的连接池
#########################################################
XML概念
xml常用于数据存储和传输,文件后缀为 .xml
它是可扩展标记语言(Extensible Markup Language,简称XML),是一种标记语言
标记,指计算机所能理解的信息符号;
通过此种标记,计算机之间可以处理包含各种信息的文章等
1 标记,指计算机所能理解的信息符号;
2 通过此种标记,计算机之间可以处理包含各种信息的文章等。
XML设计用来传送及携带数据信息,不用来表现或展示数据,所以XML用途的焦点是它说明数据是什么,以及携带数据信息。而HTML语言则用来表现数据

#########################################################
<Manager className=“de.javakaffee.web.msm.MemcachedBackupSessionManager”
memcachedNodes=“n1:172.25.230.5:11211,n2:172.25.230.6:11211”
failoverNodes=“n1” (在172.25.230.6上"n1"改为"n2")
requestUriIgnorePattern=".*.(ico|png|gif|jpg|css|js)$"
transcoderFactoryClass=“de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory”
/>

server1:
yum install memcached -y
/etc/init.d/memcached start

server2:
3)保存并启动tomcat
172.25.0.1/test.jsp

4)再次测试,如果n1挂了,session不会被重置

###注意测试的时候:想更改n1 n2 的时候 可以手动停掉server1 server2上的tomcat和memcached
##停止一端的memcache
####################################################################
一、cookie:

在网站中,http请求是无状态的。也就是说即使第一次和服务器连接后并且登录成功后,第二次请求服务器依然不能知道当前请求是哪个用户。cookie的出现就是为了解决这个问题,第一次登录后服务器返回一些数据(cookie)给浏览器,然后浏览器保存在本地,当该用户发送第二次请求的时候,就会自动的把上次请求存储的cookie数据自动的携带给服务器,服务器通过浏览器携带的数据就能判断当前用户是哪个了。cookie存储的数据量有限,不同的浏览器有不同的存储大小,但一般不超过4KB。因此使用cookie只能存储一些小量的数据。
二、session:

session和cookie的作用有点类似,都是为了存储用户相关的信息。不同的是,cookie是存储在本地浏览器,而session存储在服务器。存储在服务器的数据会更加的安全,不容易被窃取。但存储在服务器也有一定的弊端,就是会占用服务器的资源,但现在服务器已经发展至今,一些session信息还是绰绰有余的。
三、cookie和session结合使用:

web开发发展至今,cookie和session的使用已经出现了一些非常成熟的方案。在如今的市场或者企业里,一般有两种存储方式:

1、存储在服务端:通过cookie存储一个session_id,然后具体的数据则是保存在session中。如果用户已经登录,则服务器会在cookie中保存一个session_id,下次再次请求的时候,会把该session_id携带上来,服务器根据session_id在session库中获取用户的session数据。就能知道该用户到底是谁,以及之前保存的一些状态信息。这种专业术语叫做server side session。

2、将session数据加密,然后存储在cookie中。这种专业术语叫做client side session。flask采用的就是这种方式,但是也可以替换成其他形式
####################################################################

nginx的 keepalive_timeout参数是一个请求完成之后还要保持连

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值