diff --git a/README.md b/README.md index 2cab2bee7..d2482f59c 100644 --- a/README.md +++ b/README.md @@ -27,18 +27,43 @@ Docs
- -## β¨ About OpenIM +## βοΈ About OpenIM -Open-IM-Server, meticulously developed in pure Golang, is a powerful instant messaging server. Its distinct communication method, employing pb+websocket, views every interaction as a message, streamlining customization without altering server code. Built on a microservice architecture, it offers deployment through clusters for outstanding performance and scalability. +OpenIM isn't just an open-source instant messaging component, it's an integral part of your application ecosystem. Check out this diagram to understand how AppServer, AppClient, OpenIMServer, and OpenIMSDK interact. -Open-IM-Server is more than an instant messaging server; it's a powerful tool for incorporating real-time networking into your applications, positioning itself as your premier choice for integration! π + -Please be aware that Open-IM-Server does not function as a standalone product and does not offer built-in account registration or login services. To ease your implementation process, we've open-sourced the [chat repository](https://github.com/OpenIMSDK/chat), which comprises these features. Deploying this chat business server in conjunction with Open-IM-Server expedites the setup of a comprehensive chat product. π₯ +## π About OpenIMSDK -Further enhancing your experience, we also provide an SDK client, wherein most complex logics are implemented. The [SDK repository](https://github.com/OpenIMSDK/openim-sdk-core) can be found at [this link](https://github.com/OpenIMSDK/openim-sdk-core). The [chat repository](https://github.com/OpenIMSDK/chat) is our business server while the 'core' represents the high-level encapsulation of the SDK, synergistically working together to deliver superior results. β¨ +**OpenIMSDK** seamlessly integrates into your application, delivering a rich, real-time messaging experience without requiring intricate UI integration. It provides: + ++ **Local Storage**: For quick data retrieval and message synchronization. ++ **Listener Callbacks**: Ensuring real-time message interactivity. ++ **API Encapsulation**: Streamlining development processes. ++ **Connection Management**: Guaranteeing reliable message delivery. + +It's crafted in Golang and supports cross-platform deployment, ensuring a coherent messaging experience across all platforms. + +π **[Explore GO SDK](https://github.com/openimsdk/openim-sdk-core)** + +## π About OpenIMServer + +**OpenIMServer**, meticulously developed in Golang, ensures a stellar instant messaging server capability with a multifold approach: + ++ **Modular Composition**: It's comprised of several modules, such as the gateway and multiple RPC services, offering a versatile messaging environment. ++ **Microservices Architecture**: Supporting cluster modes, it assures outstanding performance and scalability to manage communication effectively across various instances. ++ **Diverse Deployment Options**: Adapts to your operational preferences, offering deployment via source code, Kubernetes, or Docker. + +### Enhanced Business Functionalities: + ++ **REST API**: OpenIMServer provides REST API for business systems, aiming to empower your operations with additional functionalities like group creation and message push via backend interfaces. ++ **Callbacks**: To expand its utility across varied business forms, OpenIMServer offers callback capabilities. That is, it sends a request to the business server before or after an event occurs, such as sending a message, enriching the interaction and data exchange flow in the communication processes. + +π **[Learn More](https://doc.rentsoft.cn/guides/introduction/product)** + + - β Powerful group features such as muting, group announcements, group validation, unlimited group members, and loading group messages as needed - -4. **Unique Features :star2:** - - β Supports read-and-burn private chats, customizable duration - - β Message editing function broadens social scenarios, making instant communication more diverse and interesting - -5. **Open Source :open_hands:** - - β The code of OpenIM is open source, self-controlled data, aimed at building a globally leading [IM open source community](https://github.com/OpenIMSDK), including [client SDK](https://github.com/openimsdk/openim-sdk-core) and server - - β Based on open source Server, many excellent open source projects have been developed, such as [OpenKF](https://github.com/OpenIMSDK/OpenKF) (Open source AI customer service system) - -6. **Easy to Expand :wrench:** - - β The OpenIM server is implemented in Golang, introducing an innovative "everything is a message" communication model, simplifying the implementation of custom messages and extended features - -7. **High Performance :racing_car:** - - β OpenIM supports a hierarchical governance architecture in the cluster, tested by a large number of users, and abstracts the storage model of online messages, offline messages, and historical messages - -8. **Full Platform Support :tv:** - - β Supports native iOS, Android; cross-platform Flutter, uni-app, ReactNative; major web front-end frameworks such as React, Vue; applets; and PC platforms supported by Electron - -9. **The ultimate deployment experience π€** - - β Supports [cluster deployment](https://github.com/openimsdk/open-im-server/edit/main/deployments/README.md) - - β Supports multi-architecture mirroring, our Docker images are hosted not only on GitHub but also on Alibaba Cloud and Docker Hub supporting multiple architectures. Visit [our GitHub packages](https://github.com/orgs/OpenIMSDK/packages?repo_name=Open-IM-Server) and read our [version management document](https://github.com/openimsdk/open-im-server/blob/main/docs/conversions/version.md) for more information. - -11. **A large ecosystem of open source communities π€²** - - β We have tens of thousands of users and many solutions to problems. - - β We have a large open source community called [OpenIMSDK](https://github.com/OpenIMSDK) that runs the core modules, we have an open source community called [openim-sigs](https://github.com/openim-sigs) to explore more IM-based infrastructure products. ## :rocket: Quick Start @@ -120,6 +108,7 @@ $ make demo π€² In order to facilitate the user experience, we have provided a variety of deployment solutions, you can choose your own deployment method according to the list below: + -