设为首页 收藏本站
查看: 901|回复: 0

[经验分享] nginx + tomcat 实现负载均衡和服务器集群

[复制链接]

尚未签到

发表于 2018-12-7 09:08:45 | 显示全部楼层 |阅读模式
  安装nginx

  所需的prce库
  wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.10.tar.gz
  tar zxvf pcre-8.10.tar.gz
  cd pcre-8.10/
  ./configure
  make && make install
  cd ../
  

  安装nginx
  wget http://nginx.org/download/nginx-0.8.54.tar.gz
  wget http://nginx.org/download/nginx-1.0.2.tar.gz
  

  tar zxvf nginx-1.0.2.tar.gz
  cd nginx-1.0.2/
  ./configure --user=www --group=www --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module
  make && make install
  cd ../
  创建Nginx日志目录
  mkdir -p /home/nginx/logs
  chmod +w /home/nginx/logs
  chown -R www:www /home/nginx/logs
  创建Nginx配置文件
  ①、在/usr/local/nginx/conf/目录中创建nginx.conf文件:
  rm -f /usr/local/nginx/conf/nginx.conf
  vi /usr/local/nginx/conf/nginx.conf
  输入以下内容:
user www www;
worker_processes 8;
error_log /home/nginx/logs/nginx_error.log  crit;
pid /usr/local/nginx/nginx.pid;
worker_rlimit_nofile 65535;
events
{
    use epoll;
    worker_connections 65535;
}
http
{
    include mime.types;
    default_type application/octet-stream;
    #charset gb2312;
    server_names_hash_bucket_size 128;
    client_header_buffer_size 32k;
    large_client_header_buffers 4 32k;
    client_max_body_size 8m;
    sendfile on;
    tcp_nopush on;
    keepalive_timeout 60;
    tcp_nodelay on;
    fastcgi_connect_timeout 300;
    fastcgi_send_timeout 300;
    fastcgi_read_timeout 300;
    fastcgi_buffer_size 64k;
    fastcgi_buffers 4 64k;
    fastcgi_busy_buffers_size 128k;
    fastcgi_temp_file_write_size 128k;
    gzip on;
    gzip_min_length 1k;
    gzip_buffers 4 16k;
    gzip_http_version 1.0;
    gzip_comp_level 2;
    gzip_types text/plain application/x-javascript text/css application/xml;
    gzip_vary on;
    #limit_zone crawler$binary_remote_addr10m;
server
  {
   listen      80;
    server_name www.test.com;
    index index.htm index.html index.jsp;
   root  /home/htdocs/web/ROOT/;
    location ~ .*$
    {
      index index.jsp;
      proxy_pass http://www.test.com:8080;
    }
    access_log logs/sp.imichat.com.log combined;
    error_page  404 = /404.html;
  }
}
  

  ②、在/usr/local/nginx/conf/目录中创建fcgi.conf文件:
  vi /usr/local/nginx/conf/fcgi.conf
  输入以下内容:
fastcgi_param  GATEWAY_INTERFACE  CGI/1.1;
fastcgi_param  SERVER_SOFTWARE    nginx;
fastcgi_param  QUERY_STRING       $query_string;
fastcgi_param  REQUEST_METHOD     $request_method;
fastcgi_param  CONTENT_TYPE       $content_type;
fastcgi_param  CONTENT_LENGTH     $content_length;
fastcgi_param  SCRIPT_FILENAME    $document_root$fastcgi_script_name;
fastcgi_param  SCRIPT_NAME        $fastcgi_script_name;
fastcgi_param  REQUEST_URI        $request_uri;
fastcgi_param  DOCUMENT_URI       $document_uri;
fastcgi_param  DOCUMENT_ROOT      $document_root;
fastcgi_param  SERVER_PROTOCOL    $server_protocol;
fastcgi_param  REMOTE_ADDR        $remote_addr;
fastcgi_param  REMOTE_PORT        $remote_port;
fastcgi_param  SERVER_ADDR        $server_addr;
fastcgi_param  SERVER_PORT        $server_port;
fastcgi_param  SERVER_NAME        $server_name;
# PHP only, required if PHP was built with --enable-force-cgi-redirect
fastcgi_param  REDIRECT_STATUS    200;
  

  启动Nginx
  /usr/local/nginx/sbin/nginx
  

  在不停止Nginx服务的情况下变更Nginx配置
  修改/usr/local/nginx/conf/nginx.conf配置文件后,请执行以下命令检查配置文件是否正确:
  /usr/local/nginx/sbin/nginx -t
  如果屏幕显示以下两行信息,说明配置文件正确:
  the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
  the configuration file /usr/local/nginx/conf/nginx.conf was tested successfully
  重启nginx:
  /usr/local/nginx/sbin/nginx -s reload
  编写每天定时切割Nginx日志的脚本
  创建脚本/usr/local/nginx/sbin/cut_nginx_log.sh
  vi /usr/local/nginx/sbin/cut_nginx_log.sh
  输入以下内容:
