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目录里面--优先级最高】

相关推荐
ALex_zry2 小时前
Docker Compose运维技术实战分享:从安装到架构解析
运维·docker·架构
测试界的海飞丝6 小时前
10道软件测试面试题及其答案:
服务器·测试工具·职场和发展
t198751286 小时前
在Ubuntu 22.04系统上安装libimobiledevice
linux·运维·ubuntu
skywalk81636 小时前
linux安装Code Server 以便Comate IDE和CodeBuddy等都可以远程连上来
linux·运维·服务器·vscode·comate
@游子7 小时前
内网渗透笔记-Day5
运维·服务器
晚风吹人醒.7 小时前
缓存中间件Redis安装及功能演示、企业案例
linux·数据库·redis·ubuntu·缓存·中间件
记得记得就1517 小时前
【Nginx 性能优化与防盗链】
运维·nginx·性能优化
Yawesh_best7 小时前
告别系统壁垒!WSL+cpolar 让跨平台开发效率翻倍
运维·服务器·数据库·笔记·web安全
V***u4537 小时前
MS SQL Server partition by 函数实战二 编排考场人员
java·服务器·开发语言
roman_日积跬步-终至千里7 小时前
【Docker】Docker Stop 后到底发生了什么?——从信号机制到优雅停机
运维·docker·容器