* Code adaptation k8s: service discovery and registration adaptation, configuration adaptation * Initial submission of the help charts script for openim API * change the help charts script * change the help charts script * change helm chart codes * change dockerfiles script * change chart script:add configmap mounts * change chart script:change repository * change chart script:msggateway add one service * change config.yaml * roll back some config values * change chart script:change Ingress rule with a rewrite annotation * add mysql charts scrible * change chart script:add mysql.config.yaml * add nfs provisioner charts * change chart script:add nfs.config.yaml * add ingress-nginx charts * change chart script:add ingress-nginx.config.yaml * add redis &mongodb charts * add kafka&minio charts * change chart script:change redis.values.yaml * change chart script:add redis.config.yaml * change chart script:change redis.config.yaml * change chart script:change mongodb.value.yaml * change chart script:change mongodb.value.yaml * change chart script:add mongodb.config.yaml * change chart script:change minio.values.yaml * change chart script:add minio.config.yaml * change chart script:change kafka.values.yaml * change chart script:add kafka.config.yaml * change chart script:change services.config.yaml * bug fix:Delete websocket's Port restrictions * bug fix:change port value * change chart script:Submit a stable version script * fix bug:Implement option interface * fix bug:change K8sDR.Register * change config.yaml * change chats script:minio service add ingress * change chats script:minio service add ingress * change chats script:kafka.replicaCount=3& change minio.api ingress * delete change chats script * change config.yaml * change openim.yaml --------- Co-authored-by: lin.huang <lin.huang@apulis.com>
OpenIM Suite Scripts
The OpenIM Suite represents a comprehensive collection of scripts, each tailored to manage and operate specific services within the OpenIM ecosystem. These scripts offer consistent, reliable, and efficient tools for initializing, controlling, and managing various OpenIM services on a Linux platform.
Features
- Robustness: Built with Bash's error handling mechanisms (errexit,nounset, andpipefail), ensuring scripts fail fast and provide relevant error messages.
- Modularity: Each script is dedicated to a particular service, promoting clarity and ease of maintenance.
- Comprehensive Logging: Integrated logging utilities offer real-time insights into operations, enhancing transparency and debuggability.
- Systemd Integration: Where applicable, scripts integrate with the systemd service manager, offering standardized service controls like start, stop, restart, and status checks.
Scripts Overview
- openim-api: Control interface for the OpenIM API service.
- openim-cmdutils: Utility toolkit for common OpenIM command-line operations.
- openim-crontask: Manages the OpenIM CronTask service, with both direct and systemctl installation methods.
- openim-msggateway: Script to operate the OpenIM Message Gateway service.
- openim-msgtransfer: Manages the OpenIM Message Transfer functionalities.
- openim-push: Interface for controlling the OpenIM Push Notification service.
- openim-rpc-auth: Script dedicated to the OpenIM RPC Authentication service.
- openim-rpc-conversation: Manages operations related to the OpenIM RPC Conversation service.
- openim-rpc-friend: Control interface for the OpenIM RPC Friend functionalities.
- openim-rpc-group: Script for managing the OpenIM RPC Group service.
- openim-rpc-msg: Operates the OpenIM RPC Messaging service.
- openim-rpc-third: Script dedicated to third-party integrations with OpenIM RPC.
- openim-rpc-user: Control interface for OpenIM RPC User operations.
OpenIM Server Installation Script Usage
The scripts within the OpenIM Suite generally adhere to two primary execution methodologies. To illustrate these methodologies, we'll use openim-crontask as a representative example.
- 
Direct Script Execution: Running the script directly, typically for straightforward start/stop operations. ./[script-name].sh
- 
Function-based Execution: Invoking specific functions within the script for more specialized operations (e.g., install, uninstall). ./scripts/install/install.sh [options]
Description:
This script is designed to handle the installation, uninstallation, and status checking of OpenIM components on the server. OpenIM is a presumed communication or messaging platform.
Commands:
- 
-i, --install: 
 Initiate the installation of all OpenIM components.
- 
-u, --uninstall: 
 Uninstall or remove all OpenIM components from the server.
- 
-s, --status: 
 Check and report the current operational status of the installed OpenIM components.
- 
-h, --help: 
 Display the help menu for available commands.
Example Usage:
To install all OpenIM components:
./scripts/install/install.sh -i
or
./scripts/install/install.sh --install
Note
: Ensure you have the necessary privileges to execute installation or uninstallation operations. It's generally recommended to take a backup before making major changes.
1. Direct Script Execution
This method involves invoking the script directly, initiating its default behavior. For instance, with openim-crontask, direct execution will start the OpenIM CronTask as a background process.
Example:
./openim-crontask.sh
Upon execution, the script will source any necessary configurations, log the start of the CronTask, and finally run the CronTask in the background. The log messages will provide feedback about the process, ensuring the user is informed of the task's progress.
2. Function-based Execution
This approach is more specialized, enabling users to call specific functions defined within the script. This is particularly useful for tasks like installation, uninstallation, and status checks.
For the openim-crontask script:
- 
Installation: It includes building the service, generating configuration files, setting up systemd services, and starting the service. ./openim-crontask.sh openim::crontask::install
- 
Uninstallation: Stops the service, removes associated binaries, configuration files, and systemd service files. ./openim-crontask.sh openim::crontask::uninstall
- 
Status Check: Verifies the running status of the service, checking for active processes and listening ports. ./openim-crontask.sh openim::crontask::status
It's crucial to familiarize oneself with the available functions within each script. This ensures optimal utilization of the provided tools and a deeper understanding of the underlying operations.
Notes
- Always ensure you have the correct permissions before executing any script.
- Environment variables may need to be set or sourced depending on your installation and configuration.