从小白到大神之路之学习运维第67天-------Tomcat应用服务 WEB服务

第三阶段基础

时  间:2023年7月25日

参加人:全班人员

内  容:

Tomcat应用服务 WEB服务

目录

一、中间件产品介绍

二、Tomcat软件简介

三、Tomcat应用场景

四、安装配置Tomcat

五、配置目录及文件说明

(一)tomcat主目录介绍

(二)Tomcat的脚本文件

(三)webapps目录介绍

六、Tomcat主配置文件说明

server.xml的结构构成:

Server.xml主要参数说明:

host参数详解:

Context参数说明

请求处理流程

处理流程:

七、自定义首页信息:

八、Nginx+Tomcat 负载均衡集群部署:

Nginx代理介绍

1、代理概述

2、正向代理

3、反向代理

安装部署:

九、Tomcat连接数据库:

十、Tomcat配置SSL加密


一、中间件产品介绍

目前来说IBM的WebSphere,Oracle的Weblogic占据了市场上Java语言Web站点的部分份额,该两种软件由于无与伦比的性能及可靠性等优势被广泛应用于大型互联网公司的Web场景中,但是其高昂的价格也使得中小型互联网公司对此望而却步。

Tomcat自5.x版本以来,其性能上已经得到很大幅度的提升,加上其开放性的框架和二次开发等特性,已经完全可以用在访问量不是很大的生产环境下,目前大多数用于JSP技术开发的电子商务网站基本上都应用了Tomcat。

中间件产品:RedHat JBoss、Oracle Tuxedo、caucho Resin。

二、Tomcat软件简介

Tomcat是Apache软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun和其他一些公司及个人共同开发而成。

Tomcat最初是由Sun的软件构架师詹姆斯·邓肯·戴维森开发的。后来他将其变为开源项目,并由Sun贡献给Apache软件基金会。由于大部分开源项目O'Reilly都会出一本相关的书,并且将其封面设计成某个动物的素描,因此他希望将此项目以一个动物的名字命名。因为他希望这种动物能够自己照顾自己,最终,他将其命名为Tomcat(公猫)。而O'Reilly出版的介绍Tomcat的书籍的封面也被设计成了一个公猫的形象。而Tomcat的Logo兼吉祥物也被设计成了一只公猫。

其实Tomcat最早在开始研发的时候并不叫这个名字,早期的Tomcat的Logo项目的名字叫Catalina,所以当我们安装完Tomcat后会发现安装路径下有很多Catalina有关的目录和文件。这些文件是我们配置或使用Tomcat的重要文件所在。

三、Tomcat应用场景

Tomcat服务器是一个免费的开放源代码的web应用服务器,属于轻量级应用服务器,应用在中小型系统和并发访问用户不是很多的场合,是开发和调试JSP页面的首选,Tomcat也可处理静态的HTML页面但是能力不及Apache或Nginx,所以Tomcat通常作为一个servlet和JSP容器,单独运行在后端。

Tomcat官网: http://tomcat.apache.org

 

四、安装配置Tomcat

实验环境:(四台服务器)

服务器

huyang1

toncat8

192.168.59.137

huyang2

tomcat8

192.168.59.138

huyang3

nginx

192.168.59.140

huyang4

mariadb

192.168.59.142

安装tomcat服务:

环境配置:

1、关闭防火墙

systemctl stop firewalld

iptables -F

setenforce 0

2、上传软件包,检查java环境,没有的需要安装jdk

部 署:

3、解包tar xf apache-tomcat-8.5.16.tar.gz

4、启动服务/usr/local/tomcat8/startup.sh

验  证:

客户端访问:192.168.59.137:8080

 

五、配置目录及文件说明

(一)tomcat主目录介绍

bin //存放windows或linux平台上启动或关闭的

(二)Tomcat的脚本文件

conf //存放Tomcat的各种全局配置文件,其中最主要的是server.xml和web.xml

lib //存放Tomcat运行需要的库文件(JARS)

logs //存放Tomcat执行时的LOG文件

webapps //Tomcat的主要Web发布目录、类似于nginx的html(包括应用程实例)

work //存放jsp编译后产生的.class文件

temp //存放临时文件

(三)webapps目录介绍

