NodeJS+Express+MySQL开发小记(2):服务器部署
http://borninsummer.com/2015/06/17/notes-on-developing-nodejs-webapp/
NodeJS+Express+MySQL开发小记(1)里讲过在本地搭建 NodeJS 网站的若干细节。本人最近在阿里云服务器上面按最低配租了4个月的云服务器,所以想试着把这个项目部署到云上。云服务器操作系统是Ubuntu 14.04 LTS。之前一直在Windows下做开发,对于Linux下的环境搭建、配置还不是很熟悉,搭建的过程中学到很多东西。
本文简单记录对服务器进行部署的一些细节方面与解决方案。
安装MySQL Server
直接通过apt-get就可以:
|
1
|
sudo apt-get install mysql-server
|
安装过程会提示 After this operation, 96.4 MB of additional disk space will be used.。MySQL的版本为Server version: 5.5.43-0ubuntu0.14.04.1 (Ubuntu)。
安装完成后,运行
|
1
|
mysql -u root -p
|
输入密码,即可进入MySQL的终端了。
用Git进行版本控制
出于跟风,以及提高技术的目的,毫不犹豫地选择了Git而不是SVN来进行代码版本控制。最初是使用Github来作为远程服务器,用了大概两个月,感觉对于开发这种业务性太强的项目(尤其要在代码里使用数据库的),使用开源的Github仓库来托管并不让人放心。
后来发现了国内的业界良心 Git@OSC ,其宣布永久开放git公有库和私有库。相关新闻:
此货的功能与Github并无太大区别,考虑到私有仓库的免费,便果断迁移了过来。
用Git部署代码
最开始是从Github上获取代码的:
|
1
2
3
4
|
cd /var
mkdir www
cd www
git clone https://github.com/zilong-thu/d.git debate
|
以后如果代码发生变动,可以这样更新代码:
|
1
2
|
cd debate
git pull origin master
|
后来远程代码仓库迁移到git@osc,那么可以添加这个新的remote,命名为osc,然后以后就只从osc进行代码获取了。以后提交代码,也就只往git@osc提交,就一切OK了。
|
1
2
3
|
git remote add osc https://git.oschina.net/zilong-thu/d.git
git pull osc master
|
如果要删除Github那个remote,可以这样:
|
1
|
git remote rm origin
|
使用SSH而非HTTPS
先生成一个SSH公钥,方法:
注意,如果是 Windows &/8 + Git Bash 环境,那么在将你的key添加到 ssh-agent 中时应该使用这个命令(参考 Stack Overflow : Could not open a connection to your authentication agent):
|
1
|
eval $(ssh-agent -s)
|
在用于开发的电脑上,修改本地代码库的remote url
|
1
|
git remote set-url origin git@github.com:USERNAME/OTHERREPOSITORY.git
|
参考
以及一个中文的 Pro Git:
运行服务
安装依赖
在debate目录下,安装node模块,执行
|
1
|
npm install
|
安装好所有依赖后,如下启动服务器:
|
1
|
npm start
|
使用阿里云给的IP加上端口号,即可访问到开启了的网站。
使NodeJS服务在后台运行
目前是使用putty使用ssh远程登录来操作服务器的,如果关闭这个putty,即会话终止,则服务也随即停止。解决思路自然是让程序在后台不间断地运行。解决方案可以参考:
因此,在/var/www/debate目录下新建一个shell脚本start.sh,内容为:
|
1
2
|
# Debate server start shell script
nohup npm start &
|
&是为了让程序能够在后台运行。这时候ctrl+c,或者关闭putty会话,就都不会杀死这个服务进程了。
用supervisor自动重启服务
NodeJS代码发生变化时,一般是必须重启Node程序才可以生效的。每次手动重启的话太麻烦,可以使用专为NodeJS打造的node-supervisor模块来实现代码变动时自动重启,以及服务崩溃时自动重启的功能。
其官网的描述是这样的:
Node Supervisor is used to restart programs when they crash.
It can also be used to restart programs when a *.js file changes.
务必要全局安装:
|
1
|
npm install -g supervisor
|
对于express 4.*版本,启动服务时是这样的:
|
1
|
npm start
|
它其实上会到package.json里面寻找这个:
|
1
2
3
|
"scripts": {
"start": "node ./bin/www"
}
|
因此执行的实际上是node ./bin/www。那么使用supervisor来代替npm start的话就应该是supervisor ./bin/www。因此,在shell脚本里可以这样写:
|
1
|
nohup supervisor ./bin/www &
|
如此一来,当更新代码时,就不必手动去重启NodeJS服务了。
停止服务
使用kill
先列出所有进程,找到Node服务的进程ID,将其杀死,即可停止服务了。
|
1
2
3
4
5
6
|
ps aux
root 11200 1.1 4.0 898452 20436 ? Sl Jun19 75:13 node /usr/local
root 11387 0.0 15.4 923264 77080 ? Sl Jun19 0:03 node ./bin/www
kill 11200
|
只要杀死node /usr/local开启的进程,node ./bin/www进程也随之死掉了。
###使用进程名+脚本来停止服务
端口
如果运行在未被占用的非80端口上,服务器一声不吭就给开了。但是如果用80端口,可能要注意一下权限的问题。最近都是使用root用户来开启Node服务并运行于80端口上,没有碰到什么问题。
使用80端口后,访问服务就不必加端口号了。
用shell实现自动化管理
NodeJS+Express+MySQL开发小记(2):服务器部署的更多相关文章
- vue+nodejs+express+mysql 建立一个在线网盘程序
vue+nodejs+express+mysql 建立一个在线网盘程序 目录 vue+nodejs+express+mysql 建立一个在线网盘程序 第一章 开发环境准备 1.1 开发所用工具简介 1 ...
- 使用pm2启动nodejs+express+mysql管理系统步骤
背景: 由于个人兴趣,了解了一下nodejs+express+mysql项目.在项目搭建完成并开发完成并部署时,遇到一个尴尬的问题,就是后台的servive服务启动问题.日常开发时,打开2个cm窗口, ...
- nodejs+express+mysql 增删改查
之前,一直使用的是nodejs+thinkjs来完成自己所需的项目需求,而对于nodejs中另外一中应用框架express却了解的少之又少,这两天就简单的了解了一下如何使用express来做一些数据库 ...
- NodeJS+Express+mySQL服务端开发详解
随着NodeJS的发展,现在已经被很多人熟知,NodeJS已经成为了前端开发人员必备的技能.本文不会对NodeJS过多介绍 如果你感兴趣可以访问NodeJS 官网, 维基百科 本文是利用NodeJS+ ...
- 【原创】基于NodeJS Express框架开发的一个VIP视频网站项目及源码分享
项目名称:视频网站项目 开发语言:HTML,CSS(前端),JavaScript,NODEJS(expres)(后台) 数据库:MySQL 开发环境:Win7,Webstorm 上线部署环境:Linu ...
- nodejs+express+mysql实现restful风格的增删改查示例
首先,放上项目github地址:https://github.com/codethereforam/express-mysql-demo 一.前言 之前学的java,一直用的ssm框架写后台.前段时间 ...
- 进入全屏 nodejs+express+mysql实现restful风格的增删改查示例
首先,放上项目github地址:https://github.com/codethereforam/express-mysql-demo 一.前言 之前学的java,一直用的ssm框架写后台.前段时间 ...
- 使用 NodeJS+Express+MySQL 实现简单的增删改查
关于node.js暂时记录如下,以后有时间一定学习 文章来自简书,作者:sprint,2016-07 使用 Node.js + Express+MySQL 实现简单的增删改查 https://www. ...
- 基于nodejs+express+mysql+webstorm+html的 增删改查
一.工具准备 Nodejs框架,WebStorm.Mysql服务.Navicat.此篇文章只讲项目的搭建过程,至于Nodejs,WebStorm.Mysql的下载.安装与配置网上资源很多,请自行查阅, ...
随机推荐
- 服务器SSL不安全漏洞修复方案
关于SSL POODLE漏洞 POODLE = Padding Oracle On Downgraded Legacy Encryption.是最新安全漏洞(CVE-2014-3566)的代号,俗称“ ...
- [Android] Android ViewPager 中加载 Fragment的两种方式 方式(一)
Android ViewPager 中加载 Fragmenet的两种方式 一.当fragment里面的内容较少时,直接 使用fragment xml布局文件填充 文件总数 布局文件:view_one. ...
- 细说REST API安全之认证授权
认证授权包含2个方面:(1)访问某个资源时必须携带用户身份信息,如:用户登录时返回用户access_token,访问资源时携带该参数.(2)检查用户是否具备访问当前资源(url或数据)的权限:访问资源 ...
- 几个js 拓扑图库
计划做一个元数据平台, 因为要包含血缘分析功能, 所以要调研一下js 拓扑图库, 候选对象主要参考知乎上的问答, javascript 有哪些适合做网络拓扑图形展示的包? https://www.zh ...
- 解决yum安装mysql时Requires: libc.so.6(GLIBC_2.17)(64bit)
1.yum install mysql-community-server 1 2 3 4 5 6 7 Error: Package: mysql-community-libs-5.7.17-1.el7 ...
- Spring整合redis配置文件详解
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...
- 四、文件IO——内核数据结构和原子操作
4.1 缓存 buff 说明 一般设置缓存 buff 的大小是由一定的规律的,就是根据磁盘块的大小来定. Linux下输入命令: df -k 查看磁盘 可以用命令查看下 /dev/sda1 磁盘的 ...
- 【bzoj 4756】[Usaco2017 Jan] Promotion Counting
Description The cows have once again tried to form a startup company, failing to remember from past ...
- Kali Linux之使用SET快捷生成钓鱼网站方法
SET (Social Engineering Tools) 1.使用命令:setoolkit 会显示工具菜单 2.输入1 ,选择菜单中的Social-Engineering Attacks (社会工 ...
- shell实现带颜色输出的进度条
1.基础版 #!/bin/bash b='' ;$i<=;i+=)) do printf "执行进度 :[%-50s]%d%%\r" $b $i sleep 0.001 b= ...