Skip to content
This repository has been archived by the owner on Apr 1, 2024. It is now read-only.

ISSUE-18822: PIP-228: Refactor Information Architecture of Pulsar Client Documentation #5227

Open
sijie opened this issue Dec 9, 2022 · 0 comments

Comments

@sijie
Copy link
Member

sijie commented Dec 9, 2022

Original Issue: apache#18822


Motivation

This proposal is focused on refactoring and improving the information architecture of the existing Pulsar client documentation. The benefits it can bring include:

  • Improve the developer experience and help them get started by offering bite-sized basics.
  • Build a solid content structure to make the doc set easier to increment and scale.
  • Contribute to decision-making and Pulsar adoption.

Goal

The following major issues of Client docs can be improved in terms of information architecture.

  • The Client concepts topic does not introduce the basic client concepts and can be enriched with content relocated from other topics.
  • Feature concept topic, e.g., messaging, also includes concept/reference information of clients that should have been decoupled. For example, the content of Producers/Consumer and their attributes (send/access/receive modes) belongs to the scope of Client concepts.
  • The structure of Pulsar client library docs (e.g., Java client) also compiles everything in one page:
    • Lack of information typing/sorting - various types of information are coupled together, which makes it difficult to navigate and digest.
    • Redundant: each client’s doc page somehow mirrors a few basic/advanced dev tasks for specific Pulsar features - overlapping feature IA and contents. Being isolated from feature contents (without single-sourcing) also makes updates easier to be missed when incremental improvements are implemented for feature contents.
      In a nutshell, keeping the IA as is will make client doc more complex in both reading/consuming and developing/maintaining, especially when it scales with more features/supports added in the future.

In a nutshell, keeping the IA as is will make client doc more complex in both reading/consuming and developing/maintaining, especially when it scales with more features/supports added in the future. The goal of this PIP is to tackle this challenge by applying the following strategies:

  • Make the overall content well-organized, bite-sized, and robustly linked.
  • Curate a Get Started section for language-specific clients with minimum basics, such as installation, hello world examples, and links to more topics, which can be advanced dev tasks, feature contents, feature matrix, etc.
  • Curate a couple of new topics to introduce advanced dev tasks regarding working with clients.

Implementation

The following figure shows an example of the IA redesign work BEFORE & AFTER.
image

Key changes

  • Concept, task, and reference types of information for Pulsar clients are well categorized and linked.
  • The structure of Client Libraries is simple and straightforward to get developers started, from installations to hello world, with rich links only to more advanced tasks and feature contents. All topics are task-oriented with a clear purpose around using Pulsar features and branching into different languages.
  • The new IA also enforces the same substructure of dev tasks to introduce how to work with language-specific clients with a sense of consistency. Language-specific code snippets are displayed via tabs.

Task Breakdown

  • Implement the IA changes with content mapping
  • Update doc and add incremental changes to align with code
  • Curate an independent page for the client-feature matrix (PIP-199)

Reference

@sijie sijie added the PIP label Dec 9, 2022
@sijie sijie added the Stale label Mar 9, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

No branches or pull requests

1 participant