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

相关推荐
orion5714 小时前
Missing Semester Class1:course overview and introduction of shell
linux
SkyWalking中文站18 小时前
认识 Horizon UI · 6/17:Trace 探索器
运维·监控·自动化运维
用户1204872216120 小时前
Linux驱动编译与加载
linux·嵌入式
程序员老赵21 小时前
服务器文件不想 SFTP 上传?Docker 跑个 File Browser,浏览器就能管理
服务器·docker·开源
火车叼位21 小时前
写给初级开发者:SSL、SSH、HTTPS 与证书体系全解析
运维
vivo互联网技术1 天前
从 10 分钟到 1 秒:ES 深度分页任意跳页的三轮优化实战
服务器·数据库·redis·elasticsearch·深度分页
用户805533698031 天前
Input 子系统架构:Core、Handler、Driver 三层是怎么协作的
linux·嵌入式
用户805533698031 天前
RK-Forge外设系列开篇 - 把板子从「能启动」变成「能用」:Ethernet/SPI/MMC 三个纯接线外设
linux·github·嵌入式
小猿姐1 天前
唯品会大规模数据库云原生实践:基于 KubeBlocks 管理数千实例的统一运维之路
运维·elasticsearch·云原生