mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-25 12:42:12 +08:00 
			
		
		
		
	Update etcd command contents.
This commit is contained in:
		
							parent
							
								
									da7943cc64
								
							
						
					
					
						commit
						0c81a76323
					
				| @ -75,6 +75,7 @@ services: | |||||||
|       - "12380:2380" |       - "12380:2380" | ||||||
|     environment: |     environment: | ||||||
|       - ETCD_NAME=s1 |       - ETCD_NAME=s1 | ||||||
|  |       - ETCD_DATA_DIR=/etcd-data | ||||||
|       - ETCD_LISTEN_CLIENT_URLS=http://0.0.0.0:2379 |       - ETCD_LISTEN_CLIENT_URLS=http://0.0.0.0:2379 | ||||||
|       - ETCD_ADVERTISE_CLIENT_URLS=http://0.0.0.0:2379 |       - ETCD_ADVERTISE_CLIENT_URLS=http://0.0.0.0:2379 | ||||||
|       - ETCD_LISTEN_PEER_URLS=http://0.0.0.0:2380 |       - ETCD_LISTEN_PEER_URLS=http://0.0.0.0:2380 | ||||||
| @ -88,20 +89,69 @@ services: | |||||||
|       - ETCD_USERNAME=openIM |       - ETCD_USERNAME=openIM | ||||||
|       - ETCD_PASSWORD=openIM123 |       - ETCD_PASSWORD=openIM123 | ||||||
|     volumes: |     volumes: | ||||||
|       - "${DATA_DIR}/components/etcd:/bitnami/etcd" |       - "${DATA_DIR}/components/etcd1:/etcd-data" | ||||||
|     command: | |     command: > | ||||||
|       /bin/bash -c ' |       /bin/sh -c ' | ||||||
|       /opt/bitnami/scripts/etcd/entrypoint.sh /opt/bitnami/scripts/etcd/run.sh & |         etcd & | ||||||
|  |         export ETCDCTL_API=3 | ||||||
| 
 | 
 | ||||||
|       sleep 10 |         echo "Waiting for etcd to become healthy..." | ||||||
|  |         until etcdctl --endpoints=http://127.0.0.1:2379 endpoint health &>/dev/null; do | ||||||
|  |           echo "Waiting for ETCD to start..." | ||||||
|  |           sleep 1 | ||||||
|  |         done | ||||||
| 
 | 
 | ||||||
|       etcdctl --endpoints=http://127.0.0.1:2379 --user=$${ETCD_ROOT_USER}:$${ETCD_ROOT_PASSWORD} user add $${ETCD_USERNAME} --new-user-password=$${ETCD_PASSWORD} || true |         echo "etcd is healthy." | ||||||
|       etcdctl --endpoints=http://127.0.0.1:2379 --user=$${ETCD_ROOT_USER}:$${ETCD_ROOT_PASSWORD} role add openim-role || true |  | ||||||
|       etcdctl --endpoints=http://127.0.0.1:2379 --user=$${ETCD_ROOT_USER}:$${ETCD_ROOT_PASSWORD} role grant-permission openim-role --prefix=true readwrite / || true |  | ||||||
|       etcdctl --endpoints=http://127.0.0.1:2379 --user=$${ETCD_ROOT_USER}:$${ETCD_ROOT_PASSWORD} role grant-permission openim-role --prefix=true readwrite "" || true |  | ||||||
|       etcdctl --endpoints=http://127.0.0.1:2379 --user=$${ETCD_ROOT_USER}:$${ETCD_ROOT_PASSWORD} user grant-role $${ETCD_USERNAME} openim-role || true |  | ||||||
| 
 | 
 | ||||||
