feat: Add the help chart script to support k8s deployment (#1145)
* 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>pull/1234/head
parent
81cc1f355a
commit
abf8e37e78
@ -0,0 +1,37 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
IMAGEHUB="registry.cn-shenzhen.aliyuncs.com/huanglin_hub"
|
||||||
|
PROJECT=$1
|
||||||
|
ALLPRO="all"
|
||||||
|
servers=(openim-api openim-crontask openim-msggateway openim-msgtransfer openim-push openim-rpc-auth openim-rpc-conversation openim-rpc-friend openim-rpc-group openim-rpc-msg openim-rpc-third openim-rpc-user)
|
||||||
|
|
||||||
|
|
||||||
|
if [ "$1" != "" ]
|
||||||
|
then
|
||||||
|
if [[ "${servers[@]}" =~ "${1}" ]]
|
||||||
|
then
|
||||||
|
echo "building ${PROJECT}"
|
||||||
|
DOCKER_PUSHIMG=${IMAGEHUB}/${PROJECT}:dev
|
||||||
|
docker rmi ${DOCKER_PUSHIMG}
|
||||||
|
docker build -f manifest/dockerfiles/${PROJECT}/Dockerfile -t ${DOCKER_PUSHIMG} .
|
||||||
|
docker push ${DOCKER_PUSHIMG}
|
||||||
|
elif [[ ! "${servers[@]}" =~ "${1}" ]]
|
||||||
|
then
|
||||||
|
if [ ${PROJECT} == ${ALLPRO} ]
|
||||||
|
then
|
||||||
|
echo "building allproject"
|
||||||
|
for element in ${servers[@]}
|
||||||
|
do
|
||||||
|
SUB_IMG=${element}
|
||||||
|
SUB_PUSHIMG=${IMAGEHUB}/${element}:dev
|
||||||
|
docker rmi ${SUB_PUSHIMG}
|
||||||
|
docker build -f manifest/dockerfiles/${SUB_IMG}/Dockerfile -t ${SUB_PUSHIMG} .
|
||||||
|
docker push ${SUB_PUSHIMG}
|
||||||
|
done
|
||||||
|
else
|
||||||
|
echo "输入的项目名称不正确"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "请传入一个参数"
|
||||||
|
fi
|
@ -0,0 +1,27 @@
|
|||||||
|
|
||||||
|
# build container
|
||||||
|
FROM golang:1.20-alpine3.18 AS builder
|
||||||
|
ENV GOPROXY https://goproxy.cn,direct
|
||||||
|
ENV GOSUMDB=sum.golang.google.cn
|
||||||
|
ENV GO111MODULE=on
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add git pkgconfig build-base
|
||||||
|
ADD go.mod .
|
||||||
|
ADD go.sum .
|
||||||
|
RUN go mod download
|
||||||
|
ADD . .
|
||||||
|
RUN go build -o cmd/openim-api/openim-api cmd/openim-api/main.go
|
||||||
|
|
||||||
|
# archive container
|
||||||
|
FROM alpine:3.18
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add ca-certificates libdrm
|
||||||
|
RUN apk add tzdata && cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
|
||||||
|
&& echo "Asia/Shanghai" > /etc/timezone \
|
||||||
|
&& apk del tzdata
|
||||||
|
|
||||||
|
WORKDIR /app/bin
|
||||||
|
COPY --from=builder /app/cmd/openim-api/openim-api /app/bin/
|
||||||
|
ENTRYPOINT ["/app/bin/openim-api"]
|
@ -0,0 +1,27 @@
|
|||||||
|
|
||||||
|
# build container
|
||||||
|
FROM golang:1.20-alpine3.18 AS builder
|
||||||
|
ENV GOPROXY https://goproxy.cn,direct
|
||||||
|
ENV GOSUMDB=sum.golang.google.cn
|
||||||
|
ENV GO111MODULE=on
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add git pkgconfig build-base
|
||||||
|
ADD go.mod .
|
||||||
|
ADD go.sum .
|
||||||
|
RUN go mod download
|
||||||
|
ADD . .
|
||||||
|
RUN go build -o cmd/openim-crontask/openim-crontask cmd/openim-crontask/main.go
|
||||||
|
|
||||||
|
# archive container
|
||||||
|
FROM alpine:3.18
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add ca-certificates libdrm
|
||||||
|
RUN apk add tzdata && cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
|
||||||
|
&& echo "Asia/Shanghai" > /etc/timezone \
|
||||||
|
&& apk del tzdata
|
||||||
|
|
||||||
|
WORKDIR /app/bin
|
||||||
|
COPY --from=builder /app/cmd/openim-crontask/openim-crontask /app/bin/
|
||||||
|
ENTRYPOINT ["/app/bin/openim-crontask"]
|
@ -0,0 +1,27 @@
|
|||||||
|
|
||||||
|
# build container
|
||||||
|
FROM golang:1.20-alpine3.18 AS builder
|
||||||
|
ENV GOPROXY https://goproxy.cn,direct
|
||||||
|
ENV GOSUMDB=sum.golang.google.cn
|
||||||
|
ENV GO111MODULE=on
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add git pkgconfig build-base
|
||||||
|
ADD go.mod .
|
||||||
|
ADD go.sum .
|
||||||
|
RUN go mod download
|
||||||
|
ADD . .
|
||||||
|
RUN go build -o cmd/openim-msggateway/openim-msggateway cmd/openim-msggateway/main.go
|
||||||
|
|
||||||
|
# archive container
|
||||||
|
FROM alpine:3.18
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add ca-certificates libdrm
|
||||||
|
RUN apk add tzdata && cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
|
||||||
|
&& echo "Asia/Shanghai" > /etc/timezone \
|
||||||
|
&& apk del tzdata
|
||||||
|
|
||||||
|
WORKDIR /app/bin
|
||||||
|
COPY --from=builder /app/cmd/openim-msggateway/openim-msggateway /app/bin/
|
||||||
|
ENTRYPOINT ["/app/bin/openim-msggateway"]
|
@ -0,0 +1,27 @@
|
|||||||
|
|
||||||
|
# build container
|
||||||
|
FROM golang:1.20-alpine3.18 AS builder
|
||||||
|
ENV GOPROXY https://goproxy.cn,direct
|
||||||
|
ENV GOSUMDB=sum.golang.google.cn
|
||||||
|
ENV GO111MODULE=on
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add git pkgconfig build-base
|
||||||
|
ADD go.mod .
|
||||||
|
ADD go.sum .
|
||||||
|
RUN go mod download
|
||||||
|
ADD . .
|
||||||
|
RUN go build -o cmd/openim-msgtransfer/openim-msgtransfer cmd/openim-msgtransfer/main.go
|
||||||
|
|
||||||
|
# archive container
|
||||||
|
FROM alpine:3.18
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add ca-certificates libdrm
|
||||||
|
RUN apk add tzdata && cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
|
||||||
|
&& echo "Asia/Shanghai" > /etc/timezone \
|
||||||
|
&& apk del tzdata
|
||||||
|
|
||||||
|
WORKDIR /app/bin
|
||||||
|
COPY --from=builder /app/cmd/openim-msgtransfer/openim-msgtransfer /app/bin/
|
||||||
|
ENTRYPOINT ["/app/bin/openim-msgtransfer"]
|
@ -0,0 +1,27 @@
|
|||||||
|
|
||||||
|
# build container
|
||||||
|
FROM golang:1.20-alpine3.18 AS builder
|
||||||
|
ENV GOPROXY https://goproxy.cn,direct
|
||||||
|
ENV GOSUMDB=sum.golang.google.cn
|
||||||
|
ENV GO111MODULE=on
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add git pkgconfig build-base
|
||||||
|
ADD go.mod .
|
||||||
|
ADD go.sum .
|
||||||
|
RUN go mod download
|
||||||
|
ADD . .
|
||||||
|
RUN go build -o cmd/openim-push/openim-push cmd/openim-push/main.go
|
||||||
|
|
||||||
|
# archive container
|
||||||
|
FROM alpine:3.18
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add ca-certificates libdrm
|
||||||
|
RUN apk add tzdata && cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
|
||||||
|
&& echo "Asia/Shanghai" > /etc/timezone \
|
||||||
|
&& apk del tzdata
|
||||||
|
|
||||||
|
WORKDIR /app/bin
|
||||||
|
COPY --from=builder /app/cmd/openim-push/openim-push /app/bin/
|
||||||
|
ENTRYPOINT ["/app/bin/openim-push"]
|
@ -0,0 +1,27 @@
|
|||||||
|
|
||||||
|
# build container
|
||||||
|
FROM golang:1.20-alpine3.18 AS builder
|
||||||
|
ENV GOPROXY https://goproxy.cn,direct
|
||||||
|
ENV GOSUMDB=sum.golang.google.cn
|
||||||
|
ENV GO111MODULE=on
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add git pkgconfig build-base
|
||||||
|
ADD go.mod .
|
||||||
|
ADD go.sum .
|
||||||
|
RUN go mod download
|
||||||
|
ADD . .
|
||||||
|
RUN go build -o cmd/openim-rpc/openim-rpc-auth/openim-rpc-auth cmd/openim-rpc/openim-rpc-auth/main.go
|
||||||
|
|
||||||
|
# archive container
|
||||||
|
FROM alpine:3.18
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add ca-certificates libdrm
|
||||||
|
RUN apk add tzdata && cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
|
||||||
|
&& echo "Asia/Shanghai" > /etc/timezone \
|
||||||
|
&& apk del tzdata
|
||||||
|
|
||||||
|
WORKDIR /app/bin
|
||||||
|
COPY --from=builder /app/cmd/openim-rpc/openim-rpc-auth/openim-rpc-auth /app/bin/
|
||||||
|
ENTRYPOINT ["/app/bin/openim-rpc-auth"]
|
@ -0,0 +1,27 @@
|
|||||||
|
|
||||||
|
# build container
|
||||||
|
FROM golang:1.20-alpine3.18 AS builder
|
||||||
|
ENV GOPROXY https://goproxy.cn,direct
|
||||||
|
ENV GOSUMDB=sum.golang.google.cn
|
||||||
|
ENV GO111MODULE=on
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add git pkgconfig build-base
|
||||||
|
ADD go.mod .
|
||||||
|
ADD go.sum .
|
||||||
|
RUN go mod download
|
||||||
|
ADD . .
|
||||||
|
RUN go build -o cmd/openim-rpc/openim-rpc-conversation/openim-rpc-conversation cmd/openim-rpc/openim-rpc-conversation/main.go
|
||||||
|
|
||||||
|
# archive container
|
||||||
|
FROM alpine:3.18
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add ca-certificates libdrm
|
||||||
|
RUN apk add tzdata && cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
|
||||||
|
&& echo "Asia/Shanghai" > /etc/timezone \
|
||||||
|
&& apk del tzdata
|
||||||
|
|
||||||
|
WORKDIR /app/bin
|
||||||
|
COPY --from=builder /app/cmd/openim-rpc/openim-rpc-conversation/openim-rpc-conversation /app/bin/
|
||||||
|
ENTRYPOINT ["/app/bin/openim-rpc-conversation"]
|
@ -0,0 +1,27 @@
|
|||||||
|
|
||||||
|
# build container
|
||||||
|
FROM golang:1.20-alpine3.18 AS builder
|
||||||
|
ENV GOPROXY https://goproxy.cn,direct
|
||||||
|
ENV GOSUMDB=sum.golang.google.cn
|
||||||
|
ENV GO111MODULE=on
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add git pkgconfig build-base
|
||||||
|
ADD go.mod .
|
||||||
|
ADD go.sum .
|
||||||
|
RUN go mod download
|
||||||
|
ADD . .
|
||||||
|
RUN go build -o cmd/openim-rpc/openim-rpc-friend/openim-rpc-friend cmd/openim-rpc/openim-rpc-friend/main.go
|
||||||
|
|
||||||
|
# archive container
|
||||||
|
FROM alpine:3.18
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add ca-certificates libdrm
|
||||||
|
RUN apk add tzdata && cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
|
||||||
|
&& echo "Asia/Shanghai" > /etc/timezone \
|
||||||
|
&& apk del tzdata
|
||||||
|
|
||||||
|
WORKDIR /app/bin
|
||||||
|
COPY --from=builder /app/cmd/openim-rpc/openim-rpc-friend/openim-rpc-friend /app/bin/
|
||||||
|
ENTRYPOINT ["/app/bin/openim-rpc-friend"]
|
@ -0,0 +1,27 @@
|
|||||||
|
|
||||||
|
# build container
|
||||||
|
FROM golang:1.20-alpine3.18 AS builder
|
||||||
|
ENV GOPROXY https://goproxy.cn,direct
|
||||||
|
ENV GOSUMDB=sum.golang.google.cn
|
||||||
|
ENV GO111MODULE=on
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add git pkgconfig build-base
|
||||||
|
ADD go.mod .
|
||||||
|
ADD go.sum .
|
||||||
|
RUN go mod download
|
||||||
|
ADD . .
|
||||||
|
RUN go build -o cmd/openim-rpc/openim-rpc-group/openim-rpc-group cmd/openim-rpc/openim-rpc-group/main.go
|
||||||
|
|
||||||
|
# archive container
|
||||||
|
FROM alpine:3.18
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add ca-certificates libdrm
|
||||||
|
RUN apk add tzdata && cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
|
||||||
|
&& echo "Asia/Shanghai" > /etc/timezone \
|
||||||
|
&& apk del tzdata
|
||||||
|
|
||||||
|
WORKDIR /app/bin
|
||||||
|
COPY --from=builder /app/cmd/openim-rpc/openim-rpc-group/openim-rpc-group /app/bin/
|
||||||
|
ENTRYPOINT ["/app/bin/openim-rpc-group"]
|
@ -0,0 +1,27 @@
|
|||||||
|
|
||||||
|
# build container
|
||||||
|
FROM golang:1.20-alpine3.18 AS builder
|
||||||
|
ENV GOPROXY https://goproxy.cn,direct
|
||||||
|
ENV GOSUMDB=sum.golang.google.cn
|
||||||
|
ENV GO111MODULE=on
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add git pkgconfig build-base
|
||||||
|
ADD go.mod .
|
||||||
|
ADD go.sum .
|
||||||
|
RUN go mod download
|
||||||
|
ADD . .
|
||||||
|
RUN go build -o cmd/openim-rpc/openim-rpc-msg/openim-rpc-msg cmd/openim-rpc/openim-rpc-msg/main.go
|
||||||
|
|
||||||
|
# archive container
|
||||||
|
FROM alpine:3.18
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add ca-certificates libdrm
|
||||||
|
RUN apk add tzdata && cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
|
||||||
|
&& echo "Asia/Shanghai" > /etc/timezone \
|
||||||
|
&& apk del tzdata
|
||||||
|
|
||||||
|
WORKDIR /app/bin
|
||||||
|
COPY --from=builder /app/cmd/openim-rpc/openim-rpc-msg/openim-rpc-msg /app/bin/
|
||||||
|
ENTRYPOINT ["/app/bin/openim-rpc-msg"]
|
@ -0,0 +1,27 @@
|
|||||||
|
|
||||||
|
# build container
|
||||||
|
FROM golang:1.20-alpine3.18 AS builder
|
||||||
|
ENV GOPROXY https://goproxy.cn,direct
|
||||||
|
ENV GOSUMDB=sum.golang.google.cn
|
||||||
|
ENV GO111MODULE=on
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add git pkgconfig build-base
|
||||||
|
ADD go.mod .
|
||||||
|
ADD go.sum .
|
||||||
|
RUN go mod download
|
||||||
|
ADD . .
|
||||||
|
RUN go build -o cmd/openim-rpc/openim-rpc-third/openim-rpc-third cmd/openim-rpc/openim-rpc-third/main.go
|
||||||
|
|
||||||
|
# archive container
|
||||||
|
FROM alpine:3.18
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add ca-certificates libdrm
|
||||||
|
RUN apk add tzdata && cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
|
||||||
|
&& echo "Asia/Shanghai" > /etc/timezone \
|
||||||
|
&& apk del tzdata
|
||||||
|
|
||||||
|
WORKDIR /app/bin
|
||||||
|
COPY --from=builder /app/cmd/openim-rpc/openim-rpc-third/openim-rpc-third /app/bin/
|
||||||
|
ENTRYPOINT ["/app/bin/openim-rpc-third"]
|
@ -0,0 +1,27 @@
|
|||||||
|
|
||||||
|
# build container
|
||||||
|
FROM golang:1.20-alpine3.18 AS builder
|
||||||
|
ENV GOPROXY https://goproxy.cn,direct
|
||||||
|
ENV GOSUMDB=sum.golang.google.cn
|
||||||
|
ENV GO111MODULE=on
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add git pkgconfig build-base
|
||||||
|
ADD go.mod .
|
||||||
|
ADD go.sum .
|
||||||
|
RUN go mod download
|
||||||
|
ADD . .
|
||||||
|
RUN go build -o cmd/openim-rpc/openim-rpc-user/openim-rpc-user cmd/openim-rpc/openim-rpc-user/main.go
|
||||||
|
|
||||||
|
# archive container
|
||||||
|
FROM alpine:3.18
|
||||||
|
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||||
|
RUN apk --no-cache add ca-certificates libdrm
|
||||||
|
RUN apk add tzdata && cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
|
||||||
|
&& echo "Asia/Shanghai" > /etc/timezone \
|
||||||
|
&& apk del tzdata
|
||||||
|
|
||||||
|
WORKDIR /app/bin
|
||||||
|
COPY --from=builder /app/cmd/openim-rpc/openim-rpc-user/openim-rpc-user /app/bin/
|
||||||
|
ENTRYPOINT ["/app/bin/openim-rpc-user"]
|
@ -0,0 +1,12 @@
|
|||||||
|
package cmd
|
||||||
|
|
||||||
|
const (
|
||||||
|
RpcPushServer = "push"
|
||||||
|
RpcAuthServer = "auth"
|
||||||
|
RpcConversationServer = "conversation"
|
||||||
|
RpcFriendServer = "friend"
|
||||||
|
RpcGroupServer = "group"
|
||||||
|
RpcMsgServer = "msg"
|
||||||
|
RpcThirdServer = "third"
|
||||||
|
RpcUserServer = "user"
|
||||||
|
)
|
@ -0,0 +1,88 @@
|
|||||||
|
package discovery_register
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"errors"
|
||||||
|
"fmt"
|
||||||
|
"github.com/OpenIMSDK/tools/discoveryregistry"
|
||||||
|
openkeeper "github.com/OpenIMSDK/tools/discoveryregistry/zookeeper"
|
||||||
|
"github.com/OpenIMSDK/tools/log"
|
||||||
|
"github.com/openimsdk/open-im-server/v3/pkg/common/config"
|
||||||
|
"google.golang.org/grpc"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
func NewDiscoveryRegister(envType string) (discoveryregistry.SvcDiscoveryRegistry, error) {
|
||||||
|
var client discoveryregistry.SvcDiscoveryRegistry
|
||||||
|
var err error
|
||||||
|
switch envType {
|
||||||
|
case "zookeeper":
|
||||||
|
client, err = openkeeper.NewClient(config.Config.Zookeeper.ZkAddr, config.Config.Zookeeper.Schema,
|
||||||
|
openkeeper.WithFreq(time.Hour), openkeeper.WithUserNameAndPassword(
|
||||||
|
config.Config.Zookeeper.Username,
|
||||||
|
config.Config.Zookeeper.Password,
|
||||||
|
), openkeeper.WithRoundRobin(), openkeeper.WithTimeout(10), openkeeper.WithLogger(log.NewZkLogger()))
|
||||||
|
case "k8s":
|
||||||
|
client, err = NewK8sDiscoveryRegister()
|
||||||
|
default:
|
||||||
|
client = nil
|
||||||
|
err = errors.New("envType not correct")
|
||||||
|
}
|
||||||
|
return client, err
|
||||||
|
}
|
||||||
|
|
||||||
|
type K8sDR struct {
|
||||||
|
options []grpc.DialOption
|
||||||
|
rpcRegisterAddr string
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewK8sDiscoveryRegister() (discoveryregistry.SvcDiscoveryRegistry, error) {
|
||||||
|
return &K8sDR{}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (cli *K8sDR) Register(serviceName, host string, port int, opts ...grpc.DialOption) error {
|
||||||
|
cli.rpcRegisterAddr = serviceName
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
func (cli *K8sDR) UnRegister() error {
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
func (cli *K8sDR) CreateRpcRootNodes(serviceNames []string) error {
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
func (cli *K8sDR) RegisterConf2Registry(key string, conf []byte) error {
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (cli *K8sDR) GetConfFromRegistry(key string) ([]byte, error) {
|
||||||
|
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
func (cli *K8sDR) GetConns(ctx context.Context, serviceName string, opts ...grpc.DialOption) ([]*grpc.ClientConn, error) {
|
||||||
|
|
||||||
|
conn, err := grpc.DialContext(ctx, serviceName, append(cli.options, opts...)...)
|
||||||
|
return []*grpc.ClientConn{conn}, err
|
||||||
|
}
|
||||||
|
func (cli *K8sDR) GetConn(ctx context.Context, serviceName string, opts ...grpc.DialOption) (*grpc.ClientConn, error) {
|
||||||
|
|
||||||
|
return grpc.DialContext(ctx, serviceName, append(cli.options, opts...)...)
|
||||||
|
}
|
||||||
|
func (cli *K8sDR) GetSelfConnTarget() string {
|
||||||
|
|
||||||
|
return cli.rpcRegisterAddr
|
||||||
|
}
|
||||||
|
func (cli *K8sDR) AddOption(opts ...grpc.DialOption) {
|
||||||
|
cli.options = append(cli.options, opts...)
|
||||||
|
}
|
||||||
|
func (cli *K8sDR) CloseConn(conn *grpc.ClientConn) {
|
||||||
|
conn.Close()
|
||||||
|
}
|
||||||
|
|
||||||
|
// do not use this method for call rpc
|
||||||
|
func (cli *K8sDR) GetClientLocalConns() map[string][]*grpc.ClientConn {
|
||||||
|
fmt.Println("should not call this function!!!!!!!!!!!!!!!!!!!!!!!!!")
|
||||||
|
return nil
|
||||||
|
}
|
Loading…
Reference in new issue