部署 Dubbo 应用到 Kubernetes + Docker 环境
部署 Dubbo 应用到 Kubernetes + Docker 示例
总体目标
- Kubernetes
- Zookeeper
- Dubbo-admin + Zookeeper
- Producer + Zookeeper 与 Consumer + Zookeeper
基本流程与工作原理
详细步骤
创建命名空间
kubectl create ns dubbo-demo
zookeeper
获取 zookeeper
helm repo add bitnami https://charts.bitnami.com/bitnami && helm repo update && helm search repo bitnami/zookeeper
拉取 zookeeper
helm pull bitnami/zookeeper --untar --version x.x.x
关闭持久化存储
### values.yaml
persistence:
enabled: false
安装 zookeeper
helm install zookeeper -f values.yaml --namespace dubbo-demo .
查看 zookeeper
kubectl get pods -n dubbo-demo
dubbo-admin
克隆项目到本地
git clone https://github.com/apache/dubbo-admin.git && cd /dubbo-admin/deploy/k8s
配置
admin.registry.address=zookeeper://zookeeper:2181
admin.config-center=zookeeper://zookeeper:2181
admin.metadata-report.address=zookeeper://zookeeper:2181
创建服务
kubectl apply -f ./ -n dubbo-demo
启动服务
kubectl --namespace dubbo-demo port-forward service/dubbo-admin 38080:38080
登录页面
服务查询
dubbo
克隆项目到本地
git clone https://github.com/apache/dubbo-samples.git && cd dubbo-samples/1-basic/dubbo-samples-spring-boot
打包编译
mvn clean package
[INFO] ------------------------------------------------------------------------
[INFO] Reactor Summary:
[INFO]
[INFO] Dubbo Samples Spring Boot 1.0-SNAPSHOT ............. SUCCESS [ 8.147 s]
[INFO] dubbo-samples-spring-boot-interface ................ SUCCESS [ 51.524 s]
[INFO] dubbo-samples-spring-boot-provider ................. SUCCESS [02:27 min]
[INFO] dubbo-samples-spring-boot-consumer 1.0-SNAPSHOT .... SUCCESS [ 0.284 s]
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 03:49 min
[INFO] Finished at: 2023-01-16T09:34:39-05:00
[INFO] ------------------------------------------------------------------------
配置
### dubbo-samples-spring-boot-provider/src/main/resources/application.yml
dubbo:
application:
name: dubbo-springboot-demo-provider
protocol:
name: dubbo
port: -1
registry:
id: zk-registry
address: zookeeper://zookeeper:2181
config-center:
address: zookeeper://zookeeper:2181
metadata-report:
address: zookeeper://zookeeper:2181
配置
### dubbo-samples-spring-boot-consumer/src/main/resources/application.yml
dubbo:
application:
name: dubbo-springboot-demo-consumer
protocol:
name: dubbo
port: -1
registry:
id: zk-registry
address: zookeeper://zookeeper:2181
config-center:
address: zookeeper://zookeeper:2181
metadata-report:
address: zookeeper://zookeeper:2181
切换到服务示例
cd && cd dubbo-samples/1-basic/dubbo-samples-spring-boot
打包编译
mvn clean package
Producer
切换至目标服务
cd dubbo-samples-spring-boot-provider/target
构建镜像
cat <<EOF > Dockerfile
FROM openjdk:8-jdk-alpine
ADD dubbo-samples-spring-boot-provider-1.0-SNAPSHOT.jar /app.jar
ENTRYPOINT ["java", "-Djava.security.egd=file:/dev/urandom", "-jar", "/app.jar"]
EOF
编译镜像
docker build --no-cache -t dubbo-springboot-provider:alpine .
导入服务
cat <<EOF > provider.yaml
apiVersion: v1
kind: Pod
metadata:
name: dubbo-springboot-provider
namespace: dubbo-demo
spec:
containers:
- name: provider
image: dubbo-springboot-provider:alpine
EOF
创建服务
kubectl create -f provider.yaml
Consumer
切换至目标服务
cd dubbo-samples-spring-boot-consumer/target
构建镜像
cat <<EOF > Dockerfile
FROM openjdk:8-jdk-alpine
ADD dubbo-samples-spring-boot-consumer-1.0-SNAPSHOT.jar /app.jar
ENTRYPOINT ["java", "-Djava.security.egd=file:/dev/urandom", "-jar", "/app.jar"]
EOF
编译服务
docker build --no-cache -t dubbo-springboot-consumer:alpine .
导入服务
cat <<EOF > consumer.yaml
apiVersion: v1
kind: Pod
metadata:
name: dubbo-springboot-consumer
namespace: dubbo-demo
spec:
containers:
- name: consumer
image: dubbo-springboot-consumer:alpine
EOF
创建服务
kubectl create -f consumer.yaml
查看服务
最后修改 March 1, 2023: Add /zh/ docs aliases (#2336) (f2070b3fdd)