Tars | 第1篇 Win10下Docker部署TarsJava(SpringBoot)全过程及踩坑记录 #yyds干货盘点#

Posted 多氯环己烷

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Tars | 第1篇 Win10下Docker部署TarsJava(SpringBoot)全过程及踩坑记录 #yyds干货盘点#相关的知识,希望对你有一定的参考价值。

@TOC


前言

受限于网上资源有限,加上小白一枚,笔者在Tars入门部署时踩了不少的坑,不过最终还是部署成功了,便想记录一下其中过程与心得;

Win10下Docker部署TarsJava(SpringBoot)主要分为这几部分:Docker部署,Tars部署以及测试,说难不难但里边处处埋坑,一不小心陷进去头发没了几斤……

这篇文章将从Docker开始描述笔者掉进去的坑,帮助小伙伴们闭坑。

统一说明:这些坑点问题均在2021年7月12号前发现,之后可能会优化,具体以官方消息为准。

一些参考资料:
TarsdocGitHub在线文档
B站TarsJava入门实战视频
TarsJava GitHub地址


1. 相关环境版本:

环境 对应版本
系统 Win10 21H1
Docker版本 20.10.7
JDK版本 1.8
SpringBoot版本 2.0.3.RELEASE
Maven版本 3.6.3
Tars版本 1.7.x(1.7.2)

坑点一:VMware与Win10 Docker冲突

大多数Windows操作系统的小伙伴电脑里都会装VMware虚拟机跑Linux操作系统,这时如果想在Windows里安装Docker,你可能会发现:要么安装不了Docker,要么安装完后VMware不能使用了。具体来说是VMware的虚拟化方案与Windows的Hpyer-V冲突,不能共存。如果想要二者共存,可以采用以下方法:

  • 将VMware版本升级到15.5.5以上,同时Win10版本升级到20H1以上;

坑点二:20.版本TarsJava(SpringBoot)依赖文件缺失

这个问题主要发生在Tars 2.0版本,如果你使用的是2.0版本,你会发现有些依赖标红,无法从Maven中央仓库自动导入,这是因为中央仓库还没有这些依赖。

  • 解决方法有两种,一是将Tars2.0版本所需的依赖自己通过install框架到本地,对于mvn来说package&install后可以正常使用;二是返回到1.7.2版本即可从中央仓库拉取;

2. Docker安装:

在Win10上安装Docker需要开启Windows本身的虚拟支持,哭具体操作是:

  • “左下角win图标” - “设置” - “应用和功能” - 最下方“程序和功能” - “启用或关闭Windows功能” - 开启Hyper或相关虚拟功能;
  • 或者直接在Windows搜索框中搜索上述相关关键字进行后续操作;
  • 开启后会要求重启,等待重启即可。


接下来到Docker官网下载Docker即可:Docker For Win

坑点三:Docker的镜像默认安装在C盘

Docker安装无脑一直下一步即可,但它会默认将拉来的镜像保存在C盘(原目录:C:\\Users\\用户名\\AppData\\Local\\Docker\\wsl),我们可以通过wsl -l -v --all命令查看:

docker-desktop用来存放程序,docker-desktop-data用来存放镜像,如果希望它在其他盘,可以参考以下操作(以移动到新目录:D:\\program\\wsl\\为例);

  1. 导出wsl子系统镜像(备份到D:\\program\\wsl\\目录下),生成.tar压缩包:
    wsl --export docker-desktop "D:\\program\\wsl\\docker-desktop\\docker-desktop.tar"
    wsl --export docker-desktop-data "D:\\program\\wsl\\docker-desktop-data\\docker-desktop-data.tar"
  2. 删除现有的wsl子系统,原目录下的ext4.vhdx文件会被删除:
    wsl --unregister docker-desktop
    wsl --unregister docker-desktop-data
  3. 重新创建wsl子系统,在新目录下生成ext4.vhdx文件:
wsl --import docker-desktop "D:\\program\\wsl\\docker-desktop" "D:\\program\\wsl\\docker-desktop\\docker-desktop.tar" --version 2
wsl --import docker-desktop-data "D:\\program\\wsl\\docker-desktop-data" "D:\\program\\wsl\\docker-desktop-data\\docker-desktop-data.tar" --version 2

以上三步就能将wsl子系统转移到D盘下的\\program\\wsl\\目录了,如果想要验证是否成功,可以使用docker随便拉取一个镜像,看看原目录C:\\Users\\用户名\\AppData\\Local\\Docker\\wsl新目录D:\\program\\wsl在拉取前后的文件大小,若在拉取后原目录大小不变,新目录增大,就成功了。

  • 成功后,新目录下的两个.tar备份文件可以删除了。

3. Tars部署:

1. 先拉取三个镜像(MySQL、Tars框架、Tars结点):

#拉取最新的镜像
docker pull tarscloud/framework:latest
#拉取节点镜像
docker pull tarscloud/tars-node:latest
#拉取数据库镜像
docker pull   mysql:5.6

2. 创建虚拟网络:

