Linux笔记 #09# Tomcat多开以及Nginx负载均衡简单例子

时间:2023-02-27 23:10:08

Tomcat怎样多开。。

演示一下如何开两个(开n个也差不了多少):

1、添加环境变量(最基础、关键的步骤!)

首先通过复制弄几个tomcat出来:

Linux笔记 #09# Tomcat多开以及Nginx负载均衡简单例子

(尽量不影响原有的配置,毕竟实际生产环境并不需要多开)

编辑etc/profile,添加如下几行,名字可以随便取,不过之后要对应:

# cat1
CAT1_BASE=/opt/tomcat/cat_7070
CAT1_HOME=/opt/tomcat/cat_7070
TOMCAT1_HOME=/opt/tomcat/cat_7070
export CAT1_BASE CAT1_HOME TOMCAT1_HOME
# cat2
CAT2_BASE=/opt/tomcat/cat_9090
CAT2_HOME=/opt/tomcat/cat_9090
TOMCAT2_HOME=/opt/tomcat/cat_9090
export CAT2_BASE CAT2_HOME TOMCAT2_HOME

编辑好后保存并退出,通过source /etc/profile命令让配置立即生效

2、改catalina.sh

catalina.sh在bin目录下,startup.sh等操作都会调用这个脚本。在起始位置添加类似下面的东西(覆盖全局环境变量):

export CATALINA_BASE=$CAT1_BASE
export CATALINA_HOME=$CAT1_HOME

Linux笔记 #09# Tomcat多开以及Nginx负载均衡简单例子

3、改相关端口

编辑conf/server.xml,反正我是一股脑把里面的8xxx全改成7xxx(除了8080改成7070外)。。改好后保存退出就可以启动了。

另外一个cat2也是一样操作。于是就可以同时开好几个tomcat啦。。

Linux笔记 #09# Tomcat多开以及Nginx负载均衡简单例子

Nginx负载均衡简单例子

超级简单。。

开好多个tomcat后,只需修改一下nginx.conf就行了,如下所示:

Linux笔记 #09# Tomcat多开以及Nginx负载均衡简单例子

user root;
worker_processes 4;
pid /run/nginx.pid; events {
worker_connections 768;
# multi_accept on;
} http { ##
# Basic Settings
## sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
types_hash_max_size 2048;
# server_tokens off; # server_names_hash_bucket_size 64;
# server_name_in_redirect off; include /etc/nginx/mime.types;
default_type application/octet-stream; ##
# SSL Settings
## ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # Dropping SSLv3, ref: POODLE
ssl_prefer_server_ciphers on; ##
# Logging Settings
## access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log; ##
# Gzip Settings
## gzip on;
gzip_disable "msie6"; # gzip_vary on;
# gzip_proxied any;
# gzip_comp_level 6;
# gzip_buffers 16 8k;
# gzip_http_version 1.1;
# gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript; ##
# Virtual Host Configs
## # include /etc/nginx/conf.d/*.conf;
# include /etc/nginx/sites-enabled/*; upstream tomcat {
server ***.**.**.**:7070 weight=1;
server ***.**.**.**:9090 weight=1;
} server {
location / {
proxy_pass http://tomcat;
}
}
} #mail {
# # See sample authentication script at:
# # http://wiki.nginx.org/ImapAuthenticateWithApachePhpScript
#
# # auth_http localhost/auth.php;
# # pop3_capabilities "TOP" "USER";
# # imap_capabilities "IMAP4rev1" "UIDPLUS";
#
# server {
# listen localhost:110;
# protocol pop3;
# proxy on;
# }
#
# server {
# listen localhost:143;
# protocol imap;
# proxy on;
# }
#}

nginx.conf

再下一步是reload、测试并观察请求分发情况。

一种方式是直接看tomcat的日志,但是有n个的话就很麻烦了。。。

另一种方式是修改nginx的默认日志输出(同样是编辑nginx.conf然后reload):

        ##
# Logging Settings
## log_format myformat '$upstream_addr - ....'; access_log /var/log/nginx/access.log myformat;
error_log /var/log/nginx/error.log;

观察access日志:

Linux笔记 #09# Tomcat多开以及Nginx负载均衡简单例子

