在kubernetes上部署Go Micro代码(一)

本文介绍了在单节点kubernetes环境下部署Go Micro应用的步骤,包括环境准备、配置pod网络、使master节点也可作为worker node,以及安装ingress。在部署代码阶段,重点讲解了如何基于go-micro构建API Gateway,使用k8s服务发现替代consul,并展示了从Dockerfile构建、保存镜像到服务器的过程,以及编写和应用k8s的deployment、service和ingress配置文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

环境准备

用kubeadm安装好kubernetes环境,我用的测试环境是单节点的,master node和worker node部署在同一台机器上。具体的安装过程就不详述了,坑还是有一些的。
首先,init的时候需要制定pod的网络环境:

kubeadm init --pod-network-cidr 10.244.0.0/16

其次,由于是单节点,因此需要设置允许master作为worker node

kubectl taint nodes --all node-role.kubernetes.io/master-

同时,由于需要采用ingress作为保留http服务的工具,还需要在k8s上提前安装好ingress。
使用官方提供的mandatory.yaml文件即可:

kubectl apply mandatory.yaml

然后安装ingress service 绑定服务器的公网IP地址,yaml如下:

apiVersion: v1
kind: Service
metadata:
  name: ingress-nginx
  namespace: ingress-nginx
spec:
  externalIPs:
  - server ip here~~~
  ports:
  - name: http
    port: 80
    targetPort: 80
    protocol: TCP
  - name: https
    port: 443
    targetPort: 443
    protocol: TCP
  selector:
    app: ingress-nginx

部署代码

首先,基于go-micro的代码是在docker-compose环境下测试通过的,整体的架构是micro作为api gateway,然后后面是api层,再

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值