へっぽこプログラマーの備忘録
プログラムを中心とした個人的なメモ用のブログです。 タイトルは迷走中。
内容の保証はできませんのであしからずご了承ください。
menu
keyboard_arrow_up
Top
search
close
home
ホーム
computer
PC一般
construction
開発環境・ツール
code
プログラミング
home
ホーム
computer
PC一般
construction
開発環境・ツール
code
プログラミング
Home
›
rocketchat
›
Rocket.Chat 移行後にアップロードファイルの URL が古いままになっている
2023/10/19
Rocket.Chat 移行後にアップロードファイルの URL が古いままになっている
update
event_note
label
rocketchat
Rocket.Chat を移行したのですが、アップロード済みファイルの URL と、サイト URL のリセット値が、移行前の古い URL のままになっていました。
## 概要 - Rocket.Chat を移行し、ドメイン (サイトURL) が変わった - その際、Rocket.Chatを 3.10.14 から 6.2.12 にアップグレードしている - MongoDB も 4.0 から 5.0 にアップグレード - Rocket.Chat 起動時に指定する環境変数 `ROOT_URL` は移行後の URL を設定済み - Rocket.Chat の管理者メニューで設定できる `サイト URL` も移行後の URL を設定済み この状況で、以下の2つの不具合を確認しました。 1. アップロード済みのファイルの URL (ダウンロードリンク) が移行前の古い URL になっている 1. Rocket.Chat の管理者メニューで設定できる `サイト URL` について、リセットボタンを押すと移行前の古い URL がセットされる ## 先に結論 `1.` については MongoDB のデータを直接修正すれば直りました。 `2.` については未解決です。 ### MongoDB のデータを確認することにしたきっかけ いろいろググっていく中で以下のページに辿り着きました。 - https://www.ryadel.com/en/rocket-chat-change-root_url-site-url-rocketchat/ こちらの方法を試しても今回発生している不具合は直りませんでしたが、これをきっかけに MongoDB の中身を調査していくことで修正できました。 MongoDB の中身の確認方法については以下が参考になりました。 - https://www.mtioutput.com/entry/2019/02/21/180000 - https://gihyo.jp/dev/serial/01/mongodb/0003 ## 調査の過程と修正方法 Rocket.Chat と MongoDB は docker で動かしています。 なので、まず MongoDB の docker コンテナに入ります。 ```sh $ docker exec -it rocketchat-mongo bash ``` コンテナに入ったら MongoDB シェルを開き、`rocketchat` のデータベースを選択します。 ```sh # mongo > use rocketchat ``` コレクションを表示してみます。 ```sh > show collections ``` たくさん表示されますが、ここから不具合内容に該当する箇所を推測して調査していきます。 ## 1. アップロードファイルのダウンロードリンクについて 前述の `1.` についてですが、こちらはアップロードファイルに関することなので、`rocketchat_uploads` の中身を表示してみました。 ```sh > db.rocketchat_uploads.find() ``` 20件のみ表示されますが、適当なデータ一件について中身をみると以下のような感じになっていました。 ```json { "_id": "27JzjqpXHxAHBzaxp", "name": "hoge.jpg", "size": 51268, "type": "image/jpeg", "rid": "MgKrXXN4XmQwtMMjgjXnWzpNvR6YrRpH4F", "userId": "jXnWzpNvR6YrRpH4F", "store": "GridFS:Uploads", "_updatedAt": ISODate("2023-07-26T03:58:50.233Z"), "instanceId": "R252ARSHBKR3RrXHY", "identify": { "format": "jpeg", "size": { "width": 495, "height": 700 } }, "complete": true, "etag": "HoMjiYj2fbb799RFK", "path": "/ufs/GridFS:Uploads/27JzjqpXHxAHBzaxp/%E5%90%8D%E7%A7%B0%E6%9C%AA%E8%A8%AD%E5%AE%9A%201.jpg", "progress": 1, "token": "68c8A8CAb8", "uploadedAt": ISODate("2023-07-26T03:58:50.852Z"), "uploading": false, "url": "http://old_domain:port/ufs/GridFS:Uploads/27JzjqpXHxAHBzaxp/%E5%90%8D%E7%A7%B0%E6%9C%AA%E8%A8%AD%E5%AE%9A%201.jpg", "typeGroup": "image" } ``` 見てわかる通り、`url` のフィールドにファイルへの絶対パスが記録されているため、これを修正しないと直らないんじゃないかと思いました。 というわけで、以下のコマンドでドメインの部分のみを置換します。 ```sh db.rocketchat_uploads.find().forEach(function(row) { row.url = row.url.replace(new RegExp("old_domain", 'g'), "new_domain"); db.rocketchat_uploads.save(row); }); ``` これで Rocket.Chat のほうを確認すると、URL が直っていました。 ## 2. サイト URL` のリセット値について 次に前述の `2.` についてですが、設定に関することなので `rocketchat_settings` を確認してみました。 こちらはついては中身を全てを見たかったので、以下のようにして json ファイルに出力して確認しました。 ```sh $ mongoexport -d rocketchat -c rocketchat_settings -o rocketchat_settings.json --type=json mongodb://localhost:27017 ``` で、中身を確認してみましたが、それらしい設定は見当たりませんでした。 他のコレクションもいろいろ確認してみましたが、それらしい設定は見つかっていません。 というわけで未解決ですが、特に実害はないので放っておいてます。
## 参考 URL - https://www.ryadel.com/en/rocket-chat-change-root_url-site-url-rocketchat/ - https://www.mtioutput.com/entry/2019/02/21/180000 - https://gihyo.jp/dev/serial/01/mongodb/0003
tweet
facebook
Pocket
B!
はてブ
LINE
chevron_left
chevron_right
Translate
Popular Posts
TortoiseGit でコミットメッセージを変更する
image
NO IMAGE
smbclient で session setup failed: NT_STATUS_LOGON_FAILURE が表示される
Docker for Windows の設定
image
NO IMAGE
マージ元ブランチとマージ先ブランチ
image
NO IMAGE
TortoiseSVN ロック状態のチェック
image
NO IMAGE
Visual Studio で文字がにじむ(ぼやける)
TortoiseGit でブランチ間の差分を見る
image
NO IMAGE
AsciidocFX をビルドする
image
NO IMAGE
PowerShellでブレークポイントが設定できない場合
[Python] 文字列の判定で、None と空文字を同時に判定する
Labels
.NET Core
31
.NET Framework
17
.NET Standard
2
AdminLTE
1
AI
1
Apache
3
AppVeyor
2
AsciiDoc
7
ASP.NET Core
55
Atom
4
AWS
5
AWS Cloud9
4
blockdiag
1
Blogger
13
Bootstrap
3
C/C++
6
C#
106
CentOS
3
Chrome
1
Chronograf
3
chrony
1
Codecov
1
CSS
1
Docker
80
DokuWiki
4
Doxygen
1
draw.io
1
EasyTag
1
Electron
1
Electron.NET
2
Entity Framework Core
9
Excel
2
FFmpeg
3
Firefox
6
Flask
1
Git
19
GitBook
4
GitBucket
7
GitHub
7
GitLab
39
Go
1
Google
1
Google Cloud Platform
1
Grafana
13
GStreamer
2
HTML
5
IIS
8
InfluxDB
14
JavaScript
15
Jekyll
2
Jenkins
7
Linux
34
Log4View
1
MahApps.Metro
3
MaterialDesignInXamlToolkit
1
MkDocs
2
MongoDB
5
MVC
1
MVVM
6
nginx
3
NLog
3
Node.js
8
npm
1
NVIDIA
3
onvif
1
OpenAPI
2
OpenCV
4
OpenSSL
3
OpenVINO
2
ownCloud
2
pandas
1
Pine Script
1
PlantUML
5
Portainer
3
PowerShell
8
Prism
2
PySide
19
Python
88
PyTorch
1
RabbitVCS
1
Razor
3
redis
1
Redmine
33
Redoc
1
remark.js
2
rocketchat
10
Ruby
3
scikit-learn
1
shotcut
1
SignalR
1
Slack
1
Socket.IO
1
SonarQube
5
Sphinx
10
SQL Server
5
SQLite
1
StableDiffusion
1
Subversion
2
Swagger
1
Swarmpit
1
Syslog
3
Telegraf
6
Tesseract
3
TestLink
2
Tomcat
2
TortoiseGit
11
TortoiseSVN
2
Trading View
1
Traefik
3
Travis CI
1
Ubuntu
31
Visual Studio
39
Visual Studio Code
10
VSCode
8
Vue.js
8
Windows
62
Windows 10
5
Windows ADK
1
Windows API
2
Windows Embedded
4
wkhtmltopdf
2
Word
3
WPF
12
WSL
5
WSL2
5
Xamarin
1
xUnit
5
yaml
1
yolo
1
アプリケーション
1
デザインパターン
1
テスト
1
バッチファイル
2
プログラミング
4
ライセンス
1
暗号資産(仮想通貨)
1
英語
2
確定申告
1
機械学習
1
強化学習
1
雑記
1
書籍
1
数学
1
正規表現
1
動画編集
1
Blog Archive
►
2024
(18)
►
9月
(5)
►
8月
(1)
►
7月
(2)
►
6月
(1)
►
4月
(2)
►
3月
(1)
►
2月
(5)
►
1月
(1)
▼
2023
(30)
►
12月
(3)
►
11月
(5)
▼
10月
(2)
Rocket.Chat 移行後にアップロードファイルの URL が古いままになっている
Rocket.Chat のアップグレード手順
►
9月
(1)
►
8月
(2)
►
7月
(4)
►
6月
(2)
►
5月
(3)
►
4月
(2)
►
3月
(2)
►
2月
(3)
►
1月
(1)
►
2022
(106)
►
12月
(5)
►
11月
(1)
►
10月
(3)
►
9月
(6)
►
8月
(7)
►
7月
(6)
►
6月
(13)
►
5月
(9)
►
4月
(15)
►
3月
(11)
►
2月
(14)
►
1月
(16)
►
2021
(85)
►
12月
(11)
►
11月
(6)
►
10月
(4)
►
9月
(10)
►
8月
(8)
►
7月
(4)
►
6月
(18)
►
5月
(7)
►
4月
(8)
►
3月
(2)
►
2月
(2)
►
1月
(5)
►
2020
(56)
►
12月
(1)
►
11月
(3)
►
10月
(3)
►
9月
(3)
►
8月
(3)
►
7月
(7)
►
6月
(7)
►
5月
(2)
►
4月
(6)
►
3月
(6)
►
2月
(3)
►
1月
(12)
►
2019
(92)
►
12月
(13)
►
11月
(9)
►
10月
(3)
►
9月
(2)
►
8月
(3)
►
7月
(5)
►
6月
(11)
►
5月
(6)
►
4月
(17)
►
3月
(9)
►
2月
(6)
►
1月
(8)
►
2018
(100)
►
12月
(1)
►
11月
(11)
►
10月
(8)
►
9月
(6)
►
8月
(10)
►
7月
(10)
►
6月
(8)
►
5月
(9)
►
4月
(8)
►
3月
(14)
►
2月
(4)
►
1月
(11)
►
2017
(117)
►
12月
(14)
►
11月
(20)
►
10月
(17)
►
9月
(19)
►
8月
(10)
►
7月
(8)
►
6月
(3)
►
5月
(6)
►
4月
(5)
►
3月
(2)
►
2月
(8)
►
1月
(5)
►
2016
(91)
►
12月
(5)
►
11月
(9)
►
10月
(11)
►
9月
(9)
►
8月
(6)
►
7月
(14)
►
6月
(14)
►
5月
(11)
►
4月
(10)
►
3月
(2)
►
2015
(23)
►
12月
(4)
►
11月
(2)
►
10月
(8)
►
9月
(8)
►
7月
(1)
►
2013
(3)
►
11月
(1)
►
9月
(1)
►
7月
(1)
►
2012
(2)
►
7月
(1)
►
6月
(1)
►
2011
(1)
►
9月
(1)
►
2009
(1)
►
7月
(1)
►
2008
(2)
►
11月
(1)
►
7月
(1)
►
2007
(3)
►
10月
(3)