admin

nginx负载均衡程序安装札记

admin 运维技术 2022-11-15 465浏览 0

对于Nginx负载均衡的设定问题我们说过很多,也总结归纳过很多。在此,我们为了巩固前面的知识,将其中的安装要点再为大家重申一下。对于环境的构建,我们不过多的介绍了,前面已经说的很清楚,现在我们从安装开始说起,直接将配置代码最为重点呈献给大家。

安装Nginx

1>安装 Nginx发音为[engine x],是由俄罗斯人Igor Sysoev建立的项目,基于BSD许可。据说他当初是F5的成员之一,英文主页:http://nginx.net。俄罗斯的一些大网站已经使用它超过两年多了,一直表现不凡。Nginx的编译参数如下:

[root@localhost]#./configure--prefix=/usr/local/server/nginx--with-openssl=/usr/include\ 
--with-pcre=/usr/include/pcre/--with-http_stub_status_module--without-http_memcached_module\ 
--without-http_fastcgi_module--without-http_rewrite_module--without-http_map_module\ 
--without-http_geo_module--without-http_autoindex_module

在这里,需要说明一下,由于Nginx的配置文件中我想用到正则,所以需要pcre模块的支持。我已经安装了pcre及pcre-devel的 rpm包,但是 Ngxin 并不能正确找到 .h/.so/.a/.la 文件,因此我稍微变通了一下:

[root@localhost]#mkdir/usr/include/pcre/.libs/ 
[root@localhost]#cp/usr/lib/libpcre.a/usr/include/pcre/.libs/libpcre.a 
[root@localhost]#cp/usr/lib/libpcre.a/usr/include/pcre/.libs/libpcre.la

然后,修改objs/Makefile大概在908行的位置上,注释掉以下内容: ./configure –disable-shared

接下来,就可以正常执行make及make install了。

2>修改配置文件/usr/local/server/nginx/conf/nginx.conf 以下是我的nginx.conf内容,仅供参考:

#运行用户 
usernobodynobody; 
#启动进程 
worker_processes2; 
#全局错误日志及PID文件 
error_loglogs/error.lognotice; 
pidlogs/nginx.pid; 
#工作模式及连接数上限 
events{ 
useepoll; 
worker_connections1024;} 
#设定http服务器,利用它的反向代理功能提供负载均衡支持 
http{ 
#设定mime类型 
includeconf/mime.types; 
default_typeapplication/octet-stream;

#p#

#设定日志格式 
log_formatmain'$remote_addr-$remote_user[$time_local]'
'"$request"$status$bytes_sent'
'"$http_referer""$http_user_agent"'
'"$gzip_ratio"'; 
log_formatdownload'$remote_addr-$remote_user[$time_local]'
'"$request"$status$bytes_sent'
'"$http_referer""$http_user_agent"'
'"$http_range""$sent_http_content_range"'; 
#设定请求缓冲 
client_header_buffer_size1k; 
large_client_header_buffers44k; 
#开启gzip模块 
gzipon; 
gzip_min_length1100; 
gzip_buffers48k; 
gzip_typestext/plain; 
output_buffers132k; 
postpone_output1460; 
#设定accesslog 
access_loglogs/access.logmain; 
client_header_timeout3m; 
client_body_timeout3m; 
send_timeout3m; 
sendfileon; 
tcp_nopushon; 
tcp_nodelayon; 
keepalive_timeout65; 
#设定负载均衡的服务器列表 
upstreammysvr{ 
#weigth参数表示权值,权值越高被分配到的几率越大 
#本机上的Squid开启3128端口 
server192.168.8.1:3128weight=5; 
server192.168.8.2:80weight=1; 
server192.168.8.3:80weight=6;} 
#设定虚拟主机 
server{ 
listen80; 
server_name192.168.8.1www.yejr.com; 
charsetgb2312; 
#设定本虚拟主机的访问日志 
access_loglogs/www.yejr.com.access.logmain; 
#如果访问/img/*,/js/*,/css/*资源,则直接取本地文件,不通过squid 
#如果这些文件较多,不推荐这种方式,因为通过squid的缓存效果更好 
location~^/(img|js|css)/{ 
root/data3/Html; 
expires24h;}
#对"/"启用负载均衡 
location/{ 
proxy_passhttp://mysvr; 
proxy_redirectoff; 
proxy_set_headerHost$host; 
proxy_set_headerX-Real-IP$remote_addr; 
proxy_set_headerX-Forwarded-For$proxy_add_x_forwarded_for; 
client_max_body_size10m; 
client_body_buffer_size128k; 
proxy_connect_timeout90; 
proxy_send_timeout90; 
proxy_read_timeout90; 
proxy_buffer_size4k; 
proxy_buffers432k; 
proxy_busy_buffers_size64k; 
proxy_temp_file_write_size64k;} 
#设定查看Nginx状态的地址 
location/NginxStatus{ 
stub_statuson; 
access_logon; 
auth_basic"NginxStatus"; 
auth_basic_user_fileconf/htpasswd;}}}

3>查看 Nginx 运行状态 输入地址 http://192.168.8.1/NginxStatus/,输入验证帐号密码,即可看到类似如下内容: Active connections: 328 server accepts handled requests 9309 8982 28890 Reading: 1 Writing: 3 Waiting: 324

***行表示目前活跃的连接数

第三行的第三个数字表示Nginx运行到当前时间接受到的总请求数,如果快达到了上限,就需要加大上限值了。

继续浏览有关 网络 的文章
发表评论