nginx+tomcat8+memcached實現session共享具體操做

本次試驗用到的軟件包的版本以下:css

wKioL1PV_D-zah4yAABI9063cOU068.jpg

1、針對10.43.2.134的操做html

1.安裝jdk環境java

tar zxf jdk-8u5-linux-x64.tar.gz linux

mkdir /usr/javanginx

mv jdk1.8.0_05/ /usr/java/web

編輯/etc/profileapache

在文檔的末尾追加以下5行內容:vim

JAVA_HOME=/usr/java/jdk1.8.0_05tomcat

JRE_HOME=/usr/java/jdk1.8.0_05/jre安全

PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin

CLASSPATH=.:${JAVA_HOME}/lib/:$JRE_HOME/lib

export JAVA_HOME JRE_HOME PATH CLASSPATH

[root@localhost jdk1.8.0_05]# source /etc/profile

查看Java的版本

[root@localhost ~]# java -version

java version "1.8.0_05"

Java(TM) SE Runtime Environment (build 1.8.0_05-b13)

Java HotSpot(TM) 64-Bit Server VM (build 25.5-b02, mixed mode)

2.安裝Tomcat 

tar zxvf apache-tomcat-8.0.8.tar.gz

mv apache-tomcat-8.0.8 /usr/local/tomcat/

#默認tomcat是root身份運行的,這樣不安全,咱們設置來用普通用戶

groupadd tomcat 

useradd -g tomcat tomcat 

passwd tomcat 

chown tomcat.tomcat -R /usr/local/tomcat 

su – tomcat /usr/local/tomcat/bin/startup.sh 

echo 「su – tomcat /usr/local/tomcat/bin/startup.sh」 >> /etc/rc.local  #開機啓動

確認服務是否啓動成功:http://www.javashuo.com/tag/http://localhost:8080

wKiom1PV89CjRPbyAAWR9Smwo48073.jpg

一樣的方式再部署一個tomcat,端口號:8081

tar zxvf apache-tomcat-8.0.8.tar.gz

mv apache-tomcat-8.0.8 /usr/local/tomcat2

chown tomcat.tomcat -R /usr/local/tomcat2 

編輯 /usr/local/tomcat2/conf/server.xml

三處修改分別是:

wKioL1PV9LiT6lkwAADRbsNHMQI927.jpg

wKiom1PV857Cz4XlAACsizZfj1Y462.jpg

wKiom1PV856zrVwuAAB9rLSM5Cg903.jpg

su – tomcat /usr/local/tomcat2/bin/startup.sh 

echo 「su – tomcat /usr/local/tomcat2/bin/startup.sh」 >> /etc/rc.local

確認服務是否啓動成功:http://localhost:8081

wKioL1PV9QjCfxyKAAT1IvNBoIo830.jpg

3.製做tomcat服務器測試頁,並測試訪問

分別在$CATALINA/webapps/ROOT/下創建測試頁面t.jsp

# vim /usr/local/tomcat/webapps/ROOT/t.jsp

<html>

    <body bgcolor="green">      

    <center>     

    <%=  request.getSession().getId()  %>     

    <h1>10.43.2.134</h1> 

    <h1>port:8080</h1>  

    </center>

    </body>

</html>

# vim /usr/local/tomcat2/webapps/ROOT/t.jsp

<html>

    <body bgcolor="red">      

    <center>     

    <%=  request.getSession().getId()  %>     

    <h1>10.43.2.134</h1> 

    <h1>port:8081</h1>  

    </center>

    </body>

</html>

打開http://10.43.2.134:8080/t.jsp和http://10.43.2.134:8081/t.jsp能夠看到不一樣的頁面

wKioL1PV9SXSrIgyAABrUh0qEHU760.jpg

wKiom1PV9AuRkVGAAAByz33N1Ow224.jpg


2、針對10.43.2.135的操做

  1. nginx的安裝

安裝依賴包:yum -y install gcc openssl-devel pcre-devel zlib-devel 

安裝nginx

useradd nginx -s /sbin/nologin

tar zxvf nginx-0.8.46.tar.gz  

cd nginx-0.8.46/  

./configure --user=nginx--group=nginx --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module  && make  &&  make install

啓動服務:/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf 

[root@localhost ~]# netstat -anpt|grep nginx 

tcp        0      0 0.0.0.0:80                  0.0.0.0:*                   LISTEN      7920/nginx

測試nginx默認web服務器是否能正常運行

wKioL1PV9XiTjiYAAAEGMLVsjng785.jpg

設置nginx開機自動啓動 

[root@rhel6u3-7 ~]# echo "/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf" >> /etc/rc.local  

[root@rhel6u3-7 ~]# cat /etc/rc.local | grep nginx 

/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf 

nginx的啓動腳本

#編寫nginx啓動、中止、重啓的管理腳本,方便使用

cat /etc/init.d/nginx

#!/bin/sh 

# nginx - this script starts and stops the nginx daemon 

# chkconfig: - 85 15 

# description: Nginx is an HTTP(S) server, HTTP(S) reverse \ 

#   proxy and IMAP/POP3 proxy server 

# processname: nginx 

