记一次Docker部署服务的爬坑历程

第一次写文。请容许我自我介绍一下...
你们好我是茉莉。为何叫茉莉呢?emmm ID茉莉转圈圈? 皮一下,嘻嘻嘻。笔者两年小菜鸡(差三天满两年)。由于公司只有一个我和前端两我的。因此线上服务部署的任务天然而然就落到了个人肩膀上啦。第一次用docker正式在生产环境部署服务。从一个坑爬出来又掉入另外一个坑。就记录一下此次上线遇到的bug。写的不对的地方麻烦各位指正噢。见谅! 好啦。废话很少说。action!php

本项目采用的是spring cloud+spring boot+spring gateway+mysql还用到了rabbitmq。服务器为centos7。 这里漏掉了一位大锅。我其实还有一个相处了三个月的后端同事。这位大锅由于请假去面试老板没有批可是他仍是去了被开了,框架都是他搭的。emmmm因而“锅”便甩到了个人头上!html

他采用的zuul被我换成了gateway。 Zuul基于servlet 2.5(使用3.x),使用阻塞API。 它不支持任何长链接,如websockets。而Gateway创建在Spring Framework 5,Project Reactor和Spring Boot 2之上,使用非阻塞API。 Websockets获得支持,而且因为它与Spring紧密集成,因此将会是一个更好的开发体验。(此段话抄自@https://juejin.im/post/5aa4eacbf265da237a4ca36f)前端

docker镜像服务使用的是阿里云的容器镜像服务。问了一下同事,说是用的google的容器工具jib。因而Cmd+Shift+F全局搜了一下jib。(原谅是公司代码因此是骑兵代码⁄(⁄ ⁄•⁄ω⁄•⁄ ⁄)⁄)java

点击进去能够看到

进入到阿里云找到容器镜像服务(此处省略不知道镜像仓库是分区的,找不到仓库觉得是没权限,而后厚着脸皮要来了管理员帐号修改了离职同事的员工帐号也仍是没有找到仓库的步骤)

而后我建立了一个命名空间xxx-prod,而后在该空间下为每一个服务都建好了仓库.私有仓库。代码源我选择的是本地仓库推送到镜像仓库。其余的我也不太了解。

(后来发现其实不用建,jib提交会自动建立仓库,手动建立的时候选择) 使用jib提交上去后,能够在仓库的版本信息里看到更新。

而后链接上服务器。在home文件夹下面建立一个docker文件夹

//在root根目录
//~]# centos7的emmm怎么说呢,就是GitBash和OS系统上面是$ windows下面cmd是>
//home下面建立一个docker文件夹
~]# mkdir /home/docker
//进入建立的docker
~]# cd /home/docker
复制代码

而后开始pull咱们上传到阿里云的镜像。其实随便哪一个目录均可以pull(此处省略第一次pull阿里镜像服务时,没有看操做指南,一度怀疑本身帐号没有权限实际上是没有login,而后一直docker login,却不知后面应该加上阿里云的镜像地址:registry.cn-hangzhou.aliyuncs.com) 在阿里云的镜像服务管理控制台,随便点开一个镜像仓库——>管理,能够看到对镜像仓库的操做指南mysql

镜像拉取完毕之后输入

~]# docker images
复制代码

能够看到本身刚才pull到的镜像。nginx

我问同事这里怎么这么多镜像,他跟我解释说
emmm,行吧!总以为有不少镜像占内存(但愿有知道的大佬不吝赐教,感谢)

启动eurekaweb

~]# docker run -d --name eureka -p 8761:8761 -p 15672:15672 -p 9001:9001 -v /etc/localtime:/etc/localtime registry.cn-hangzhou.aliyuncs.com/xx_xxx_prod/eureka
// -d后台运行 -p绑定端口这里绑定了三个端口,一个是注册中心自己的端口,一个是网关的端口,另一个是rabbitmq的端口 
//-v打印版本信息 
复制代码

因为使用了rabbitmq,因此还须要再建立一个rabbitmq容器。 仍是先拉取镜像面试

//这里注意获取镜像的时候要获取management版本的,不要获取last版本的,management版本的才带有管理界面。
~]# docker pull rabbitmq:management
~]# docker run -d --name rabbit -e RABBITMQ_DEFAULT_USER=xxx -e RABBITMQ_DEFAULT_PASS=xxx --network=container:eureka rabbitmq:management
//由于docker容器间是网络隔断的 --network是加入eureka同样的网络环境这样才能被eureka治理下的服务访问到。
//-e是设置默认的帐户密码 指令中是xxx,用到的朋友请自行调整。
复制代码

而后启动本身的服务redis

~]# docker run -d --name xxx -v /home/docker/web-prod/logs:/logs -v /etc/localtime:/etc/localtime --network=container:eureka registry.cn-hangzhou.aliyuncs.com/xx_xxx_prod/xxx 
//-v是将日志挂载到本身制定的目录。 一样--network加入eureka的网络,这里不用绑定端口。
//启动后能够在注册中心的控制台查看服务状态。ip + eureka的端口。
复制代码

这样服务就跑起来啦。其余服务步骤相似。最后补充一些在上线是遇到的小插曲。 一开始不知道docker容器间是网络隔断的,一直连不上rabbitmq,由于以前一直没有使用--network假如eureka的网络。因此服务内localhost访问不到rabbitmq。还有,若是服务中有用到rabbitmq延时队列的话,还须要安装延时队列的插件。 插件安装步骤spring

打开官网下载:http://www.rabbitmq.com/community-plugins.html
选择相应的对应的版本“3.7.x”点击下载。
~]# docker cp /home/docker/rabbitmq_delayed_message_exchange-20171201-3.7.x.ez rabbit:/plugins
//进入到docker内部
~]# docker exec -it rabbit /bin/bash
//开启插件
rabbitmq-plugins enable rabbitmq_delayed_message_exchange
//查看安装的全部插件
rabbitmq-plugins list
复制代码

安装成功,如图:

docker rm 删除容器时,忽然就删除不了了。docker ps -a发现该容器的状态是Dead(死亡),网上查阅了不少资料,什么强删、查看挂载状态、手动删除文件夹、查看端口占用状况。几乎都试过了,没有效果。

最后大概经验使然,鬼使神差的把nginx和httpd都关掉而后就能够删除了。 不要问我为何同一台服务器同时装nginx和httpd,此项目本来是php项目,由他们部署的,我接手后本身使用的nginx。

还有一个很奇怪的问题,虽然解决了但后面我仍是不太明白为何会这样子。用户表里面有一个last_password_reset_date,用户登陆时会校验这个时间字段,一直报token失效,一个个字段日志输入后,发着这个字段比数据库里面的时间相差10个小时,当时想过是时区问题。可是同一张表的另外一个register_date字段时间是正常的,因而便没有处理时区。排查了好久,觉得是java接受的时间类型不对,或是同事对这个字段进行了处理。一直没搞定。后面我把线上环境脸上测试库,发现又正常。最后查看了一下测试环境数据库的时区 ,是东八区。线上库是默认的GTM。最后把正式库的时间改为了东八区就行了。

还有一个就是Redis,由于以前有一个公众号服务,用到了redis,当时redis服务是在宿主机上面的。因此,想就连服务器宿主机上面算了,可是一开始连不上,后来把redis的配置文件改了一下,bind参数绑定内网ip就行了。而后程序里面使用内网ip连上redis。

好啦就这样。利用零零碎碎的时间,写了三天,但愿能够给你们带来一点帮助。掰掰!

相关文章
相关标签/搜索