最近有个项目要做上线,以前是基于mupx进行部署的。
但是官方推荐1.4.x以后,使用另外一个部署方式kadirahq/mup。
主要考虑到以下问题,后续考虑采用独立部署各个部分,所以写了该篇文章。
1、Meteor每次重大版本在部署方面都有调整,,比如1.2 1.4x以后的推荐部署方式都不同。学习成本较大,另外考虑到meteor相关独立包的社区稳定性等。
2、更好的拓展等。
最终部署模式如下:
Nginx + pm2 +mongodb
安装Mongodb
安装步骤
1、查看当前Meteor推荐的mongo版本
meteor运行项目后,重新打开控制台,在项目下运行meteor mongo,会显示当前使用的mongo版本,我这边现在看到的是3.2版本
2、下载和解压。
官网下载指定版本mongo官方地址https://www.mongodb.com/lp/download/mongodb-enterprise?jmp=nav,选择版本和环境,复制下载的连接地址。
进入下载目录
cd /root/mongodb
下载安装包
wget http://downloads.mongodb.org/linux/mongodb-linux-x86_64-ubuntu1604-3.2.9.tgz
解压到当前目录,并移动到/usr/mongodb下
tar -zxvf mongodb-linux-x86_64-ubuntu1604-3.2.9.tgz </br>
mv mongodb-linux-x86_64-ubuntu1604-3.2.9 /usr/mongodb
创建data文件夹用于存放数据,创建logs文件用于存放文件
cd /usr/local/mongodb
mkdir data
touch logs
设置mongodb /etc/profile路径, 方便以后可以直接使用mongod mongo命令
vi /etc/profile
最后一行加入,并保存退出
export PATH=/usr/local/mongodb/bin:$PATH
-使配置生效
source /etc/profile
3.启动服务,并做副本设置
启动mongodb服务,以--fork replSet 模式,并设置副本名称为meteor,当然也可以是其他名称
mongod -dbpath=/usr/local/mongodb/data -logpath=/usr/local/mongodb/logs --fork --replSet meteor
运行mongo进入 mongo shell,在 mongo shell 里键入
var config = {_id:"meteor",members:[{_id:0,host:"127.0.0.1:27017"}]}
rs.initiate(config)
你应该会看到返回
{"ok":1}
要确认 mongo 是否运行正常,可以进入 mongo shell,然后运行rs.status(), 如果正常可以看到类似如下的返回
{
"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
}
mongodb安装结束。
安装pm2
因为国内墙的问题,我第一次安装很容易就成功,第二次安装就一直在失败。所以这里采用nvm进行安装。
nvm的github地址如下为:https://github.com/creationix/nvm,可按照步骤进行安装
1、安装nvm
我选择了使用wget安装,当然使用curl安装也可以,需要先安装curl
wget -qO- https://raw.githubusercontent.com/creationix/nvm/v0.33.0/install.sh | bash
完成后nvm就被安装在了/.nvm下啦,接下来就需要配一下环境变量了,我们设置变量到/.profile文件下,这个文件默认是隐藏的。
打开文件,并在最后一行加入配置内容,wq保存退出。
vi ~/.profile
export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh" # This loads nvm
执行source ~/.profile 使配置生效
然后可以执行nvm --version 看看当前版本,如果安装OK,会打印当前nvm版本
nvm --version
0.33.0
安装Node
我们使用nvm安装指定版本的node,Meteor使用的node版本可以在官网找到,也可以在.meteor/local/build/.node_version.txt文件中查看,当前我们安装v4.6.2
nvm install v4.6.2
######################################################################## 100.0%
安装完成后,shell输入node-v来验证当前node版本
node -v
v4.6.2
安装 pm2
这里没有什么特别的,就是跟安装其他 npm 包类似。我没有使用淘宝的 cnpm,因为我发现直接使用 npm 也没有太大问题,就是稍微慢点,但是还没有到不可接受的地步,如果很慢,可以考虑使用cnpm。
npm install pm2 -g
pm2 startup ubuntu
我们运行一下pm2 list,看查看一下当前的服务列表,这个时候应该是空的
cnpm安装命令
npm install cnpm -g --registry=https://registry.npm.taobao.org
打包部署项目
代码文件夹
创建存放 Meteor build 打包成 Node.js app 后的源代码文件夹,我们后面会用到
mkdir /home/meteor
mkdir /home/meteor/build
本地打包 Meteor App
进入meteor app的目录,运行以下代码
meteor build --architecture=os.linux.x86_64 ../build
会在项目同级目录创建build文件夹,build成功后,会有一个*.tar.gz压缩文件,这个就是我们要的
我们上传该文件到/home/meteor/build
运行
在服务器上进入 /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 目录,运行
vim 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 改为你用的地址。
最后运行 pm2 start pm2.json 命令, 你的 meteor 就运行在你的服务器上了。这个时候再运行pm2 list,就能看到你服务状态
最后使用 http://your.server.ip.address:3000 访问你的网站。
当然你也可以使用其 port,例如 80 端口。
安装Nginx
安装
服务安装完成了,我们使用Nginx来完成负载,现在很多平台,如微信小程序,苹果app store都需要使用https/wss。
我们进一步使用nginx来完成。
首先,使用命令安装nginx
apt-get install nginx
使用该命令安装完成后,会默认安装支持的ssl_module,如果手动下载安装包,需要指定安装相关的模块。
安装完成后,默认的安装目录在/etc/ngnix下,如果需要添加新的.conf,在/etc/nginx/conf.d/下新增即可。
使用命令,启动ngnix
service nginx start
这个时候在浏览器访问ip,应该就可以看到以下内容,就是安装成功了
Welcome to nginx!
If you see this page, the nginx web server is successfully installed and working. Further configuration is required.
For online documentation and support please refer to nginx.org.
Commercial support is available at nginx.com.Thank you for using nginx.
申请SSL证书
配置conf,如果需要ssl,需要去申请证书,申请ssl证书,网络已经有很多的教程了,因为我使用let's encrypt一直失败,所以使用了腾讯提供的免费证书。
如果不需要https/wss此步骤可跳过
配置conf
首选,我们创建两个.conf,
http.conf
主要做了一个处理,就是http请求rewrite到https
server {
listen 80;
server_name test.com www.your_domain.com;
rewrite ^(.*)$ https://$host$1 permanent;
}
https.conf
upstream www_pool{
server 127.0.0.1:3000;
#server 192.168.0.12:3000;
}
server {
listen 443;
server_name your_domain.com;
ssl on;
ssl_certificate /root/ssl/Nginx/1_.com_bundle.crt;
ssl_certificate_key /root/ssl/Nginx/2_.com.key;
ssl_session_timeout 5m;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
ssl_prefer_server_ciphers on;
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_set_header X-NginX-Proxy true;
proxy_pass http://www_pool;
proxy_redirect off;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_redirect off;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
注:配置中的your_domain为你自己的domain
检查nginx配置
service nginx configtest
重启nginx
service nginx restart
到此就完成了Meteor的部署工作。
References: