mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 21:22:16 +08:00 
			
		
		
		
	update create in k8s
This commit is contained in:
		
							parent
							
								
									2d5eb5197b
								
							
						
					
					
						commit
						f3f0fd022e
					
				| @ -30,18 +30,6 @@ spec: | |||||||
|             - containerPort: 9092 # PLAINTEXT |             - containerPort: 9092 # PLAINTEXT | ||||||
|             - containerPort: 9093 # CONTROLLER |             - containerPort: 9093 # CONTROLLER | ||||||
|             - containerPort: 9094 # EXTERNAL |             - containerPort: 9094 # EXTERNAL | ||||||
|           # command: |  | ||||||
|           #   - /bin/bash |  | ||||||
|           #   - "-c" |  | ||||||
|           #   - | |  | ||||||
|           #     # /opt/bitnami/scripts/kafka/run.sh & /opt/bitnami/kafka/create-topic.sh; wait |  | ||||||
|           #     # /opt/bitnami/scripts/kafka/entrypoint.sh && /opt/bitnami/scripts/kafka/setup.sh  && /opt/bitnami/scripts/kafka/run.sh |  | ||||||
|           #     & while ! echo > /dev/tcp/localhost/9092; do |  | ||||||
|           #         echo "Waiting for Kafka to start..." |  | ||||||
|           #         sleep 5 |  | ||||||
|           #       done |  | ||||||
|           #       /opt/bitnami/kafka/create-topic.sh |  | ||||||
|           #       tail -f /dev/null |  | ||||||
|           env: |           env: | ||||||
|             - name: TZ |             - name: TZ | ||||||
|               value: "Asia/Shanghai" |               value: "Asia/Shanghai" | ||||||
| @ -59,34 +47,18 @@ spec: | |||||||
|               value: "CONTROLLER:PLAINTEXT,EXTERNAL:PLAINTEXT,PLAINTEXT:PLAINTEXT" |               value: "CONTROLLER:PLAINTEXT,EXTERNAL:PLAINTEXT,PLAINTEXT:PLAINTEXT" | ||||||
|             - name: KAFKA_CFG_CONTROLLER_LISTENER_NAMES |             - name: KAFKA_CFG_CONTROLLER_LISTENER_NAMES | ||||||
|               value: "CONTROLLER" |               value: "CONTROLLER" | ||||||
|  |             - name: KAFKA_NUM_PARTITIONS | ||||||
|  |               value: "8" | ||||||
|  |             - name: KAFKA_CFG_AUTO_CREATE_TOPICS_ENABLE | ||||||
|  |               value: "true" | ||||||
|           volumeMounts: |           volumeMounts: | ||||||
|             - name: kafka-data |             - name: kafka-data | ||||||
|               mountPath: /bitnami/kafka |               mountPath: /bitnami/kafka | ||||||
|             - name: kafka-scripts |  | ||||||
|               mountPath: /opt/bitnami/kafka/create-topic.sh |  | ||||||
|               subPath: create-topic.sh |  | ||||||
|         - name: create-topics |  | ||||||
|           image: bitnami/kafka:3.5.1 |  | ||||||
|           command: |  | ||||||
|             - /bin/bash |  | ||||||
|             - "-c" |  | ||||||
|             - | |  | ||||||
|               /opt/bitnami/kafka/create-topic.sh && \ |  | ||||||
|               tail -f /dev/null |  | ||||||
|           volumeMounts: |  | ||||||
|             - name: kafka-scripts |  | ||||||
|               mountPath: /opt/bitnami/kafka/create-topic.sh |  | ||||||
|               subPath: create-topic.sh |  | ||||||
|             - name: kafka-data |  | ||||||
|               mountPath: /bitnami/kafka |  | ||||||
|       volumes: |       volumes: | ||||||
|         - name: kafka-scripts |         - name: kafka-scripts | ||||||
|           configMap: |           configMap: | ||||||
|             name: openim-config |             name: openim-config | ||||||
|             defaultMode: 0755 |             defaultMode: 0755 | ||||||
|             items: |  | ||||||
|               - key: create-topic.sh |  | ||||||
|                 path: create-topic.sh |  | ||||||
|         - name: kafka-data |         - name: kafka-data | ||||||
|           persistentVolumeClaim: |           persistentVolumeClaim: | ||||||
|             claimName: kafka-pvc |             claimName: kafka-pvc | ||||||
|  | |||||||
| @ -15,12 +15,35 @@ spec: | |||||||
|     spec: |     spec: | ||||||
|       containers: |       containers: | ||||||
|         - name: mongo |         - name: mongo | ||||||
|           image: mongo:6.0.2 |           image: mongo:7.0 | ||||||
|           command: |           command: | ||||||
|             [ |             [ | ||||||
|               "/bin/bash", |               "/bin/bash", | ||||||
|               "-c", |               "-c", | ||||||
|               "docker-entrypoint.sh mongod --wiredTigerCacheSizeGB 1 --auth & sleep 15; /scripts/mongo-init.sh; wait", |               ' | ||||||
|  |               docker-entrypoint.sh mongod --wiredTigerCacheSizeGB $wiredTigerCacheSizeGB --auth & | ||||||
|  |               until mongosh -u $MONGO_INITDB_ROOT_USERNAME -p $MONGO_INITDB_ROOT_PASSWORD --authenticationDatabase admin --eval "db.runCommand({ ping: 1 })" &>/dev/null; do | ||||||
|  |                 echo "Waiting for MongoDB to start..." | ||||||
|  |                 sleep 1 | ||||||
|  |               done && | ||||||
|  |               mongosh -u $MONGO_INITDB_ROOT_USERNAME -p $MONGO_INITDB_ROOT_PASSWORD --authenticationDatabase admin --eval " | ||||||
|  |               db = db.getSiblingDB(\"$MONGO_INITDB_DATABASE\"); | ||||||
|  |               if (!db.getUser(\"$MONGO_OPENIM_USERNAME\")) { | ||||||
|  |                 db.createUser({ | ||||||
|  |                   user: \"$MONGO_OPENIM_USERNAME\", | ||||||
|  |                   pwd: \"$MONGO_OPENIM_PASSWORD\", | ||||||
|  |                   roles: [{role: \"readWrite\", db: \"$MONGO_INITDB_DATABASE\"}] | ||||||
|  |                 }); | ||||||
|  |                 print(\"User created successfully: \"); | ||||||
|  |                 print(\"Username: $MONGO_OPENIM_USERNAME\"); | ||||||
|  |                 print(\"Password: $MONGO_OPENIM_PASSWORD\"); | ||||||
|  |                 print(\"Database: $MONGO_INITDB_DATABASE\"); | ||||||
|  |               } else { | ||||||
|  |                 print(\"User already exists in database: $MONGO_INITDB_DATABASE, Username: $MONGO_OPENIM_USERNAME\"); | ||||||
|  |               } | ||||||
|  |               " && | ||||||
|  |               tail -f /dev/null | ||||||
|  |               ' | ||||||
|             ] |             ] | ||||||
|           ports: |           ports: | ||||||
|             - containerPort: 27017 |             - containerPort: 27017 | ||||||
| @ -53,18 +76,8 @@ spec: | |||||||
|           volumeMounts: |           volumeMounts: | ||||||
|             - name: mongo-storage |             - name: mongo-storage | ||||||
|               mountPath: /data/db |               mountPath: /data/db | ||||||
|             - name: script-volume |  | ||||||
|               mountPath: /scripts |  | ||||||
|               # subPath: mongo-init.sh |  | ||||||
| 
 | 
 | ||||||
|       volumes: |       volumes: | ||||||
|         - name: script-volume |  | ||||||
|           configMap: |  | ||||||
|             name: openim-config |  | ||||||
|             items: |  | ||||||
|               - key: mongo-init.sh |  | ||||||
|                 path: mongo-init.sh |  | ||||||
|                 mode: 0755 |  | ||||||
|         - name: mongo-storage |         - name: mongo-storage | ||||||
|           persistentVolumeClaim: |           persistentVolumeClaim: | ||||||
|             claimName: mongo-pvc |             claimName: mongo-pvc | ||||||
|  | |||||||
| @ -811,112 +811,6 @@ data: | |||||||
|             labels: |             labels: | ||||||
|               namespace: default |               namespace: default | ||||||
| 
 | 
 | ||||||
|   mongo-init.sh: | |  | ||||||
|     echo "before running mongosh..." |  | ||||||
|     mongosh <<EOF |  | ||||||
|     var maxRetries = 300; |  | ||||||
|     var connected = false; |  | ||||||
|     var rootUsername = '$MONGO_INITDB_ROOT_USERNAME'; |  | ||||||
|     var rootPassword = '$MONGO_INITDB_ROOT_PASSWORD'; |  | ||||||
|     var dbName = '$MONGO_INITDB_DATABASE'; |  | ||||||
|     var openimUsername = '$MONGO_OPENIM_USERNAME'; |  | ||||||
|     var openimPassword = '$MONGO_OPENIM_PASSWORD'; |  | ||||||
| 
 |  | ||||||
|     print('Starting MongoDB connection script...'); |  | ||||||
|     print('Root username: ' + rootUsername); |  | ||||||
|     print('Target database: ' + dbName); |  | ||||||
|     print('OpenIM user to create: ' + openimUsername); |  | ||||||
| 
 |  | ||||||
|     while (!connected && maxRetries > 0) { |  | ||||||
|         try { |  | ||||||
|             print('Attempting to connect to MongoDB. Remaining retries: ' + maxRetries); |  | ||||||
|             db = connect('mongodb://127.0.0.1:27017/admin'); |  | ||||||
|             var authResult = db.auth(rootUsername, rootPassword); |  | ||||||
|             if (authResult) { |  | ||||||
|                 print('Authentication successful for root user: ' + rootUsername); |  | ||||||
|                 connected = true; |  | ||||||
|             } else { |  | ||||||
|                 print('Authentication failed for root user: ' + rootUsername + ' with password: ' + rootPassword); |  | ||||||
|                 quit(1); |  | ||||||
|             } |  | ||||||
|         } catch (e) { |  | ||||||
|             maxRetries--; |  | ||||||
|             print('Connection failed due to error: ' + e); |  | ||||||
|             print('Retrying... Remaining attempts: ' + maxRetries); |  | ||||||
|             sleep(1000); // Sleep for 1 second |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     if (connected) { |  | ||||||
|         print('Connected to MongoDB successfully. Proceeding to create user...'); |  | ||||||
|         db = db.getSiblingDB(dbName); |  | ||||||
|         var createUserResult = db.createUser({ |  | ||||||
|             user: openimUsername, |  | ||||||
|             pwd: openimPassword, |  | ||||||
|             roles: [{ |  | ||||||
|                 role: 'readWrite', |  | ||||||
|                 db: dbName |  | ||||||
|             }] |  | ||||||
|         }); |  | ||||||
| 
 |  | ||||||
|         if (createUserResult.ok == 1) { |  | ||||||
|             print('User creation successful. User: ' + openimUsername + ', Database: ' + dbName); |  | ||||||
|         } else { |  | ||||||
|             print('User creation failed for user: ' + openimUsername + ' in database: ' + dbName); |  | ||||||
|             quit(1); |  | ||||||
|         } |  | ||||||
|     } else { |  | ||||||
|         print('Failed to connect to MongoDB after 300 retries.'); |  | ||||||
|         quit(1); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     print('Script execution completed.'); |  | ||||||
|     EOF |  | ||||||
|     echo "mongosh completed..." |  | ||||||
| 
 |  | ||||||
|   create-topic.sh: | |  | ||||||
|     #!/usr/bin/env bash |  | ||||||
|     # Wait for Kafka to be ready |  | ||||||
| 
 |  | ||||||
|     KAFKA_SERVER=kafka-service:9092 |  | ||||||
| 
 |  | ||||||
|     MAX_ATTEMPTS=300 |  | ||||||
|     attempt_num=1 |  | ||||||
| 
 |  | ||||||
|     echo "Waiting for Kafka to be ready..." |  | ||||||
| 
 |  | ||||||
|     until /opt/bitnami/kafka/bin/kafka-topics.sh --list --bootstrap-server $KAFKA_SERVER; do |  | ||||||
|       echo "Attempt $attempt_num of $MAX_ATTEMPTS: Kafka not ready yet..." |  | ||||||
|       if [ $attempt_num -eq $MAX_ATTEMPTS ]; then |  | ||||||
|         echo "Kafka not ready after $MAX_ATTEMPTS attempts, exiting" |  | ||||||
|         exit 1 |  | ||||||
|       fi |  | ||||||
|       attempt_num=$((attempt_num+1)) |  | ||||||
|       sleep 1 |  | ||||||
|     done |  | ||||||
| 
 |  | ||||||
|     echo "Kafka is ready. Creating topics..." |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|     topics=("toRedis" "toMongo" "toPush" "toOfflinePush") |  | ||||||
|     partitions=8 |  | ||||||
|     replicationFactor=1 |  | ||||||
| 
 |  | ||||||
|     for topic in "${topics[@]}"; do |  | ||||||
|       if /opt/bitnami/kafka/bin/kafka-topics.sh --create \ |  | ||||||
|         --bootstrap-server $KAFKA_SERVER \ |  | ||||||
|         --replication-factor $replicationFactor \ |  | ||||||
|         --partitions $partitions \ |  | ||||||
|         --topic $topic |  | ||||||
|       then |  | ||||||
|         echo "Topic $topic created." |  | ||||||
|       else |  | ||||||
|         echo "Failed to create topic $topic." |  | ||||||
|       fi |  | ||||||
|     done |  | ||||||
| 
 |  | ||||||
|     echo "All topics created." |  | ||||||
| 
 |  | ||||||
|   webhooks.yml: | |   webhooks.yml: | | ||||||
|     url: http://127.0.0.1:10006/callbackExample |     url: http://127.0.0.1:10006/callbackExample | ||||||
|     beforeSendSingleMsg: |     beforeSendSingleMsg: | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user