# config: /etc/nginx/nginx.conf 

# config: /etc/sysconfig/nginx 

# pidfile: /var/run/nginx.pid 

# Source function library. 

. /etc/rc.d/init.d/functions 

# Source networking configuration. 

. /etc/sysconfig/network 

# Check that networking is up. 

[ "$NETWORKING" = "no" ] && exit 0 

    nginx="/usr/local/nginx/sbin/nginx" 

    prog=$(basename $nginx) 

    NGINX_CONF_FILE="/usr/local/nginx/conf/nginx.conf" 

[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx 

    lockfile=/var/lock/subsys/nginx 

start() { 

    [ -x $nginx ] || exit 5 

    [ -f $NGINX_CONF_FILE ] || exit 6 

    echo -n $"Starting $prog: " 

    daemon $nginx -c $NGINX_CONF_FILE 

    retval=$? 

    echo 

[ $retval -eq 0 ] && touch $lockfile 

    return $retval 

stop() { 

    echo -n $"Stopping $prog: " 

    killproc $prog -QUIT 

    retval=$? 

    echo 

[ $retval -eq 0 ] && rm -f $lockfile 

    return $retval 

    killall -9 nginx 

restart() { 

    configtest || return $? 

    stop 

    sleep 1 

    start 

reload() { 

    configtest || return $? 

    echo -n $"Reloading $prog: " 

    killproc $nginx -HUP 

    RETVAL=$? 

    echo 

force_reload() { 

    restart 

configtest() { 

    $nginx -t -c $NGINX_CONF_FILE 

rh_status() { 

    status $prog 

rh_status_q() { 

    rh_status >/dev/null 2>&1 

case "$1" in 

    start) 

        rh_status_q && exit 0 

        $1 

    ;; 

    stop) 

        rh_status_q || exit 0 

        $1 

    ;; 

    restart|configtest) 

        $1 

    ;; 

    reload) 

        rh_status_q || exit 7 

        $1 

    ;; 

    force-reload) 

        force_reload 

    ;; 

    status) 

        rh_status 

    ;; 

    condrestart|try-restart) 

        rh_status_q || exit 0 

    ;; 

    *) 

        echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}" 

        exit 2 

esac 

[root@rhel6u3-7 init.d]# chmod 755 nginx  

[root@rhel6u3-7 init.d]# chkconfig --add nginx  

[root@rhel6u3-7 init.d]# chkconfig --level 35 nginx on   

[root@rhel6u3-7 init.d]# chkconfig --list | grep nginx 

nginx           0:off   1:off   2:off   3:on    4:off   5:on    6:off 

測試nginx腳本文件是否可以正常使用

[root@rhel6u3-7 init.d]# /etc/init.d/nginx restart 

nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok 

nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful 

Stopping nginx:                                            [  OK  ] 

Starting nginx:                                            [  OK  ] 

[root@rhel6u3-7 init.d]# /etc/init.d/nginx reload  

nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok 

nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful 

Reloading nginx:                                           [  OK  ] 

[root@rhel6u3-7 ~]# cat /usr/local/nginx/logs/nginx.pid  

15799 

[root@rhel6u3-7 ~]# kill -HUP `cat /usr/local/nginx/logs/nginx.pid`

 [root@rhel6u3-7 init.d]# /etc/init.d/nginx stop 

Stopping nginx:                                            [  OK  ] 

2.編輯nginx的主配置文件,實現對10.43.2.134上兩個tomcat的代理

cat nginx.conf

user  nginx nginx;

worker_processes  1;

error_log  logs/error.log;

pid        logs/nginx.pid;

events {

    worker_connections  1024;

}


http {

    include       mime.types;

    default_type  application/octet-stream;


    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '

                      '$status $body_bytes_sent "$http_referer" '

                      '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;

    #tcp_nopush     on;

    #keepalive_timeout  0;

    keepalive_timeout  65;

    #gzip  on;

    upstream tomcatweb {

server 10.43.2.134:8080;

server 10.43.2.134:8081;

    }

    server {

        listen       80;

        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;


        location / {

            root   html;

            index  index.html index.htm;

   proxy_pass http://tomcatweb;

        }

        error_page   500 502 503 504  /50x.html;

        location = /50x.html {

            root   html;

        }

    }

}

3.從新加載nginx服務並驗證

從新加載:/etc/init.d/nginx reload 

驗證:能夠看到nginx已經成功代理10.43.2.134上的兩個tomcat,訪問http://10.43.2.135/t.jsp可以正常訪問到10.43.2.134:8080/test.jsp和http://10.43.2.134:8081/test.jsp交替出現,而且session  id 刷新一次變化一次。

wKiom1PV7jqAhzZVAACslTGf15s392.jpg

wKioL1PV71SQsjeXAADEecTNV5c607.jpg

4.安裝memcache

安裝libevent

注:memcached是基於libevent進行事件處理的,因此咱們得先安裝libevent

[root@memcache src]# tar xf libevent-2.0.21-stable.tar.gz

[root@memcache src]# cd libevent-2.0.21-stable

[root@memcache libevent-2.0.21-stable]# ./configure --prefix=/usr/local/libevent

