Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mqttsnet/open-exp-plugin
open-exp-plugin 是一个示例插件,旨在展示如何开发和扩展 ThingLinks 平台的功能。此插件提供了一个实验性功能扩展示例,帮助开发者深入了解如何利用 ThingLinks 的 API 和插件架构进行自定义开发和集成。
https://github.com/mqttsnet/open-exp-plugin
exp iot mqtt plugin thinglinks
Last synced: 5 days ago
JSON representation
open-exp-plugin 是一个示例插件,旨在展示如何开发和扩展 ThingLinks 平台的功能。此插件提供了一个实验性功能扩展示例,帮助开发者深入了解如何利用 ThingLinks 的 API 和插件架构进行自定义开发和集成。
- Host: GitHub
- URL: https://github.com/mqttsnet/open-exp-plugin
- Owner: mqttsnet
- License: other
- Created: 2024-09-01T11:46:07.000Z (5 months ago)
- Default Branch: main
- Last Pushed: 2024-12-27T14:38:20.000Z (27 days ago)
- Last Synced: 2025-01-11T09:09:09.743Z (12 days ago)
- Topics: exp, iot, mqtt, plugin, thinglinks
- Language: Java
- Homepage: https://www.mqttsnet.com/
- Size: 3.17 MB
- Stars: 177
- Watchers: 2
- Forks: 6
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[![MQTTSNET Logo](./docs/images/logo.png)](http://www.mqttsnet.com)
## ThingLinks Open Exp Plugin | [中文文档](README_zh.md)
# Open Exp Plugin Overview
**Open-Exp-Plugin Sample Marketplace** is a plugin repository based on the ThingLinks Open EXP extension point plugin system. It is designed to demonstrate how to develop, extend, and integrate functionalities within the ThingLinks platform. This marketplace provides a variety of plugin examples to help developers quickly get started and understand the powerful capabilities and flexibility of the plugin system.
## Features
- **Plugin Architecture**: Demonstrates the ThingLinks plugin architecture, supporting various plugin development models.
- **Hot-Swappable Support**: Plugins support dynamic installation and uninstallation at runtime without restarting the main application.
- **Multi-Tenant Support**: Supports loading different plugins based on tenant ID for customized functionality.
- **Modular Design**: Plugins and the main application adopt a modular design, supporting the isolation and integration of extension points and plugins.
- **Classloader Isolation**: Provides Parent First and Self First classloader isolation mechanisms to ensure independence between plugins.## Usage Example
### How to Use the Plugin Sample Marketplace
1. **Enable Dependencies and Select Plugins**: Enable the `example` related dependencies in the `pom.xml` file of the `open-exp-plugin` module.
![img_1.png](docs/images/img_1.png)
2. **Reload Projects**: Reload all Maven projects to ensure the dependencies are correctly loaded.
3. **Clean and Package**: Clean and package the `all-package` module.
![img_2.png](docs/images/img_2.png)
4. **After Packaging**: The plugin packages are by default generated in the `exp-plugins` directory.
![img_3.png](docs/images/img_3.png)
5. **Start the Main Application**: Run the `Main` class in the `example-springboot3` module.
The main application will automatically load and install the packaged plugins(That is, plugins in the exp-plugins directory). If you need to reinstall or uninstall plugins, simply call the relevant API.
### Notes
1. **Configuration Definition**: Plugin configurations should be defined in the `Boot` class.
![img_4.png](docs/images/img_4.png)
Configuration usage:
![img_5.png](docs/images/img_5.png)2. **MQTT Configuration**: In the `example-plugin-tcptomqtt` and `example-plugin-udptomqtt` plugins, MQTT server configurations should be adjusted according to the actual environment.
![img_8.png](docs/images/img_8.png)3. **Annotation Import**: Ensure that the packages imported by the `@PostConstruct` and `@PreDestroy` annotations in the plugin's entry point are correct.
![img_7.png](docs/images/img_7.png)## Core Features
- **Extension Point Interface**: Defines multiple extension point interfaces for plugins to implement.
- **Multi-Tenant Support**: Different tenants can use different plugin implementations, with support for tenant priority sorting and filtering.
- **Hot-Swappable Mechanism**: Supports dynamic loading and unloading of plugins, enhancing system extensibility and flexibility.
- **Classloader Isolation**: Ensures isolation between the plugin and the main application classloader, maintaining independence and security.## License
[Apache License, Version 2.0](LICENSE)
## Contact
If you have any questions or need support, please contact the community team at [email protected].
## Source Code
The source code for this project is available at: [GitHub Repository](https://github.com/mqttsnet/open-exp-plugin)
## Join Us
We welcome you to join the **MQTTSNET Community**, where you can explore and promote IoT technology development together with developers from around the world. Through the community, you can access the latest technical information, rich development resources, and opportunities to communicate with other developers.
Visit the [ThingLinks Official Website](https://www.mqttsnet.com) for more information and to join our developer community!