`
tuhaitao
  • 浏览: 378838 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

使用Nginx帮助Jboss负载

阅读更多
    下载稳定版本,目前是nginx-0.7.64
    http://nginx.net/

shell>> cd /opt
shell>> wget http://sysoev.ru/nginx/nginx-0.7.64.tar.gz
shell>> tar xzvf nginx-0.7.64.tar.gz
shell>> cd nginx-0.7.64

    然后开始编译安装,先配置编译变量:
./configure \
    --user=nginx \
    --group=nginx \
    --prefix=/opt/nginx \
    --sbin-path=/usr/sbin/nginx \
    --conf-path=/etc/nginx/nginx.conf \
    --error-log-path=/var/log/nginx/error.log \
    --http-log-path=/var/log/nginx/access.log \
    --http-client-body-temp-path=/tmp/nginx/client_body \
    --http-proxy-temp-path=/tmp/nginx/proxy \
    --http-fastcgi-temp-path=/tmp/nginx/fastcgi \
    --pid-path=/var/run/nginx.pid \
    --lock-path=/var/lock/subsys/nginx \
    --with-http_stub_status_module

这里解释一下:
# --user            是指启用程序所属用户
# --group           是指启动程序所属组
# --prefix          是指nginx安装目录(不是源代码目录)
# --sbin-path       是指nginx命令位置
# --conf-path       是指配置文件路径
# --error-log-path  是错误日志路径
# --http-log-path   是访问日志

     其他是一些临时文件的路径和做linux service需要用到的文件

需要监控服务需安装此监控状态模块

# --with-http_stub_status_module

    然后make
shell>> cd /opt/nginx
shell>> make
shell>> make install


    现在已经可以通过nginx命令来启动了,但是我们如果想要把nginx做成一个服务,必须要写一个shell.
简单说一下,
# chkconfig:   - 85 15 所有运行级别,启动优先级85, 关闭优先级15
# processname: 进程名称
# config:      nginx配置文件位置
# config:      系统会优先找第一个,如果找不到再去找第二个
# pidfile:     进程ID存放文件,用来存放程序启动后的进程ID

# Source function library.  linux常用的方法库,有兴趣可以去看看service XXX status 就使用了里边的一个方法
# Source networking configuration.  网络配置
#!/bin/sh
#
# nginx - this script starts and stops the nginx daemon
#         by haitao.tu at 2009-12-15
#         email:tuhaitao@foxmail.com
#
# 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/sbin/nginx"
prog=$(basename $nginx)

NGINX_CONF_FILE="/etc/nginx/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
    retval=$?
    echo
    [ $retval -eq 0 ] && rm -f $lockfile
    return $retval
}

restart() {
    configtest_q || configtest || return 6
    stop
    start
}

reload() {
    configtest_q || configtest || return 6
    echo -n $"Reloading $prog: "
    killproc $nginx -HUP
    echo
}

configtest() {
  $nginx -t -c $NGINX_CONF_FILE
}

configtest_q() {
    configtest >/dev/null 2>&1
}

rh_status() {
    status $prog
}

rh_status_q() {
    rh_status >/dev/null 2>&1
}

# Upgrade the binary with no downtime.
upgrade() {
    local pidfile="/var/run/${prog}.pid"
    local oldbin_pidfile="${pidfile}.oldbin"

    configtest_q || configtest || return 6
    echo -n $"Staring new master $prog: "
    killproc $nginx -USR2
    retval=$?
    echo 
    sleep 1
    if [[ -f ${oldbin_pidfile} && -f ${pidfile} ]];  then
        echo -n $"Graceful shutdown of old $prog: "
        killproc -p ${oldbin_pidfile} -QUIT
        retval=$?
        echo 
        return 0
    else
        echo $"Something bad happened, manual intervention required, maybe restart?"
        return 1
    fi
}

case "$1" in
    start)
        rh_status_q && exit 0
        $1
        ;;
    stop)
        rh_status_q || exit 0
        $1
        ;;
    restart|configtest)
        $1
        ;;
    force-reload|upgrade)
        rh_status_q || exit 7
        upgrade
        ;;
    reload)
        rh_status_q || exit 7
        $1
        ;;
    status|status_q)
        rh_$1
        ;;
    condrestart|try-restart)
        rh_status_q || exit 7
        restart
            ;;
    *)
        echo $"Usage: $0 {start|stop|reload|configtest|status|force-reload|upgrade|restart}"
        exit 2
esac


    好了,已经做成chkconfig了,下边需要配置一下nginx反向代理,需要修改/etc/nginx/nginx.conf配置文件

user  nginx;
worker_processes  2;

error_log   /var/log/nginx/error.log;
#error_log  /var/log/nginx/error.log  notice;
#error_log  /var/log/nginx/error.log  info;

pid         /var/run/nginx.pid;


events {
    use epoll; # 采用epoll,是linux下最快的event
    worker_connections  2048;
}


http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    #gzip  on;

    #反向代理配置 ,向内网6台jboss转发
    upstream jboss5 {
        server 172.16.201.127:8080 weight=10;
        server 172.16.201.128:8080 weight=10;
        server 172.16.201.129:8080 weight=10;
        server 172.16.201.130:8080 weight=10;
        server 172.16.201.131:8080 weight=10;
        server 172.16.201.132:8080 weight=10;
    }

    server {
        listen       80;
        server_name  localhost;

        location ~ ^/nginx_status/ {
            stub_status on;
            access_log off;
        }

        location / {
            proxy_pass http://jboss5;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

    }

}


分享到:
评论
1 楼 shibingli 2012-06-08  
session怎么同步的?

相关推荐

    Nginx 1.2.1 + JBOSS AS 7 负载配置及Session处理

    在负载均衡方面,文章首先介绍了 JBOSS 官方文档中推荐使用 Apache Httpd 作为负载均衡服务器,但是作者由于个人喜好 Nginx,所以选择使用 Nginx 1.2.1 + JBOSS AS 7 实现负载均衡。 在 Session 处理方面,文章介绍...

    nginx替代方案,nginx代替apache与jboss

    本文将详细介绍如何使用 Nginx 替代 Apache,并与 JBoss 结合使用,以提高系统的整体性能。 #### 现有部署情况 当前系统使用的是 **Apache + mod_jk + JBoss** 的组合。其中 mod_jk 作为 Apache 和 JBoss 之间的...

    JBoss负载均衡与Mysql主从备份

    ### JBoss负载均衡与MySQL主从备份 在现代IT架构中,为了提高系统的稳定性和响应速度,企业常常采用负载均衡技术和数据库的主从备份方案。本文将深入探讨JBoss应用服务器如何实现负载均衡以及MySQL数据库如何配置...

    tomcat和Nginx

    深入理解这两者的源码可以帮助优化性能,而工具的使用则强调了实践操作的重要性。 综上所述,理解和掌握Tomcat的配置以及Nginx的负载均衡配置,是构建高效、稳定的Web服务架构的关键步骤。在实际应用中,应根据业务...

    JBoss集群配置的Session复制

    JBoss集群通常与Apache HTTP服务器结合使用,通过mod_jk模块实现负载均衡。mod_jk是Apache的一个模块,它负责将HTTP请求转发到后端的JBoss服务器上,并且可以基于一定的规则进行Session的粘滞处理,即让同一Session...

    性能调优 海量并发 系统架构

    基于nginx的tomcat负载均衡和集群 实现多服务器负载均衡 系统性能优化 数据库 Nginx+Squid负载均衡 配置好的集群 总共三十个文档">Apache+Tomcat+Session+Memcache 高性能群集搭建 J2EE性能调优 Jboss的优化配置 ...

    jboss集群安装手册

    JBoss 集群安装手册详细讲解了在Windows环境下如何设置和配置JBoss集群,以及利用Nginx实现负载均衡。以下是对主要内容的详细解析: 1. **引言** - **1.1 说明**:该文档适用于两台Windows Server 2008系统的环境...

    Red Hat Enterprise Linux+Nginx软件安装指南

    通过Mon提供负载均衡nginxd进程和jboss进程的维护和监视,对集群内部负载均衡进程故障做自动修复和记录日志。 高可用性特性列表  主节点电源失效,故障修复速度为12-16s。  主节点意外重启,故障修复速度为12-16s...

    Jboss集群配置

    在提供的文件中,`Jboss集群配置.doc`可能是详细的配置步骤文档,`Apache与Jboss负载均衡教程.pptx`可能包含Apache和JBoss集成的教程,而`jboss集群_jboss5[1].1_apache2.2.4.rar`则可能包含具体的配置示例和必要的...

    windows jboss 集群2

    5. **负载均衡器**:可选配如HAProxy或Nginx等负载均衡器,根据策略分配请求到不同的JBoss实例。 6. **部署应用**:在所有节点上部署相同的应用,确保版本一致。 7. **启动集群**:依次启动各节点,检查集群状态,...

    jboss服务器配置指南

    本配置指南将深入探讨JBoss服务器的配置和优化,帮助你更好地理解和管理这个强大的平台。 1. **安装与启动** - JBoss的下载:首先,你需要从Red Hat的官方网站获取最新版本的JBoss服务器,通常包括EAP(企业应用...

    tomcat apache jboss集群分布

    1. **负载均衡**:通过负载均衡器,如Apache的mod_proxy或Nginx,可以将请求分散到多个服务器上,避免单点故障,提高系统性能。例如,Apache可以通过配置代理模块来分发到多个Tomcat实例。 2. **session复制**:在...

    weblogic、jboss集群配置,参数优化

    5. **反向代理和负载均衡器**:如使用Nginx或HAProxy,可以在外部对集群进行负载均衡和故障切换。 参数优化是提升WebLogic和JBoss性能的关键。以下是一些常见的优化策略: - **内存调优**:根据应用需求调整堆大小...

    JBOSS4.2.2EJBWEB群集配置与部署全过程

    本文将详细阐述JBOSS 4.2.2版本的EJB和Web应用的群集配置与部署全过程,帮助你掌握这一重量级应用服务器的使用技巧。 首先,我们要理解JBOSS 4.2.2中的EJB(Enterprise JavaBeans)。EJB是Java EE平台的核心组件之...

    jboss集群

    2. **负载均衡**:可以通过配置反向代理服务器(如Apache HTTP Server或Nginx)或者使用内置的JGroups模块来实现。负载均衡器根据预设策略将请求分发到不同的JBoss实例上,比如轮询、最少连接数等。 3. **Session...

    JBoss422集群配置指南(01)

    本指南将深入讲解JBoss4.2.2的集群配置,旨在帮助初学者掌握企业级系统性能优化策略。 一、集群概念与优势 1. 概念:集群是指将多个独立的服务器通过网络连接,形成一个逻辑上的整体,对外提供一致的服务。JBoss...

    JBOSS集群说明与配置[参照].pdf

    JBoss使用JGroups进行会话复制,保证用户在节点间切换时会话信息的一致性。 4. 组通信:JGroups是JBoss集群用于节点间通信的基础框架,它提供了可靠的消息传递、成员发现和故障检测等功能。 5. 分布式缓存:JBoss...

    rhel+nginx+portal

    3. **集成Portal**: 选择合适的Portal服务,如JBoss Portal或Liferay,安装并配置,确保与Nginx的反向代理设置兼容。 4. **安全优化**: 对RHEL进行安全配置,包括防火墙规则、SELinux策略、系统更新和日志监控。 5. ...

    JBOSS集群说明与配置[归类].pdf

    4. 会话复制配置:在JBoss的web容器中(如Tomcat),配置session复制策略,如使用基于内存的复制或基于数据库的持久化。 5. 配置故障转移和心跳检测:设置节点间的通信协议和心跳检查间隔,以确保及时发现和处理...

Global site tag (gtag.js) - Google Analytics