docs //tomcat帮助文档

examples //web应用实例

host-manager //主机管理

manager //管理

ROOT //默认站点根目录

catalina.policy   //权限控制配置文件

catalina.properties //Tomcat属性配置文件

context.xml   //context用于指定额外的web目录

logging.properties  //日志log相关配置文件

server.xml   //主配置文件

tomcat-users.xml   //manager-gui管理用户配置文件(Tomcat安装后生成的管理界面,该文件可开启访问)

web.xml //Tomcat的servlet,servlet-mapping,filter,MIME等相关配置

六、Tomcat主配置文件说明

server.xml 主要配置文件,可修改启动端口,设置网站根目录,虚拟主机,多实例、开启https加密等功能。

server.xml的结构构成:

 

Server.xml主要参数说明:

组件名称

功能介绍

server

表示一个运行于JVM中的tomcat实例。

service(服务)

将connector关联至engine,因此一个service内部可以有多个connector,但只能有一个引擎engine,负责处理所有Connector所获得的客户请求。service内部有两个connector,一个engine。因此,一般情况下一个server内部只有一个service,一个service内部只有一个engine,但一个service内部可以有多个connector。

connector

接收用户请求,类似于httpd的listen配置监听端口的。

一个Connector在某个指定端口上侦听客户请求,并将获得的请求交给Engine来处理,从Engine处获得回应并返回客户。

Tomcat Engine有两个典型的Connector,一个直接侦听来自browser的http请求,一个侦听来自其他webserver的请ote Http/1.1 Connector在端口8080处侦听来自客户Browser的http请求。

Coyote JK2 Connector在端口8009处侦听来自其他webserver(Apache)的servlet/jsp代理请求。

engine

核心容器组件,catalina引擎,负责通过connector接收用户请求,并处理请求,将请求转至对应的虚拟主机host。

Engine有一个默认的虚拟主机,当请求无法匹配到任何一个Host上的时候,将交给该默认Host来处理。

host

代表一个Virtual Host,虚拟主机,每个虚拟主机和某个网络域名Domain Name相匹配

每个虚拟主机下都可以部署(deploy)一个或者多个Web app,每个web app 对应一个Context,有一个Context path。

当Host获得一个请求时,将把该请求匹配到某个Context上,然后把该请求交给该Context来处理,匹配的方法是最长匹配,所以一个path==“”的Context将成为该Host的默认Context匹配。

所有无法和凄然Context的路径名匹配的请求都将最终和该默认Context匹配。

context

定义一个应用程序,是一个最内层的容器类组件(不能再嵌套)。配置context的主要目的指定对应对的webapp的根目录,类似于httpd的alias,其还能为webapp指定额外的属性,如部署方式等。

realm

可以用于任意容器类的组件中,关联一个用户认证库,实现认证和授权。可以关联的认证库有两种:UserDatabaseRealm、MemoryRealm和JDBCRealm。

UserDatabaseRealm

使用JNDI自定义的用户认证库。

MemoryRealm

认证信息定义在tomcat-users.xml中。

JDBCRealm

认证信息定义在数据库中,并通过JDBC连接至数据库中查找认证用户。

host参数详解:

参数

参数说明

host

表示一个虚拟主机

name

指定主机名(域名)

appBase

应用程序基本目录,即存放应用程序的目录.一般为appBase="webapps" ,相对于CATALINA_HOME而言的,也可以写绝对路径。

unpackWARs

如果为true,则tomcat会自动将WAR文件解压,否则不解压,直接从WAR文件中运行应用程序

autoDeploy

在tomcat启动时,是否自动部署。

xmlValidation

是否启动xml的校验功能,一般xmlValidation="false"。

xmlNamespaceAware

检测名称空间,一般xmlNamespaceAware="false"。

Context参数说明

参数

参数说明

Context

表示一个web应用程序加载位置,通常为WAR文件位置

docBase

应用程序的路径或者是WAR文件存放的路径,也可以使用相对路径,起始路径为此Context所属Host中appBase定义的路径。

path

表示此web应用程序的url的前缀,这样请求的url为http://localhost:8080/path/****

reloadable

