Linux中國

構建一個即時消息應用(一):模式

這是一系列關於構建「即時消息」應用的新帖子。你應該對這類應用並不陌生。有了它們的幫助,我們才可以與朋友暢聊無忌。Facebook MessengerWhatsAppSkype 就是其中的幾個例子。正如你所看到的那樣,這些應用允許我們發送圖片、傳輸視頻、錄製音頻、以及和一大幫子人聊天等等。當然,我們的教程應用將會盡量保持簡單,只在兩個用戶之間發送文本消息。

我們將會用 CockroachDB 作為 SQL 資料庫,用 Go 作為後端語言,並且用 JavaScript 來製作 web 應用。

這是第一篇帖子,我們將會講述資料庫的設計。

CREATE TABLE users (
    id SERIAL NOT NULL PRIMARY KEY,
    username STRING NOT NULL UNIQUE,
    avatar_url STRING,
    github_id INT NOT NULL UNIQUE
);

顯然,這個應用需要一些用戶。我們這裡採用社交登錄的形式。由於我選用了 GitHub,所以這裡需要保存一個對 GitHub 用戶 ID 的引用。

CREATE TABLE conversations (
    id SERIAL NOT NULL PRIMARY KEY,
    last_message_id INT,
    INDEX (last_message_id DESC)
);

每個對話都會引用最近一條消息。每當我們輸入一條新消息時,我們都會更新這個欄位。我會在後面添加外鍵約束。

… 你可能會想,我們可以先對對話進行分組,然後再通過這樣的方式獲取最近一條消息。但這樣做會使查詢變得更加複雜。

CREATE TABLE participants (
    user_id INT NOT NULL REFERENCES users ON DELETE CASCADE,
    conversation_id INT NOT NULL REFERENCES conversations ON DELETE CASCADE,
    messages_read_at TIMESTAMPTZ NOT NULL DEFAULT now(),
    PRIMARY KEY (user_id, conversation_id)
);

儘管之前我提到過對話只會在兩個用戶之間進行,但我們還是採用了允許向對話中添加多個參與者的設計。因此,在對話和用戶之間有一個參與者表。

為了知道用戶是否有未讀消息,我們在消息表中添加了「讀取時間」(messages_read_at)欄位。每當用戶在對話中讀取消息時,我們都會更新它的值,這樣一來,我們就可以將它與對話中最後一條消息的「創建時間」(created_at)欄位進行比較。

CREATE TABLE messages (
    id SERIAL NOT NULL PRIMARY KEY,
    content STRING NOT NULL,
    user_id INT NOT NULL REFERENCES users ON DELETE CASCADE,
    conversation_id INT NOT NULL REFERENCES conversations ON DELETE CASCADE,
    created_at TIMESTAMPTZ NOT NULL DEFAULT now(),
    INDEX(created_at DESC)
);

儘管我們將消息表放在最後,但它在應用中相當重要。我們用它來保存對創建它的用戶以及它所出現的對話的引用。而且還可以根據「創建時間」(created_at)來創建索引以完成對消息的排序。

ALTER TABLE conversations
ADD CONSTRAINT fk_last_message_id_ref_messages
FOREIGN KEY (last_message_id) REFERENCES messages ON DELETE SET NULL;

我在前面已經提到過這個外鍵約束了,不是嗎:D

有這四張表就足夠了。你也可以將這些查詢保存到一個文件中,並將其通過管道傳送到 Cockroach CLI。

首先,我們需要啟動一個新節點:

cockroach start --insecure --host 127.0.0.1

然後創建資料庫和這些表:

cockroach sql --insecure -e "CREATE DATABASE messenger"
cat schema.sql | cockroach sql --insecure -d messenger

這篇帖子就到這裡。在接下來的部分中,我們將會介紹「登錄」,敬請期待。

via: https://nicolasparada.netlify.com/posts/go-messenger-schema/

作者:Nicolás Parada 選題:lujun9972 譯者:PsiACE 校對:wxy

本文由 LCTT 原創編譯,Linux 中國 榮譽推出


本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive

對這篇文章感覺如何?

太棒了
0
不錯
0
愛死了
0
不太好
0
感覺很糟
0
雨落清風。心向陽

    You may also like

    Leave a reply

    您的郵箱地址不會被公開。 必填項已用 * 標註

    此站點使用Akismet來減少垃圾評論。了解我們如何處理您的評論數據

    More in:Linux中國