使用Docker在MacOS上部署Parse Server和Parse Server Dashboard

部署parse-server

官方镜像在这里parseplatform/parse-server,就当前日期(2022年9月1日),官方的文档并没有着重介绍如何使用Docker进行部署。

第一步:拉取parse-server镜像到本地
docker pull parseplatform/parse-server
第二步:挂载

我们需要考虑的挂载包括下面这些内容:

配置文件:/parse-server/config
Cloud Code:/parse-server/cloud
日志:/parse-server/logs

我们需要在主机内创建相应的文件/目录,通过 -v 指令将本地的和镜像内的进行挂载(映射)。

首先,需要在本地创建相应的目录,在我们的项目开发目录parse.server.docker下创建下面这些目录以及子目录。

cd $HOME 
cd parse.server.docker
mkdir ./parse-server
mkdir ./logs/parse-server
mkdir -p ./parse-server/{config,cloud}
touch ./parse-server/config/config.json
touch ./parse-server/cloud/main.js

初始化配置文件

{
  "appId": "APPLICATION_ID",
  "masterKey": "MASTER_KEY",
  "appName": "Hello World",
  "serverURL": "http://localhost:1337/parse",
  "cloud":"/parse-server/cloud/main.js",
  "databaseURI": "mongodb://parse:parse@mongo/parse_server_database"
}

这里我们配置了几个必备的参数,如需要更多的配置,可以参考配置文件。

这里需要非常注意:由于我们的mongo数据库也是由docker启动的,databaseURI必须以这种格式进行书写:即mongodb://用户名:密码@由docker启动的mongdb的名字/数据库名。例如结合我们之前创建的,这里应该为:--databaseURI mongodb://parse:parse@mongo/parse_server_database

此外,目前我们的serverURL使用的是http://localhost:1337/parse,而非https://localhost:1337/parse。如果需要支持https,这就是另一个故事了。

初始化Cloud Code文件

Parse.Cloud.define("HelloCloud", async (request) => {
    return 'Hello Cloud';
  });

这里我们定义一个“HelloCloud”函数,方便我们后面测试Cloud功能。

第三步:启动parse-server
cd $HOME/parse.server.docker
docker run \
--name parse-server \
-p 1337:1337 \
-v $(pwd)/parse-server/config:/parse-server/config \
-v $(pwd)/parse-server/cloud:/parse-server/cloud \
-v $(pwd)/logs/parse-server:/parse-server/logs \
--link mongo:mongo \
-d parseplatform/parse-server /parse-server/config/config.json

在这里我们根据配置文件启动Parse Server,因此不需要再额外指定parse-server的启动参数了。

第四步:测试Parse-Server

在这里我们使用REST API进行测试,执行下面的命令,往数据库表GameScore中插入一条数据

curl -X POST \
-H "X-Parse-Application-Id: APPLICATION_ID" \
-H "Content-Type: application/json" \
-d '{"score":1337,"playerName":"Sean Plott","cheatMode":false}' \
http://localhost:1337/parse/classes/GameScore

返回结果类似,这样就是执行成功了。

{
  "objectId":"l7D7mO73Jh",
  "createdAt":"2022-08-31T22:12:15.955Z"
}
第五步:测试Cloud Code

执行下面的命令

curl -X POST \
  -H "X-Parse-Application-Id: APPLICATION_ID" \
  -H "Content-Type: application/json" \
  http://localhost:1337/parse/functions/HelloCloud

返回的结果如下:

{"result":"Hello Cloud"}

部署parse-dashboard

第一步:拉取parse-dashboard镜像到本地
docker pull parseplatform/parse-dashboard:4.1.4

为什么指定版本?因为当前的latest版本有一个错误(https://github.com/parse-community/parse-dashboard/issues/2194

第二步:挂载

我们需要考虑的挂载包括下面这些内容:

配置文件:/src/Parse-Dashboard/parse-dashboard-config.json

首先,需要在本地创建相应的目录,在我们的项目开发目录parse.server.docker下创建下面这些目录以及子目录。

cd $HOME 
cd parse.server.docker
mkdir ./parse-dashboard
mkdir ./parse-dashboard/config
touch ./parse-dashboard/config/parse-dashboard-config.json

初始化配置文件

{
    "apps": [
        { 
            "serverURL": "http://localhost:1337/parse",
            "appId": "APPLICATION_ID",
            "masterKey": "MASTER_KEY",
            "appName": "Hello World",
        }
    ],
    "users": [
        {
            "user":"parse",
            "pass":"password"
        }
    ]
}
第三步:启动parse-dashboard
cd $HOME/parse.server.docker
docker run \
--name parse-dashboard \
-p 4040:4040 \
-v $(pwd)/parse-dashboard/config/parse-dashboard-config.json:/src/Parse-Dashboard/parse-dashboard-config.json \
-d parseplatform/parse-dashboard:4.1.4 \
--allowInsecureHTTP \
--mountPath /parse-dashboard

注意,parse dashboard默认只能通过https访问,指定--allowInsecureHTTP则可以通过http访问。--mountPath /parse-dashboard非常重要,而且/不能省。

第四步:验证

在浏览器中输入http://localhost:4040,会出现如下的页面、

截屏2022-09-01 16.13.42.png

输入用户名密码之后,跳转到如下的页面


截屏2022-09-01 16.13.59.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,366评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,521评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,689评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,925评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,942评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,727评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,447评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,349评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,820评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,990评论 3 337
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,127评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,812评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,471评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,017评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,142评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,388评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,066评论 2 355

推荐阅读更多精彩内容