ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Tars | Win10下Docker部署TarsJava(SpringBoot)全过程及踩坑记录

2021-07-12 16:30:20  阅读:232  来源: 互联网

标签:SpringBoot -- wsl desktop Tars Win10 docker Docker


小白部署TarsJava


前言

受限于网上资源有限,加上小白一枚,笔者在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安装:

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"
  1. 删除现有的wsl子系统,原目录下的ext4.vhdx文件会被删除:
wsl --unregister docker-desktop
wsl --unregister docker-desktop-data
  1. 重新创建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部署:

使用docker部署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日志如下则成功:
在这里插入图片描述
9. 访问http:{"你的主机ip"}:3000,设置登录密码,用户名为admin

若出现如下画面,恭喜你,Tars部署成功!
在这里插入图片描述

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

需要注意红框的两个名字,服务名为将来打成jar包的文件名,OBJ为接口名。Tars是根据应用.服务名称.OJB来寻址的。

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

  • 服务端配置:
    在这里插入图片描述
  • 客户端配置:
    在这里插入图片描述

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

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

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

笔者使用官方的语句,发生如下错误导致框架起不来:
在这里插入图片描述
猜测是win10与Linux命令语法不同导致,因此将单引号改成双引号,与数据库那里的配置统一。


4. 代码处理:

Tars部署好后就可以上传代码了,可以自己写也可以使用官方examples,这里笔者使用官方examples作为演示。

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是否成功,可以通过接口调试是否成功判断。

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

首先进入接口调试,点击添加;
在这里插入图片描述
接着上传.tars文件,该文件在..\src\main\resources目录下,客户端上传hello.tars文件,服务端上传client.tars文件。

在这里插入图片描述
上传完后点击调试:
在这里插入图片描述

按照下图进行操作即可查看调试结果。
在这里插入图片描述



最后

新人制作,如有错误,欢迎指出,感激不尽!
欢迎关注公众号,会分享一些更日常的东西!
如需转载,请标注出处!

标签:SpringBoot,--,wsl,desktop,Tars,Win10,docker,Docker
来源: https://blog.csdn.net/dlhjw1412/article/details/118667445

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有