添加一个nginx-sticky-module模块,可以防止session丢失,使用nginx sticky模块实现基于cookie的负载均衡。
注:建议去官网下载安装包
${0}:安装包所在目录;${1}:nginx安装位置;${2}:pcre安装位置;
${3}:zlib安装位置 ${4}:openssl安装位置
下载nginx-sticky-module压缩包并解压
先检查openssl 和openssl-devel是否安装
若未安装,参考本文结尾处openssl 安装和openssl-devel 安装
若已安装,继续以下步骤
# cd ${0}/nginx-1.8.1
# ./configure --prefix=${1} --with-pcre=${2} --with-zlib=${3} --with-openssl=${4} --add-module=${0}/nginx-sticky-module-1.1
#make
#make install
报错:
make过程中可能会报
1) . 已经安装了pcre和zlib但是报找不到(lib)错误
原因:--with-pcre和--with-zlib未配置或者配置错误
配置位置应为安装位置:--with-pcre=/usr/local/pcre
2)../ngx_http_sticky_misc.c:281:2:error: passing argument 2 of ‘ngx_sock_ntop’ makes integer from pointer withouta cast
需要进入
nginx-sticky-module-1.1解压之后的文件夹
# vi ngx_http_sticky_misc.c +281
原来:
# digest->len = ngx_sock_ntop(in,digest->data, len, 1);
改成:
# digest->len=ngx_sock_ntop(in,sizeof(struct sockaddr_in),digest->data, len, 1);
3)src/core/ngx_sha1.h:19:17:error: sha.h: No such file or directory
需要安装openssl 和 openssl-devel
openssl 安装
# cd ${0}
# tar –zxvf openssl-1.1.0.tar.gz
# cd openssl-1.1.0
# ./configure prefix=${4}
# make
# make install
openssl-devel 安装
centos:
yum –y install openssl-devel
ubuntu:
sudo apt-get install openssl
sudo apt-get install libssl-dev