微服务架构本地尝试(四)-容器

容器的好处就不多说了,一次构建到处运行.对于微服务来说,需要将各个微服务部署到多个主机上,而且所需要的环境还不一定相同,甚至冲突,那么容器就很好的解决了这个问题,容器所占用的资源比虚拟机小多了.而且容器部署起来很是方便.然后go和docker也是很配的一对,go编译之后可以直接的放入容器中运行,而不需要依赖环境.

这一节的话我们还需要在代码里面种加入服务发现和注册的功能,以便在容器中能够动态扩容.

《微服务架构本地尝试(四)-容器》

服务注册

先获取开发包

go get -u github.com/hashicorp/consul
# 其实好像不要-u...我习惯加上然后帮我编译了...

我另外封装了一下,可以去看我的代码consul

这里另外说一下,consul的tag,我们解析的时候可以带上tag

例如我这里的发帖微服务,一个是对外的restful,一个是内部的rpc,我们可以注册两个相同名字的服务,然后给他们打上tag,解析的时候tag可以放最前面,例如:restful.post_micro.service.consul

Demo:

//注册服务
    rpcService := consul.Service{
        Name:    "auth_micro",
        Tags:    []string{"rpc"},
        Address: consul.LocalIP(),
        Port:    5000,
    }
    defer rpcService.Deregister()
    err = rpcService.Register()

//使用
    rpcService := consul.Service{
        Name: "auth_micro",
        Tags: []string{"rpc"},
    }
    rpcConn, err = rpcService.GetRPCService()

Dockerfile

go的话我们可以多阶段构建,第一阶段编译,第二阶段运行,这样可以减小我们最终的镜像大小.我们可以先把golang的镜像pull下来docker pull golang然后基于这个镜像来编译,然后再吧编译好的放到第二阶段中运行,我们可以选择最小的alpine来运行

这里又遇到坑,我要获取一些被墙了的包…然而我容器里面又没有工具…后面只好再装一个镜像来折腾了,然而不支持google.golang.org…只能git clone了,我有点遭不住《微服务架构本地尝试(四)-容器》,为了做好这个镜像,还用了个奇淫巧技…在后面加入;exit 0防止报错停止构建

emmmm上面放弃了,git clone下来还有些依赖,依赖又需要去clone,太复杂了,然后我灵机一动…好像可以直接用我的代理…真香…

ENV HTTP_PROXY=http://10.0.75.1:1080/ \
    HTTPS_PROXY=http://10.0.75.1:1080/ 

折腾了挺久….算是吧dockerfile写好了,然后在docker-compose里面添加两个服务,post端口暴露出来,我就可以直接试试能不能访问了

    post_1:
        image: post:latest
        container_name: micro_post_micro_1
        ports: 
            - 8004:8004
        networks: 
            - micro

    auth_1:
        image: auth:latest
        container_name: micro_auth_microo_1
        networks: 
            - micro

《微服务架构本地尝试(四)-容器》

直接运行compose,一次成功,很是欣慰

《微服务架构本地尝试(四)-容器》

右边那个就是我们容器中运行的了,有一个报错的,没有自动清理掉,consul好像不能自动清理,可以在健康监测那里添加一个DeregisterCriticalServiceAfter参数,到期删除,不知道能不能设置一个比较短的时间,然后每隔一段时间就重新注册一次服务,刷新有效期这样达到自动清理的效果.或者结束的时候调用注销方法(但是在容器里面每次都是强制结束…没有调用到注销的方法)

到这里的时候我们已经可以将我们的微服务集群动态扩容了,但是还缺少很多东西这一节就到这里了….然后还需要用到数据库重写一下服务,或者选一个web框架,后面还有难点要整.

点赞

发表评论

电子邮件地址不会被公开。 必填项已用*标注

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据