这个属性非常重要,如果为true,则tomcat会自动检测应用程序的/WEB-INF/lib 和/WEB-INF/classes目录的变化,自动装载新的应用程序,可以在不重启tomcat的情况下改变应用程序

请求处理流程

处理流程:

用户发送请求到WEB服务器,该请求会被正在监听的Connector连接器接收,并把该请求交给Service下的Engine来处理,并等待Engine处理的结果。

Engine获得请求后会根据请求的主机信息来匹配相应的Host主机,Host主机会根据请求的路径匹配对应的Context,Context web应用匹配上之后就构建request、response请求对象,调用指定的Servlet来处理请求。

请求处理完成后会将response对象返回给Host主机,Host主机将response对象返回给Engine引擎,Engine再将response对象返回给Connector链接器,最后Connector连接器将response返回给浏览器。

七、自定义首页信息:

例:

1、创建信息文件存放位置

mkdir -pv /web/webapp

2、创建测试页面

vim /web/webapp/index.jsp

配置如下:

3、修改Tomcat的server.xml文件

vim /usr/local/tomcat8/conf/server.xml

配置如下:

4、重启服务,客户端登录验证

八、Nginx+Tomcat 负载均衡集群部署:

Nginx代理介绍

Nginx 服务器的反向代理服务是其最常用的重要功能,由反向代理服务也可以衍生出很多与此相关的 Nginx 服务器重要功能,比如后面会介绍的负载均衡。

当然在了解反向代理之前,我们需要先知道什么是代理以及什么是正反向代理。

1、代理概述

举一个现实生活中的例子:

比如我们要买一间二手房,虽然我们可以自己去找房源,但是这太花费时间精力了,而且房屋质量检测以及房屋过户等一系列手续也都得我们去办,再说现在这个社会,等我们找到房源,说不定房子都已经涨价了,那么怎么办呢?最简单快捷的方法就是找二手房中介公司(为什么?别人那里房源多啊),于是我们就委托中介公司来给我找合适的房子,以及后续的质量检测过户等操作,我们只需要选好自己想要的房子,然后交钱就行了。

代理简单来说,就是如果我们想做什么,但又不想直接去做,那么这时候就找另外一个人帮我们去做。那么这个例子里面的中介公司就是给我们做代理服务的,我们委托中介公司帮我们找房子。

Nginx 主要能够代理如下几种协议,其中用到的最多的就是做Http代理服务器。

2、正向代理

  弄清楚什么是代理了,那么什么又是正向代理呢?

这里我再举一个例子:

大家都知道,现在国内是访问不了 Google的,那么怎么才能访问 Google呢?我们又想,美国人不是能访问 Google吗(这不废话,Google就是美国的),如果我们电脑的对外公网 IP 地址能变成美国的 IP 地址,那不就可以访问 Google了。你很聪明,VPN 就是这样产生的。我们在访问 Google 时,先连上 VPN 服务器将我们的 IP 地址变成美国的 IP 地址,然后就可以顺利的访问了。

 这里的 VPN 就是做正向代理的。正向代理服务器位于客户端和服务器之间,为了向服务器获取数据,客户端要向代理服务器发送一个请求,并指定目标服务器,代理服务器将目标服务器返回的数据转交给客户端。这里客户端是要进行一些正向代理的设置的。

3、反向代理

反向代理,其实客户端对代理是无感知的,因为客户端不需要任何配置就可以访问,我们只需要将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器获取数据后,在返回给客户端,此时反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器IP地址。

  下面我们通过两张图来对比正向代理和方向代理:

  理解这两种代理的关键在于代理服务器所代理的对象是什么,正向代理代理的是客户端,我们需要在客户端进行一些代理的设置。而反向代理代理的是服务器,作为客户端的我们是无法感知到服务器的真实存在的。

反向代理和正向代理的区别就是:正向代理代理客户端,反向代理代理服务器。

一台Tomcat站点由于可能出现单点故障及无法应付过多客户复杂多样的请求等问题,不能单独应用于生产环境下,所以需要一套可靠的解决方案来完善web站点架构。

Nginx 是一款非常优秀的http服务器软件,它能够支持高达50000个并发连接数的响应,拥有强大的静态资源处理能力,运行稳定,并且内存,CPU等系统资源消耗非常低,  

