Solo 升级小记

本贴最后更新于 245 天前,其中的信息可能已经时异事殊

将近两个周没有登录博客了,今天使用 kubernetes-client 开发工具对 k8s 进行管理的时候踩了一个坑,随即准备写一篇博客记录整个过程,但是发现使用 GitHub 账号登录时总是出现 404,如图所示:

查看后台日志如下:

 
[INFO ]-[2020-01-16 23:14:16]-[org.b3log.solo.Server:215]: Solo is booting [ver=3.6.7, os=Linux, isDocker=true, inJar=false, luteAvailable=false, pid=1, runtimeDatabase=MYSQL, runtimeMode=PRODUCTION, jdbc.username=root, jdbc.URL=jdbc:mysql://127.0.0.1:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC]
[INFO ]-[2020-01-16 23:14:18]-[org.b3log.solo.util.Skins:77]: Loaded template from directory [/opt/solo/]
[INFO ]-[2020-01-16 23:14:18]-[org.b3log.solo.Server:260]: Solo is running
[ERROR]-[2020-01-16 23:15:17]-[org.b3log.solo.processor.OAuthProcessor:119]: Gets oauth client id failed: HTTP/1.1 404 Not Found
[INFO ]-[2020-01-16 10:20:32]-[org.b3log.solo.processor.SitemapProcessor:109]: Generated sitemap
[ERROR]-[2020-01-16 21:48:32]-[org.b3log.solo.processor.OAuthProcessor:119]: Gets oauth client id failed: HTTP/1.1 404 Not Found

大概意思是获取 OAuth client id 失败了,想到之前在论坛上看到有一哥们安装 solo 就出现了 404,就上去瞄了一眼 D 大的回复,大多数都是建议更新后重启,现在就我重启的整个过程做一个记录,方便后面的兄弟遇到同样的问题时可以参考:

一、首先执行如下命令:

docker pull b3log/solo

会出现以下内容:

表示最新的镜像已经拉去下来了。(因为镜像是一层一层制作出来的,其中 Already exists 表示一些层已经存在了,可以进行复用)

二、然后执行 images 命令可以查看最新版的镜像已经拉下来了,并且替换掉了之前的镜像(并且可以看到新版的镜像比之前的镜像缩小了将近 20M,说明 D 大可能对镜像做过瘦身,给点个赞):

docker images

三、备份数据库

首先查看 MySQL 容器的 id:

docker ps | grep mysql

进入容器:

docker exec -it 6abbb1c15646 bash

之后备份数据的操作就和在本地安装了 MySQL 的电脑上操作一样了,这里不再赘述。

这里要强调的一点是,当你生成备份文件之后,最好将该文件拷贝到宿主机上,也就是你的服务器上面,可以通过以下操作完成:

# 在容器内执行
mysqldump -u root -p solo > /home/solo.sql
# 退出容器
exit
# 将容器内的备份文件拷贝到服务器的home目录下
docker cp 6abbb1c15646:/home/solo.sql /home
然后找到之前启动的solo容器,kill掉

然后使用 rm 命令彻底删除容器:

(可选)删除之前老版本的镜像(因为我的服务器硬盘容量不大,我一般都是能删的尽量都删干净了)

到这里我们博客的升级之旅就已经完成了,执行最后一步 docker run 重新拉起我们的容器就大功告成了:

docker run --detach --name solo --network=host --env RUNTIME_DB="MYSQL" --env JDBC_USERNAME="root" --env JDBC_PASSWORD="123456" --env JDBC_DRIVER="com.mysql.cj.jdbc.Driver" --env JDBC_URL="jdbc:mysql://127.0.0.1:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC" .....

四、重新登录后台管理界面

赞助商 我要投放

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...