热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Golang微服务micro学习记录之快速开始

一、下载安装官方给的步骤:goget-ugithub.commicromicroOrviaDockerdockerpullmicrohqmicro我呢是在Windows上面学习,没
一、下载安装

官方给的步骤:

go get -u github.com/micro/micro
//Or via Docker
//docker pull microhq/micro

我呢是在Windows上面学习,没有使用docker,因此使用第一种方法。不过使用中遇到了一点问题:

package golang.org/x/net/ipv4: directory "E:\\go\\Projects\\src\\golang.org\\x\\net\\ipv4" is not using a known version control system
package golang.org/x/net/ipv6: directory "E:\\go\\Projects\\src\\golang.org\\x\\net\\ipv6" is not using a known version control system
package golang.org/x/crypto/acme/autocert: unrecognized import path "golang.org/x/crypto/acme/autocert" (https fetch: Get https://golang.org/x/crypto/acme/autocert?go-get=1: dial tcp 216.239.37.1:443: connectex: A
connection attempt failed because the connected party did not properly respond after a period of time, or established connection failed because connected host has failed to respond.)

前三个呢暂时不管,最后一个是golang.org包里面没有autocert这个包,被墙了下载不了,自己到网上下载,比如下载整个crypto包然后手动移动,链接https://github.com/golang/crypto在这里。
好,已安装完毕。

二、安装依赖

The micro toolkit has two dependencies:
* [Service Discovery] - used for name resolution
* [Protobuf] - used for code generation

按照官方的说法,micro要使用两个依赖,一个是Service Discovery,一个是Protobuf;第一个是服务发现,微服务呢使用了这个功能,也就是自动注册服务并且自动被发现,啥意思呢,就是你增加一个服务提供给用户,原来呢我们要手动调整原来的接口,调整负载等,但是有Service Discovery这个东西呢就自动化帮助我们做这些事,如下表(来自这里):

《Golang微服务micro学习记录之快速开始》 注册发现模式

然后第二个依赖是Protobuf,就是类似json转换的序列化工具。

下面说说这两个依赖怎么安装使用。

1、Service Discovery

这里使用默认的consul,这里是下载地址,下载相应版本,解压后

《Golang微服务micro学习记录之快速开始》 consul

然后将此文件夹加入环境变量,方便我们在任何地方都能直接调用consul命令启动consul,当然也可以不加,那么每次启动都要进入该文件夹下启动。

使用命令:

consul agent -dev

即可开启consul的监听,这里只在一台电脑上开启微服务,那么暂时不用使用consul的其它命令,如果要在多台电脑远程开启多个微服务,或者使用docker开启多个微服务,就需要了解consul的命令了,这个我们后面再详细说。

2、Protobuf

Protobuf是啥呢,就是类似json、xml一样的东西,是一种轻便高效的结构化数据存储格式,但是它需要专门的工具来生成,方便我们快速开发。安装包在这里
https://github.com/google/protobuf/releases
我们可以在这里下载Windows下的压缩包,解压加环境变量即可使用exe文件来使用Protobuf的生成工具了。下面是解压后的文件夹:

《Golang微服务micro学习记录之快速开始》 protoc文件夹.png

将bin文件夹加入环境变量,或者里面的protoc.exe路径加入环境变量,这个exe文件就是我们转换protobuf的工具。

然后我们使用一些golang对于protobuf的工具,go get相应的库


# install protoc-gen-go
go get -u github.com/golang/protobuf/{proto,protoc-gen-go}
# install protoc-gen-micro
go get -u github.com/micro/protoc-gen-micro

用于自动化生成go-protobuf和go-micro需要的代码文件,使用这些工具将会非常方便。

三、运行测试(一)

先进入这个文件夹github.com/micro/micro,

cd GOPATH/src/github.com/micro/micro

然后执行go build或者直接

go build GOPATH/src/github.com/micro/micro

将在 GOPATH/bin文件夹下生成micro.exe文件,将GOPATH/bin文件夹路径加入环境变量后我们就可以直接运行micro命令了,如果没有在bin文件夹生成那么手动移到该文件夹。
然后使用下面的命令来自动生成代码

micro new github.com/micro/example

也可以不这样生成,可以生成到自己目录下

