mirror of
https://github.com/openimsdk/open-im-server.git
synced 2025-04-06 04:15:46 +08:00
* fix: fix update groupName invalid. (#2673) * refactor: change platform to platformID (#2670) * feat: don`t return nil data (#2675) Co-authored-by: Monet Lee <monet_lee@163.com> * refactor: update fields type in userStatus and check registered. (#2676) * fix: usertoken auth. (#2677) * refactor: update fields type in userStatus and check registered. * fix: usertoken auth. * update contents. * update content. * update * fix * update pb file. * feat: add friend agree after callback (#2680) * fix: sn not sort (#2682) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close * fix: listen error * fix: listen error * update go.mod * feat: add log * fix: token parse token value * fix: GetMsgBySeqs boundary issues * fix: sn_ not sort * fix: sn_ not sort * fix: sn_ not sort --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * refactor: add GetAdminToken interface. (#2684) * refactor: add GetAdminToken interface. * update config. * fix: admin token (#2686) * fix: update workflows logic. (#2688) * refactor: add GetAdminToken interface. * update config. * update workflows logic. * fix: admin token (#2687) * update the front image (#2692) * update the front image * update version * feat: improve publish docker image workflows (#2697) * refactor: add GetAdminToken interface. * update config. * update workflows logic. * feat: improve publish docker image workflows * update condition logic. * fix: update load file logic. (#2700) * refactor: add GetAdminToken interface. * update config. * update workflows logic. * feat: improve publish docker image workflows * update condition logic. * fix: update load file logic. * feat: Msg filter (#2703) * feat: msg filter * feat: msg filter * feat: msg filter * feat: provide the interface required by js sdk (#2712) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close * fix: listen error * fix: listen error * update go.mod * feat: add log * fix: token parse token value * fix: GetMsgBySeqs boundary issues * fix: sn_ not sort * fix: sn_ not sort * fix: sn_ not sort * fix: jssdk add * fix: jssdk support * fix: jssdk support * fix: jssdk support --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * Line webhook (#2716) * feat: online and offline webhook * feat: online and offline webhook * feat: remove zk * fix: the message I sent is not set to read seq in mongodb (#2718) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close * fix: listen error * fix: listen error * update go.mod * feat: add log * fix: token parse token value * fix: GetMsgBySeqs boundary issues * fix: sn_ not sort * fix: sn_ not sort * fix: sn_ not sort * fix: jssdk add * fix: jssdk support * fix: jssdk support * fix: jssdk support * fix: the message I sent is not set to read seq in mongodb --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * fix: cannot modify group member avatars (#2719) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close * fix: listen error * fix: listen error * update go.mod * feat: add log * fix: token parse token value * fix: GetMsgBySeqs boundary issues * fix: sn_ not sort * fix: sn_ not sort * fix: sn_ not sort * fix: jssdk add * fix: jssdk support * fix: jssdk support * fix: jssdk support * fix: the message I sent is not set to read seq in mongodb * fix: cannot modify group member avatars --------- Co-authored-by: withchao <withchao@users.noreply.github.com> --------- Co-authored-by: Monet Lee <monet_lee@163.com> Co-authored-by: icey-yu <119291641+icey-yu@users.noreply.github.com> Co-authored-by: chao <48119764+withchao@users.noreply.github.com> Co-authored-by: withchao <withchao@users.noreply.github.com> Co-authored-by: skiffer-git <72860476+skiffer-git@users.noreply.github.com>
175 lines
4.9 KiB
YAML
175 lines
4.9 KiB
YAML
networks:
|
|
openim:
|
|
driver: bridge
|
|
|
|
services:
|
|
mongodb:
|
|
image: "${MONGO_IMAGE}"
|
|
ports:
|
|
- "37017:27017"
|
|
container_name: mongo
|
|
command: ["/bin/bash", "-c", "/docker-entrypoint-initdb.d/mongo-init.sh; docker-entrypoint.sh mongod --wiredTigerCacheSizeGB 1 --auth"]
|
|
volumes:
|
|
- "${DATA_DIR}/components/mongodb/data/db:/data/db"
|
|
- "${DATA_DIR}/components/mongodb/data/logs:/data/logs"
|
|
- "${DATA_DIR}/components/mongodb/data/conf:/etc/mongo"
|
|
- "./scripts/mongo-init.sh:/docker-entrypoint-initdb.d/mongo-init.sh:ro"
|
|
environment:
|
|
- TZ=Asia/Shanghai
|
|
- wiredTigerCacheSizeGB=1
|
|
- MONGO_INITDB_ROOT_USERNAME=root
|
|
- MONGO_INITDB_ROOT_PASSWORD=openIM123
|
|
- MONGO_INITDB_DATABASE=openim_v3
|
|
- MONGO_OPENIM_USERNAME=openIM
|
|
- MONGO_OPENIM_PASSWORD=openIM123
|
|
restart: always
|
|
networks:
|
|
- openim
|
|
|
|
redis:
|
|
image: "${REDIS_IMAGE}"
|
|
container_name: redis
|
|
ports:
|
|
- "16379:6379"
|
|
volumes:
|
|
- "${DATA_DIR}/components/redis/data:/data"
|
|
- "${DATA_DIR}/components/redis/config/redis.conf:/usr/local/redis/config/redis.conf"
|
|
environment:
|
|
TZ: Asia/Shanghai
|
|
restart: always
|
|
sysctls:
|
|
net.core.somaxconn: 1024
|
|
command: redis-server /usr/local/redis/config/redis.conf --requirepass openIM123 --appendonly yes
|
|
networks:
|
|
- openim
|
|
|
|
etcd:
|
|
image: "${ETCD_IMAGE}"
|
|
container_name: etcd
|
|
ports:
|
|
- "12379:2379"
|
|
- "12380:2380"
|
|
environment:
|
|
- ETCD_NAME=s1
|
|
- ETCD_DATA_DIR=/etcd-data
|
|
- ETCD_LISTEN_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_INITIAL_ADVERTISE_PEER_URLS=http://0.0.0.0:2380
|
|
- ETCD_INITIAL_CLUSTER=s1=http://0.0.0.0:2380
|
|
- ETCD_INITIAL_CLUSTER_TOKEN=tkn
|
|
- ETCD_INITIAL_CLUSTER_STATE=new
|
|
restart: always
|
|
networks:
|
|
- openim
|
|
|
|
kafka:
|
|
image: "${KAFKA_IMAGE}"
|
|
container_name: kafka
|
|
user: root
|
|
restart: always
|
|
ports:
|
|
- "19094:9094"
|
|
volumes:
|
|
- ./scripts/create-topic.sh:/opt/bitnami/kafka/create-topic.sh
|
|
- "${DATA_DIR}/components/kafka:/bitnami/kafka"
|
|
command: >
|
|
bash -c "/opt/bitnami/scripts/kafka/run.sh & /opt/bitnami/kafka/create-topic.sh; wait"
|
|
environment:
|
|
#KAFKA_HEAP_OPTS: "-Xms128m -Xmx256m"
|
|
TZ: Asia/Shanghai
|
|
KAFKA_CFG_NODE_ID: 0
|
|
KAFKA_CFG_PROCESS_ROLES: controller,broker
|
|
KAFKA_CFG_CONTROLLER_QUORUM_VOTERS: 0@kafka:9093
|
|
KAFKA_CFG_LISTENERS: PLAINTEXT://:9092,CONTROLLER://:9093,EXTERNAL://:9094
|
|
KAFKA_CFG_ADVERTISED_LISTENERS: PLAINTEXT://kafka:9092,EXTERNAL://localhost:19094
|
|
KAFKA_CFG_LISTENER_SECURITY_PROTOCOL_MAP: CONTROLLER:PLAINTEXT,EXTERNAL:PLAINTEXT,PLAINTEXT:PLAINTEXT
|
|
KAFKA_CFG_CONTROLLER_LISTENER_NAMES: CONTROLLER
|
|
networks:
|
|
- openim
|
|
|
|
|
|
minio:
|
|
image: "${MINIO_IMAGE}"
|
|
ports:
|
|
- "10005:9000"
|
|
- "19090:9090"
|
|
container_name: minio
|
|
volumes:
|
|
- "${DATA_DIR}/components/mnt/data:/data"
|
|
- "${DATA_DIR}/components/mnt/config:/root/.minio"
|
|
environment:
|
|
TZ: Asia/Shanghai
|
|
MINIO_ROOT_USER: root
|
|
MINIO_ROOT_PASSWORD: openIM123
|
|
restart: always
|
|
command: minio server /data --console-address ':9090'
|
|
networks:
|
|
- openim
|
|
|
|
openim-web-front:
|
|
image: ${OPENIM_WEB_FRONT_IMAGE}
|
|
container_name: openim-web-front
|
|
restart: always
|
|
ports:
|
|
- "11001:80"
|
|
networks:
|
|
- openim
|
|
|
|
openim-admin-front:
|
|
image: ${OPENIM_ADMIN_FRONT_IMAGE}
|
|
container_name: openim-admin-front
|
|
restart: always
|
|
ports:
|
|
- "11002:80"
|
|
networks:
|
|
- openim
|
|
|
|
# prometheus:
|
|
# image: ${PROMETHEUS_IMAGE}
|
|
# container_name: prometheus
|
|
# restart: always
|
|
# user: root
|
|
# volumes:
|
|
# - ./config/prometheus.yml:/etc/prometheus/prometheus.yml
|
|
# - ./config/instance-down-rules.yml:/etc/prometheus/instance-down-rules.yml
|
|
# - ${DATA_DIR}/components/prometheus/data:/prometheus
|
|
# command:
|
|
# - '--config.file=/etc/prometheus/prometheus.yml'
|
|
# - '--storage.tsdb.path=/prometheus'
|
|
# ports:
|
|
# - "19091:9090"
|
|
# networks:
|
|
# - openim
|
|
#
|
|
# alertmanager:
|
|
# image: ${ALERTMANAGER_IMAGE}
|
|
# container_name: alertmanager
|
|
# restart: always
|
|
# volumes:
|
|
# - ./config/alertmanager.yml:/etc/alertmanager/alertmanager.yml
|
|
# - ./config/email.tmpl:/etc/alertmanager/email.tmpl
|
|
# ports:
|
|
# - "19093:9093"
|
|
# networks:
|
|
# - openim
|
|
#
|
|
# grafana:
|
|
# image: ${GRAFANA_IMAGE}
|
|
# container_name: grafana
|
|
# user: root
|
|
# restart: always
|
|
# environment:
|
|
# - GF_SECURITY_ALLOW_EMBEDDING=true
|
|
# - GF_SESSION_COOKIE_SAMESITE=none
|
|
# - GF_SESSION_COOKIE_SECURE=true
|
|
# - GF_AUTH_ANONYMOUS_ENABLED=true
|
|
# - GF_AUTH_ANONYMOUS_ORG_ROLE=Admin
|
|
# ports:
|
|
# - "13000:3000"
|
|
# volumes:
|
|
# - ${DATA_DIR:-./}/components/grafana:/var/lib/grafana
|
|
# networks:
|
|
# - openim
|
|
|