目前很多大型网站都用Nginx服务器做后端网站程序的反向代理及负载均衡器,来提升整个站点的负载并发能力。

安装部署:

三台服务器,两台tomcat,一台nginx

Tomcat1:huyang1  Tomcat2:huyang2  nginx:huyang3

安装部署:

安装tomcat服务器:

1)关闭防火墙,selinux

2)安装JDK,配置Java环境,版本保持一致

3)安装Tomcat,版本与Tomcat 1 保持一致

4)建立一个web目录,并在里面建立一个webapp目录,用于存放网站文件

5)在webapp目录下建立一个index.jsp的测试页面

 

安装nginx服务器:

1、关闭防火墙

2、安装依赖

 yum -y install pcre-devel zlib-devel openssl-devel

lrzsz

3、 创建nginx访问用户

useradd -M -s /sbin/nologin nginx

4、下载tar包,解压,配置,编译,安装

tar xf nginx-1.16.tar.gz -C /usr/src/

cd /usr/src/nginx-1.16/

./configure --prefix=/usr/local/nginx  --user=nginx

--group=nginx --with-file-aio --with-http

_stub_status_module --with-http_ssl_module

--with-http_flv_module

--with-http_gzip_static_module && make && make install

5、修改配置文件

vim /usr/local/nginx/conf/nginx.conf

配置如下:

6、启动服务

/usr/local/nginx/sbin/nginx

7、客户端登录验证

8、负载代理验证

 

 

代理成功,因为设置的权重均为weight=1,所以现在每

刷新一次更换一下信息。

九、Tomcat连接数据库:

服务器设置:

一台tomcat,一台mariadb

Tomcat:huyang1

Mariadb:huyang4

Tomcat服务器配置:(在上述的基础上)

1、下载并解压SLSaleSystem

tar xf SLSaleSystem.tar.gz -C /web/webapp/

ls /web/webapp/SLSaleSystem/

2、修改tomcat配置文件

vim /usr/local/tomcat8/conf/server.xml

配置如下:

3、客户端访问

当前未连接数据库,只可以访问,不可以登录

数据库配置:

1、下载安装包

yum -y install mariadb-server mariadb

2、启动服务并进入数据库

systemctl start mariadb

建立数据库,授权,刷新,退出

create database slsaledb;

grant all on slsaledb.* to admin@'%' identified by '123456';

 flush privileges;

3、导入信息

mysql -uroot < slsaledb-2014-4-10.sql

Tomcat服务器:修改配置文件

vim /web/webapp/SLSaleSystem/WEB-INF/classes/jdbc.properties

配置如下:加入数据库的ip和端口,授权账户和密码

客户端登录验证:

输入账户和密码后,呈现下列画面。

以下,商城框架搭建完毕,可供开发人员拓展!

十、Tomcat配置SSL加密

说明:当通过Nginx调度tomcat进行工作时,如果Nginx配置了ssl,Tomcat是无需配置的。

扩展实验:Nginx+OpenSSL实现https协议

创建加密用的私钥和证书文件

[root@localhost ~]# keytool -genkeypair -alias tomcat -keyalg RSA -keystore /usr/local/tomcat8/keystore

修改server.xml配置文件,创建支持加密连接的Connector

vim /usr/local/tomcat8/conf/server.xml

配置如下:

将上述配置注释去掉并修改为如下配置:

而后重启tomcat

/usr/local/tomcat8/bin/shutdown.sh

/usr/local/tomcat8/bin/startup.sh

密码和证书的位置根据个人的具体环境而设置,属性参数如下所述:

属性

描述

clientAuth

如果设为true,表示Tomcat要求所有的SSL客户出示安全证书,对SSL客户进行身份验证

keystoreFile

指定keystore文件的存放位置,可以指定绝对路径,也可以指定相对于<CATALINA_HOME>(Tomcat安装目录)环境变量 的相对路径。如果此项没有设定,默认情况下,Tomcat将从当前操作系统用户的用户目录下读取名为“.keystore”的文件。

keystorePass

指定keystore的密码,如果此项没有设定,在默认情况下,Tomcat将使用“changeit”作为默认密码。

sslProtocol