micro new hdy/micro/example

那么生成的项目就在GOPATH/src/hdy/micro/example

example/
Dockerfile # A template docker file
README.md # A readme with command used
handler/ # Example rpc handler
main.go # The main Go program
proto/ # Protobuf directory
subscriber/ # Example pubsub Subscriber

然后进入项目文件夹

cd GOPATH/src/hdy/micro/example

运行下面的代码生成protobuf和micro代码文件

protoc --proto_path=. --micro_out=. --go_out=. proto/example/example.proto

然后就是一个完整的微服务项目了,请注意:

请确保已经新开窗口运行 consul agent -dev
//运行微服务时会向consul注册这个微服务,因此要先运行consul

最后:

go run main.go

OK,顺利运行第一个微服务。

四、运行测试(二)

运行下面的代码:

micro list services

将输出:

consul
go.micro.srv.example
topic:topic.go.micro.srv.example

更详细的测试,请查看这里https://github.com/micro/micro的测试方法,代码都一样,输出应该一样,具体就不详细展开了,下一节我们再详细分析微服务的编写和部署等方面。
具体有什么不明白的可以私信或者百度和谷歌。


推荐阅读
  • 突然觉得服务器ssh密码登录总是浪费一定量的时间,就想试试用sshKey进行登录。生成服务器sshkey和本地sshkey$ssh-keygen在服务器上生成一个authorize ... [详细]
  • apk简单介绍APK的组成apk安装流程app的启动过程apk打包流程AIDLAIDL介绍为什么要设计这门语言它有哪些语法?默认支持的数据类型包括什么是apk打包流程 ... [详细]
  • delphi控件大全
    本文章已收录于:delphi控件查询:http:www.torry.nethttp:www.jrsoftware.orgTb97最有名的工具条(ToolBar) ... [详细]
  • 本文翻译自:WhatisaMavenartifact?什么是神器?为什么Maven需要它?#1楼参考:https:sta ... [详细]
  • mongodb复制集部署文档 ... [详细]
  • FluxCD、ArgoCD或Jenkins X,哪个才是适合你的GitOps工具?
    GitOps是一种使用基于Git的工作流程来全面管理应用和基础设施的想法,其在最近获得了极大关注。新一代的部署工具更能说明这一点,它们将GitOps作为 ... [详细]
  • socket.io是个基于node.js的快平台实时通讯框架。只用不到10行代码,就可以搭建一个简单的多人实时聊天室。先来看看运行后的效果:socket.io多人聊天室只要简单几 ... [详细]
  • hibernate映射组件映射
    在Hibernate中,component是某个实体的逻辑组成部分,它与实体的根本区别是没有oid(对象标识符),compo ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 编程语言是从哪蹦出来的——大型伦理寻根现场
    Hello,我是Alex007,一个热爱计算机编程和硬件设计的小白,为啥是007呢?因为叫Alex的人太多了,再加上每天007的生活,Alex007就诞生了。聊一聊编程到底是啥,怎 ... [详细]
  • 转载自:http:www.hbtelecom.com.cndetail.asp?news_id78369_______________________________ ... [详细]
  • GPS 校验和 代码_Linux recovery 移除签名校验
    原创作者:王锐,多年Linux系统、龙芯平台移植与优化研发经验,LinuxContributor、Mozillian。背景某个设备配套的刷 ... [详细]
  • jdk安装与环境变量配置,看这一篇就够了
    文章目录场景jdk下载安装如何环境变量的配置总结场景在做java开发或者android开发,经常会碰到jdk安装与环境变量的配置,每次配置的时候,经常需要去查看一下,而且偶尔还会出 ... [详细]
  • 如何理解MyBatis动态SQL
    本篇内容主要讲解“如何理解MyBatis动态SQL”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解M ... [详细]
  • 安装mysqlclient失败解决办法
    本文介绍了在MAC系统中,使用django使用mysql数据库报错的解决办法。通过源码安装mysqlclient或将mysql_config添加到系统环境变量中,可以解决安装mysqlclient失败的问题。同时,还介绍了查看mysql安装路径和使配置文件生效的方法。 ... [详细]
author-avatar
玻璃里的鱼鱼
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有