#!/bin/bash
# This script run at 00:00
# The Nginx logs path
logs_root_path="/home/nginx/logs/"
logs_path=${logs_root_path}$(date -d "yesterday" +"%Y")/$(date -d "yesterday" +"%m")/
  

  mkdir -p ${logs_path}
  

  #日志文件名 ====================================================
logs_name="weblogs"
logs_file=${logs_root_path}${logs_name}.log
cut_logs_file=${logs_path}${logs_name}_$(date -d "yesterday" +"%Y%m%d").log
mv ${logs_file} ${cut_logs_file}
tar czf ${cut_logs_file}.tar.gz ${cut_logs_file}
rm -f ${cut_logs_file}
  #重启nginx
  /usr/local/nginx/sbin/nginx -s reload
  

  对这个脚本赋执行权限
  # chmod +x /usr/local/nginx/sbin/cut_nginx_log.sh
  设置crontab,每天凌晨00:00切割nginx访问日志
  crontab -e
  输入以下内容:
1
00 00 * * * /bin/bash  /usr/local/nginx/sbin/cut_nginx_log.sh
  2、配置nginx负载均衡
  编辑nginx.conf
  vim /usr/local/nginx/conf/nginx.conf
  在server上面增加
upstream  www.test.com {
              server  www.test.com:8888;
              server  www.test.com:8080;
  


  #ip_hash;   注:如果加入了ip_hash, 这种只能适用于当某个用户连接上了一台服务器后,他登陆之后所做的一切操作都只会在那一台服务器不会跳转到另外的服务器,如果那台服务器over掉了,则会自动退出,连接到另一服务器

  }
  www.test.com 是自己的服务器,最好是用域名
  upstream后面的名字要与proxy_pass 这个名字一样,建议upstream后面的名字,proxy_pass 后面的名字,server_name 后面的名字一致
  示例:
  upstream  www.test.com {
  server  www.test.com:8888;
  server  www.test.com:8080;
  }
  #测试
  

server
  {
   listen      80;
    server_name www.test.com;
    index index.htm index.html index.jsp;
   root  /home/htdocs/web/ROOT/;
    location ~ .*$
    {
      index index.jsp;
      proxy_pass http://www.test.com; 注:做了负载均衡,这个后面就不能再加端口
    }
    access_log logs/sp.imichat.com.log combined;
    error_page  404 = /404.html;
  }
  注:如果负载均衡不成功,请检查是否没有经过nginx,80端口直接被转发到了tomcat服务的端口上
  

  3、配置tomcat集群
  优化tomcat 最大并发数,编辑server.xml
  
  
  
  修改web.xml

  增加标签:
  直接加在 之前就可以了,这个是加入tomcat 的session 复制的,做tomcat 集群必须需要这一步,否则用户的session 就无法正常使用.
  

  

  转载注明出处:http://sulao.cn/?id=213
  





运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-644202-1-1.html 上篇帖子: 使用jdk自带的工具监控tomcat服务器 下篇帖子: eclipse正常启动tomcat, 访问http://localhost:8080 却报404错误
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表