下载稳定版本,目前是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;
}
}
}
分享到:
相关推荐
在负载均衡方面,文章首先介绍了 JBOSS 官方文档中推荐使用 Apache Httpd 作为负载均衡服务器,但是作者由于个人喜好 Nginx,所以选择使用 Nginx 1.2.1 + JBOSS AS 7 实现负载均衡。 在 Session 处理方面,文章介绍...
本文将详细介绍如何使用 Nginx 替代 Apache,并与 JBoss 结合使用,以提高系统的整体性能。 #### 现有部署情况 当前系统使用的是 **Apache + mod_jk + JBoss** 的组合。其中 mod_jk 作为 Apache 和 JBoss 之间的...
### JBoss负载均衡与MySQL主从备份 在现代IT架构中,为了提高系统的稳定性和响应速度,企业常常采用负载均衡技术和数据库的主从备份方案。本文将深入探讨JBoss应用服务器如何实现负载均衡以及MySQL数据库如何配置...
深入理解这两者的源码可以帮助优化性能,而工具的使用则强调了实践操作的重要性。 综上所述,理解和掌握Tomcat的配置以及Nginx的负载均衡配置,是构建高效、稳定的Web服务架构的关键步骤。在实际应用中,应根据业务...
JBoss集群通常与Apache HTTP服务器结合使用,通过mod_jk模块实现负载均衡。mod_jk是Apache的一个模块,它负责将HTTP请求转发到后端的JBoss服务器上,并且可以基于一定的规则进行Session的粘滞处理,即让同一Session...
基于nginx的tomcat负载均衡和集群 实现多服务器负载均衡 系统性能优化 数据库 Nginx+Squid负载均衡 配置好的集群 总共三十个文档">Apache+Tomcat+Session+Memcache 高性能群集搭建 J2EE性能调优 Jboss的优化配置 ...
JBoss 集群安装手册详细讲解了在Windows环境下如何设置和配置JBoss集群,以及利用Nginx实现负载均衡。以下是对主要内容的详细解析: 1. **引言** - **1.1 说明**:该文档适用于两台Windows Server 2008系统的环境...
通过Mon提供负载均衡nginxd进程和jboss进程的维护和监视,对集群内部负载均衡进程故障做自动修复和记录日志。 高可用性特性列表 主节点电源失效,故障修复速度为12-16s。 主节点意外重启,故障修复速度为12-16s...
在提供的文件中,`Jboss集群配置.doc`可能是详细的配置步骤文档,`Apache与Jboss负载均衡教程.pptx`可能包含Apache和JBoss集成的教程,而`jboss集群_jboss5[1].1_apache2.2.4.rar`则可能包含具体的配置示例和必要的...
5. **负载均衡器**:可选配如HAProxy或Nginx等负载均衡器,根据策略分配请求到不同的JBoss实例。 6. **部署应用**:在所有节点上部署相同的应用,确保版本一致。 7. **启动集群**:依次启动各节点,检查集群状态,...
本配置指南将深入探讨JBoss服务器的配置和优化,帮助你更好地理解和管理这个强大的平台。 1. **安装与启动** - JBoss的下载:首先,你需要从Red Hat的官方网站获取最新版本的JBoss服务器,通常包括EAP(企业应用...
1. **负载均衡**:通过负载均衡器,如Apache的mod_proxy或Nginx,可以将请求分散到多个服务器上,避免单点故障,提高系统性能。例如,Apache可以通过配置代理模块来分发到多个Tomcat实例。 2. **session复制**:在...
5. **反向代理和负载均衡器**:如使用Nginx或HAProxy,可以在外部对集群进行负载均衡和故障切换。 参数优化是提升WebLogic和JBoss性能的关键。以下是一些常见的优化策略: - **内存调优**:根据应用需求调整堆大小...
本文将详细阐述JBOSS 4.2.2版本的EJB和Web应用的群集配置与部署全过程,帮助你掌握这一重量级应用服务器的使用技巧。 首先,我们要理解JBOSS 4.2.2中的EJB(Enterprise JavaBeans)。EJB是Java EE平台的核心组件之...
2. **负载均衡**:可以通过配置反向代理服务器(如Apache HTTP Server或Nginx)或者使用内置的JGroups模块来实现。负载均衡器根据预设策略将请求分发到不同的JBoss实例上,比如轮询、最少连接数等。 3. **Session...
本指南将深入讲解JBoss4.2.2的集群配置,旨在帮助初学者掌握企业级系统性能优化策略。 一、集群概念与优势 1. 概念:集群是指将多个独立的服务器通过网络连接,形成一个逻辑上的整体,对外提供一致的服务。JBoss...
JBoss使用JGroups进行会话复制,保证用户在节点间切换时会话信息的一致性。 4. 组通信:JGroups是JBoss集群用于节点间通信的基础框架,它提供了可靠的消息传递、成员发现和故障检测等功能。 5. 分布式缓存:JBoss...
3. **集成Portal**: 选择合适的Portal服务,如JBoss Portal或Liferay,安装并配置,确保与Nginx的反向代理设置兼容。 4. **安全优化**: 对RHEL进行安全配置,包括防火墙规则、SELinux策略、系统更新和日志监控。 5. ...
4. 会话复制配置:在JBoss的web容器中(如Tomcat),配置session复制策略,如使用基于内存的复制或基于数据库的持久化。 5. 配置故障转移和心跳检测:设置节点间的通信协议和心跳检查间隔,以确保及时发现和处理...