Linux笔记 #09# Tomcat多开以及Nginx负载均衡简单例子的更多相关文章

  1. nginx负载均衡简单配置

    nginx负载均衡简单配置准备三台虚拟机来做这个实验:192.168.232.132        web服务器192.168.232.133        web服务器192.168.232.134 ...

  2. Tomcat服务部署与Nginx负载均衡配置

    一.中间键产品介绍 目前来说IBM的WebSphere,Oracle的Weblogic占据了市场上java语言Web站点的部分份额,该两种软件都是商业化的软件,由于性能优越,可靠性高等优点应用于大型互 ...

  3. Linux(CENTOS7) Nginx负载均衡简单配置

    负载均衡的作用 1.转发功能 按照一定的算法[权重.轮询],将客户端请求转发到不同应用服务器上,减轻单个服务器压力,提高系统并发量. 2.故障移除 通过心跳检测的方式,判断应用服务器当前是否可以正常工 ...

  4. Nginx 笔记与总结(16)nginx 负载均衡

    nginx 反向代理时,如果后端有多台服务器,就可以实现负载均衡. 实现原理:把多台服务器用 upstream 绑定在一起并起一个组名,然后 proxy_pass 指向该组. ngx_http_ups ...

  5. window下nginx负载均衡简单配置-----权重的实现

    下面介绍一个在window下的nginx的负载均衡配置. 需要你在你的电脑上跑两个tomcat.一个8080,一个9080. 需要一个nginx服务器. 需要修改本机的host 注意:我们这里配置不会 ...

  6. nginx负载均衡简单实例

    nginx分配服务器策略 1.轮询(默认) 每一个请求按时间顺序逐一分配到不同的祸端服务器,如果后端服务器 down 掉,能自动抵触 2.weight(权重) weight代表权重,默认为1,权重越高 ...

  7. php nginx 负载均衡简单配置过程

    负载均衡 负载均衡是我们大流量网站要做的一个东西,下面我来给大家介绍在Nginx服务器上进行负载均衡配置方法,希望对有需要的同学有所帮助哦. 简单了解一下什么是负载均衡,单从字面上的意思来理解就可以解 ...

  8. nginx 负载均衡简单配置

    配置要求: 三台服务器 127.0.0.1       主负载(把访问请求分给主机池) 127.0.0.2       主机2 127.0.0.3       主机3 第一步: 配置127.0.0.1 ...

  9. Tomcat集群 Nginx负载均衡 shell脚本实时监控Nginx

    第一步,安装Tomcat 系统环境:Centos7 第1步:下载tomcat安装包 tomcat官网:https://tomcat.apache.org/ 第2步:安装包上传至linux中 第3步:下 ...

随机推荐

  1. 几篇关于VisualStudio的调试工具文章

    现代的软件变得日益复杂,强大的调试功能也变得日益重要起来.在VisualStudio的最近几个版本中,在调试工具方面也是增强了不少的,本文转录了几个微软官方介绍的一些新增的调试功能的文章,如果能很好的 ...

  2. 转:Android studio Gradle

    提高Android Studio中Gradle执行效率 分类: android studio2015-06-26 11:54 2374人阅读 评论(2) 收藏 举报 android studiogra ...

  3. 《C++ Primer 4th》读书笔记 第4章-数组和指针

    原创文章,转载请注明出处: http://www.cnblogs.com/DayByDay/p/3911573.html

  4. Makefile与shell脚本区别

    http://blog.chinaunix.net/uid-20672257-id-3345593.html 在Makefile可以调用shell脚本,但是Makefile和shell脚本是不同的.本 ...

  5. 导入maven项目各个注解均报错了

    所遇问题: 导入maven项目各个注解均报错了; 思考1: 这个项目使用了springboot;spring是个”大容器”,所有对象的创建和管理都交给了它, (SpringBoot是一个框架,一种全新 ...

  6. 杜伦大学提出GANomaly:无需负例样本实现异常检测

    杜伦大学提出GANomaly:无需负例样本实现异常检测 本期推荐的论文笔记来自 PaperWeekly 社区用户 @TwistedW.在异常检测模块下,如果没有异常(负例样本)来训练模型,应该如何实现 ...

  7. jsp 中变量作用域:pageScope、requestScope、sessionScope、applicationScope

    jsp 中,变量的作用域,一共有4种: pageScope:表示变量只能在本页面使用. requestScope:表示变量能在本次请求中使用. sessionScope:表示变量能在本次会话中使用. ...

  8. C# WebService调用方法

    public class WebServiceHelper    {        /// < summary>         /// 动态调用web服务         /// &lt ...

  9. MapReduce原理——分而治之

    一.MapReduce简介 二.MapReduce并行处理的基本过程 三.MapReduce实际处理流程 四.一个job的运行流程 一.MapReduce简介 MapReduce是一种并行可扩展计算模 ...

  10. c&num; 消息机制

    1.windows系统是一个消息驱动的系统,windows本身有自己的消息队列. 系统传递消息给应用程序. 应用程序的消息机制:应用程序的执行是通过消息驱动的.消息是整个应用程序的工作引擎. 2.c# ...