Linux运维新手的修炼手扎之第21天

Nginx服务和Tomcat服务

1 负载均衡

语法格式:upstream[一个或多个]

复制代码
root@ubuntu24-13:~# vim /etc/nginx/conf.d/vhost.conf
    upstream group1 {
        server 10.0.0.16;
    }
    upstream group2 {
        server 10.0.0.14;
    }
    server {
        listen 80;
        server_name sswang1.magedu.com;
        location / {
            proxy_pass http://group1;
        }
    }
    server {
        listen 80;
        server_name sswang2.magedu.com;
        location / {
            proxy_pass http://group2;
        }
    }

调度算法:轮询、加权轮询[weight=3]、

备用主机实践[backup标记该Server为备用,当所有后端服务器不可用时,才使用此服务器]、

复制代码
upstream group1 {
            	# 10.0.0.14 平常不用
         		server 10.0.0.16;
         		server 10.0.0.14 backup;
        	}

应用平滑下线[down标记该Server临时不可用,可用于平滑下线后端服务器,新请求不再调度到此服务器,原有连接不受影响]、

复制代码
upstream group1 {
                # 10.0.0.14 准备下线
                server 10.0.0.16;
                server 10.0.0.14 down;
			}

ip_hash[根据客户端IP的哈希值固定分配到同一台后端服务器,第一次找的谁,以后都找它]、

复制代码
 upstream group1 {
                ip_hash;
                server 10.0.0.16;
                server 10.0.0.14;
			}

hash $key[自定义哈希键(如 URL、参数),相同键的请求固定分配到同一服务器]

复制代码
upstream group1 {
                hash $request_uri consistent;  # 按请求URI哈希,consistent可选,使用一致性哈希算法减少服务器增减时的重新映射
                server 10.0.0.16;
                server 10.0.0.14;
			}

2 四层代理

语法格式:外层stream,内部【upstream + server[不需要location]】
用apt方式安装的nginx,默认是--with-stream=dynamic动态加载的,需要加载模块load_module /usr/lib/nginx/modules/ngx_stream_module.so

复制代码
root@ubuntu24-13:~# vim /etc/nginx/nginx.conf 
    stream {
        include /etc/nginx/conf.d/stream_configs/*.conf;
    }
    root@ubuntu24-13:~# mkdir -p /etc/nginx/conf.d/stream_configs
	root@ubuntu24-13:~# vim /etc/nginx/conf.d/stream_configs/tcp.conf
    upstream mysqlserver{
        server 10.0.0.16:3306;
    }
    upstream redisserver{
        server 10.0.0.14:6379;
    }
    server{
        listen 3306;
        proxy_pass mysqlserver;
	}
	server{
        listen 6379;
        proxy_pass redisserver;
	}

4 java基础

java代码逻辑:
单一功能:语法 - 源代码 - 字节码 - jvm
复杂功能:语法 - 源代码 - 字节码 - JRE(jvm + 运行库环境)
项目维护:语法 - 源代码 - 字节码 - JDK(JRE(jvm + 运行库环境) + 维护工具)
java环境部署:jdk【oracle+openjdk】
5 tomcat基础
环境部署:tomcat 和 jdk 有版本兼容性|最低版本要求[tomcat10最低版本要求jdk11、tomcat9最低版本要求jdk8]
运行命令:
主控制脚本:catalina.sh start|stop
启动 Tomcat:startup.sh=catalina.sh start
关闭 Tomcat:shutdown.sh=catalina.sh stop
tomcat配置结构:
server、service、connector - engine、host
context:全局的【tomcat的配置目录】、host专用【单一web目录里面--优先级最高】

相关推荐
Ha_To15 分钟前
2025.12.18 NAT地址转换、PAT
linux·服务器·网络
爱吃番茄鼠骗21 分钟前
Linux操作系统———I/O多路复用
linux
BullSmall33 分钟前
集群-节点的概念
运维
vortex536 分钟前
Linux 命令行入门:命令的构成与选项用法
linux·运维·服务器
m0_474606781 小时前
Linux安装docker教程
linux·运维·docker
落霞的思绪1 小时前
Mybatis读取PostGIS生成矢量瓦片实现大数据量图层的“快显”
linux·运维·mybatis·gis
山风wind1 小时前
网络分层模型:OSI和TCP/IP参考模型
服务器·网络·tcp/ip
像风一样的男人@1 小时前
linux --防火墙
linux·运维·服务器
skywalk81631 小时前
使用Trae 自动编程:为小学生学汉语项目增加不同出版社教材的区分
服务器·前端·人工智能·trae
网硕互联的小客服2 小时前
Centos系统如何更改root账户用户名?需要注意什么?
linux·运维·服务器·数据库·安全