指定套接字(Socket)使用的加密/解密协议,默认值为TLS,用户不应该修改这个默认值。

ciphers

指定套接字可用的用于加密的密码清单,多个密码间以逗号(,)分隔。如果此项没有设定,在默认情况下,套接字可以使用任意一个可用的密码。

建议用google浏览器访问:https://192.168.200.114:8443

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/46007.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Java】Java多线程编程基础

文章目录 1. 进程与线程1.1 进程与线程的基本认识1.1.1 进程&#xff08;Process&#xff09;1.1.2 线程&#xff08;Thread&#xff09; 1.2 为什么会有线程1.2.1 以看视频为例 2. 多线程实现2.1 Thread类实现多线程2.2 Runnable接口实现多线程2.3 Callable接口实现多线程2.3 …

Oracle输出文本平面(CSV、XML)文本数据详细过程

此过程是提供给前端,调用的接口,为报表提供”下载“功能。以下是本人在测试环境的测试,有什么不足的地方,请留言指教,谢谢。 1、测试表 分别对测试表输出csv、xml两种格式文件数据。前期的准备工作。 --在服务器端创建directory,用管理员用户 create or replace directo…

win10计算器无法打开

问题背景: 打开计算器报错&#xff0c;显示无法打开应用&#xff0c;请打开应用商店获取更多信息。 解决过程 网上试了很多方法&#xff0c;看的最多的是 1、点开计算器重置应用 2、输入命令重新安装 。。。。。。。 说实话都没解决 最后看到这三个图标后&#xff0c;突然…

DAY2,Qt(继续完善登录框,信号与槽的使用 )

1.继续完善登录框&#xff0c;当登录成功时&#xff0c;关闭登录界面&#xff0c;跳转到新的界面中&#xff0c;来回切换页面&#xff1b; ---mychat.h chatroom.h---两个页面头文件 #ifndef MYCHAT_H #define MYCHAT_H#include <QWidget> #include <QDebug> /…

【如何训练一个中英翻译模型】LSTM机器翻译seq2seq字符编码(一)

系列文章 【如何训练一个中英翻译模型】LSTM机器翻译seq2seq字符编码&#xff08;一&#xff09; 【如何训练一个中英翻译模型】LSTM机器翻译模型训练与保存&#xff08;二&#xff09; 【如何训练一个中英翻译模型】LSTM机器翻译模型部署&#xff08;三&#xff09; 【如何训…

ARM异常处理

一、异常二、异常处理机制三、ARM异常源四、ARM异常模式五、ARM异常响应CPSR寄存器ARM寄存器 六、异常向量表七、异常返回八、IRQ异常举例九、异常优先级十、FIQ和IRQ 一、异常 概念 处理器在正常执行程序的过程中可能会遇到一些不正常的事件发生 这时处理器就要将当前的程序暂…

【简单认识MySQL的MHA高可用配置】

文章目录 一、简介1、概述2、MHA 的组成3&#xff0e;MHA 的特点4、MHA工作原理 二、搭建MHA高可用数据库群集1.主从复制2.MHA配置 三、故障模拟四、故障修复步骤&#xff1a; 一、简介 1、概述 MHA&#xff08;Master High Availability&#xff09;是一套优秀的MySQL高可用…

【Kafka】常用操作

1、基本概念 1. 消息&#xff1a; Kafka是一个分布式流处理平台&#xff0c;它通过消息进行数据的传输和存储。消息是Kafka中的基本单元&#xff0c;可以包含任意类型的数据。 2. 生产者&#xff08;Producer&#xff09;&#xff1a; 生产者负责向Kafka主题发送消息。它将消息…

web自动化测试进阶篇05 ——— 界面交互场景测试

&#x1f60f;作者简介&#xff1a;博主是一位测试管理者&#xff0c;同时也是一名对外企业兼职讲师。 &#x1f4e1;主页地址&#xff1a;【Austin_zhai】 &#x1f646;目的与景愿&#xff1a;旨在于能帮助更多的测试行业人员提升软硬技能&#xff0c;分享行业相关最新信息。…

stm32 IIC通信

