Dalam artikel ini, kami akan menelusuri reka bentuk platform media sosial yang dipermudah menggunakan Go, memfokuskan pada prinsip reka bentuk sistem peringkat rendah. Platform kami termasuk ciri teras seperti pendaftaran pengguna, membuat siaran, pengendalian suka dan ulasan, dan sistem pemberitahuan untuk memastikan pengguna sentiasa dikemas kini. Contoh ini menggambarkan cara ciri ini boleh dibina ke dalam sistem yang modular, berskala dan cekap.
Kami akan menggunakan keupayaan serentak Go dan corak reka bentuk seperti fasad untuk mencipta struktur yang diperkemas dan boleh diselenggara, membolehkan platform mengendalikan pelbagai interaksi pengguna dengan lancar.
Platform media sosial yang kami bina memfokuskan pada ciri utama ini:
Mari kita pecahkan komponen utama platform kami dan lihat cara setiap bahagian disepadukan ke dalam sistem.
Komponen UserManager bertanggungjawab untuk pendaftaran pengguna dan pengurusan profil. Setiap pengguna mempunyai butiran profil penting seperti ID, nama dan bio, dan pengurus memastikan pengguna boleh ditambah dan diambil dengan cekap. Beberapa fungsi utama ialah:
type User struct { type User struct { ID int Name string Email string Password string DisplayPicture *string Bio *string friends map[int]*User posts []*Post } type UserManager struct { users map[int]*User mu sync.RWMutex } func (um *UserManager) AddUser(user *User) { um.mu.Lock() defer um.mu.Unlock() um.users[user.ID] = user fmt.Printf("User added: %d\n", user.ID) } func (um *UserManager) GetUserByID(userID int) (*User, error) { um.mu.RLock() defer um.mu.RUnlock() user, ok := um.users[userID] if !ok { return nil, fmt.Errorf("user not found") } return user, nil } func (um *UserManager) AddFriend(requesterID, receiverID int) error { requester, err := um.GetUserByID(requesterID) if err != nil { return err } receiver, err := um.GetUserByID(receiverID) if err != nil { return err } requester.AddFriend(receiver) receiver.AddFriend(requester) fmt.Printf("Friendship added between users: %d and %d\n", requesterID, receiverID) return nil }
Dalam aplikasi dunia sebenar, UserManager akan menyambung ke pangkalan data, tetapi di sini kami menggunakan peta untuk kesederhanaan.
PostManager mengendalikan kandungan yang dijana pengguna dengan mengurus siaran, suka dan ulasan. Komponen ini membolehkan pengguna membuat siaran, seperti siaran orang lain, mengulas dan mendapatkan semula siaran. Beberapa fungsi utama ialah:
type Post struct { ID int UserID int Content string IsPublished bool URLs []*string Likes int Comments []*Comment PublishedAt time.Time CommentsEnabled bool HiddenFromUsers map[int]bool } type PostManager struct { posts map[int]*Post mu sync.RWMutex } func (pm *PostManager) GetPost(postID int) (*Post, error) { pm.mu.RLock() defer pm.mu.RUnlock() post, exists := pm.posts[postID] if !exists { return nil, fmt.Errorf("post not found") } return post, nil } func (pm *PostManager) AddPost(post *Post, user *User) { pm.mu.Lock() defer pm.mu.Unlock() pm.posts[post.ID] = post user.AddPost(post) } func (pm *PostManager) LikePost(postID int) (*Post, error) { pm.mu.Lock() post := pm.posts[postID] pm.mu.Unlock() if post == nil { return nil, fmt.Errorf("post not found") } pm.mu.Lock() defer pm.mu.Unlock() post.Like() return post, nil }
Pengurus Pos boleh berinteraksi dengan pangkalan data untuk menyimpan dan mendapatkan semula siaran, membenarkan penapisan mengikut pelbagai kriteria.
Pengurus Pemberitahuan bertanggungjawab untuk memastikan pengguna dikemas kini tentang aktiviti platform, seperti menerima suka atau mengulas pada siaran mereka. Setiap jenis pemberitahuan (suka, ulasan, permintaan rakan) dihantar melalui pengurus ini, memastikan pengguna dimaklumkan dalam masa nyata. Beberapa fungsi utama ialah:
type Notification struct { ID string Type NotificationType Content string UserID int } type NotificationManager struct { notifications map[int][]*Notification mu sync.RWMutex } func (nm *NotificationManager) AddNotification(userID int, notificationType NotificationType, message string) { nm.mu.Lock() defer nm.mu.Unlock() notification := NewNotification(fmt.Sprintf("notification-%d", time.Now().UnixMicro()), notificationType, message, userID) nm.notifications[userID] = append(nm.notifications[userID], notification) } func (nm *NotificationManager) GetNotificationsForUser(userID int) ([]*Notification, error) { nm.mu.RLock() defer nm.mu.RUnlock() notifications, ok := nm.notifications[userID] if !ok { return nil, fmt.Errorf("user not found") } return notifications, nil }
Dengan NotificationManager, kami boleh memberitahu pengguna tentang interaksi yang berkaitan dengan siaran mereka, membolehkan pengalaman yang lebih menarik. Dalam sistem pengeluaran, pemberitahuan boleh dihantar melalui saluran atau pemberitahuan tolak.
Untuk memudahkan interaksi antara komponen yang berbeza, kami menggunakan corak Fasad. ActivityFacade menggabungkan fungsi UserManager, PostManager dan NotificationManager, menyediakan antara muka bersatu untuk apl media sosial kami.
type User struct { type User struct { ID int Name string Email string Password string DisplayPicture *string Bio *string friends map[int]*User posts []*Post } type UserManager struct { users map[int]*User mu sync.RWMutex } func (um *UserManager) AddUser(user *User) { um.mu.Lock() defer um.mu.Unlock() um.users[user.ID] = user fmt.Printf("User added: %d\n", user.ID) } func (um *UserManager) GetUserByID(userID int) (*User, error) { um.mu.RLock() defer um.mu.RUnlock() user, ok := um.users[userID] if !ok { return nil, fmt.Errorf("user not found") } return user, nil } func (um *UserManager) AddFriend(requesterID, receiverID int) error { requester, err := um.GetUserByID(requesterID) if err != nil { return err } receiver, err := um.GetUserByID(receiverID) if err != nil { return err } requester.AddFriend(receiver) receiver.AddFriend(requester) fmt.Printf("Friendship added between users: %d and %d\n", requesterID, receiverID) return nil }
Dengan ActivityFacade, kami boleh menyelaraskan interaksi pengguna dengan platform, mengurangkan kerumitan mengurus secara langsung setiap subsistem. Pendekatan ini menjadikan kod lebih modular, boleh diselenggara dan lebih mudah dikembangkan.
Dalam mana-mana platform media sosial, berbilang pengguna melakukan tindakan secara serentak. Alat konkurensi Go, terutamanya RWMutex penyegerakan, sesuai untuk mengendalikan bacaan dan tulis serentak dengan cara yang selamat.
Menggunakan RWMutex, kami memastikan berbilang pengguna boleh membaca siaran serentak, tetapi hanya seorang yang boleh menyukai atau mengulas pada satu-satu masa, menghalang keadaan perlumbaan dan rasuah data.
Reka bentuk sistem peringkat rendah kami untuk platform media sosial di Go menyediakan asas yang kukuh untuk mengembangkan ciri menjadikannya berskala dan mudah diselenggara.
Bidang yang berpotensi untuk peningkatan masa depan termasuk:
Untuk pelaksanaan kod penuh, sila semak repositori berikut:
Selamat datang ke repositori Reka Bentuk Sistem Tahap Rendah dalam Go! Repositori ini mengandungi pelbagai masalah reka bentuk sistem peringkat rendah dan penyelesaiannya dilaksanakan dalam Go. Matlamat utama adalah untuk menunjukkan reka bentuk dan seni bina sistem melalui contoh praktikal.
Reka bentuk sistem peringkat rendah melibatkan pemahaman konsep teras seni bina sistem dan mereka bentuk sistem berskala, boleh diselenggara dan cekap. Repositori ini akan cuba merangkumi penyelesaian pelbagai masalah dan senario menggunakan Go.
Projek pertama dalam repositori ini ialah Sistem Tempat Letak Kereta. Sistem ini menyerupai tempat letak kereta di mana kenderaan boleh diletakkan dan tidak diletakkan. Ia menunjukkan:
Atas ialah kandungan terperinci Reka Bentuk Sistem: Membina Platform Media Sosial Mudah dalam Go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!