[root@memcache libevent-2.0.21-stable]# make && make install

安裝memcached

[root@memcache src]# tar xf memcached-1.4.15.tar.gz

[root@memcache src]# cd memcached-1.4.15

[root@memcache memcached-1.4.15]# ./configure --prefix=/usr/local/memcached --with-libevent=/usr/local/libevent

[root@memcache memcached-1.4.15]# make && make install

[root@memcache ~]# memcached -d -m 500 -u root -l 192.168.18.201 -c 256 -P /tmp/memcached.pid -vvv  

查看一下啓動端口

root@memcache ~]# netstat -ntulp 

Active Internet connections (only servers)  

Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID/Program name

tcp        0      0 192.168.18.201:11211        0.0.0.0:*                   LISTEN      8086/memcached   

tcp        0      0 0.0.0.0:22                  0.0.0.0:*                   LISTEN      1026/sshd        

tcp        0      0 127.0.0.1:25                0.0.0.0:*                   LISTEN      1103/master      

tcp        0      0 127.0.0.1:6010              0.0.0.0:*                   LISTEN      1137/sshd        

tcp        0      0 127.0.0.1:6011              0.0.0.0:*                   LISTEN      8044/sshd        

tcp        0      0 :::22                       :::*                        LISTEN      1026/sshd        

tcp        0      0 ::1:25                      :::*                        LISTEN      1103/master      

tcp        0      0 ::1:6010                    :::*                        LISTEN      1137/sshd        

tcp        0      0 ::1:6011                    :::*                        LISTEN      8044/sshd        

udp        0      0 192.168.18.201:11211        0.0.0.0:*                               8086/memcached

提供SysV的startup腳本

[root@memcache ~]# vim /etc/init.d/memcached 

#!/bin/bash  

#  

# Init file for memcached  

#  

# chkconfig: - 86 14  

# description: Distributed memory caching daemon  

#  

# processname: memcached  

# config: /etc/sysconfig/memcached

. /etc/rc.d/init.d/functions

## Default variables 

PORT="11211"  

USER="root"  

MAXCONN="1024"  

CACHESIZE="64"  

OPTIONS=""

RETVAL=0 

prog="/usr/local/memcached/bin/memcached"  

desc="Distributed memory caching"  

lockfile="/var/lock/subsys/memcached"

start() { 

        echo -n $"Starting $desc (memcached): "  

        daemon $prog -d -p $PORT -u $USER -c $MAXCONN -m $CACHESIZE  $OPTIONS  

        RETVAL=$?  

        echo  

        [ $RETVAL -eq 0 ] && touch $lockfile  

        return $RETVAL  

}

stop() { 

        echo -n $"Shutting down $desc (memcached): "  

        killproc $prog  

        RETVAL=$?  

        echo  

        [ $RETVAL -eq 0 ] && rm -f $lockfile  

        return $RETVAL  

}

restart() { 

        stop  

        start  

}

reload() { 

        echo -n $"Reloading $desc ($prog): "  

        killproc $prog -HUP  

        RETVAL=$?  

        echo  

        return $RETVAL  

}

case "$1" in 

  start)  

        start  

        ;;  

  stop)  

        stop  

        ;;  

  restart)  

        restart  

        ;;  

  condrestart)  

        [ -e $lockfile ] && restart  

        RETVAL=$?  

        ;;    

  reload)  

        reload  

        ;;  

  status)  

        status $prog  

        RETVAL=$?  

        ;;  

   *)  

        echo $"Usage: $0 {start|stop|restart|condrestart|status}"  

        RETVAL=1  

esac

增長執行權限

[root@memcache ~]# chmod +x /etc/init.d/memcached

加入服務列表並設置開機自啓動

[root@memcache ~]# chkconfig --add memcached 

[root@memcache ~]# chkconfig memcached on  

[root@memcache ~]# chkconfig memcached --list  

memcached          0:關閉    1:關閉    2:啓用    3:啓用    4:啓用    5:啓用    6:關閉


三 、如何實現memcached session共享

如下操做在每一個tomcat上都須要執行

  1. 在$CATALINA/lib中添加以下jar包

wKioL1PV8j7jup8pAACAGsxDPKg546.jpg

jar包的下載地址:http://down.51cto.com/data/1634273

2.修改配置文件context.xml

context.xml中添加以下內容

<ManagerclassName="de.javakaffee.web.msm.MemcachedBackupSessionManager"

       memcachedNodes="n1:10.43.2.135:11211"

        sticky="false"

        sessionBackupAsync="false"

        lockingMode="none"

       requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"

       transcoderFactoryClass="de.javakaffee.web.msm.JavaSerializationTranscoderFactory"/>

3.重啓tomcat服務並進行驗證

再次http://10.43.2.135/t.jsp 能夠看到10.43.2.134:8080/t.jsp和http://10.43.2.134:8081/t.jsp交替出現,端口變化,session  id保持不變

wKiom1PV8lmxfouRAABp8B79MzE908.jpg

wKioL1PV83PgUAVFAABriS2wm2U574.jpg

相關文章
相關標籤/搜索