Servlet源碼分析

前面我們已經(jīng)分析過(guò)了啟動(dòng)過(guò)程,現(xiàn)在server可以接受client端的request停巷,并進(jìn)行處理。
request由servlet進(jìn)行處理榕栏,并返回結(jié)果∨锨冢現(xiàn)在我們看一下,web.xml文件中的REST API是如何和servlet相對(duì)應(yīng)的扒磁。

web.xml

下面是web.xml文件中關(guān)于connector的servlet的配置信息庆揪。

<!-- Connectors servlet -->
  <servlet>
    <servlet-name>v1.ConnectorsServlet</servlet-name>
    <servlet-class>org.apache.sqoop.server.v1.ConnectorServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
  </servlet>

  <servlet-mapping>
    <servlet-name>v1.ConnectorsServlet</servlet-name>
    <url-pattern>/v1/connectors/*</url-pattern>
  </servlet-mapping>

從上面的配置信息我們可以看出關(guān)于URL中關(guān)于/v1/connectors/*的請(qǐng)求信息都被轉(zhuǎn)發(fā)給v1.ConnectorsServlet來(lái)進(jìn)行處理,也就是org.apache.sqoop.server.v1.ConnectorServlet類妨托。

SqoopProtocolServlet類

org.apache.sqoop.server.v1包中實(shí)現(xiàn)的所有servlet都繼承了SqoopProtocolServlet類缸榛。SqoopProtocolServlet類繼承了HttpServlet類±忌耍總體的繼承關(guān)系如下圖所示:

servlet類間關(guān)系圖.png

SqoopProtocolServlet繼承了HttpServlet類内颗,實(shí)現(xiàn)了doGet, doPut, doPost, doDelete四個(gè)方法。并實(shí)現(xiàn)了handleGetRequest敦腔,handlePostRequest均澳,handlePutRequest, handleDeleteRequest四個(gè)方法用于子類進(jìn)行繼承会烙。
默認(rèn)的方法實(shí)現(xiàn)為各自調(diào)用do##的實(shí)現(xiàn)负懦。
如下所示:

@Override
  protected final void doGet(HttpServletRequest req, HttpServletResponse resp)
      throws ServletException, IOException {
    RequestContext rctx = new RequestContext(req, resp);

    try {
      JsonBean bean = handleGetRequest(rctx);
      if (bean != null) {
        sendSuccessResponse(rctx, bean);
      }
    } catch (Exception ex) {
      LOG.error("Exception in GET " + rctx.getPath(), ex);
      sendErrorResponse(rctx, ex);
    }
  }
====================
protected JsonBean handleGetRequest(RequestContext ctx) throws Exception {
    super.doGet(ctx.getRequest(), ctx.getResponse());

    return null;
  }

ConnectorServlet類

ConnectorServlet類僅僅將其請(qǐng)求委托給connectorRequestHandler進(jìn)行處理筒捺。主要實(shí)現(xiàn)如下:

@SuppressWarnings("serial")
public class ConnectorServlet extends SqoopProtocolServlet {

  private RequestHandler connectorRequestHandler;

  public ConnectorServlet() {
    connectorRequestHandler = new ConnectorRequestHandler();
  }

  @Override
  protected JsonBean handleGetRequest(RequestContext ctx) throws Exception {
    return connectorRequestHandler.handleEvent(ctx);
  }
}

ConnectorRequestHandler類

ConnectorRequestHandler類實(shí)現(xiàn)RequestHandler接口柏腻。主要的功能在于對(duì)client端發(fā)送的request請(qǐng)求進(jìn)行處理。
其處理的主要步驟為:

  • 判斷是否為GET (connector只支持HTTP GET方法)
  • 判斷是根據(jù)id/name還是讀取所有的信息
  • 將請(qǐng)求進(jìn)一步的委托給ConnectorManager讀取信息
  • 返回結(jié)果
    源代碼如下:
public class ConnectorRequestHandler implements RequestHandler {

  private static final Logger LOG = Logger.getLogger(ConnectorRequestHandler.class);

  private static final String CONNECTORS_PATH = "connectors";

  public ConnectorRequestHandler() {
    LOG.info("ConnectorRequestHandler initialized");
  }

  @Override
  public JsonBean handleEvent(RequestContext ctx) {
    // connector only support GET requests
    if (ctx.getMethod() != Method.GET) {
      throw new SqoopException(ServerError.SERVER_0002, "Unsupported HTTP method for connector:"
          + ctx.getMethod());
    }

    List<MConnector> connectors;
    Map<Long, ResourceBundle> configParamBundles;
    Locale locale = ctx.getAcceptLanguageHeader();
    String cIdentifier = ctx.getLastURLElement();

    LOG.info("ConnectorRequestHandler handles cid: " + cIdentifier);

    if (ctx.getPath().contains(CONNECTORS_PATH) || cIdentifier.equals("all")) {
      connectors = ConnectorManager.getInstance().getConnectorConfigurables();
      configParamBundles = ConnectorManager.getInstance().getResourceBundles(locale);
      AuditLoggerManager.getInstance().logAuditEvent(ctx.getUserName(),
          ctx.getRequest().getRemoteAddr(), "get", "connectors", "all");

      // Authorization check
      connectors = AuthorizationEngine.filterResource(MResource.TYPE.CONNECTOR, connectors);

      return new ConnectorsBean(connectors, configParamBundles);

    } else {
      // NOTE: we now support using unique name as well as the connector id
      // NOTE: connectorId is a fallback for older sqoop clients if any, since we want to primarily use unique conenctorNames
      long cId = HandlerUtils.getConnectorIdFromIdentifier(cIdentifier);

      configParamBundles = new HashMap<Long, ResourceBundle>();

      MConnector connector = ConnectorManager.getInstance().getConnectorConfigurable(cId);
      configParamBundles.put(cId, ConnectorManager.getInstance().getResourceBundle(cId, locale));

      AuditLoggerManager.getInstance().logAuditEvent(ctx.getUserName(),
          ctx.getRequest().getRemoteAddr(), "get", "connector", String.valueOf(cIdentifier));

      // Authorization check
      AuthorizationEngine.readConnector(String.valueOf(connector.getPersistenceId()));

      return new ConnectorBean(Arrays.asList(connector), configParamBundles);
    }
  }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末系吭,一起剝皮案震驚了整個(gè)濱河市五嫂,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖沃缘,帶你破解...
    沈念sama閱讀 219,427評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件躯枢,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡槐臀,警方通過(guò)查閱死者的電腦和手機(jī)锄蹂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)水慨,“玉大人得糜,你說(shuō)我怎么就攤上這事∥鳎” “怎么了朝抖?”我有些...
    開(kāi)封第一講書人閱讀 165,747評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)谍珊。 經(jīng)常有香客問(wèn)我治宣,道長(zhǎng),這世上最難降的妖魔是什么砌滞? 我笑而不...
    開(kāi)封第一講書人閱讀 58,939評(píng)論 1 295
  • 正文 為了忘掉前任侮邀,我火速辦了婚禮,結(jié)果婚禮上贝润,老公的妹妹穿的比我還像新娘豌拙。我一直安慰自己,他們只是感情好题暖,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,955評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布按傅。 她就那樣靜靜地躺著,像睡著了一般胧卤。 火紅的嫁衣襯著肌膚如雪唯绍。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 51,737評(píng)論 1 305
  • 那天枝誊,我揣著相機(jī)與錄音况芒,去河邊找鬼。 笑死叶撒,一個(gè)胖子當(dāng)著我的面吹牛绝骚,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播祠够,決...
    沈念sama閱讀 40,448評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼压汪,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了古瓤?” 一聲冷哼從身側(cè)響起止剖,我...
    開(kāi)封第一講書人閱讀 39,352評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤腺阳,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后穿香,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體亭引,經(jīng)...
    沈念sama閱讀 45,834評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,992評(píng)論 3 338
  • 正文 我和宋清朗相戀三年皮获,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了焙蚓。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,133評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡洒宝,死狀恐怖主届,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情待德,我是刑警寧澤君丁,帶...
    沈念sama閱讀 35,815評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站将宪,受9級(jí)特大地震影響绘闷,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜较坛,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,477評(píng)論 3 331
  • 文/蒙蒙 一印蔗、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧丑勤,春花似錦华嘹、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,022評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至岔霸,卻和暖如春薛躬,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背呆细。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,147評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工型宝, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人絮爷。 一個(gè)月前我還...
    沈念sama閱讀 48,398評(píng)論 3 373
  • 正文 我出身青樓趴酣,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親坑夯。 傳聞我的和親對(duì)象是個(gè)殘疾皇子岖寞,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,077評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)渊涝,斷路器慎璧,智...
    卡卡羅2017閱讀 134,672評(píng)論 18 139
  • 0 系列目錄# WEB請(qǐng)求處理 WEB請(qǐng)求處理一:瀏覽器請(qǐng)求發(fā)起處理 WEB請(qǐng)求處理二:Nginx請(qǐng)求反向代理 本...
    七寸知架構(gòu)閱讀 13,964評(píng)論 22 190
  • 從三月份找實(shí)習(xí)到現(xiàn)在床嫌,面了一些公司跨释,掛了不少胸私,但最終還是拿到小米、百度鳖谈、阿里岁疼、京東、新浪缆娃、CVTE捷绒、樂(lè)視家的研發(fā)崗...
    時(shí)芥藍(lán)閱讀 42,255評(píng)論 11 349
  • Servlet Interface 是Java Servlet API的核心抽象。所有的servlets都直接或者...
    Lucky_Micky閱讀 1,699評(píng)論 2 2
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語(yǔ)法贯要,類相關(guān)的語(yǔ)法暖侨,內(nèi)部類的語(yǔ)法,繼承相關(guān)的語(yǔ)法崇渗,異常的語(yǔ)法字逗,線程的語(yǔ)...
    子非魚_t_閱讀 31,644評(píng)論 18 399