使用该方式需要有基本的 Linux 知识
这里介绍的部署方法都是手动,可以帮助理解 Meteor App 在生产环境下是如何运行的
部署 Meteor 应用的常用工具 mup 和 mupx 都是使用 docker,而 docker 被墙了,所以我们不能使用 mup,mupx 来部署 Meteor 应用到国内服务器,除非使用一些绕远路的方法,例如修改他们的 docker image 源到 daocloud,或者在其他地方部署好了再拷贝到国内的服务器,总之都要做不少额外工作。这里介绍一种不使用 docker 而只使用 Meteor 自身的 build 命令,再加上 pm2 来部署 Meteor 应用的方法。不过最好你的本地开发电脑可以翻墙,这样安装 Meteor 和相关的 npm 包更顺畅,但是这些和部署无关。
配置服务器
建议使用 Ubuntu 14.04 64bit LTS 版本,root 用户就可以了。新开一台 VPS 后使用下面的命令更新一下 Ubuntu 的包列表, 这样 Ubuntu 知道到哪里去下载最新的软件包。
apt-get update //这里并不更新 Ubuntu 的任何软件,只是更新使用到的包的列表
如果你是新的服务器,可能还需要安装 curl 和 git
apt-get install curl
apt-get install git
安装 Node.js 4
curl -sL https://deb.nodesource.com/setup_4.x | sudo -E bash -
apt-get install -y nodejs
安装完成后,可以使用如下命名检验安装是否成功以及版本。
node -v
如果安装正常会显示 Node 版本,我的是 v4.5.0
安装 MongoDB
MongoDB 官方的源在中国太慢,一般需要大概 3 个小时完成下载,推荐使用清华大学的源,详细步骤见这里
对于前面步骤里提到的 " 再选择你的 Debian/Ubuntu 版本,文本框中内容写进 /etc/apt/sources.list.d/mongodb.list "
可以使用命令
nano /etc/apt/sources.list.d/mongodb.list
然后把下面的内容粘贴过去,再 ctr + x,再按 y 键确认退出
deb http://mirrors.tuna.tsinghua.edu.cn/mongodb/apt/ubuntu trusty/mongodb-org/stable multiverse
按照前面步骤完成 MongoDB 安装后运行 <code>mongo</code> 测试是否安装成功。如果遇到下面的错误
Failed global initialization: BadValue Invalid or no user locale set. Please ensure LANG and/or LC_* environment variables are set correctly.
需要设置如下语言环境
export LC_ALL=C
然后再使用下面命令修改 mongod 的配置
nano /etc/mongod.conf
找到 "#replication" 的注释处,改为如下内容
replication:
replSetName: meteor
然后重启 mongo
service mongod restart
重启后,运行 <code>mongo</code> 进入 mongo shell,在 mongo shell 里键入
var config = {_id: "meteor", members: [{_id: 0, host: "127.0.0.1:27017"}]}
rs.initiate(config)
你应该会看到返回
{"ok":1}
最后,再次重启mongo
service mongod restart
要确认 mongo 是否运行正常,可以进入 mongo shell,然后运行 <code>rs.status()</code> , 如果正常可以看到类似如下的返回
{
"set" : "meteor",
"date" : ISODate("2016-08-22T10:54:53.367Z"),
"myState" : 1,
"term" : NumberLong(2),
"heartbeatIntervalMillis" : NumberLong(2000),
"members" : [
{
"_id" : 0,
"name" : "127.0.0.1:27017",
"health" : 1,
"state" : 1,
"stateStr" : "PRIMARY",
"uptime" : 12576,
"optime" : {
"ts" : Timestamp(1471850718, 1),
"t" : NumberLong(2)
},
"optimeDate" : ISODate("2016-08-22T07:25:18Z"),
"electionTime" : Timestamp(1471850717, 1),
"electionDate" : ISODate("2016-08-22T07:25:17Z"),
"configVersion" : 1,
"self" : true
}
],
"ok" : 1
}
安装 pm2
这里没有什么特别的,就是跟安装其他 npm 包类似。我没有使用淘宝的 cnpm,因为我发现直接使用 npm 也没有太大问题,就是稍微慢点,但是还没有到不可接受的地步。
npm install pm2 -g
pm2 startup ubuntu
我后来发现这也要看机房,有的机房会很慢很慢,甚至安装不了,比如阿里云最便宜的华北1 机房。但是青云的华南机房就没有问题,原版的 npm 包安装起来很快。
如果你的 npm 安装有问题,可以使用 cnpm,先安装淘宝的 cnpm 包
npm install cnpm -g --registry=https://registry.npm.taobao.org
然后通过 cnpm 来安装 pm2,安装方式和 npm 几乎一样
cnpm install pm2 -g
安装后的使用方式和通过 npm 安装的一样。
代码文件夹
创建存放 Meteor build 打包成 Node.js app 后的源代码文件夹,我们后面会用到
mkdir /home/meteor
mkdir /home/meteor/build
到现在服务器端配置完毕
本地打包 Meteor App
假设你的 Meteor 源代码在你的本地开发电脑上一个叫 meteor-build-test 的文件夹里,我们在它的同级目录建立一个叫 build 的文件夹。然后运行
cd meteor-build-test
meteor build --architecture=os.linux.x86_64 ../build
scp ../build/meteor-build-test.tar.gz root@your.server.ip.address:/home/meteor/build
上面的命令就是把 Meteor app 打包成普通的 Node.js app,然后上传到我们之前在服务器上创建的文件夹里。
运行
在服务器上进入 /home/meteor/build,然后运行
tar xvf meteor-build-test.tar.gz
解压完成后,运行
cd bundle/programs/server && npm install
或者使用 cnpm,如果连接 npm 源有问题
cd bundle/programs/server && cnpm install
安装打包完成后的 Node app 使用到的 npm 包。安装完成后回到 bundle 目录,运行
nano pm2.json
再把
{
"apps": [{
"name": "appName",
"cwd": "/home/meteor/build/bundle",
"script": "main.js",
"env": {
"NODE_ENV": "production",
"WORKER_ID": "0",
"PORT": "3000",
"ROOT_URL": "http://your.server.ip.address",
"MONGO_URL": "mongodb://localhost:27017/meteor",
"MONGO_OPLOG_URL": "mongodb://localhost:27017/local",
"HTTP_FORWARDED_COUNT": "1",
"METEOR_SETTINGS": {}
}
}]
}
拷贝过去,记得把 ROOT_URL 改为你用的地址。
最后运行 <code> pm2 start pm2.json </code> 命令, 你的 meteor 就运行在你的服务器上了。最后使用 <code> http://your.server.ip.address:3000 </code> 访问你的网站。当然你也可以使用其 port,例如 80 端口。
我们也可以把这个过程做成 bash 脚本自动运行,以后每次修改代码后就不用再手动敲打每个命令来部署了。
References: