24年7月份更新:
因为某些众所周知的原因,docker pull现在不能直接拉镜像了,翻墙也难搞,所以拉镜像得另辟蹊径了。
配置yum源、下载docker和配置镜像加速就不赘述了,网上大把。
CentOS8 更改YUM源_centos8更换yum源-CSDN博客
CentOS 8.4安装Docker - 追逐时光者 - 博客园 (cnblogs.com)
常用images可以在这里找到:
AtomHub 可信镜像仓库平台 · OpenAtom Foundation (atomgit.com)
但是AtomHub有点少,RocketMQ和MinIO等都没有。不过对于苍穹外卖,也够用了
或者通过 Docker Proxy 镜像加速 这种方法拿到镜像。
找到常用的镜像和版本后,拉下来,应该会显示这样:
由于是第三方拉的镜像,所以名字会很长,以后创建容器都得输这么长,很不方便。所以建议重命名:
docker tag 镜像id 你想改成的名字:版本号
当然,[:版本号]这里是可选的,如果拉的是latest,那可以不加
重命名后就会有两个镜像,只是其中一个是重命名后的
再通过
docker rmi 名字很长的镜像的名字
删掉旧的就行了。
准备阿里云ECS服务器
领服务器网上有很多教程(此处不作赘述)
Huawei云、Ali云还有其他很多地方都有服务器可以白嫖,本质都一样,所以挑个能找到的就行。我最开始找的ali的,就用这个来做示范了。
唯一要注意的是选哪种服务器,有centos、ubantu、Windows Server等,根据熟悉程度选就行。
我这里选的是centos。
其他的不再赘述。
领取完服务器后就能看到了:
主要是要记住公网IP。实例名称可以改一下,这个只是方便自己看。
准备开放端口
云服务器不像本地localhost,在后面拼个端口号就能访问到相应应用,需要手动开启。
开启入口在控制台->网络与安全->安全组->创建安全组
在入方向->手动添加,选择想要开放的端口号就可以。建议提前想好要开放的端口。
比如数据库3306 、redis6379、nginx80、苍穹外卖项目端口(假设为8080)。
注意,后面nginx、mysql、redis和项目都使用docker部署,所以这里的端口指的是服务器本机开放的端口(不知如何表达)
就是说,举个例子,在创建 nginx docker的时候,指定了端口“-p 8089:80”,那么为了正常访问nginx应该开放的是8089;同理,如果你想要创建MySQL docker时指定“-p 6380:6379”,那应该开放的就是6380.
开放完端口后,记得把实例加进安全组:
点进安全组->实例列表->实例加入安全组
准备前端文件
建议下个tree,这个可以以树形结构列出目录和文件,挺方便的:
yum install tree -y
是否需要做这一步取决于你是否要把苍穹外卖改成其它什么XXX外卖。
如果要改成自己的项目名称、logo的话,找到前端代码,查找替换名字、整几张相同规格图片替换即可。
当然完全可以自己写一个前端(逃
步骤参考
后面的步骤参考这一篇:
苍穹外卖部署到云服务器使用Docker学习笔记-CSDN博客
我根据自己需要做些改变和补充
准备后端文件
把苍穹外卖的yml文件中数据库和redis的host改成上面记住的公网ip,注意,数据库密码和redis密码提前想好并记住。
然后IDEA打包,把jar包传到服务器上即可。
使用docker部署nginx、redis、mysql
还是参考上面提到的文章。
nginx
部署好nginx后,在浏览器访问 [ 公网IP+nginx docker端口 ] 应该就能看到前端了,不过第一次加载会很慢。
redis
redis.conf配置文件(参考):
appendonly yes requirepass 你的密码 slowlog-log-slower-than 1000 slowlog-max-len 1000
slowlog两行是慢查询的配置,
dlower-than 1000 表示超过1000μs(即1ms)的查询为慢查询
max-len 1000 表示保留1000条慢查询日志。
以后可以根据慢查询日志来找性能瓶颈。
docker run --restart=always \ -p 6379:6379 \ --name EcsRedis \ -v /dockerapps/redis/conf/redis.conf:/etc/redis/redis.conf \ -v /dockerapps/redis/data:/data \ -v /etc/localtime:/etc/localtime \ -d redis \ redis-server /etc/redis/redis.conf
端口按你自己想要开放的设置,和上面你在ECS控制台开放的端口一致就可以。
其中/dockerapps/**里面是自己创建的用于存放和管理redis配置文件和数据的目录,建议自定义,方便管理。
-v /etc/localtime:/etc/localtime \这一行是把服务器的时间配置文件绑定到容器内,否则会出现容器内时间和服务器时间不一致的问题,一般是差一个时区,即容器内时间慢8小时。
部署好redis后,可以通过命令行运行redis验证
docker exec -it myredis redis-cli
或者直接通过其他redis管理工具(比如Another Redis Desktop Manager)测试连接
mysql
docker run -d \ --name EcsMysql \ -p 3306:3306 \ -e TZ=Asia/Shanghai \ -e MYSQL_ROOT_PASSWORD=你的密码 \ mysql
手动设置时区,避免时间不一致。
同样,部署完后可以通过
docker exec -it mysql bash
进入命令行,然后正常登录mysql测试一下就行
同样可以使用数据库管理工具测试连接
部署后端代码
注意,参考文章里的DockerFile jdk版本是11,这个要根据自己苍穹外卖所使用的java版本来写,我的是17,所以就改成17。
这里就是上面提到的端口注意事项,安全组里开放的后端端口就是这里的8081,项目里yml文件的端口就是8080。记得对应上,
如果这里创建docker映射的是8082:8080,安全组开放的是8081,或者
创建docker映射的是8081:8080,结果自己苍穹外卖的yml文件端口写的是8088
这样当然是运行不了的。
注意:还是容器时间和服务器时间的问题,创建docker容器时要手动指定时区,否则下单会因为时间对不上直接失败。
DockerFile参考:
(这个DockerFile是9月份补的,这时候docker pull已经被限制了,所以你得自己找docker的jdk)
FROM hub.atomgit.com/amd64/openjdk:17-jdk-slim LABEL maintainer=你的名字。当然可以不写 ENV TZ=Asia/Shanghai RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone COPY *.jar /app.jar ENTRYPOINT ["java","-jar","/app.jar"]
部署好后,直接根据ip+端口去访问一下Knife4j文档看能不能看到就好。
修改nginx.conf文件中的转发规则时,可以直接修改这里:
就不用在下面手动一个一个改了。
注意!后面的端口是你苍穹外卖docker开放的端口。不是nginx的端口。
其他
WebSocket失灵的问题上面提到的文章也有修改方法,这里不重复了。不过还是听不到那个提示音的,搞不定。