docker network create -d bridge --subnet=172.25.0.0/16 --gateway=172.25.0.1 tars

3. 启动数据库:

docker run -d \\
--net=tars \\
-e MYSQL_ROOT_PASSWORD="root@appinside" \\
--ip="172.25.0.2" \\
--name=tars-mysql \\
mysql:5.6

4. 等待30s,数据库启动需要时间:

可以进到docker里查看MySQL的日志信息,如下则启动成功:

5. 启动Tars框架:

docker run -d \\
--net=tars \\
-e MYSQL_HOST=172.25.0.2 \\
-e MYSQL_ROOT_PASSWORD="root@appinside" \\
-eREBUILD=false  -eSLAVE=false \\
-e INET=eth0 \\
--ip="172.25.0.4" \\
-p 3000-3001:3000-3001 \\
tarscloud/framework

6. 等待60s,框架启动需要时间:

可以进到Docker里查看框架的日志信息,如下则启动成功:


7. 启动Tars结点:

启动web请求
docker run -d --net=tars --ip="172.25.0.3" -eWEB_HOST=http://172.25.0.4:3000 tarscloud/tars-node

8. Docker日志如下则成功:

  1. 访问http:"你的主机ip":3000,设置登录密码,用户名为admin

    若出现如下画面,恭喜你,Tars部署成功!

10. 点击运维管理,按照如下图片进行配置:

填写完配置信息后,点击获取端口可以自动获取端口,接着点击确认 - 部署,即可完成服务端与客户端的部署。

  • 服务端配置:
  • 客户端配置:

坑点四:Tars框架MySQL密码错误

官方文档的shell命令与笔者上述第五点在MySQL密码上略有不同;

  • 文档上是:-e MYSQL_ROOT_PASSWORD=root@appinside \\
  • 笔者是:-e MYSQL_ROOT_PASSWORD="root@appinside" \\

笔者使用官方的语句,发生如下错误导致框架起不来:

猜测是win10与Linux命令语法不同导致,因此将单引号改成双引号,与数据库那里的配置统一。

4. 代码处理:

1. 首先进入TarsJava GitHub官方地址,点进examples:https://github.com/TarsCloud/TarsJava

2. 在这里我们仅关注以下三个SpringBoot文件:

3. Idea打开server文件(服务端)

对于服务端,需要修改的地方只有一处,即:OJB接口名,这里要与上述服务端配置的OJB名对应。然后打包即可。

打包完后修改打包后的文件夹名为服务名

回到Tars平台,选择之前配置好的服务,点击发布管理,选中服务节点,点击“发布选中节点”:


点击上传包,然后选中我们改好名字的服务包文件。


文件上传后会生成一个时间戳选项,选择后发布即可;

当屏幕中显示三个Active时表明服务上传成功。

4. Idea打开client文件(客户端)

客户端包上传与服务端类似,只不过需要修改以下两个地方:

需要注意2.匹配服务名可以从以下地方查看:

选中服务端,点击服务管理,点击管理Servant;

复制红框内的内容,Ctrl CV到代码里即可;

后续步骤就跟服务端一样了,这里就不啰嗦了,这里放上一张客户端成功发布包图。

坑点五:发布包与服务名不匹配

这个问题是没有修改发布包名为服务名,这点在官方GitHub文档上没有提及,可能是新版本特性吧:

  • 将打包名.jar,该为服务名即可:
    (将Server1改成Server,Server1为笔者故意写错做演示用)

坑点六:[alarm] down, server is inactive

笔者在进行部署是经常遇到的这个错误:

这个错误的原因很大概率是因为自己的代码有问题,笔者在这里遇到的问题有:

  • 打包时文档检验出现错误;
  • 没有配置Obj接口;
  • SpringBoot依赖文件找不到等;

这个问题需要认真检查代码。

(这里笔者故意将MyServer.Server.ServerObj改成MyServer.Server.ServerObj1,以演示错误。)

5. 接口调试:

下面以服务端为例,客户端相同:

首先进入接口调试,点击添加;

接着上传.tars文件,该文件在..\\src\\main\\resources目录下,客户端上传hello.tars文件,服务端上传client.tars文件。


上传完后点击调试:

按照下图进行操作即可查看调试结果。


最后

::: hljs-center

新人制作,如有错误,欢迎指出,感激不尽!

:::

::: hljs-center

欢迎关注公众号,会分享一些更日常的东西!

:::

::: hljs-center

如需转载,请标注出处!

:::

::: hljs-center

:::

以上是关于Tars | 第1篇 Win10下Docker部署TarsJava(SpringBoot)全过程及踩坑记录 #yyds干货盘点#的主要内容,如果未能解决你的问题,请参考以下文章

win10环境下使用docker部署spring-boot项目

治疗磁盘空间不足焦虑症,释放容器占用空间——Win10+docker篇

Tars | 第2篇 TarsJava SpingBoot启动与负载均衡源码初探 #yyds干货盘点#

tars环境部署

RPCTars框架在Ubuntu上的部署小结

Win10安装docker步骤