文章目录 IIC 通信一、硬件电路二、IIC时序基本单元三、IIC时序1.指定地址写2.当前地址读3.指定地址读 IIC 通信 IIC总线是一种通用数据总线&#xff0c;有两根通信线&#xff08;SCL(串行时钟总线),SDA&#xff08;串行数据总线&#xff09;&#xff09;。 特点&#xff1a;同…

【SpringCloud Alibaba】(二)微服务环境搭建

1. 项目流程搭建 整个项目主要分为 用户微服务、商品微服务和订单微服务&#xff0c;整个过程模拟的是用户下单扣减库存的操作。这里&#xff0c;为了简化整个流程&#xff0c;将商品的库存信息保存到了商品数据表&#xff0c;同时&#xff0c;使用商品微服务来扣减库存。小伙…

Rust vs Go:常用语法对比(十一)

题目来自 Rust Vs Go: Which Language Is Better For Developing High-Performance Applications?[1] 202. Sum of squares Calculate the sum of squares s of data, an array of floating point values. 计算平方和 package mainimport ( "math")func main() { da…

android数据的储存、文件的储存、SharedPreferences储存、SQLite的基本用法

一、文件的储存 1、将数据储存到文件中 Context类中提供了openfileOutput()方法&#xff0c;用来获取一个文件流&#xff0c;这个方法接收两个参数&#xff0c;第一个参数是文件名&#xff0c;在文件创建的时候使用的就是这个名称&#xff0c;注意这里指定的文件名不可以包含…

React AntDesign写一个导出数据的提示语 上面有跳转的路径,或者点击知道了,关闭该弹层

效果如下&#xff1a; 代码如下&#xff1a; ForwardDataCenterModal(_blank);export const ForwardDataCenterModal (target?: string) > {let contentBefore React.createElement(span, null, 数据正在处理中&#xff0c;请稍后前往);let contentAfter React.creat…

JAVA基础-集合(List与Map)

目录 引言 一&#xff0c;Collection集合 1.1,List接口 1.1.1&#xff0c;ArrayList 1.1.1.1&#xff0c;ArrayList的add&#xff08;&#xff09;添加方法 1.1.1.2&#xff0c;ArrayList的remove&#xff08;&#xff09;删除方法 1.1.1.3&#xff0c;ArrayList的contai…

网络超时导致namenode被kill的定位

交换机升级导致部分网络通信超时, 集群的namenode主从切换后,主namenode进程被杀死。 网络问题导致namenode与zk间的连接超时触发了hadoop集群的防脑裂机制而主动kill掉了超时的namenode进程。 日志分析发现zk和namenode之间的网络连接超时: 超时触发了namenode切换,并将超时…

游戏引擎UE如何革新影视行业?创意云全面支持UE云渲染

虚幻引擎UE&#xff08;Unreal Engine&#xff09;作为一款“殿堂级”的游戏引擎&#xff0c;占据了全球80%的商用游戏引擎市场&#xff0c;但如果仅仅将其当做游戏开发的工具&#xff0c;显然是低估了它的能力。比如迪士尼出品的电视剧《曼达洛人》、电影《狮子王》等等都使用…

白话机器学习笔记(三)评估已建立的模型

模型评估 在进行回归和分类时&#xff0c;为了进行预测&#xff0c;我们定义了函数 f θ ( x ) f_\theta(x) fθ​(x)&#xff0c;然后根据训练数据求出了函数的参数 θ \theta θ。 如何预测函数 f θ ( x ) f_\theta(x) fθ​(x)的精度&#xff1f;看它能否很好的拟合训练数…

【Django学习】(十五)API接口文档平台_项目流程分析_日志器_认证_授权

一、API接口文档平台 使用API接口文档不经可以很好的的维护接口数据&#xff0c;还给测试人员的接口测试工作带来了便利&#xff1b; 我们可以在全局配置文件中添加路由路径生成接口文档 1、使用docs接口文档维护接口 1.1在全局配置文件里指定用于支持coreapi的Schema # 指…

Linux の shell 流程控制

条件控制 # if then 如果else 没有语句 可以省略 if condition then#语句 fi# if then 。。。 else 。。。 fi if condition then#语句 else#语句 fi# if condition then#语句 elif condition2 then#语句 else#语句 fiif [ $a -gt $b ] thenecho "a > b&quo…