|       tail -f /dev/null |         echo "Checking authentication status..." | ||||||
|  |         if ! etcdctl --endpoints=http://127.0.0.1:2379 auth status | grep -q "Authentication Status: true"; then | ||||||
|  |           echo "Authentication is disabled. Creating users and enabling..." | ||||||
|  |            | ||||||
|  |           # Create users and setup permissions | ||||||
|  |           etcdctl --endpoints=http://127.0.0.1:2379 user add $${ETCD_ROOT_USER} --new-user-password=$${ETCD_ROOT_PASSWORD} || true | ||||||
|  |           etcdctl --endpoints=http://127.0.0.1:2379 user add $${ETCD_USERNAME} --new-user-password=$${ETCD_PASSWORD} || true | ||||||
|  |            | ||||||
|  |           etcdctl --endpoints=http://127.0.0.1:2379 role add openim-role || true | ||||||
|  |           etcdctl --endpoints=http://127.0.0.1:2379 role grant-permission openim-role --prefix=true readwrite / || true | ||||||
|  |           etcdctl --endpoints=http://127.0.0.1:2379 role grant-permission openim-role --prefix=true readwrite "" || true | ||||||
|  |           etcdctl --endpoints=http://127.0.0.1:2379 user grant-role $${ETCD_USERNAME} openim-role || true | ||||||
|  |            | ||||||
|  |           etcdctl --endpoints=http://127.0.0.1:2379 user grant-role $${ETCD_ROOT_USER} $${ETCD_USERNAME} root || true | ||||||
|  |            | ||||||
|  |           echo "Enabling authentication..." | ||||||
|  |           etcdctl --endpoints=http://127.0.0.1:2379 auth enable | ||||||
|  |           echo "Authentication enabled successfully" | ||||||
|  |         else | ||||||
|  |           echo "Authentication is already enabled. Checking OpenIM user..." | ||||||
|  |            | ||||||
|  |           # Check if openIM user exists and can perform operations | ||||||
|  |           if ! etcdctl --endpoints=http://127.0.0.1:2379 --user=$${ETCD_USERNAME}:$${ETCD_PASSWORD} put /test/auth "auth-check" &>/dev/null; then | ||||||
|  |             echo "OpenIM user test failed. Recreating user with root credentials..." | ||||||
|  |              | ||||||
|  |             # Try to create/update the openIM user using root credentials | ||||||
|  |             etcdctl --endpoints=http://127.0.0.1:2379 --user=$${ETCD_ROOT_USER}:$${ETCD_ROOT_PASSWORD} user add $${ETCD_USERNAME} --new-user-password=$${ETCD_PASSWORD} --no-password-file || true | ||||||
|  |             etcdctl --endpoints=http://127.0.0.1:2379 --user=$${ETCD_ROOT_USER}:$${ETCD_ROOT_PASSWORD} role add openim-role || true | ||||||
|  |             etcdctl --endpoints=http://127.0.0.1:2379 --user=$${ETCD_ROOT_USER}:$${ETCD_ROOT_PASSWORD} role grant-permission openim-role --prefix=true readwrite / || true | ||||||
|  |             etcdctl --endpoints=http://127.0.0.1:2379 --user=$${ETCD_ROOT_USER}:$${ETCD_ROOT_PASSWORD} role grant-permission openim-role --prefix=true readwrite "" || true | ||||||
|  |             etcdctl --endpoints=http://127.0.0.1:2379 --user=$${ETCD_ROOT_USER}:$${ETCD_ROOT_PASSWORD} user grant-role $${ETCD_USERNAME} openim-role || true | ||||||
|  |             etcdctl --endpoints=http://127.0.0.1:2379 user grant-role $${ETCD_ROOT_USER} $${ETCD_USERNAME} root || true | ||||||
|  |              | ||||||
|  |             echo "OpenIM user recreated with required permissions" | ||||||
|  |           else | ||||||
|  |             echo "OpenIM user exists and has correct permissions" | ||||||
|  |             etcdctl --endpoints=http://127.0.0.1:2379 --user=$${ETCD_USERNAME}:$${ETCD_PASSWORD} del /test/auth &>/dev/null | ||||||
|  |           fi | ||||||
|  |         fi | ||||||
|  |          | ||||||
|  |         echo "Testing authentication with OpenIM user..." | ||||||
|  |         if etcdctl --endpoints=http://127.0.0.1:2379 --user=$${ETCD_USERNAME}:$${ETCD_PASSWORD} put /test/auth "auth-works"; then | ||||||
|  |           echo "Authentication working properly" | ||||||
|  |           etcdctl --endpoints=http://127.0.0.1:2379 --user=$${ETCD_USERNAME}:$${ETCD_PASSWORD} del /test/auth | ||||||
|  |         else | ||||||
|  |           echo "WARNING: Authentication test failed" | ||||||
|  |         fi | ||||||
|  |          | ||||||
|  |         tail -f /dev/null | ||||||
|       ' |       ' | ||||||
|     restart: always |     restart: always | ||||||
|     networks: |     networks: | ||||||
| @ -172,7 +222,7 @@ services: | |||||||
|       - "11002:80" |       - "11002:80" | ||||||
|     networks: |     networks: | ||||||
|       - openim |       - openim | ||||||
|        | 
 | ||||||
|   prometheus: |   prometheus: | ||||||
|     image: ${PROMETHEUS_IMAGE} |     image: ${PROMETHEUS_IMAGE} | ||||||
|     container_name: prometheus |     container_name: prometheus | ||||||
| @ -185,9 +235,9 @@ services: | |||||||
|       - ./config/instance-down-rules.yml:/etc/prometheus/instance-down-rules.yml |       - ./config/instance-down-rules.yml:/etc/prometheus/instance-down-rules.yml | ||||||
|       - ${DATA_DIR}/components/prometheus/data:/prometheus |       - ${DATA_DIR}/components/prometheus/data:/prometheus | ||||||
|     command: |     command: | ||||||
|       - '--config.file=/etc/prometheus/prometheus.yml' |       - "--config.file=/etc/prometheus/prometheus.yml" | ||||||
|       - '--storage.tsdb.path=/prometheus' |       - "--storage.tsdb.path=/prometheus" | ||||||
|       - '--web.listen-address=:${PROMETHEUS_PORT}' |       - "--web.listen-address=:${PROMETHEUS_PORT}" | ||||||
|     network_mode: host |     network_mode: host | ||||||
| 
 | 
 | ||||||
|   alertmanager: |   alertmanager: | ||||||
| @ -200,8 +250,8 @@ services: | |||||||
|       - ./config/alertmanager.yml:/etc/alertmanager/alertmanager.yml |       - ./config/alertmanager.yml:/etc/alertmanager/alertmanager.yml | ||||||
|       - ./config/email.tmpl:/etc/alertmanager/email.tmpl |       - ./config/email.tmpl:/etc/alertmanager/email.tmpl | ||||||
|     command: |     command: | ||||||
|       - '--config.file=/etc/alertmanager/alertmanager.yml' |       - "--config.file=/etc/alertmanager/alertmanager.yml" | ||||||
|       - '--web.listen-address=:${ALERTMANAGER_PORT}' |       - "--web.listen-address=:${ALERTMANAGER_PORT}" | ||||||
|     network_mode: host |     network_mode: host | ||||||
| 
 | 
 | ||||||
|   grafana: |   grafana: | ||||||
| @ -233,9 +283,8 @@ services: | |||||||
|       - /sys:/host/sys:ro |       - /sys:/host/sys:ro | ||||||
|       - /:/rootfs:ro |       - /:/rootfs:ro | ||||||
|     command: |     command: | ||||||
|       - '--path.procfs=/host/proc' |       - "--path.procfs=/host/proc" | ||||||
|       - '--path.sysfs=/host/sys' |       - "--path.sysfs=/host/sys" | ||||||
|       - '--path.rootfs=/rootfs' |       - "--path.rootfs=/rootfs" | ||||||
|       - '--web.listen-address=:19100' |       - "--web.listen-address=:19100" | ||||||
|     network_mode: host |     network_mode: host | ||||||
| 
 |  | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user